From: Kuniyuki Iwashima Date: Sat, 2 Sep 2023 00:27:08 +0000 (-0700) Subject: af_unix: Fix data race around sk->sk_err. X-Git-Tag: v6.6.17~3965^2~19^2 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=b192812905e4b134f7b7994b079eb647e9d2d37e;p=platform%2Fkernel%2Flinux-rpi.git af_unix: Fix data race around sk->sk_err. As with sk->sk_shutdown shown in the previous patch, sk->sk_err can be read locklessly by unix_dgram_sendmsg(). Let's use READ_ONCE() for sk_err as well. Note that the writer side is marked by commit cc04410af7de ("af_unix: annotate lockless accesses to sk->sk_err"). Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2") Signed-off-by: Kuniyuki Iwashima Reviewed-by: Eric Dumazet Signed-off-by: David S. Miller --- diff --git a/net/core/sock.c b/net/core/sock.c index e3da7eae..16584e2 100644 --- a/net/core/sock.c +++ b/net/core/sock.c @@ -2749,7 +2749,7 @@ static long sock_wait_for_wmem(struct sock *sk, long timeo) break; if (READ_ONCE(sk->sk_shutdown) & SEND_SHUTDOWN) break; - if (sk->sk_err) + if (READ_ONCE(sk->sk_err)) break; timeo = schedule_timeout(timeo); }