diff options
Diffstat (limited to 'net/ipv4/ipmr.c')
| -rw-r--r-- | net/ipv4/ipmr.c | 15 | 
1 files changed, 8 insertions, 7 deletions
| diff --git a/net/ipv4/ipmr.c b/net/ipv4/ipmr.c index 866ee89f5254..92dd4b74d513 100644 --- a/net/ipv4/ipmr.c +++ b/net/ipv4/ipmr.c @@ -1678,17 +1678,18 @@ static void ip_encap(struct net *net, struct sk_buff *skb,  	nf_reset(skb);  } -static inline int ipmr_forward_finish(struct sock *sk, struct sk_buff *skb) +static inline int ipmr_forward_finish(struct net *net, struct sock *sk, +				      struct sk_buff *skb)  {  	struct ip_options *opt = &(IPCB(skb)->opt); -	IP_INC_STATS_BH(dev_net(skb_dst(skb)->dev), IPSTATS_MIB_OUTFORWDATAGRAMS); -	IP_ADD_STATS_BH(dev_net(skb_dst(skb)->dev), IPSTATS_MIB_OUTOCTETS, skb->len); +	IP_INC_STATS(net, IPSTATS_MIB_OUTFORWDATAGRAMS); +	IP_ADD_STATS(net, IPSTATS_MIB_OUTOCTETS, skb->len);  	if (unlikely(opt->optlen))  		ip_forward_options(skb); -	return dst_output_sk(sk, skb); +	return dst_output(net, sk, skb);  }  /* @@ -1745,7 +1746,7 @@ static void ipmr_queue_xmit(struct net *net, struct mr_table *mrt,  		 * to blackhole.  		 */ -		IP_INC_STATS_BH(dev_net(dev), IPSTATS_MIB_FRAGFAILS); +		IP_INC_STATS(net, IPSTATS_MIB_FRAGFAILS);  		ip_rt_put(rt);  		goto out_free;  	} @@ -1787,8 +1788,8 @@ static void ipmr_queue_xmit(struct net *net, struct mr_table *mrt,  	 * not mrouter) cannot join to more than one interface - it will  	 * result in receiving multiple packets.  	 */ -	NF_HOOK(NFPROTO_IPV4, NF_INET_FORWARD, NULL, skb, -		skb->dev, dev, +	NF_HOOK(NFPROTO_IPV4, NF_INET_FORWARD, +		net, NULL, skb, skb->dev, dev,  		ipmr_forward_finish);  	return; | 
