浏览代码

netvsc: replace netdev_alloc_skb_ip_align with napi_alloc_skb

Gives potential performance gain.

Signed-off-by: Stephen Hemminger <sthemmin@microsoft.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
stephen hemminger 8 年之前
父节点
当前提交
e91e7dd71d
共有 1 个文件被更改,包括 4 次插入2 次删除
  1. 4 2
      drivers/net/hyperv/netvsc_drv.c

+ 4 - 2
drivers/net/hyperv/netvsc_drv.c

@@ -589,13 +589,14 @@ void netvsc_linkstatus_callback(struct hv_device *device_obj,
 }
 }
 
 
 static struct sk_buff *netvsc_alloc_recv_skb(struct net_device *net,
 static struct sk_buff *netvsc_alloc_recv_skb(struct net_device *net,
+					     struct napi_struct *napi,
 					     const struct ndis_tcp_ip_checksum_info *csum_info,
 					     const struct ndis_tcp_ip_checksum_info *csum_info,
 					     const struct ndis_pkt_8021q_info *vlan,
 					     const struct ndis_pkt_8021q_info *vlan,
 					     void *data, u32 buflen)
 					     void *data, u32 buflen)
 {
 {
 	struct sk_buff *skb;
 	struct sk_buff *skb;
 
 
-	skb = netdev_alloc_skb_ip_align(net, buflen);
+	skb = napi_alloc_skb(napi, buflen);
 	if (!skb)
 	if (!skb)
 		return skb;
 		return skb;
 
 
@@ -664,7 +665,8 @@ int netvsc_recv_callback(struct net_device *net,
 		net = vf_netdev;
 		net = vf_netdev;
 
 
 	/* Allocate a skb - TODO direct I/O to pages? */
 	/* Allocate a skb - TODO direct I/O to pages? */
-	skb = netvsc_alloc_recv_skb(net, csum_info, vlan, data, len);
+	skb = netvsc_alloc_recv_skb(net, &nvchan->napi,
+				    csum_info, vlan, data, len);
 	if (unlikely(!skb)) {
 	if (unlikely(!skb)) {
 		++net->stats.rx_dropped;
 		++net->stats.rx_dropped;
 		rcu_read_unlock();
 		rcu_read_unlock();