Commit 1ce25e9f authored by Masami Hiramatsu's avatar Masami Hiramatsu Committed by Steven Rostedt (VMware)

tracing: Add generic event-name based remove event method

Add a generic method to remove event from dynamic event
list. This is same as other system under ftrace. You
just need to pass the event name with '!', e.g.

  # echo p:new_grp/new_event _do_fork > dynamic_events

This creates an event, and

  # echo '!p:new_grp/new_event _do_fork' > dynamic_events

Or,

  # echo '!p:new_grp/new_event' > dynamic_events

will remove new_grp/new_event event.

Note that this doesn't check the event prefix (e.g. "p:")
strictly, because the "group/event" name must be unique.

Link: http://lkml.kernel.org/r/154140869774.17322.8887303560398645347.stgit@devboxReviewed-by: default avatarTom Zanussi <tom.zanussi@linux.intel.com>
Tested-by: default avatarTom Zanussi <tom.zanussi@linux.intel.com>
Signed-off-by: default avatarMasami Hiramatsu <mhiramat@kernel.org>
Signed-off-by: default avatarSteven Rostedt (VMware) <rostedt@goodmis.org>
parent 7e1413ed
...@@ -37,10 +37,17 @@ int dyn_event_release(int argc, char **argv, struct dyn_event_operations *type) ...@@ -37,10 +37,17 @@ int dyn_event_release(int argc, char **argv, struct dyn_event_operations *type)
char *system = NULL, *event, *p; char *system = NULL, *event, *p;
int ret = -ENOENT; int ret = -ENOENT;
if (argv[0][0] == '-') {
if (argv[0][1] != ':') if (argv[0][1] != ':')
return -EINVAL; return -EINVAL;
event = &argv[0][2]; event = &argv[0][2];
} else {
event = strchr(argv[0], ':');
if (!event)
return -EINVAL;
event++;
}
p = strchr(event, '/'); p = strchr(event, '/');
if (p) { if (p) {
system = event; system = event;
...@@ -69,7 +76,7 @@ static int create_dyn_event(int argc, char **argv) ...@@ -69,7 +76,7 @@ static int create_dyn_event(int argc, char **argv)
struct dyn_event_operations *ops; struct dyn_event_operations *ops;
int ret; int ret;
if (argv[0][0] == '-') if (argv[0][0] == '-' || argv[0][0] == '!')
return dyn_event_release(argc, argv, NULL); return dyn_event_release(argc, argv, NULL);
mutex_lock(&dyn_event_ops_mutex); mutex_lock(&dyn_event_ops_mutex);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment