diff options
author | Eric Dumazet <eric.dumazet@gmail.com> | 2010-08-31 14:25:32 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-09-01 13:57:55 -0400 |
commit | 86cac58b71227cc34a3d0e78f19585c0eff49ea3 (patch) | |
tree | e3329c4599474c12f17b0de5b2e8e4ff92233853 /drivers/net/skge.c | |
parent | aed5029ead26fe47527d9e9f2052cf56b72543f0 (diff) |
skge: add GRO support
- napi_gro_flush() is exported from net/core/dev.c, to avoid
an irq_save/irq_restore in the packet receive path.
- use napi_gro_receive() instead of netif_receive_skb()
- use napi_gro_flush() before calling __napi_complete()
- turn on NETIF_F_GRO by default
- Tested on a Marvell 88E8001 Gigabit NIC
Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/skge.c')
-rw-r--r-- | drivers/net/skge.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/net/skge.c b/drivers/net/skge.c index 40e5c46e7571..a8a63581d63d 100644 --- a/drivers/net/skge.c +++ b/drivers/net/skge.c | |||
@@ -3178,8 +3178,7 @@ static int skge_poll(struct napi_struct *napi, int to_do) | |||
3178 | 3178 | ||
3179 | skb = skge_rx_get(dev, e, control, rd->status, rd->csum2); | 3179 | skb = skge_rx_get(dev, e, control, rd->status, rd->csum2); |
3180 | if (likely(skb)) { | 3180 | if (likely(skb)) { |
3181 | netif_receive_skb(skb); | 3181 | napi_gro_receive(napi, skb); |
3182 | |||
3183 | ++work_done; | 3182 | ++work_done; |
3184 | } | 3183 | } |
3185 | } | 3184 | } |
@@ -3192,6 +3191,7 @@ static int skge_poll(struct napi_struct *napi, int to_do) | |||
3192 | if (work_done < to_do) { | 3191 | if (work_done < to_do) { |
3193 | unsigned long flags; | 3192 | unsigned long flags; |
3194 | 3193 | ||
3194 | napi_gro_flush(napi); | ||
3195 | spin_lock_irqsave(&hw->hw_lock, flags); | 3195 | spin_lock_irqsave(&hw->hw_lock, flags); |
3196 | __napi_complete(napi); | 3196 | __napi_complete(napi); |
3197 | hw->intr_mask |= napimask[skge->port]; | 3197 | hw->intr_mask |= napimask[skge->port]; |
@@ -3849,6 +3849,7 @@ static struct net_device *skge_devinit(struct skge_hw *hw, int port, | |||
3849 | dev->features |= NETIF_F_IP_CSUM | NETIF_F_SG; | 3849 | dev->features |= NETIF_F_IP_CSUM | NETIF_F_SG; |
3850 | skge->rx_csum = 1; | 3850 | skge->rx_csum = 1; |
3851 | } | 3851 | } |
3852 | dev->features |= NETIF_F_GRO; | ||
3852 | 3853 | ||
3853 | /* read the mac address */ | 3854 | /* read the mac address */ |
3854 | memcpy_fromio(dev->dev_addr, hw->regs + B2_MAC_1 + port*8, ETH_ALEN); | 3855 | memcpy_fromio(dev->dev_addr, hw->regs + B2_MAC_1 + port*8, ETH_ALEN); |