]> git.baikalelectronics.ru Git - kernel.git/commit
tracing/uprobes: Fail to unregister if probe event files are in use
authorSteven Rostedt (Red Hat) <rostedt@goodmis.org>
Thu, 4 Jul 2013 03:33:51 +0000 (23:33 -0400)
committerSteven Rostedt <rostedt@goodmis.org>
Thu, 1 Aug 2013 22:25:50 +0000 (18:25 -0400)
commit7f0e3c3a97e8b608e7f854f197732a584dec14b4
tree5589795f4b86670b2d4f4851a4de8f1401c6c7ff
parenta86c43f6d75a5535df15e3099d1427b6b3f522ef
tracing/uprobes: Fail to unregister if probe event files are in use

Uprobes suffer the same problem that kprobes have. There's a race between
writing to the "enable" file and removing the probe. The probe checks for
it being in use and if it is not, goes about deleting the probe and the
event that represents it. But the problem with that is, after it checks
if it is in use it can be enabled, and the deletion of the event (access
to the probe) will fail, as it is in use. But the uprobe will still be
deleted. This is a problem as the event can reference the uprobe that
was deleted.

The fix is to remove the event first, and check to make sure the event
removal succeeds. Then it is safe to remove the probe.

When the event exists, either ftrace or perf can enable the probe and
prevent the event from being removed.

Link: http://lkml.kernel.org/r/20130704034038.991525256@goodmis.org
Acked-by: Oleg Nesterov <oleg@redhat.com>
Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
kernel/trace/trace_uprobe.c