mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
bnxt_en: Adjust TX rings if reservation is less than requested
Before we accept an ethtool request to increase a resource (such as
rings), we call the FW to check that the requested resource is likely
available first before we commit. But it is still possible that
the actual reservation or allocation can fail. The existing code
is missing the logic to adjust the TX rings in case the reserved
TX rings are less than requested. Add a warning message (a similar
message for RX rings already exists) and add the logic to adjust
the TX rings. Without this fix, the number of TX rings reported
to the stack can exceed the actual TX rings and ethtool -l will
report more than the actual TX rings.
Fixes: 674f50a5b0
("bnxt_en: Implement new method to reserve rings.")
Reviewed-by: Kalesh AP <kalesh-anakkur.purayil@broadcom.com>
Reviewed-by: Somnath Kotur <somnath.kotur@broadcom.com>
Signed-off-by: Michael Chan <michael.chan@broadcom.com>
Link: https://patch.msgid.link/20250825175927.459987-3-michael.chan@broadcom.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
2747328ba2
commit
1ee581c24d
@ -8024,6 +8024,11 @@ static int __bnxt_reserve_rings(struct bnxt *bp)
|
||||
hwr.rx = rx_rings << 1;
|
||||
tx_cp = bnxt_num_tx_to_cp(bp, hwr.tx);
|
||||
hwr.cp = sh ? max_t(int, tx_cp, rx_rings) : tx_cp + rx_rings;
|
||||
if (hwr.tx != bp->tx_nr_rings) {
|
||||
netdev_warn(bp->dev,
|
||||
"Able to reserve only %d out of %d requested TX rings\n",
|
||||
hwr.tx, bp->tx_nr_rings);
|
||||
}
|
||||
bp->tx_nr_rings = hwr.tx;
|
||||
|
||||
/* If we cannot reserve all the RX rings, reset the RSS map only
|
||||
@ -12879,6 +12884,13 @@ static int __bnxt_open_nic(struct bnxt *bp, bool irq_re_init, bool link_re_init)
|
||||
if (rc)
|
||||
return rc;
|
||||
|
||||
/* Make adjustments if reserved TX rings are less than requested */
|
||||
bp->tx_nr_rings -= bp->tx_nr_rings_xdp;
|
||||
bp->tx_nr_rings_per_tc = bnxt_tx_nr_rings_per_tc(bp);
|
||||
if (bp->tx_nr_rings_xdp) {
|
||||
bp->tx_nr_rings_xdp = bp->tx_nr_rings_per_tc;
|
||||
bp->tx_nr_rings += bp->tx_nr_rings_xdp;
|
||||
}
|
||||
rc = bnxt_alloc_mem(bp, irq_re_init);
|
||||
if (rc) {
|
||||
netdev_err(bp->dev, "bnxt_alloc_mem err: %x\n", rc);
|
||||
|
Loading…
Reference in New Issue
Block a user