2
0
mirror of git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git synced 2025-09-04 20:19:47 +08:00

drivers/net/ethernet/via/via-velocity.c: update napi implementation

Drivers supporting NAPI should use a NAPI-specific function for receiving
packets.  Hence netif_rx is changed to netif_receive_skb.

Furthermore netif_napi_del should be used in the probe and remove function
to clean up the NAPI resource information.

Thanks to Francois Romieu, David Shwatrz and Rami Rosen for their help on
this patch.

Signed-off-by: Julia Lawall <Julia.Lawall@lip6.fr>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Julia Lawall 2013-08-14 16:26:53 +02:00 committed by David S. Miller
parent 728e2ccaa3
commit 2fdac010bd

View File

@ -2100,7 +2100,7 @@ static int velocity_receive_frame(struct velocity_info *vptr, int idx)
__vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q), vid); __vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q), vid);
} }
netif_rx(skb); netif_receive_skb(skb);
stats->rx_bytes += pkt_len; stats->rx_bytes += pkt_len;
stats->rx_packets++; stats->rx_packets++;
@ -2884,6 +2884,7 @@ out:
return ret; return ret;
err_iounmap: err_iounmap:
netif_napi_del(&vptr->napi);
iounmap(regs); iounmap(regs);
err_free_dev: err_free_dev:
free_netdev(netdev); free_netdev(netdev);
@ -2904,6 +2905,7 @@ static int velocity_remove(struct device *dev)
struct velocity_info *vptr = netdev_priv(netdev); struct velocity_info *vptr = netdev_priv(netdev);
unregister_netdev(netdev); unregister_netdev(netdev);
netif_napi_del(&vptr->napi);
iounmap(vptr->mac_regs); iounmap(vptr->mac_regs);
free_netdev(netdev); free_netdev(netdev);
velocity_nics--; velocity_nics--;