aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/trace/trace.h
diff options
context:
space:
mode:
authorTom Zanussi <tzanussi@gmail.com>2009-03-31 01:48:49 -0400
committerIngo Molnar <mingo@elte.hu>2009-04-13 18:00:50 -0400
commite1112b4d96859367a93468027c9635e2ac04eb3f (patch)
tree5170980ea71ee4bb5d0196880b58dbc997211b65 /kernel/trace/trace.h
parent66de7792c02693b49671afe58c771fde3b092fc7 (diff)
tracing/filters: add run-time field descriptions to TRACE_EVENT_FORMAT events
This patch adds run-time field descriptions to all the event formats exported using TRACE_EVENT_FORMAT. It also hooks up all the tracers that use them (i.e. the tracers in the 'ftrace subsystem') so they can also have their output filtered by the event-filtering mechanism. When I was testing this, there were a couple of things that fooled me into thinking the filters weren't working, when actually they were - I'll mention them here so others don't make the same mistakes (and file bug reports. ;-) One is that some of the tracers trace multiple events e.g. the sched_switch tracer uses the context_switch and wakeup events, and if you don't set filters on all of the traced events, the unfiltered output from the events without filters on them can make it look like the filtering as a whole isn't working properly, when actually it is doing what it was asked to do - it just wasn't asked to do the right thing. The other is that for the really high-volume tracers e.g. the function tracer, the volume of filtered events can be so high that it pushes the unfiltered events out of the ring buffer before they can be read so e.g. cat'ing the trace file repeatedly shows either no output, or once in awhile some output but that isn't there the next time you read the trace, which isn't what you normally expect when reading the trace file. If you read from the trace_pipe file though, you can catch them before they disappear. Changes from v1: As suggested by Frederic Weisbecker: - get rid of externs in functions - added unlikely() to filter_check_discard() Signed-off-by: Tom Zanussi <tzanussi@gmail.com> Signed-off-by: Steven Rostedt <srostedt@redhat.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/trace/trace.h')
-rw-r--r--kernel/trace/trace.h20
1 files changed, 20 insertions, 0 deletions
diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h
index 34b94c3f40ad..e7737281953f 100644
--- a/kernel/trace/trace.h
+++ b/kernel/trace/trace.h
@@ -866,6 +866,21 @@ extern void filter_free_subsystem_preds(struct event_subsystem *system);
866extern int filter_add_subsystem_pred(struct event_subsystem *system, 866extern int filter_add_subsystem_pred(struct event_subsystem *system,
867 struct filter_pred *pred); 867 struct filter_pred *pred);
868 868
869static inline void
870filter_check_discard(struct ftrace_event_call *call, void *rec,
871 struct ring_buffer_event *event)
872{
873 if (unlikely(call->preds) && !filter_match_preds(call, rec))
874 ring_buffer_event_discard(event);
875}
876
877#define __common_field(type, item) \
878 ret = trace_define_field(event_call, #type, "common_" #item, \
879 offsetof(typeof(field.ent), item), \
880 sizeof(field.ent.item)); \
881 if (ret) \
882 return ret;
883
869void event_trace_printk(unsigned long ip, const char *fmt, ...); 884void event_trace_printk(unsigned long ip, const char *fmt, ...);
870extern struct ftrace_event_call __start_ftrace_events[]; 885extern struct ftrace_event_call __start_ftrace_events[];
871extern struct ftrace_event_call __stop_ftrace_events[]; 886extern struct ftrace_event_call __stop_ftrace_events[];
@@ -897,4 +912,9 @@ do { \
897 __trace_printk(ip, fmt, ##args); \ 912 __trace_printk(ip, fmt, ##args); \
898} while (0) 913} while (0)
899 914
915#undef TRACE_EVENT_FORMAT
916#define TRACE_EVENT_FORMAT(call, proto, args, fmt, tstruct, tpfmt) \
917 extern struct ftrace_event_call event_##call;
918#include "trace_event_types.h"
919
900#endif /* _LINUX_KERNEL_TRACE_H */ 920#endif /* _LINUX_KERNEL_TRACE_H */