提交 c1f5163d 编写于 作者: M Michael Chan 提交者: David S. Miller

bnx2: Fix bug in bnx2_free_tx_skbs().

In rare cases, bnx2x_free_tx_skbs() can unmap the wrong DMA address
when it gets to the last entry of the tx ring.  We were not using
the proper macro to skip the last entry when advancing the tx index.
Reported-by: NZongyun Lai <zlai@vmware.com>
Reviewed-by: NJeffrey Huang <huangjw@broadcom.com>
Signed-off-by: NMichael Chan <mchan@broadcom.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 b28ba726
...@@ -5372,7 +5372,7 @@ bnx2_free_tx_skbs(struct bnx2 *bp) ...@@ -5372,7 +5372,7 @@ bnx2_free_tx_skbs(struct bnx2 *bp)
int k, last; int k, last;
if (skb == NULL) { if (skb == NULL) {
j++; j = NEXT_TX_BD(j);
continue; continue;
} }
...@@ -5384,8 +5384,8 @@ bnx2_free_tx_skbs(struct bnx2 *bp) ...@@ -5384,8 +5384,8 @@ bnx2_free_tx_skbs(struct bnx2 *bp)
tx_buf->skb = NULL; tx_buf->skb = NULL;
last = tx_buf->nr_frags; last = tx_buf->nr_frags;
j++; j = NEXT_TX_BD(j);
for (k = 0; k < last; k++, j++) { for (k = 0; k < last; k++, j = NEXT_TX_BD(j)) {
tx_buf = &txr->tx_buf_ring[TX_RING_IDX(j)]; tx_buf = &txr->tx_buf_ring[TX_RING_IDX(j)];
dma_unmap_page(&bp->pdev->dev, dma_unmap_page(&bp->pdev->dev,
dma_unmap_addr(tx_buf, mapping), dma_unmap_addr(tx_buf, mapping),
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册