mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
tracing: Return -EBUSY when event_enable_func() fails to get module
Since try_module_get() returns false( = 0) when it fails to pindown a module, event_enable_func() returns 0 which means "succeed". This can cause a kernel panic when the entry is removed, because the event is already released. This fixes the bug by returning -EBUSY, because the reason why it fails is that the module is being removed at that time. Link: http://lkml.kernel.org/r/20130516114848.13508.97899.stgit@mhiramat-M0-7522 Cc: Srikar Dronamraju <srikar@linux.vnet.ibm.com> Cc: Oleg Nesterov <oleg@redhat.com> Cc: Tom Zanussi <tom.zanussi@intel.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Ingo Molnar <mingo@redhat.com> Signed-off-by: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com> Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
This commit is contained in:
parent
b62fdd97fc
commit
6ed0106667
@ -2072,8 +2072,10 @@ event_enable_func(struct ftrace_hash *hash,
|
|||||||
out_reg:
|
out_reg:
|
||||||
/* Don't let event modules unload while probe registered */
|
/* Don't let event modules unload while probe registered */
|
||||||
ret = try_module_get(file->event_call->mod);
|
ret = try_module_get(file->event_call->mod);
|
||||||
if (!ret)
|
if (!ret) {
|
||||||
|
ret = -EBUSY;
|
||||||
goto out_free;
|
goto out_free;
|
||||||
|
}
|
||||||
|
|
||||||
ret = __ftrace_event_enable_disable(file, 1, 1);
|
ret = __ftrace_event_enable_disable(file, 1, 1);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
|
Loading…
Reference in New Issue
Block a user