@@ -1728,9 +1728,20 @@ pm80xx_chip_interrupt_enable(struct pm8001_hba_info *pm8001_ha, u8 vec)
{
#ifdef PM8001_USE_MSIX
u32 mask;
- mask = (u32)(1 << vec);
+ u32 vec_u;
- pm8001_cw32(pm8001_ha, 0, MSGU_ODMR_CLR, (u32)(mask & 0xFFFFFFFF));
+ if (vec < 32) {
+ mask = (u32)(1 << vec);
+ /*vectors 0 - 31*/
+ pm8001_cw32(pm8001_ha, 0, MSGU_ODMR_CLR,
+ (u32)(mask & 0xFFFFFFFF));
+ } else {
+ vec_u = vec - 32;
+ mask = (u32)(1 << vec_u);
+ /*vectors 32 - 63*/
+ pm8001_cw32(pm8001_ha, 0, MSGU_ODMR_CLR_U,
+ (u32)(mask & 0xFFFFFFFF));
+ }
return;
#endif
pm80xx_chip_intx_interrupt_enable(pm8001_ha);
@@ -1747,11 +1758,25 @@ pm80xx_chip_interrupt_disable(struct pm8001_hba_info *pm8001_ha, u8 vec)
{
#ifdef PM8001_USE_MSIX
u32 mask;
- if (vec == 0xFF)
+ u32 vec_u;
+
+ if (vec == 0xFF) {
mask = 0xFFFFFFFF;
- else
+ /* disable all vectors 0-31, 32-63*/
+ pm8001_cw32(pm8001_ha, 0, MSGU_ODMR, mask);
+ pm8001_cw32(pm8001_ha, 0, MSGU_ODMR_U, mask);
+ } else if (vec < 32) {
mask = (u32)(1 << vec);
- pm8001_cw32(pm8001_ha, 0, MSGU_ODMR, (u32)(mask & 0xFFFFFFFF));
+ /*vectors 0 - 31*/
+ pm8001_cw32(pm8001_ha, 0, MSGU_ODMR,
+ (u32)(mask & 0xFFFFFFFF));
+ } else {
+ vec_u = vec - 32;
+ mask = (u32)(1 << vec_u);
+ /*vectors 32 - 63*/
+ pm8001_cw32(pm8001_ha, 0, MSGU_ODMR_U,
+ (u32)(mask & 0xFFFFFFFF));
+ }
return;
#endif
pm80xx_chip_intx_interrupt_disable(pm8001_ha);