116444a8aSArnaldo Carvalho de Melo# 2606576ceSSteven Rostedt# Architectures that offer an FUNCTION_TRACER implementation should 3606576ceSSteven Rostedt# select HAVE_FUNCTION_TRACER: 416444a8aSArnaldo Carvalho de Melo# 52a3a4f66SFrédéric Weisbecker 62a3a4f66SFrédéric Weisbeckerconfig NOP_TRACER 72a3a4f66SFrédéric Weisbecker bool 82a3a4f66SFrédéric Weisbecker 9606576ceSSteven Rostedtconfig HAVE_FUNCTION_TRACER 1016444a8aSArnaldo Carvalho de Melo bool 11bc0c38d1SSteven Rostedt 1215e6cb36SFrederic Weisbeckerconfig HAVE_FUNCTION_RET_TRACER 1315e6cb36SFrederic Weisbecker bool 1415e6cb36SFrederic Weisbecker 1560a7ecf4SSteven Rostedtconfig HAVE_FUNCTION_TRACE_MCOUNT_TEST 1660a7ecf4SSteven Rostedt bool 1760a7ecf4SSteven Rostedt help 1860a7ecf4SSteven Rostedt This gets selected when the arch tests the function_trace_stop 1960a7ecf4SSteven Rostedt variable at the mcount call site. Otherwise, this variable 2060a7ecf4SSteven Rostedt is tested by the called function. 2160a7ecf4SSteven Rostedt 22677aa9f7SSteven Rostedtconfig HAVE_DYNAMIC_FTRACE 23677aa9f7SSteven Rostedt bool 24677aa9f7SSteven Rostedt 258da3821bSSteven Rostedtconfig HAVE_FTRACE_MCOUNT_RECORD 268da3821bSSteven Rostedt bool 278da3821bSSteven Rostedt 28352ad25aSSteven Rostedtconfig TRACER_MAX_TRACE 29352ad25aSSteven Rostedt bool 30352ad25aSSteven Rostedt 317a8e76a3SSteven Rostedtconfig RING_BUFFER 327a8e76a3SSteven Rostedt bool 337a8e76a3SSteven Rostedt 34bc0c38d1SSteven Rostedtconfig TRACING 35bc0c38d1SSteven Rostedt bool 36bc0c38d1SSteven Rostedt select DEBUG_FS 377a8e76a3SSteven Rostedt select RING_BUFFER 38c2c80529SAl Viro select STACKTRACE if STACKTRACE_SUPPORT 395f87f112SIngo Molnar select TRACEPOINTS 40f3384b28SSteven Rostedt select NOP_TRACER 41bc0c38d1SSteven Rostedt 4217d80fd0SPeter Zijlstramenu "Tracers" 4317d80fd0SPeter Zijlstra 44606576ceSSteven Rostedtconfig FUNCTION_TRACER 451b29b018SSteven Rostedt bool "Kernel Function Tracer" 46606576ceSSteven Rostedt depends on HAVE_FUNCTION_TRACER 47d3ee6d99SIngo Molnar depends on DEBUG_KERNEL 481b29b018SSteven Rostedt select FRAME_POINTER 491b29b018SSteven Rostedt select TRACING 5035e8e302SSteven Rostedt select CONTEXT_SWITCH_TRACER 511b29b018SSteven Rostedt help 521b29b018SSteven Rostedt Enable the kernel to trace every kernel function. This is done 531b29b018SSteven Rostedt by using a compiler feature to insert a small, 5-byte No-Operation 541b29b018SSteven Rostedt instruction to the beginning of every kernel function, which NOP 551b29b018SSteven Rostedt sequence is then dynamically patched into a tracer call when 561b29b018SSteven Rostedt tracing is enabled by the administrator. If it's runtime disabled 571b29b018SSteven Rostedt (the bootup default), then the overhead of the instructions is very 581b29b018SSteven Rostedt small and not measurable even in micro-benchmarks. 5935e8e302SSteven Rostedt 6015e6cb36SFrederic Weisbeckerconfig FUNCTION_RET_TRACER 6115e6cb36SFrederic Weisbecker bool "Kernel Function return Tracer" 6215e6cb36SFrederic Weisbecker depends on !DYNAMIC_FTRACE 6315e6cb36SFrederic Weisbecker depends on HAVE_FUNCTION_RET_TRACER 6415e6cb36SFrederic Weisbecker depends on FUNCTION_TRACER 6515e6cb36SFrederic Weisbecker help 6615e6cb36SFrederic Weisbecker Enable the kernel to trace a function at its return. 6715e6cb36SFrederic Weisbecker It's first purpose is to trace the duration of functions. 6815e6cb36SFrederic Weisbecker This is done by setting the current return address on the thread 6915e6cb36SFrederic Weisbecker info structure of the current task. 7015e6cb36SFrederic Weisbecker 7181d68a96SSteven Rostedtconfig IRQSOFF_TRACER 7281d68a96SSteven Rostedt bool "Interrupts-off Latency Tracer" 7381d68a96SSteven Rostedt default n 7481d68a96SSteven Rostedt depends on TRACE_IRQFLAGS_SUPPORT 7581d68a96SSteven Rostedt depends on GENERIC_TIME 76d3ee6d99SIngo Molnar depends on DEBUG_KERNEL 7781d68a96SSteven Rostedt select TRACE_IRQFLAGS 7881d68a96SSteven Rostedt select TRACING 7981d68a96SSteven Rostedt select TRACER_MAX_TRACE 8081d68a96SSteven Rostedt help 8181d68a96SSteven Rostedt This option measures the time spent in irqs-off critical 8281d68a96SSteven Rostedt sections, with microsecond accuracy. 8381d68a96SSteven Rostedt 8481d68a96SSteven Rostedt The default measurement method is a maximum search, which is 8581d68a96SSteven Rostedt disabled by default and can be runtime (re-)started 8681d68a96SSteven Rostedt via: 8781d68a96SSteven Rostedt 8881d68a96SSteven Rostedt echo 0 > /debugfs/tracing/tracing_max_latency 8981d68a96SSteven Rostedt 906cd8a4bbSSteven Rostedt (Note that kernel size and overhead increases with this option 916cd8a4bbSSteven Rostedt enabled. This option and the preempt-off timing option can be 926cd8a4bbSSteven Rostedt used together or separately.) 936cd8a4bbSSteven Rostedt 946cd8a4bbSSteven Rostedtconfig PREEMPT_TRACER 956cd8a4bbSSteven Rostedt bool "Preemption-off Latency Tracer" 966cd8a4bbSSteven Rostedt default n 976cd8a4bbSSteven Rostedt depends on GENERIC_TIME 986cd8a4bbSSteven Rostedt depends on PREEMPT 99d3ee6d99SIngo Molnar depends on DEBUG_KERNEL 1006cd8a4bbSSteven Rostedt select TRACING 1016cd8a4bbSSteven Rostedt select TRACER_MAX_TRACE 1026cd8a4bbSSteven Rostedt help 1036cd8a4bbSSteven Rostedt This option measures the time spent in preemption off critical 1046cd8a4bbSSteven Rostedt sections, with microsecond accuracy. 1056cd8a4bbSSteven Rostedt 1066cd8a4bbSSteven Rostedt The default measurement method is a maximum search, which is 1076cd8a4bbSSteven Rostedt disabled by default and can be runtime (re-)started 1086cd8a4bbSSteven Rostedt via: 1096cd8a4bbSSteven Rostedt 1106cd8a4bbSSteven Rostedt echo 0 > /debugfs/tracing/tracing_max_latency 1116cd8a4bbSSteven Rostedt 1126cd8a4bbSSteven Rostedt (Note that kernel size and overhead increases with this option 1136cd8a4bbSSteven Rostedt enabled. This option and the irqs-off timing option can be 1146cd8a4bbSSteven Rostedt used together or separately.) 1156cd8a4bbSSteven Rostedt 116f06c3810SIngo Molnarconfig SYSPROF_TRACER 117f06c3810SIngo Molnar bool "Sysprof Tracer" 1184d2df795SThomas Gleixner depends on X86 119f06c3810SIngo Molnar select TRACING 120f06c3810SIngo Molnar help 121f06c3810SIngo Molnar This tracer provides the trace needed by the 'Sysprof' userspace 122f06c3810SIngo Molnar tool. 123f06c3810SIngo Molnar 124352ad25aSSteven Rostedtconfig SCHED_TRACER 125352ad25aSSteven Rostedt bool "Scheduling Latency Tracer" 126d3ee6d99SIngo Molnar depends on DEBUG_KERNEL 127352ad25aSSteven Rostedt select TRACING 128352ad25aSSteven Rostedt select CONTEXT_SWITCH_TRACER 129352ad25aSSteven Rostedt select TRACER_MAX_TRACE 130352ad25aSSteven Rostedt help 131352ad25aSSteven Rostedt This tracer tracks the latency of the highest priority task 132352ad25aSSteven Rostedt to be scheduled in, starting from the point it has woken up. 133352ad25aSSteven Rostedt 13435e8e302SSteven Rostedtconfig CONTEXT_SWITCH_TRACER 13535e8e302SSteven Rostedt bool "Trace process context switches" 136d3ee6d99SIngo Molnar depends on DEBUG_KERNEL 13735e8e302SSteven Rostedt select TRACING 13835e8e302SSteven Rostedt select MARKERS 13935e8e302SSteven Rostedt help 14035e8e302SSteven Rostedt This tracer gets called from the context switch and records 14135e8e302SSteven Rostedt all switching of tasks. 14235e8e302SSteven Rostedt 1431f5c2abbSFrédéric Weisbeckerconfig BOOT_TRACER 1441f5c2abbSFrédéric Weisbecker bool "Trace boot initcalls" 1451f5c2abbSFrédéric Weisbecker depends on DEBUG_KERNEL 1461f5c2abbSFrédéric Weisbecker select TRACING 147ea31e72dSFrederic Weisbecker select CONTEXT_SWITCH_TRACER 1481f5c2abbSFrédéric Weisbecker help 1491f5c2abbSFrédéric Weisbecker This tracer helps developers to optimize boot times: it records 15098d9c66aSIngo Molnar the timings of the initcalls and traces key events and the identity 15198d9c66aSIngo Molnar of tasks that can cause boot delays, such as context-switches. 15298d9c66aSIngo Molnar 15398d9c66aSIngo Molnar Its aim is to be parsed by the /scripts/bootgraph.pl tool to 15498d9c66aSIngo Molnar produce pretty graphics about boot inefficiencies, giving a visual 15598d9c66aSIngo Molnar representation of the delays during initcalls - but the raw 15698d9c66aSIngo Molnar /debug/tracing/trace text output is readable too. 15798d9c66aSIngo Molnar 15898d9c66aSIngo Molnar ( Note that tracing self tests can't be enabled if this tracer is 15998d9c66aSIngo Molnar selected, because the self-tests are an initcall as well and that 16098d9c66aSIngo Molnar would invalidate the boot trace. ) 1611f5c2abbSFrédéric Weisbecker 162*1f0d69a9SSteven Rostedtconfig TRACE_UNLIKELY_PROFILE 163*1f0d69a9SSteven Rostedt bool "Trace likely/unlikely profiler" 164*1f0d69a9SSteven Rostedt depends on DEBUG_KERNEL 165*1f0d69a9SSteven Rostedt select TRACING 166*1f0d69a9SSteven Rostedt help 167*1f0d69a9SSteven Rostedt This tracer profiles all the the likely and unlikely macros 168*1f0d69a9SSteven Rostedt in the kernel. It will display the results in: 169*1f0d69a9SSteven Rostedt 170*1f0d69a9SSteven Rostedt /debugfs/tracing/profile_likely 171*1f0d69a9SSteven Rostedt /debugfs/tracing/profile_unlikely 172*1f0d69a9SSteven Rostedt 173*1f0d69a9SSteven Rostedt Note: this will add a significant overhead, only turn this 174*1f0d69a9SSteven Rostedt on if you need to profile the system's use of these macros. 175*1f0d69a9SSteven Rostedt 176*1f0d69a9SSteven Rostedt Say N if unsure. 177*1f0d69a9SSteven Rostedt 178e5a81b62SSteven Rostedtconfig STACK_TRACER 179e5a81b62SSteven Rostedt bool "Trace max stack" 180606576ceSSteven Rostedt depends on HAVE_FUNCTION_TRACER 1812ff01c6aSIngo Molnar depends on DEBUG_KERNEL 182606576ceSSteven Rostedt select FUNCTION_TRACER 183e5a81b62SSteven Rostedt select STACKTRACE 184e5a81b62SSteven Rostedt help 1854519d9e5SIngo Molnar This special tracer records the maximum stack footprint of the 1864519d9e5SIngo Molnar kernel and displays it in debugfs/tracing/stack_trace. 1874519d9e5SIngo Molnar 1884519d9e5SIngo Molnar This tracer works by hooking into every function call that the 1894519d9e5SIngo Molnar kernel executes, and keeping a maximum stack depth value and 1904519d9e5SIngo Molnar stack-trace saved. Because this logic has to execute in every 1914519d9e5SIngo Molnar kernel function, all the time, this option can slow down the 1924519d9e5SIngo Molnar kernel measurably and is generally intended for kernel 1934519d9e5SIngo Molnar developers only. 1944519d9e5SIngo Molnar 1954519d9e5SIngo Molnar Say N if unsure. 196e5a81b62SSteven Rostedt 1973d083395SSteven Rostedtconfig DYNAMIC_FTRACE 1983d083395SSteven Rostedt bool "enable/disable ftrace tracepoints dynamically" 199606576ceSSteven Rostedt depends on FUNCTION_TRACER 200677aa9f7SSteven Rostedt depends on HAVE_DYNAMIC_FTRACE 201d3ee6d99SIngo Molnar depends on DEBUG_KERNEL 2023d083395SSteven Rostedt default y 2033d083395SSteven Rostedt help 2043d083395SSteven Rostedt This option will modify all the calls to ftrace dynamically 2053d083395SSteven Rostedt (will patch them out of the binary image and replaces them 2063d083395SSteven Rostedt with a No-Op instruction) as they are called. A table is 2073d083395SSteven Rostedt created to dynamically enable them again. 2083d083395SSteven Rostedt 209606576ceSSteven Rostedt This way a CONFIG_FUNCTION_TRACER kernel is slightly larger, but otherwise 2103d083395SSteven Rostedt has native performance as long as no tracing is active. 2113d083395SSteven Rostedt 2123d083395SSteven Rostedt The changes to the code are done by a kernel thread that 2133d083395SSteven Rostedt wakes up once a second and checks to see if any ftrace calls 2143d083395SSteven Rostedt were made. If so, it runs stop_machine (stops all CPUS) 2153d083395SSteven Rostedt and modifies the code to jump over the call to ftrace. 21660a11774SSteven Rostedt 2178da3821bSSteven Rostedtconfig FTRACE_MCOUNT_RECORD 2188da3821bSSteven Rostedt def_bool y 2198da3821bSSteven Rostedt depends on DYNAMIC_FTRACE 2208da3821bSSteven Rostedt depends on HAVE_FTRACE_MCOUNT_RECORD 2218da3821bSSteven Rostedt 22260a11774SSteven Rostedtconfig FTRACE_SELFTEST 22360a11774SSteven Rostedt bool 22460a11774SSteven Rostedt 22560a11774SSteven Rostedtconfig FTRACE_STARTUP_TEST 22660a11774SSteven Rostedt bool "Perform a startup test on ftrace" 2273ce2b920SFrédéric Weisbecker depends on TRACING && DEBUG_KERNEL && !BOOT_TRACER 22860a11774SSteven Rostedt select FTRACE_SELFTEST 22960a11774SSteven Rostedt help 23060a11774SSteven Rostedt This option performs a series of startup tests on ftrace. On bootup 23160a11774SSteven Rostedt a series of tests are made to verify that the tracer is 23260a11774SSteven Rostedt functioning properly. It will do tests on all the configured 23360a11774SSteven Rostedt tracers of ftrace. 23417d80fd0SPeter Zijlstra 23517d80fd0SPeter Zijlstraendmenu 236