aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/bnx2.c41
1 files changed, 25 insertions, 16 deletions
diff --git a/drivers/net/bnx2.c b/drivers/net/bnx2.c
index 6fbb5486163d..0d592f7c3a99 100644
--- a/drivers/net/bnx2.c
+++ b/drivers/net/bnx2.c
@@ -1656,23 +1656,30 @@ static inline void
1656bnx2_reuse_rx_skb(struct bnx2 *bp, struct sk_buff *skb, 1656bnx2_reuse_rx_skb(struct bnx2 *bp, struct sk_buff *skb,
1657 u16 cons, u16 prod) 1657 u16 cons, u16 prod)
1658{ 1658{
1659 struct sw_bd *cons_rx_buf = &bp->rx_buf_ring[cons]; 1659 struct sw_bd *cons_rx_buf, *prod_rx_buf;
1660 struct sw_bd *prod_rx_buf = &bp->rx_buf_ring[prod]; 1660 struct rx_bd *cons_bd, *prod_bd;
1661 struct rx_bd *cons_bd = &bp->rx_desc_ring[cons]; 1661
1662 struct rx_bd *prod_bd = &bp->rx_desc_ring[prod]; 1662 cons_rx_buf = &bp->rx_buf_ring[cons];
1663 prod_rx_buf = &bp->rx_buf_ring[prod];
1663 1664
1664 pci_dma_sync_single_for_device(bp->pdev, 1665 pci_dma_sync_single_for_device(bp->pdev,
1665 pci_unmap_addr(cons_rx_buf, mapping), 1666 pci_unmap_addr(cons_rx_buf, mapping),
1666 bp->rx_offset + RX_COPY_THRESH, PCI_DMA_FROMDEVICE); 1667 bp->rx_offset + RX_COPY_THRESH, PCI_DMA_FROMDEVICE);
1667 1668
1668 prod_rx_buf->skb = cons_rx_buf->skb; 1669 bp->rx_prod_bseq += bp->rx_buf_use_size;
1669 pci_unmap_addr_set(prod_rx_buf, mapping,
1670 pci_unmap_addr(cons_rx_buf, mapping));
1671 1670
1672 memcpy(prod_bd, cons_bd, 8); 1671 prod_rx_buf->skb = skb;
1673 1672
1674 bp->rx_prod_bseq += bp->rx_buf_use_size; 1673 if (cons == prod)
1674 return;
1675 1675
1676 pci_unmap_addr_set(prod_rx_buf, mapping,
1677 pci_unmap_addr(cons_rx_buf, mapping));
1678
1679 cons_bd = &bp->rx_desc_ring[cons];
1680 prod_bd = &bp->rx_desc_ring[prod];
1681 prod_bd->rx_bd_haddr_hi = cons_bd->rx_bd_haddr_hi;
1682 prod_bd->rx_bd_haddr_lo = cons_bd->rx_bd_haddr_lo;
1676} 1683}
1677 1684
1678static int 1685static int
@@ -1699,14 +1706,19 @@ bnx2_rx_int(struct bnx2 *bp, int budget)
1699 u32 status; 1706 u32 status;
1700 struct sw_bd *rx_buf; 1707 struct sw_bd *rx_buf;
1701 struct sk_buff *skb; 1708 struct sk_buff *skb;
1709 dma_addr_t dma_addr;
1702 1710
1703 sw_ring_cons = RX_RING_IDX(sw_cons); 1711 sw_ring_cons = RX_RING_IDX(sw_cons);
1704 sw_ring_prod = RX_RING_IDX(sw_prod); 1712 sw_ring_prod = RX_RING_IDX(sw_prod);
1705 1713
1706 rx_buf = &bp->rx_buf_ring[sw_ring_cons]; 1714 rx_buf = &bp->rx_buf_ring[sw_ring_cons];
1707 skb = rx_buf->skb; 1715 skb = rx_buf->skb;
1708 pci_dma_sync_single_for_cpu(bp->pdev, 1716
1709 pci_unmap_addr(rx_buf, mapping), 1717 rx_buf->skb = NULL;
1718
1719 dma_addr = pci_unmap_addr(rx_buf, mapping);
1720
1721 pci_dma_sync_single_for_cpu(bp->pdev, dma_addr,
1710 bp->rx_offset + RX_COPY_THRESH, PCI_DMA_FROMDEVICE); 1722 bp->rx_offset + RX_COPY_THRESH, PCI_DMA_FROMDEVICE);
1711 1723
1712 rx_hdr = (struct l2_fhdr *) skb->data; 1724 rx_hdr = (struct l2_fhdr *) skb->data;
@@ -1747,8 +1759,7 @@ bnx2_rx_int(struct bnx2 *bp, int budget)
1747 skb = new_skb; 1759 skb = new_skb;
1748 } 1760 }
1749 else if (bnx2_alloc_rx_skb(bp, sw_ring_prod) == 0) { 1761 else if (bnx2_alloc_rx_skb(bp, sw_ring_prod) == 0) {
1750 pci_unmap_single(bp->pdev, 1762 pci_unmap_single(bp->pdev, dma_addr,
1751 pci_unmap_addr(rx_buf, mapping),
1752 bp->rx_buf_use_size, PCI_DMA_FROMDEVICE); 1763 bp->rx_buf_use_size, PCI_DMA_FROMDEVICE);
1753 1764
1754 skb_reserve(skb, bp->rx_offset); 1765 skb_reserve(skb, bp->rx_offset);
@@ -1794,8 +1805,6 @@ reuse_rx:
1794 rx_pkt++; 1805 rx_pkt++;
1795 1806
1796next_rx: 1807next_rx:
1797 rx_buf->skb = NULL;
1798
1799 sw_cons = NEXT_RX_BD(sw_cons); 1808 sw_cons = NEXT_RX_BD(sw_cons);
1800 sw_prod = NEXT_RX_BD(sw_prod); 1809 sw_prod = NEXT_RX_BD(sw_prod);
1801 1810
@@ -3360,7 +3369,7 @@ bnx2_init_rx_ring(struct bnx2 *bp)
3360 val = (u64) bp->rx_desc_mapping & 0xffffffff; 3369 val = (u64) bp->rx_desc_mapping & 0xffffffff;
3361 CTX_WR(bp, GET_CID_ADDR(RX_CID), BNX2_L2CTX_NX_BDHADDR_LO, val); 3370 CTX_WR(bp, GET_CID_ADDR(RX_CID), BNX2_L2CTX_NX_BDHADDR_LO, val);
3362 3371
3363 for ( ;ring_prod < bp->rx_ring_size; ) { 3372 for (i = 0; i < bp->rx_ring_size; i++) {
3364 if (bnx2_alloc_rx_skb(bp, ring_prod) < 0) { 3373 if (bnx2_alloc_rx_skb(bp, ring_prod) < 0) {
3365 break; 3374 break;
3366 } 3375 }