aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/include/net/vxlan.h
diff options
context:
space:
mode:
authorXin Long <lucien.xin@gmail.com>2020-09-13 19:51:50 +0800
committerDavid S. Miller <davem@davemloft.net>2020-09-14 16:49:39 -0700
commit13e6ce98aa65ab5ce19351c020419360dfe8af29 (patch)
tree85f3cd4dd493f7ed32eceefe7b5c9755a81f8b70 /include/net/vxlan.h
parenttipc: use skb_unshare() instead in tipc_buf_append() (diff)
downloadwireguard-linux-13e6ce98aa65ab5ce19351c020419360dfe8af29.tar.xz
wireguard-linux-13e6ce98aa65ab5ce19351c020419360dfe8af29.zip
net: sched: only keep the available bits when setting vxlan md->gbp
As we can see from vxlan_build/parse_gbp_hdr(), when processing metadata on vxlan rx/tx path, only dont_learn/policy_applied/policy_id fields can be set to or parse from the packet for vxlan gbp option. So we'd better do the mask when set it in act_tunnel_key and cls_flower. Otherwise, when users don't know these bits, they may configure with a value which can never be matched. Reported-by: Shuang Li <shuali@redhat.com> Signed-off-by: Xin Long <lucien.xin@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to '')
-rw-r--r--include/net/vxlan.h3
1 files changed, 3 insertions, 0 deletions
diff --git a/include/net/vxlan.h b/include/net/vxlan.h
index 3a41627cbdfe..08537aa14f7c 100644
--- a/include/net/vxlan.h
+++ b/include/net/vxlan.h
@@ -121,6 +121,9 @@ struct vxlanhdr_gbp {
#define VXLAN_GBP_POLICY_APPLIED (BIT(3) << 16)
#define VXLAN_GBP_ID_MASK (0xFFFF)
+#define VXLAN_GBP_MASK (VXLAN_GBP_DONT_LEARN | VXLAN_GBP_POLICY_APPLIED | \
+ VXLAN_GBP_ID_MASK)
+
/*
* VXLAN Generic Protocol Extension (VXLAN_F_GPE):
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+