mirror of
https://github.com/torvalds/linux.git
synced 2024-11-30 16:11:38 +00:00
bnxt_en: Fix VNIC clearing logic for 57500 chips.
During device shutdown, the VNIC clearing sequence needs to be modified
to free the VNIC first before freeing the RSS contexts. The current
code is doing the reverse and we can get mis-directed RX completions
to CP ring ID 0 when the RSS contexts are freed and zeroed. The clearing
of RSS contexts is not required with the new sequence.
Refactor the VNIC clearing logic into a new function bnxt_clear_vnic()
and do the chip specific VNIC clearing sequence.
Fixes: 7b3af4f75b
("bnxt_en: Add RSS support for 57500 chips.")
Signed-off-by: Michael Chan <michael.chan@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
f1472cb09f
commit
a46ecb116f
@ -7016,19 +7016,29 @@ static void bnxt_hwrm_clear_vnic_rss(struct bnxt *bp)
|
||||
bnxt_hwrm_vnic_set_rss(bp, i, false);
|
||||
}
|
||||
|
||||
static void bnxt_hwrm_resource_free(struct bnxt *bp, bool close_path,
|
||||
bool irq_re_init)
|
||||
static void bnxt_clear_vnic(struct bnxt *bp)
|
||||
{
|
||||
if (bp->vnic_info) {
|
||||
bnxt_hwrm_clear_vnic_filter(bp);
|
||||
if (!bp->vnic_info)
|
||||
return;
|
||||
|
||||
bnxt_hwrm_clear_vnic_filter(bp);
|
||||
if (!(bp->flags & BNXT_FLAG_CHIP_P5)) {
|
||||
/* clear all RSS setting before free vnic ctx */
|
||||
bnxt_hwrm_clear_vnic_rss(bp);
|
||||
bnxt_hwrm_vnic_ctx_free(bp);
|
||||
/* before free the vnic, undo the vnic tpa settings */
|
||||
if (bp->flags & BNXT_FLAG_TPA)
|
||||
bnxt_set_tpa(bp, false);
|
||||
bnxt_hwrm_vnic_free(bp);
|
||||
}
|
||||
/* before free the vnic, undo the vnic tpa settings */
|
||||
if (bp->flags & BNXT_FLAG_TPA)
|
||||
bnxt_set_tpa(bp, false);
|
||||
bnxt_hwrm_vnic_free(bp);
|
||||
if (bp->flags & BNXT_FLAG_CHIP_P5)
|
||||
bnxt_hwrm_vnic_ctx_free(bp);
|
||||
}
|
||||
|
||||
static void bnxt_hwrm_resource_free(struct bnxt *bp, bool close_path,
|
||||
bool irq_re_init)
|
||||
{
|
||||
bnxt_clear_vnic(bp);
|
||||
bnxt_hwrm_ring_free(bp, close_path);
|
||||
bnxt_hwrm_ring_grp_free(bp);
|
||||
if (irq_re_init) {
|
||||
|
Loading…
Reference in New Issue
Block a user