Skip to content

Commit 12f2d03

Browse files
committed
eth: bnxt: fix missing ring index trim on error path
Commit under Fixes converted tx_prod to be free running but missed masking it on the Tx error path. This crashes on error conditions, for example when DMA mapping fails. Fixes: 6d1add9 ("bnxt_en: Modify TX ring indexing logic.") Reviewed-by: Michael Chan <[email protected]> Link: https://patch.msgid.link/[email protected] Signed-off-by: Jakub Kicinski <[email protected]>
1 parent 903d2b9 commit 12f2d03

File tree

1 file changed

+2
-2
lines changed
  • drivers/net/ethernet/broadcom/bnxt

1 file changed

+2
-2
lines changed

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

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -787,15 +787,15 @@ static netdev_tx_t bnxt_start_xmit(struct sk_buff *skb, struct net_device *dev)
787787
dev_kfree_skb_any(skb);
788788
tx_kick_pending:
789789
if (BNXT_TX_PTP_IS_SET(lflags)) {
790-
txr->tx_buf_ring[txr->tx_prod].is_ts_pkt = 0;
790+
txr->tx_buf_ring[RING_TX(bp, txr->tx_prod)].is_ts_pkt = 0;
791791
atomic64_inc(&bp->ptp_cfg->stats.ts_err);
792792
if (!(bp->fw_cap & BNXT_FW_CAP_TX_TS_CMP))
793793
/* set SKB to err so PTP worker will clean up */
794794
ptp->txts_req[txts_prod].tx_skb = ERR_PTR(-EIO);
795795
}
796796
if (txr->kick_pending)
797797
bnxt_txr_db_kick(bp, txr, txr->tx_prod);
798-
txr->tx_buf_ring[txr->tx_prod].skb = NULL;
798+
txr->tx_buf_ring[RING_TX(bp, txr->tx_prod)].skb = NULL;
799799
dev_core_stats_tx_dropped_inc(dev);
800800
return NETDEV_TX_OK;
801801
}

0 commit comments

Comments
 (0)