tracing: Add down_write(trace_event_sem) when adding trace event

When a module is loaded, it adds trace events defined by the module. It
may also need to modify the modules trace printk formats to replace enum
names with their values.

If two modules are loaded at the same time, the adding of the event to the
ftrace_events list can corrupt the walking of the list in the code that is
modifying the printk format strings and crash the kernel.

The addition of the event should take the trace_event_sem for write while
it adds the new event.

Also add a lockdep_assert_held() on that semaphore in
__trace_add_event_dirs() as it iterates the list.

Cc: stable@vger.kernel.org
Cc: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Acked-by: Masami Hiramatsu (Google) <mhiramat@kernel.org>
Link: https://lore.kernel.org/20250718223158.799bfc0c@batman.local.home
Reported-by: Fusheng Huang(黄富生) <Fusheng.Huang@luxshare-ict.com>
Closes: https://lore.kernel.org/all/20250717105007.46ccd18f@batman.local.home/
Fixes: 110bf2b764eb6 ("tracing: add protection around module events unload")
Signed-off-by: Steven Rostedt (Google) <rostedt@goodmis.org>

Changed files
+5
kernel
+5
kernel/trace/trace_events.c
··· 3136 3136 if (ret < 0) 3137 3137 return ret; 3138 3138 3139 + down_write(&trace_event_sem); 3139 3140 list_add(&call->list, &ftrace_events); 3141 + up_write(&trace_event_sem); 3142 + 3140 3143 if (call->flags & TRACE_EVENT_FL_DYNAMIC) 3141 3144 atomic_set(&call->refcnt, 0); 3142 3145 else ··· 3752 3749 { 3753 3750 struct trace_event_call *call; 3754 3751 int ret; 3752 + 3753 + lockdep_assert_held(&trace_event_sem); 3755 3754 3756 3755 list_for_each_entry(call, &ftrace_events, list) { 3757 3756 ret = __trace_add_new_event(call, tr);