From: Kuniyuki Iwashima Date: Tue, 23 Aug 2022 17:46:50 +0000 (-0700) Subject: net: Fix a data-race around sysctl_tstamp_allow_data. X-Git-Tag: v6.1-rc5~537^2~8^2~10 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=d2154b0afa73c0159b2856f875c6b4fe7cf6a95e;p=platform%2Fkernel%2Flinux-starfive.git net: Fix a data-race around sysctl_tstamp_allow_data. While reading sysctl_tstamp_allow_data, it can be changed concurrently. Thus, we need to add READ_ONCE() to its reader. Fixes: b245be1f4db1 ("net-timestamp: no-payload only sysctl") Signed-off-by: Kuniyuki Iwashima Signed-off-by: David S. Miller --- diff --git a/net/core/skbuff.c b/net/core/skbuff.c index 5ea1d07..84bb5e1 100644 --- a/net/core/skbuff.c +++ b/net/core/skbuff.c @@ -4797,7 +4797,7 @@ static bool skb_may_tx_timestamp(struct sock *sk, bool tsonly) { bool ret; - if (likely(sysctl_tstamp_allow_data || tsonly)) + if (likely(READ_ONCE(sysctl_tstamp_allow_data) || tsonly)) return true; read_lock_bh(&sk->sk_callback_lock);