net: diag: Don't double-free TCP_NEW_SYN_RECV sockets in tcp_abort
[ Upstream commitacc2cf4e37
] When tcp_diag_destroy closes a TCP_NEW_SYN_RECV socket, it first frees it by calling inet_csk_reqsk_queue_drop_and_and_put in tcp_abort, and then frees it again by calling sock_gen_put. Since tcp_abort only has one caller, and all the other codepaths in tcp_abort don't free the socket, just remove the free in that function. Cc: David Ahern <dsa@cumulusnetworks.com> Tested: passes Android sock_diag_test.py, which exercises this codepath Fixes:d7226c7a4d
("net: diag: Fix refcnt leak in error path destroying socket") Signed-off-by: Lorenzo Colitti <lorenzo@google.com> Signed-off-by: Eric Dumazet <edumazet@google.com> Reviewed-by: David Ahern <dsa@cumulusnetworks.com> Tested-by: David Ahern <dsa@cumulusnetworks.com> Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
cfb876dc30
commit
cc0ab64759
@ -3415,8 +3415,7 @@ int tcp_abort(struct sock *sk, int err)
|
|||||||
struct request_sock *req = inet_reqsk(sk);
|
struct request_sock *req = inet_reqsk(sk);
|
||||||
|
|
||||||
local_bh_disable();
|
local_bh_disable();
|
||||||
inet_csk_reqsk_queue_drop_and_put(req->rsk_listener,
|
inet_csk_reqsk_queue_drop(req->rsk_listener, req);
|
||||||
req);
|
|
||||||
local_bh_enable();
|
local_bh_enable();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user