From: David S. Miller Date: Mon, 23 Jul 2012 23:27:54 +0000 (-0700) Subject: net: Make skb->skb_iif always track skb->dev X-Git-Url: https://openfabrics.org/gitweb/?a=commitdiff_plain;h=b68581778cd0051a3fb9a2b614dee7eccb5127ff;p=~shefty%2Frdma-dev.git net: Make skb->skb_iif always track skb->dev Make it follow device decapsulation, from things such as VLAN and bonding. The stuff that actually cares about pre-demuxed device pointers, is handled by the "orig_dev" variable in __netif_receive_skb(). And the only consumer of that is the po->origdev feature of AF_PACKET sockets. Signed-off-by: David S. Miller --- diff --git a/net/core/dev.c b/net/core/dev.c index cca02ae7a84..0ebaea16632 100644 --- a/net/core/dev.c +++ b/net/core/dev.c @@ -3173,8 +3173,6 @@ static int __netif_receive_skb(struct sk_buff *skb) if (netpoll_receive_skb(skb)) return NET_RX_DROP; - if (!skb->skb_iif) - skb->skb_iif = skb->dev->ifindex; orig_dev = skb->dev; skb_reset_network_header(skb); @@ -3186,6 +3184,7 @@ static int __netif_receive_skb(struct sk_buff *skb) rcu_read_lock(); another_round: + skb->skb_iif = skb->dev->ifindex; __this_cpu_inc(softnet_data.processed);