diff options
| author | Eric Dumazet <edumazet@google.com> | 2017-10-02 12:20:51 -0700 | 
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2017-10-02 15:23:42 -0700 | 
| commit | eefca20eb20c66b06cf5ed09b49b1a7caaa27b7b (patch) | |
| tree | 49ff0df975ed5fc89db450ca9b17ed040c1f7939 /lib/mpi/mpi-cmp.c | |
| parent | 4ee4553e861a2a7c4f5b045d9453729d837d4a7d (diff) | |
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 'lib/mpi/mpi-cmp.c')
0 files changed, 0 insertions, 0 deletions
