Thread (4 messages) 4 messages, 4 authors, 2025-05-09

Re: [PATCH] tracing: fprobe: Fix RCU warning message in list traversal

From: Masami Hiramatsu (Google) <mhiramat@kernel.org>
Date: 2025-05-09 21:55:32
Also in: lkml

On Fri, 9 May 2025 16:30:08 +0200
Matthieu Baerts [off-list ref] wrote:
Hi Breno,

On 10/04/2025 14:22, Breno Leitao wrote:
quoted
When CONFIG_PROVE_RCU_LIST is enabled, fprobe triggers the following
warning:

    WARNING: suspicious RCU usage
    kernel/trace/fprobe.c:457 RCU-list traversed in non-reader section!!

    other info that might help us debug this:
	#1: ffffffff863c4e08 (fprobe_mutex){+.+.}-{4:4}, at: fprobe_module_callback+0x7b/0x8c0

    Call Trace:
	fprobe_module_callback
	notifier_call_chain
	blocking_notifier_call_chain

This warning occurs because fprobe_remove_node_in_module() traverses an
RCU list using RCU primitives without holding an RCU read lock. However,
the function is only called from fprobe_module_callback(), which holds
the fprobe_mutex lock that provides sufficient protection for safely
traversing the list.

Fix the warning by specifying the locking design to the
CONFIG_PROVE_RCU_LIST mechanism. Add the lockdep_is_held() argument to
hlist_for_each_entry_rcu() to inform the RCU checker that fprobe_mutex
provides the required protection.
@Breno: thank you for the patch, I have it applied for a while on a
branch dedicated to our CI to avoid false positive reports.

Tested-by: Matthieu Baerts (NGI0) <matttbe@kernel.org>
Oops, I missed this patch.

Let me pick it up and send it urgently.

Thank you,

Hopefully this fix can be sent to Linus before the v6.15 release :)

Cheers,
Matt
-- 
Sponsored by the NGI0 Core fund.

-- 
Masami Hiramatsu (Google) [off-list ref]
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help