summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWilliam Tu <u9012063@gmail.com>2018-04-24 23:46:59 -0700
committerDaniel Borkmann <daniel@iogearbox.net>2018-04-25 09:51:54 +0200
commit5540fbf43845868defcb599ec91c678275a20671 (patch)
tree7fe49e4fba413a173b442c2fb866520011c689fe
parentb3f8adee85e81a4e8b8ea842cdd9c8e5ec63573d (diff)
downloadlinux-5540fbf43845868defcb599ec91c678275a20671.tar.gz
linux-5540fbf43845868defcb599ec91c678275a20671.tar.bz2
linux-5540fbf43845868defcb599ec91c678275a20671.zip
bpf: clear the ip_tunnel_info.
The percpu metadata_dst might carry the stale ip_tunnel_info and cause incorrect behavior. When mixing tests using ipv4/ipv6 bpf vxlan and geneve tunnel, the ipv6 tunnel info incorrectly uses ipv4's src ip addr as its ipv6 src address, because the previous tunnel info does not clean up. The patch zeros the fields in ip_tunnel_info. Signed-off-by: William Tu <u9012063@gmail.com> Reported-by: Yifeng Sun <pkusunyifeng@gmail.com> Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
-rw-r--r--net/core/filter.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/net/core/filter.c b/net/core/filter.c
index d31aff93270d..e77c30ca491d 100644
--- a/net/core/filter.c
+++ b/net/core/filter.c
@@ -3240,6 +3240,7 @@ BPF_CALL_4(bpf_skb_set_tunnel_key, struct sk_buff *, skb,
skb_dst_set(skb, (struct dst_entry *) md);
info = &md->u.tun_info;
+ memset(info, 0, sizeof(*info));
info->mode = IP_TUNNEL_INFO_TX;
info->key.tun_flags = TUNNEL_KEY | TUNNEL_CSUM | TUNNEL_NOCACHE;