summaryrefslogtreecommitdiff
path: root/net/sched/cls_flower.c
diff options
context:
space:
mode:
authorXin Long <lucien.xin@gmail.com>2020-09-13 19:43:03 +0800
committerDavid S. Miller <davem@davemloft.net>2020-09-14 16:53:38 -0700
commit8e1b3ac4786680c2d2b5a24e38a2d714c3bcd1ef (patch)
tree14d2af7c1ff1a284ba31c3062f76e1ea1b57559f /net/sched/cls_flower.c
parentad7b27c9e64afce4ad69020329a3e89f6df4f382 (diff)
downloadlinux-rpi-8e1b3ac4786680c2d2b5a24e38a2d714c3bcd1ef.tar.gz
linux-rpi-8e1b3ac4786680c2d2b5a24e38a2d714c3bcd1ef.tar.bz2
linux-rpi-8e1b3ac4786680c2d2b5a24e38a2d714c3bcd1ef.zip
net: sched: initialize with 0 before setting erspan md->u
In fl_set_erspan_opt(), all bits of erspan md was set 1, as this function is also used to set opt MASK. However, when setting for md->u.index for opt VALUE, the rest bits of the union md->u will be left 1. It would cause to fail the match of the whole md when version is 1 and only index is set. This patch is to fix by initializing with 0 before setting erspan md->u. Reported-by: Shuang Li <shuali@redhat.com> Fixes: 79b1011cb33d ("net: sched: allow flower to match erspan options") Signed-off-by: Xin Long <lucien.xin@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sched/cls_flower.c')
-rw-r--r--net/sched/cls_flower.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/net/sched/cls_flower.c b/net/sched/cls_flower.c
index e8fda1bd4d9d..fed18fd2c50b 100644
--- a/net/sched/cls_flower.c
+++ b/net/sched/cls_flower.c
@@ -1223,6 +1223,7 @@ static int fl_set_erspan_opt(const struct nlattr *nla, struct fl_flow_key *key,
}
if (tb[TCA_FLOWER_KEY_ENC_OPT_ERSPAN_INDEX]) {
nla = tb[TCA_FLOWER_KEY_ENC_OPT_ERSPAN_INDEX];
+ memset(&md->u, 0x00, sizeof(md->u));
md->u.index = nla_get_be32(nla);
}
} else if (md->version == 2) {