diff options
author | Jason Xing <kernelxing@tencent.com> | 2024-03-08 12:25:03 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2024-03-11 11:37:40 +0100 |
commit | 9eb430d40e449640122b0b33ace1f33e793ecc5f (patch) | |
tree | 67d61ee4f1d892e408cdce3698a574e3bac29a81 /net/mptcp | |
parent | ynl: samples: fix recycling rate calculation (diff) | |
download | linux-9eb430d40e449640122b0b33ace1f33e793ecc5f.tar.xz linux-9eb430d40e449640122b0b33ace1f33e793ecc5f.zip |
mptcp: annotate a data-race around sysctl_tcp_wmem[0]
It's possible that writer and the reader can manipulate the same
sysctl knob concurrently. Using READ_ONCE() to prevent reading
an old value.
Signed-off-by: Jason Xing <kernelxing@tencent.com>
Reviewed-by: Eric Dumazet <edumazet@google.com>
Reviewed-by: Mat Martineau <martineau@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/mptcp')
-rw-r--r-- | net/mptcp/protocol.h | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/mptcp/protocol.h b/net/mptcp/protocol.h index f16edef6026a..a10ebf3ee10a 100644 --- a/net/mptcp/protocol.h +++ b/net/mptcp/protocol.h @@ -850,7 +850,7 @@ static inline void __mptcp_sync_sndbuf(struct sock *sk) if (sk->sk_userlocks & SOCK_SNDBUF_LOCK) return; - new_sndbuf = sock_net(sk)->ipv4.sysctl_tcp_wmem[0]; + new_sndbuf = READ_ONCE(sock_net(sk)->ipv4.sysctl_tcp_wmem[0]); mptcp_for_each_subflow(mptcp_sk(sk), subflow) { ssk_sndbuf = READ_ONCE(mptcp_subflow_tcp_sock(subflow)->sk_sndbuf); |