aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorStephen Hemminger <shemminger@linux-foundation.org>2007-06-04 16:25:38 -0400
committerJeff Garzik <jeff@garzik.org>2007-07-08 22:16:40 -0400
commitf65a71775cc3eb5d5d8ac4c349c8f48a7d5c7759 (patch)
tree7733077740f8af58631f478998a6fd3fa9a0a1e7 /drivers
parenta72a8179734393ca351f6ecf8cad6841ab7e1470 (diff)
b44: tx bounce sizing.
No need to grap full size MTU buffer for possibly small transmit bounce buffers. Signed-off-by: Stephen Hemminger <shemminger@linux-foundation.org> Signed-off-by: Jeff Garzik <jeff@garzik.org>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/b44.c12
1 files changed, 5 insertions, 7 deletions
diff --git a/drivers/net/b44.c b/drivers/net/b44.c
index e87bab9f9bea..d10d31cd12d7 100644
--- a/drivers/net/b44.c
+++ b/drivers/net/b44.c
@@ -69,7 +69,6 @@
69#define NEXT_TX(N) (((N) + 1) & (B44_TX_RING_SIZE - 1)) 69#define NEXT_TX(N) (((N) + 1) & (B44_TX_RING_SIZE - 1))
70 70
71#define RX_PKT_BUF_SZ (1536 + bp->rx_offset + 64) 71#define RX_PKT_BUF_SZ (1536 + bp->rx_offset + 64)
72#define TX_PKT_BUF_SZ (B44_MAX_MTU + ETH_HLEN + 8)
73 72
74/* minimum number of free TX descriptors required to wake up TX process */ 73/* minimum number of free TX descriptors required to wake up TX process */
75#define B44_TX_WAKEUP_THRESH (B44_TX_RING_SIZE / 4) 74#define B44_TX_WAKEUP_THRESH (B44_TX_RING_SIZE / 4)
@@ -968,7 +967,6 @@ static void b44_tx_timeout(struct net_device *dev)
968static int b44_start_xmit(struct sk_buff *skb, struct net_device *dev) 967static int b44_start_xmit(struct sk_buff *skb, struct net_device *dev)
969{ 968{
970 struct b44 *bp = netdev_priv(dev); 969 struct b44 *bp = netdev_priv(dev);
971 struct sk_buff *bounce_skb;
972 int rc = NETDEV_TX_OK; 970 int rc = NETDEV_TX_OK;
973 dma_addr_t mapping; 971 dma_addr_t mapping;
974 u32 len, entry, ctrl; 972 u32 len, entry, ctrl;
@@ -986,12 +984,13 @@ static int b44_start_xmit(struct sk_buff *skb, struct net_device *dev)
986 984
987 mapping = pci_map_single(bp->pdev, skb->data, len, PCI_DMA_TODEVICE); 985 mapping = pci_map_single(bp->pdev, skb->data, len, PCI_DMA_TODEVICE);
988 if (dma_mapping_error(mapping) || mapping + len > DMA_30BIT_MASK) { 986 if (dma_mapping_error(mapping) || mapping + len > DMA_30BIT_MASK) {
987 struct sk_buff *bounce_skb;
988
989 /* Chip can't handle DMA to/from >1GB, use bounce buffer */ 989 /* Chip can't handle DMA to/from >1GB, use bounce buffer */
990 if (!dma_mapping_error(mapping)) 990 if (!dma_mapping_error(mapping))
991 pci_unmap_single(bp->pdev, mapping, len, PCI_DMA_TODEVICE); 991 pci_unmap_single(bp->pdev, mapping, len, PCI_DMA_TODEVICE);
992 992
993 bounce_skb = __dev_alloc_skb(TX_PKT_BUF_SZ, 993 bounce_skb = __dev_alloc_skb(len, GFP_ATOMIC | GFP_DMA);
994 GFP_ATOMIC|GFP_DMA);
995 if (!bounce_skb) 994 if (!bounce_skb)
996 goto err_out; 995 goto err_out;
997 996
@@ -1000,13 +999,12 @@ static int b44_start_xmit(struct sk_buff *skb, struct net_device *dev)
1000 if (dma_mapping_error(mapping) || mapping + len > DMA_30BIT_MASK) { 999 if (dma_mapping_error(mapping) || mapping + len > DMA_30BIT_MASK) {
1001 if (!dma_mapping_error(mapping)) 1000 if (!dma_mapping_error(mapping))
1002 pci_unmap_single(bp->pdev, mapping, 1001 pci_unmap_single(bp->pdev, mapping,
1003 len, PCI_DMA_TODEVICE); 1002 len, PCI_DMA_TODEVICE);
1004 dev_kfree_skb_any(bounce_skb); 1003 dev_kfree_skb_any(bounce_skb);
1005 goto err_out; 1004 goto err_out;
1006 } 1005 }
1007 1006
1008 skb_copy_from_linear_data(skb, skb_put(bounce_skb, len), 1007 skb_copy_from_linear_data(skb, skb_put(bounce_skb, len), len);
1009 skb->len);
1010 dev_kfree_skb_any(skb); 1008 dev_kfree_skb_any(skb);
1011 skb = bounce_skb; 1009 skb = bounce_skb;
1012 } 1010 }