diff options
author | Frederic Weisbecker <fweisbec@gmail.com> | 2008-11-11 01:14:25 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-11-11 04:29:12 -0500 |
commit | 15e6cb3673ea6277999642802406a764b49391b0 (patch) | |
tree | d0a46a918caa64d5fb1ed37be3e026b30e94fe77 /kernel/trace/Kconfig | |
parent | caf4b323b02a16c92fba449952ac6515ddc76d7a (diff) |
tracing: add a tracer to catch execution time of kernel functions
Impact: add new tracing plugin which can trace full (entry+exit) function calls
This tracer uses the low level function return ftrace plugin to
measure the execution time of the kernel functions.
The first field is the caller of the function, the second is the
measured function, and the last one is the execution time in
nanoseconds.
- v3:
- HAVE_FUNCTION_RET_TRACER have been added. Each arch that support ftrace return
should enable it.
- ftrace_return_stub becomes ftrace_stub.
- CONFIG_FUNCTION_RET_TRACER depends now on CONFIG_FUNCTION_TRACER
- Return traces printing can be used for other tracers on trace.c
- Adapt to the new tracing API (no more ctrl_update callback)
- Correct the check of "disabled" during insertion.
- Minor changes...
Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Steven Rostedt <rostedt@goodmis.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/trace/Kconfig')
-rw-r--r-- | kernel/trace/Kconfig | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/kernel/trace/Kconfig b/kernel/trace/Kconfig index fc4febc3334a..d986216c8327 100644 --- a/kernel/trace/Kconfig +++ b/kernel/trace/Kconfig | |||
@@ -9,6 +9,9 @@ config NOP_TRACER | |||
9 | config HAVE_FUNCTION_TRACER | 9 | config HAVE_FUNCTION_TRACER |
10 | bool | 10 | bool |
11 | 11 | ||
12 | config HAVE_FUNCTION_RET_TRACER | ||
13 | bool | ||
14 | |||
12 | config HAVE_FUNCTION_TRACE_MCOUNT_TEST | 15 | config HAVE_FUNCTION_TRACE_MCOUNT_TEST |
13 | bool | 16 | bool |
14 | help | 17 | help |
@@ -54,6 +57,17 @@ config FUNCTION_TRACER | |||
54 | (the bootup default), then the overhead of the instructions is very | 57 | (the bootup default), then the overhead of the instructions is very |
55 | small and not measurable even in micro-benchmarks. | 58 | small and not measurable even in micro-benchmarks. |
56 | 59 | ||
60 | config FUNCTION_RET_TRACER | ||
61 | bool "Kernel Function return Tracer" | ||
62 | depends on !DYNAMIC_FTRACE | ||
63 | depends on HAVE_FUNCTION_RET_TRACER | ||
64 | depends on FUNCTION_TRACER | ||
65 | help | ||
66 | Enable the kernel to trace a function at its return. | ||
67 | It's first purpose is to trace the duration of functions. | ||
68 | This is done by setting the current return address on the thread | ||
69 | info structure of the current task. | ||
70 | |||
57 | config IRQSOFF_TRACER | 71 | config IRQSOFF_TRACER |
58 | bool "Interrupts-off Latency Tracer" | 72 | bool "Interrupts-off Latency Tracer" |
59 | default n | 73 | default n |