From: Kuniyuki Iwashima Date: Wed, 20 Jul 2022 16:50:22 +0000 (-0700) Subject: tcp: Fix a data-race around sysctl_tcp_min_tso_segs. X-Git-Tag: Ubuntu-5.15.0-49.55~72 X-Git-Url: https://git.proxmox.com/?a=commitdiff_plain;h=e9c6073d1e45a927008fd63dac016600734ece03;p=mirror_ubuntu-jammy-kernel.git tcp: Fix a data-race around sysctl_tcp_min_tso_segs. BugLink: https://bugs.launchpad.net/bugs/1989218 [ Upstream commit e0bb4ab9dfddd872622239f49fb2bd403b70853b ] While reading sysctl_tcp_min_tso_segs, it can be changed concurrently. Thus, we need to add READ_ONCE() to its reader. Fixes: 95bd09eb2750 ("tcp: TSO packets automatic sizing") Signed-off-by: Kuniyuki Iwashima Signed-off-by: David S. Miller Signed-off-by: Sasha Levin Signed-off-by: Kamal Mostafa Signed-off-by: Stefan Bader --- diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c index 4389ad7e4c8c..51f31311fdb6 100644 --- a/net/ipv4/tcp_output.c +++ b/net/ipv4/tcp_output.c @@ -1986,7 +1986,7 @@ static u32 tcp_tso_segs(struct sock *sk, unsigned int mss_now) min_tso = ca_ops->min_tso_segs ? ca_ops->min_tso_segs(sk) : - sock_net(sk)->ipv4.sysctl_tcp_min_tso_segs; + READ_ONCE(sock_net(sk)->ipv4.sysctl_tcp_min_tso_segs); tso_segs = tcp_tso_autosize(sk, mss_now, min_tso); return min_t(u32, tso_segs, sk->sk_gso_max_segs);