net: annotate sk->sk_rcvlowat lockless reads
sock_rcvlowat() or int_sk_rcvlowat() might be called without the socket lock for example from tcp_poll(). Use READ_ONCE() to document the fact that other cpus might change sk->sk_rcvlowat under us and avoid KCSAN splats. Use WRITE_ONCE() on write sides too. Signed-off-by: Eric Dumazet <edumazet@google.com> Signed-off-by: Jakub Kicinski <jakub.kicinski@netronome.com>
This commit is contained in:

committed by
Jakub Kicinski

parent
8265792bf8
commit
eac66402d1
@@ -2271,7 +2271,9 @@ static inline long sock_sndtimeo(const struct sock *sk, bool noblock)
|
||||
|
||||
static inline int sock_rcvlowat(const struct sock *sk, int waitall, int len)
|
||||
{
|
||||
return (waitall ? len : min_t(int, sk->sk_rcvlowat, len)) ? : 1;
|
||||
int v = waitall ? len : min_t(int, READ_ONCE(sk->sk_rcvlowat), len);
|
||||
|
||||
return v ?: 1;
|
||||
}
|
||||
|
||||
/* Alas, with timeout socket operations are not restartable.
|
||||
|
Reference in New Issue
Block a user