diff options
author | Eric Dumazet <edumazet@google.com> | 2017-10-02 21:20:51 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2017-10-03 00:23:42 +0200 |
commit | eefca20eb20c66b06cf5ed09b49b1a7caaa27b7b (patch) | |
tree | 49ff0df975ed5fc89db450ca9b17ed040c1f7939 /net/sunrpc/svc.c | |
parent | Merge branch 'mlxsw-gre-fixes' (diff) | |
download | linux-eefca20eb20c66b06cf5ed09b49b1a7caaa27b7b.tar.xz linux-eefca20eb20c66b06cf5ed09b49b1a7caaa27b7b.zip |
socket, bpf: fix possible use after free
Starting from linux-4.4, 3WHS no longer takes the listener lock.
Since this time, we might hit a use-after-free in sk_filter_charge(),
if the filter we got in the memcpy() of the listener content
just happened to be replaced by a thread changing listener BPF filter.
To fix this, we need to make sure the filter refcount is not already
zero before incrementing it again.
Fixes: e994b2f0fb92 ("tcp: do not lock listener to process SYN packets")
Signed-off-by: Eric Dumazet <edumazet@google.com>
Acked-by: Alexei Starovoitov <ast@kernel.org>
Acked-by: Daniel Borkmann <daniel@iogearbox.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sunrpc/svc.c')
0 files changed, 0 insertions, 0 deletions