aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/netxen/netxen_nic_init.c
diff options
context:
space:
mode:
authorDhananjay Phadke <dhananjay@qlogic.com>2009-09-03 09:10:53 -0400
committerDavid S. Miller <davem@davemloft.net>2009-09-03 23:01:56 -0400
commitbc75e5bfad2a6d24fc5a9885a2f6b93f82c6c5f1 (patch)
tree52c4b697f034607cc6cc3b8505a26819cffc572e /drivers/net/netxen/netxen_nic_init.c
parentd4ab88194e982a0d213000a75475d3e76b2626f0 (diff)
netxen: fix lro buffer allocation
Alloc 12k skbuffs so that firmware can aggregate more packets into one buffer. This doesn't raise memory consumption since 9k skbs use 16k slab cache anyway. Signed-off-by: Dhananjay Phadke <dhananjay@netxen.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/netxen/netxen_nic_init.c')
-rw-r--r--drivers/net/netxen/netxen_nic_init.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/drivers/net/netxen/netxen_nic_init.c b/drivers/net/netxen/netxen_nic_init.c
index 8d4aa6f74bff..04e36f2b1a93 100644
--- a/drivers/net/netxen/netxen_nic_init.c
+++ b/drivers/net/netxen/netxen_nic_init.c
@@ -265,6 +265,10 @@ int netxen_alloc_sw_resources(struct netxen_adapter *adapter)
265 else 265 else
266 rds_ring->dma_size = 266 rds_ring->dma_size =
267 NX_P2_RX_JUMBO_BUF_MAX_LEN; 267 NX_P2_RX_JUMBO_BUF_MAX_LEN;
268
269 if (adapter->capabilities & NX_CAP0_HW_LRO)
270 rds_ring->dma_size += NX_LRO_BUFFER_EXTRA;
271
268 rds_ring->skb_size = 272 rds_ring->skb_size =
269 rds_ring->dma_size + NET_IP_ALIGN; 273 rds_ring->dma_size + NET_IP_ALIGN;
270 break; 274 break;
@@ -1217,6 +1221,7 @@ netxen_process_rcv(struct netxen_adapter *adapter,
1217 if (pkt_offset) 1221 if (pkt_offset)
1218 skb_pull(skb, pkt_offset); 1222 skb_pull(skb, pkt_offset);
1219 1223
1224 skb->truesize = skb->len + sizeof(struct sk_buff);
1220 skb->protocol = eth_type_trans(skb, netdev); 1225 skb->protocol = eth_type_trans(skb, netdev);
1221 1226
1222 napi_gro_receive(&sds_ring->napi, skb); 1227 napi_gro_receive(&sds_ring->napi, skb);
@@ -1278,8 +1283,7 @@ netxen_process_lro(struct netxen_adapter *adapter,
1278 1283
1279 skb_put(skb, lro_length + data_offset); 1284 skb_put(skb, lro_length + data_offset);
1280 1285
1281 skb->truesize = (skb->len + sizeof(struct sk_buff) + 1286 skb->truesize = skb->len + sizeof(struct sk_buff) + skb_headroom(skb);
1282 ((unsigned long)skb->data - (unsigned long)skb->head));
1283 1287
1284 skb_pull(skb, l2_hdr_offset); 1288 skb_pull(skb, l2_hdr_offset);
1285 skb->protocol = eth_type_trans(skb, netdev); 1289 skb->protocol = eth_type_trans(skb, netdev);