hv_netvsc: pass netvsc_device to receive callback
The netvsc_receive_callback function was using RCU to find the appropriate underlying netvsc_device. Since calling function already had that pointer, this was unnecessary. Signed-off-by: Stephen Hemminger <sthemmin@microsoft.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
79cf1bae38
commit
345ac08990
|
@ -202,6 +202,7 @@ int netvsc_send(struct net_device_context *ndc,
|
||||||
void netvsc_linkstatus_callback(struct net_device *net,
|
void netvsc_linkstatus_callback(struct net_device *net,
|
||||||
struct rndis_message *resp);
|
struct rndis_message *resp);
|
||||||
int netvsc_recv_callback(struct net_device *net,
|
int netvsc_recv_callback(struct net_device *net,
|
||||||
|
struct netvsc_device *nvdev,
|
||||||
struct vmbus_channel *channel,
|
struct vmbus_channel *channel,
|
||||||
void *data, u32 len,
|
void *data, u32 len,
|
||||||
const struct ndis_tcp_ip_checksum_info *csum_info,
|
const struct ndis_tcp_ip_checksum_info *csum_info,
|
||||||
|
|
|
@ -739,34 +739,26 @@ static struct sk_buff *netvsc_alloc_recv_skb(struct net_device *net,
|
||||||
* "wire" on the specified device.
|
* "wire" on the specified device.
|
||||||
*/
|
*/
|
||||||
int netvsc_recv_callback(struct net_device *net,
|
int netvsc_recv_callback(struct net_device *net,
|
||||||
|
struct netvsc_device *net_device,
|
||||||
struct vmbus_channel *channel,
|
struct vmbus_channel *channel,
|
||||||
void *data, u32 len,
|
void *data, u32 len,
|
||||||
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)
|
||||||
{
|
{
|
||||||
struct net_device_context *net_device_ctx = netdev_priv(net);
|
struct net_device_context *net_device_ctx = netdev_priv(net);
|
||||||
struct netvsc_device *net_device;
|
|
||||||
u16 q_idx = channel->offermsg.offer.sub_channel_index;
|
u16 q_idx = channel->offermsg.offer.sub_channel_index;
|
||||||
struct netvsc_channel *nvchan;
|
struct netvsc_channel *nvchan = &net_device->chan_table[q_idx];
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
struct netvsc_stats *rx_stats;
|
struct netvsc_stats *rx_stats;
|
||||||
|
|
||||||
if (net->reg_state != NETREG_REGISTERED)
|
if (net->reg_state != NETREG_REGISTERED)
|
||||||
return NVSP_STAT_FAIL;
|
return NVSP_STAT_FAIL;
|
||||||
|
|
||||||
rcu_read_lock();
|
|
||||||
net_device = rcu_dereference(net_device_ctx->nvdev);
|
|
||||||
if (unlikely(!net_device))
|
|
||||||
goto drop;
|
|
||||||
|
|
||||||
nvchan = &net_device->chan_table[q_idx];
|
|
||||||
|
|
||||||
/* Allocate a skb - TODO direct I/O to pages? */
|
/* Allocate a skb - TODO direct I/O to pages? */
|
||||||
skb = netvsc_alloc_recv_skb(net, &nvchan->napi,
|
skb = netvsc_alloc_recv_skb(net, &nvchan->napi,
|
||||||
csum_info, vlan, data, len);
|
csum_info, vlan, data, len);
|
||||||
if (unlikely(!skb)) {
|
if (unlikely(!skb)) {
|
||||||
++net_device_ctx->eth_stats.rx_no_memory;
|
++net_device_ctx->eth_stats.rx_no_memory;
|
||||||
drop:
|
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
return NVSP_STAT_FAIL;
|
return NVSP_STAT_FAIL;
|
||||||
}
|
}
|
||||||
|
@ -790,8 +782,6 @@ drop:
|
||||||
u64_stats_update_end(&rx_stats->syncp);
|
u64_stats_update_end(&rx_stats->syncp);
|
||||||
|
|
||||||
napi_gro_receive(&nvchan->napi, skb);
|
napi_gro_receive(&nvchan->napi, skb);
|
||||||
rcu_read_unlock();
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -352,6 +352,7 @@ static inline void *rndis_get_ppi(struct rndis_packet *rpkt, u32 type)
|
||||||
}
|
}
|
||||||
|
|
||||||
static int rndis_filter_receive_data(struct net_device *ndev,
|
static int rndis_filter_receive_data(struct net_device *ndev,
|
||||||
|
struct netvsc_device *nvdev,
|
||||||
struct rndis_device *dev,
|
struct rndis_device *dev,
|
||||||
struct rndis_message *msg,
|
struct rndis_message *msg,
|
||||||
struct vmbus_channel *channel,
|
struct vmbus_channel *channel,
|
||||||
|
@ -388,7 +389,8 @@ static int rndis_filter_receive_data(struct net_device *ndev,
|
||||||
*/
|
*/
|
||||||
data = (void *)((unsigned long)data + data_offset);
|
data = (void *)((unsigned long)data + data_offset);
|
||||||
csum_info = rndis_get_ppi(rndis_pkt, TCPIP_CHKSUM_PKTINFO);
|
csum_info = rndis_get_ppi(rndis_pkt, TCPIP_CHKSUM_PKTINFO);
|
||||||
return netvsc_recv_callback(ndev, channel,
|
|
||||||
|
return netvsc_recv_callback(ndev, nvdev, channel,
|
||||||
data, rndis_pkt->data_len,
|
data, rndis_pkt->data_len,
|
||||||
csum_info, vlan);
|
csum_info, vlan);
|
||||||
}
|
}
|
||||||
|
@ -420,7 +422,8 @@ int rndis_filter_receive(struct net_device *ndev,
|
||||||
|
|
||||||
switch (rndis_msg->ndis_msg_type) {
|
switch (rndis_msg->ndis_msg_type) {
|
||||||
case RNDIS_MSG_PACKET:
|
case RNDIS_MSG_PACKET:
|
||||||
return rndis_filter_receive_data(ndev, rndis_dev, rndis_msg,
|
return rndis_filter_receive_data(ndev, net_dev,
|
||||||
|
rndis_dev, rndis_msg,
|
||||||
channel, data, buflen);
|
channel, data, buflen);
|
||||||
case RNDIS_MSG_INIT_C:
|
case RNDIS_MSG_INIT_C:
|
||||||
case RNDIS_MSG_QUERY_C:
|
case RNDIS_MSG_QUERY_C:
|
||||||
|
|
Loading…
Reference in New Issue