From: Peter Oskolkov Date: Wed, 16 Jan 2019 16:47:54 +0000 (-0800) Subject: bpf: bpf_setsockopt: reset sock dst on SO_MARK changes X-Git-Tag: v4.14.104~32 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=f040249c14ed75436f86e9b59e7e0eeb1027ff6c;p=users%2Fjedix%2Flinux-maple.git bpf: bpf_setsockopt: reset sock dst on SO_MARK changes [ Upstream commit f4924f24da8c7ef64195096817f3cde324091d97 ] In sock_setsockopt() (net/core/sock.h), when SO_MARK option is used to change sk_mark, sk_dst_reset(sk) is called. The same should be done in bpf_setsockopt(). Fixes: 8c4b4c7e9ff0 ("bpf: Add setsockopt helper function to bpf") Reported-by: Maciej Żenczykowski Signed-off-by: Peter Oskolkov Acked-by: Martin KaFai Lau Reviewed-by: Maciej Żenczykowski Signed-off-by: Daniel Borkmann Signed-off-by: Sasha Levin --- diff --git a/net/core/filter.c b/net/core/filter.c index a8a9ff0568b91..41ede90fc28f5 100644 --- a/net/core/filter.c +++ b/net/core/filter.c @@ -3102,7 +3102,10 @@ BPF_CALL_5(bpf_setsockopt, struct bpf_sock_ops_kern *, bpf_sock, sk->sk_rcvlowat = val ? : 1; break; case SO_MARK: - sk->sk_mark = val; + if (sk->sk_mark != val) { + sk->sk_mark = val; + sk_dst_reset(sk); + } break; default: ret = -EINVAL;