tracing: Call traceoff trigger after event is recorded
authorMasami Hiramatsu <mhiramat@kernel.org>
Thu, 8 Sep 2016 16:05:45 +0000 (01:05 +0900)
committerSteven Rostedt <rostedt@goodmis.org>
Fri, 23 Sep 2016 13:47:59 +0000 (09:47 -0400)
Call traceoff trigger after the event is recorded.
Since current traceoff trigger is called before recording
the event, we can not know what event stopped tracing.

Typical usecase of traceoff/traceon trigger is tracing
function calls and trace events between a pair of events.
For example, trace function calls between syscall entry/exit.
In that case, it is useful if we can see the return code
of the target syscall.

Link: http://lkml.kernel.org/r/147335074530.12462.4526186083406015005.stgit@devbox
Signed-off-by: Masami Hiramatsu <mhiramat@kernel.org>
Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
kernel/trace/trace_events_trigger.c

index a975571cde2407fa50910335c6b31fc2df128906..6721a1e89f39c7ff086acef638dabfcac030c31e 100644 (file)
@@ -1028,6 +1028,7 @@ static struct event_command trigger_traceon_cmd = {
 static struct event_command trigger_traceoff_cmd = {
        .name                   = "traceoff",
        .trigger_type           = ETT_TRACE_ONOFF,
+       .flags                  = EVENT_CMD_FL_POST_TRIGGER,
        .func                   = event_trigger_callback,
        .reg                    = register_trigger,
        .unreg                  = unregister_trigger,