diff options
author | Yuya Kusakabe | 2019-04-16 03:22:28 +0200 |
---|---|---|
committer | Greg Kroah-Hartman | 2019-04-27 09:36:30 +0200 |
commit | 2804598764f984a8c5cdee377a73e0bf86dc5dd4 (patch) | |
tree | 3e7a04c80d3865ffbbb935b2930f832cf1ed212a /net/core | |
parent | net: bridge: multicast: use rcu to access port list from br_multicast_start_q... (diff) | |
download | kernel-qcow2-linux-2804598764f984a8c5cdee377a73e0bf86dc5dd4.tar.gz kernel-qcow2-linux-2804598764f984a8c5cdee377a73e0bf86dc5dd4.tar.xz kernel-qcow2-linux-2804598764f984a8c5cdee377a73e0bf86dc5dd4.zip |
net: Fix missing meta data in skb with vlan packet
[ Upstream commit d85e8be2a5a02869f815dd0ac2d743deb4cd7957 ]
skb_reorder_vlan_header() should move XDP meta data with ethernet header
if XDP meta data exists.
Fixes: de8f3a83b0a0 ("bpf: add meta pointer for direct access")
Signed-off-by: Yuya Kusakabe <yuya.kusakabe@gmail.com>
Signed-off-by: Takeru Hayasaka <taketarou2@gmail.com>
Co-developed-by: Takeru Hayasaka <taketarou2@gmail.com>
Reviewed-by: Toshiaki Makita <makita.toshiaki@lab.ntt.co.jp>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'net/core')
-rw-r--r-- | net/core/skbuff.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/net/core/skbuff.c b/net/core/skbuff.c index ceee28e184af..8b5768113acd 100644 --- a/net/core/skbuff.c +++ b/net/core/skbuff.c @@ -5071,7 +5071,8 @@ EXPORT_SYMBOL_GPL(skb_gso_validate_mac_len); static struct sk_buff *skb_reorder_vlan_header(struct sk_buff *skb) { - int mac_len; + int mac_len, meta_len; + void *meta; if (skb_cow(skb, skb_headroom(skb)) < 0) { kfree_skb(skb); @@ -5083,6 +5084,13 @@ static struct sk_buff *skb_reorder_vlan_header(struct sk_buff *skb) memmove(skb_mac_header(skb) + VLAN_HLEN, skb_mac_header(skb), mac_len - VLAN_HLEN - ETH_TLEN); } + + meta_len = skb_metadata_len(skb); + if (meta_len) { + meta = skb_metadata_end(skb) - meta_len; + memmove(meta + VLAN_HLEN, meta, meta_len); + } + skb->mac_header += VLAN_HLEN; return skb; } |