diff options
author | Jiri Benc <jbenc@redhat.com> | 2016-10-10 17:02:43 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-10-13 10:03:23 -0400 |
commit | 72ec108d701506fa6cd2f66ec5b15ea71df3c464 (patch) | |
tree | beb6ca2c112efd4ec175f6b51aeba5986c637315 /net/openvswitch | |
parent | 20ecf1e4e30005ad50f561a92c888b6477f99341 (diff) | |
download | linux-72ec108d701506fa6cd2f66ec5b15ea71df3c464.tar.gz linux-72ec108d701506fa6cd2f66ec5b15ea71df3c464.tar.bz2 linux-72ec108d701506fa6cd2f66ec5b15ea71df3c464.zip |
openvswitch: fix vlan subtraction from packet length
When the packet has its vlan tag in skb->vlan_tci, the length of the VLAN
header is not counted in skb->len. It doesn't make sense to subtract it.
Fixes: 018c1dda5ff1 ("openvswitch: 802.1AD Flow handling, actions, vlan parsing, netlink attributes")
Signed-off-by: Jiri Benc <jbenc@redhat.com>
Acked-by: Pravin B Shelar <pshelar@ovn.org>
Acked-by: Eric Garver <e@erig.me>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/openvswitch')
-rw-r--r-- | net/openvswitch/vport.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/net/openvswitch/vport.c b/net/openvswitch/vport.c index 8f198437c724..7387418ac514 100644 --- a/net/openvswitch/vport.c +++ b/net/openvswitch/vport.c @@ -485,7 +485,8 @@ static unsigned int packet_length(const struct sk_buff *skb) { unsigned int length = skb->len - ETH_HLEN; - if (skb_vlan_tagged(skb)) + if (!skb_vlan_tag_present(skb) && + eth_type_vlan(skb->protocol)) length -= VLAN_HLEN; /* Don't subtract for multiple VLAN tags. Most (all?) drivers allow |