diff options
author | Dave Hansen <dave.hansen@linux.intel.com> | 2013-06-21 11:51:38 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2013-06-23 05:52:58 -0400 |
commit | 0c4df02d739fed5ab081b330d67403206dd3967e (patch) | |
tree | 37296c48ff5adef1537fd5c64977a3c1a0e8cff2 /include/trace/events | |
parent | 14c63f17b1fde5a575a28e96547a22b451c71fb5 (diff) |
x86: Add NMI duration tracepoints
This patch has been invaluable in my adventures finding
issues in the perf NMI handler. I'm as big a fan of
printk() as anybody is, but using printk() in NMIs is
deadly when they're happening frequently.
Even hacking in trace_printk() ended up eating enough
CPU to throw off some of the measurements I was making.
Signed-off-by: Dave Hansen <dave.hansen@linux.intel.com>
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: paulus@samba.org
Cc: acme@ghostprotocols.net
Cc: Dave Hansen <dave@sr71.net>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'include/trace/events')
-rw-r--r-- | include/trace/events/nmi.h | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/include/trace/events/nmi.h b/include/trace/events/nmi.h new file mode 100644 index 000000000000..da3ee96b8d03 --- /dev/null +++ b/include/trace/events/nmi.h | |||
@@ -0,0 +1,37 @@ | |||
1 | #undef TRACE_SYSTEM | ||
2 | #define TRACE_SYSTEM nmi | ||
3 | |||
4 | #if !defined(_TRACE_NMI_H) || defined(TRACE_HEADER_MULTI_READ) | ||
5 | #define _TRACE_NMI_H | ||
6 | |||
7 | #include <linux/ktime.h> | ||
8 | #include <linux/tracepoint.h> | ||
9 | |||
10 | TRACE_EVENT(nmi_handler, | ||
11 | |||
12 | TP_PROTO(void *handler, s64 delta_ns, int handled), | ||
13 | |||
14 | TP_ARGS(handler, delta_ns, handled), | ||
15 | |||
16 | TP_STRUCT__entry( | ||
17 | __field( void *, handler ) | ||
18 | __field( s64, delta_ns) | ||
19 | __field( int, handled ) | ||
20 | ), | ||
21 | |||
22 | TP_fast_assign( | ||
23 | __entry->handler = handler; | ||
24 | __entry->delta_ns = delta_ns; | ||
25 | __entry->handled = handled; | ||
26 | ), | ||
27 | |||
28 | TP_printk("%ps() delta_ns: %lld handled: %d", | ||
29 | __entry->handler, | ||
30 | __entry->delta_ns, | ||
31 | __entry->handled) | ||
32 | ); | ||
33 | |||
34 | #endif /* _TRACE_NMI_H */ | ||
35 | |||
36 | /* This part ust be outside protection */ | ||
37 | #include <trace/define_trace.h> | ||