net: vlan: goto another_round instead of calling __netif_receive_skb

Now, when vlan tag on untagged in non-accelerated path is stripped from
skb, headers are reset right away. Benefit from that and avoid calling
__netif_receive_skb recursivelly and just use another_round.

Signed-off-by: Jiri Pirko <jpirko@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Jiri Pirko 2011-08-22 12:43:22 -07:00 committed by David S. Miller
parent c8d755b59a
commit 0dfe178239
1 changed files with 3 additions and 4 deletions

View File

@ -3236,10 +3236,9 @@ static int __netif_receive_skb(struct sk_buff *skb)
ret = deliver_skb(skb, pt_prev, orig_dev); ret = deliver_skb(skb, pt_prev, orig_dev);
pt_prev = NULL; pt_prev = NULL;
} }
if (vlan_do_receive(&skb)) { if (vlan_do_receive(&skb))
ret = __netif_receive_skb(skb); goto another_round;
goto out; else if (unlikely(!skb))
} else if (unlikely(!skb))
goto out; goto out;
} }