]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
af_unix: Annotate data-race of gc_in_progress in wait_for_unix_gc().
authorKuniyuki Iwashima <kuniyu@amazon.com>
Tue, 23 Jan 2024 17:08:52 +0000 (09:08 -0800)
committerSasha Levin <sashal@kernel.org>
Tue, 26 Mar 2024 22:21:17 +0000 (18:21 -0400)
[ Upstream commit 31e03207119a535d0b0e3b3a7f91983aeb2cb14d ]

gc_in_progress is changed under spin_lock(&unix_gc_lock),
but wait_for_unix_gc() reads it locklessly.

Let's use READ_ONCE().

Fixes: 5f23b734963e ("net: Fix soft lockups/OOM issues w/ unix garbage collector")
Signed-off-by: Kuniyuki Iwashima <kuniyu@amazon.com>
Link: https://lore.kernel.org/r/20240123170856.41348-2-kuniyu@amazon.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
net/unix/garbage.c

index ab2c83d58b62af59c8e3227c38c948a978473f6b..9bfffe2a7f020fa5d592d272df6bf1d3c66b7fee 100644 (file)
@@ -198,7 +198,7 @@ void wait_for_unix_gc(void)
        if (READ_ONCE(unix_tot_inflight) > UNIX_INFLIGHT_TRIGGER_GC &&
            !READ_ONCE(gc_in_progress))
                unix_gc();
-       wait_event(unix_gc_wait, gc_in_progress == false);
+       wait_event(unix_gc_wait, !READ_ONCE(gc_in_progress));
 }
 
 /* The external entry point: unix_gc() */