]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
tcp: Fix use-after-free of nreq in reqsk_timer_handler().
authorKuniyuki Iwashima <kuniyu@amazon.com>
Sat, 23 Nov 2024 17:42:36 +0000 (09:42 -0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 5 Dec 2024 12:54:01 +0000 (13:54 +0100)
[ Upstream commit c31e72d021db2714df03df6c42855a1db592716c ]

The cited commit replaced inet_csk_reqsk_queue_drop_and_put() with
__inet_csk_reqsk_queue_drop() and reqsk_put() in reqsk_timer_handler().

Then, oreq should be passed to reqsk_put() instead of req; otherwise
use-after-free of nreq could happen when reqsk is migrated but the
retry attempt failed (e.g. due to timeout).

Let's pass oreq to reqsk_put().

Fixes: e8c526f2bdf1 ("tcp/dccp: Don't use timer_pending() in reqsk_queue_unlink().")
Reported-by: Liu Jian <liujian56@huawei.com>
Closes: https://lore.kernel.org/netdev/1284490f-9525-42ee-b7b8-ccadf6606f6d@huawei.com/
Signed-off-by: Kuniyuki Iwashima <kuniyu@amazon.com>
Reviewed-by: Vadim Fedorenko <vadim.fedorenko@linux.dev>
Reviewed-by: Liu Jian <liujian56@huawei.com>
Reviewed-by: Eric Dumazet <edumazet@google.com>
Reviewed-by: Martin KaFai Lau <martin.lau@kernel.org>
Link: https://patch.msgid.link/20241123174236.62438-1-kuniyu@amazon.com
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
net/ipv4/inet_connection_sock.c

index cd7989b514eaa76525aea3e3ddffddc2cbae3548..f5592670420b5b6ec0ebef23e2e9ef3a745320e7 100644 (file)
@@ -1188,7 +1188,7 @@ no_ownership:
 
 drop:
        __inet_csk_reqsk_queue_drop(sk_listener, oreq, true);
-       reqsk_put(req);
+       reqsk_put(oreq);
 }
 
 static bool reqsk_queue_hash_req(struct request_sock *req,