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-Url: https://git.stricted.de/?a=commitdiff_plain;h=d2c7c751db2a248dbe1f29b1c8a29fa8d65ae28f;p=GitHub%2FLineageOS%2Fandroid_kernel_motorola_exynos9610.git net: Fix a data-race around sysctl_tstamp_allow_data. [ Upstream commit d2154b0afa73c0159b2856f875c6b4fe7cf6a95e ] 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 Signed-off-by: Sasha Levin --- diff --git a/net/core/skbuff.c b/net/core/skbuff.c index 629997753f69..11d0ffc51c24 100644 --- a/net/core/skbuff.c +++ b/net/core/skbuff.c @@ -4352,7 +4352,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);