Skip to content

Commit 626af9b

Browse files
kadesai16gregkh
authored andcommitted
bnxt_en: call pci_alloc_irq_vectors() after bnxt_reserve_rings()
[ Upstream commit 1ae04e4 ] On some architectures (e.g. ARM), calling pci_alloc_irq_vectors() will immediately cause the MSIX table to be written. This will not work if we haven't called bnxt_reserve_rings() to properly map the MSIX table to the MSIX vectors reserved by FW. Fix the FW error recovery path to delay the bnxt_init_int_mode() -> pci_alloc_irq_vectors() call by removing it from bnxt_hwrm_if_change(). bnxt_request_irq() later in the code path will call it and by then the MSIX table is properly mapped. Fixes: 4343838 ("bnxt_en: Replace deprecated PCI MSIX APIs") Suggested-by: Michael Chan <michael.chan@broadcom.com> Signed-off-by: Kashyap Desai <kashyap.desai@broadcom.com> Signed-off-by: Michael Chan <michael.chan@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Sasha Levin <sashal@kernel.org>
1 parent aa15f38 commit 626af9b

File tree

1 file changed

+1
-6
lines changed
  • drivers/net/ethernet/broadcom/bnxt

1 file changed

+1
-6
lines changed

drivers/net/ethernet/broadcom/bnxt/bnxt.c

Lines changed: 1 addition & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -11851,13 +11851,8 @@ static int bnxt_hwrm_if_change(struct bnxt *bp, bool up)
1185111851
set_bit(BNXT_STATE_ABORT_ERR, &bp->state);
1185211852
return rc;
1185311853
}
11854+
/* IRQ will be initialized later in bnxt_request_irq()*/
1185411855
bnxt_clear_int_mode(bp);
11855-
rc = bnxt_init_int_mode(bp);
11856-
if (rc) {
11857-
clear_bit(BNXT_STATE_FW_RESET_DET, &bp->state);
11858-
netdev_err(bp->dev, "init int mode failed\n");
11859-
return rc;
11860-
}
1186111856
}
1186211857
rc = bnxt_cancel_reservations(bp, fw_reset);
1186311858
}

0 commit comments

Comments
 (0)