From: Kuniyuki Iwashima Date: Tue, 23 Aug 2022 17:46:53 +0000 (-0700) Subject: net: Fix a data-race around netdev_budget. X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=c9328c3d5a9eb21da020c7a9490964554963d2eb;p=GitHub%2FLineageOS%2Fandroid_kernel_motorola_exynos9610.git net: Fix a data-race around netdev_budget. [ Upstream commit 2e0c42374ee32e72948559d2ae2f7ba3dc6b977c ] While reading netdev_budget, it can be changed concurrently. Thus, we need to add READ_ONCE() to its reader. Fixes: 51b0bdedb8e7 ("[NET]: Separate two usages of netdev_max_backlog.") Signed-off-by: Kuniyuki Iwashima Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- diff --git a/net/core/dev.c b/net/core/dev.c index 51721fb2e30c..f6d3cbc57425 100644 --- a/net/core/dev.c +++ b/net/core/dev.c @@ -5649,7 +5649,7 @@ static __latent_entropy void net_rx_action(struct softirq_action *h) struct softnet_data *sd = this_cpu_ptr(&softnet_data); unsigned long time_limit = jiffies + usecs_to_jiffies(netdev_budget_usecs); - int budget = netdev_budget; + int budget = READ_ONCE(netdev_budget); LIST_HEAD(list); LIST_HEAD(repoll);