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 HAVE_FUNCTION_RET_TRACER 6315e6cb36SFrederic Weisbecker depends on FUNCTION_TRACER 6415e6cb36SFrederic Weisbecker help 6515e6cb36SFrederic Weisbecker Enable the kernel to trace a function at its return. 6615e6cb36SFrederic Weisbecker It's first purpose is to trace the duration of functions. 6715e6cb36SFrederic Weisbecker This is done by setting the current return address on the thread 6815e6cb36SFrederic Weisbecker info structure of the current task. 6915e6cb36SFrederic Weisbecker 7081d68a96SSteven Rostedtconfig IRQSOFF_TRACER 7181d68a96SSteven Rostedt bool "Interrupts-off Latency Tracer" 7281d68a96SSteven Rostedt default n 7381d68a96SSteven Rostedt depends on TRACE_IRQFLAGS_SUPPORT 7481d68a96SSteven Rostedt depends on GENERIC_TIME 75d3ee6d99SIngo Molnar depends on DEBUG_KERNEL 7681d68a96SSteven Rostedt select TRACE_IRQFLAGS 7781d68a96SSteven Rostedt select TRACING 7881d68a96SSteven Rostedt select TRACER_MAX_TRACE 7981d68a96SSteven Rostedt help 8081d68a96SSteven Rostedt This option measures the time spent in irqs-off critical 8181d68a96SSteven Rostedt sections, with microsecond accuracy. 8281d68a96SSteven Rostedt 8381d68a96SSteven Rostedt The default measurement method is a maximum search, which is 8481d68a96SSteven Rostedt disabled by default and can be runtime (re-)started 8581d68a96SSteven Rostedt via: 8681d68a96SSteven Rostedt 8781d68a96SSteven Rostedt echo 0 > /debugfs/tracing/tracing_max_latency 8881d68a96SSteven Rostedt 896cd8a4bbSSteven Rostedt (Note that kernel size and overhead increases with this option 906cd8a4bbSSteven Rostedt enabled. This option and the preempt-off timing option can be 916cd8a4bbSSteven Rostedt used together or separately.) 926cd8a4bbSSteven Rostedt 936cd8a4bbSSteven Rostedtconfig PREEMPT_TRACER 946cd8a4bbSSteven Rostedt bool "Preemption-off Latency Tracer" 956cd8a4bbSSteven Rostedt default n 966cd8a4bbSSteven Rostedt depends on GENERIC_TIME 976cd8a4bbSSteven Rostedt depends on PREEMPT 98d3ee6d99SIngo Molnar depends on DEBUG_KERNEL 996cd8a4bbSSteven Rostedt select TRACING 1006cd8a4bbSSteven Rostedt select TRACER_MAX_TRACE 1016cd8a4bbSSteven Rostedt help 1026cd8a4bbSSteven Rostedt This option measures the time spent in preemption off critical 1036cd8a4bbSSteven Rostedt sections, with microsecond accuracy. 1046cd8a4bbSSteven Rostedt 1056cd8a4bbSSteven Rostedt The default measurement method is a maximum search, which is 1066cd8a4bbSSteven Rostedt disabled by default and can be runtime (re-)started 1076cd8a4bbSSteven Rostedt via: 1086cd8a4bbSSteven Rostedt 1096cd8a4bbSSteven Rostedt echo 0 > /debugfs/tracing/tracing_max_latency 1106cd8a4bbSSteven Rostedt 1116cd8a4bbSSteven Rostedt (Note that kernel size and overhead increases with this option 1126cd8a4bbSSteven Rostedt enabled. This option and the irqs-off timing option can be 1136cd8a4bbSSteven Rostedt used together or separately.) 1146cd8a4bbSSteven Rostedt 115f06c3810SIngo Molnarconfig SYSPROF_TRACER 116f06c3810SIngo Molnar bool "Sysprof Tracer" 1174d2df795SThomas Gleixner depends on X86 118f06c3810SIngo Molnar select TRACING 119f06c3810SIngo Molnar help 120f06c3810SIngo Molnar This tracer provides the trace needed by the 'Sysprof' userspace 121f06c3810SIngo Molnar tool. 122f06c3810SIngo Molnar 123352ad25aSSteven Rostedtconfig SCHED_TRACER 124352ad25aSSteven Rostedt bool "Scheduling Latency Tracer" 125d3ee6d99SIngo Molnar depends on DEBUG_KERNEL 126352ad25aSSteven Rostedt select TRACING 127352ad25aSSteven Rostedt select CONTEXT_SWITCH_TRACER 128352ad25aSSteven Rostedt select TRACER_MAX_TRACE 129352ad25aSSteven Rostedt help 130352ad25aSSteven Rostedt This tracer tracks the latency of the highest priority task 131352ad25aSSteven Rostedt to be scheduled in, starting from the point it has woken up. 132352ad25aSSteven Rostedt 13335e8e302SSteven Rostedtconfig CONTEXT_SWITCH_TRACER 13435e8e302SSteven Rostedt bool "Trace process context switches" 135d3ee6d99SIngo Molnar depends on DEBUG_KERNEL 13635e8e302SSteven Rostedt select TRACING 13735e8e302SSteven Rostedt select MARKERS 13835e8e302SSteven Rostedt help 13935e8e302SSteven Rostedt This tracer gets called from the context switch and records 14035e8e302SSteven Rostedt all switching of tasks. 14135e8e302SSteven Rostedt 1421f5c2abbSFrédéric Weisbeckerconfig BOOT_TRACER 1431f5c2abbSFrédéric Weisbecker bool "Trace boot initcalls" 1441f5c2abbSFrédéric Weisbecker depends on DEBUG_KERNEL 1451f5c2abbSFrédéric Weisbecker select TRACING 146ea31e72dSFrederic Weisbecker select CONTEXT_SWITCH_TRACER 1471f5c2abbSFrédéric Weisbecker help 1481f5c2abbSFrédéric Weisbecker This tracer helps developers to optimize boot times: it records 14998d9c66aSIngo Molnar the timings of the initcalls and traces key events and the identity 15098d9c66aSIngo Molnar of tasks that can cause boot delays, such as context-switches. 15198d9c66aSIngo Molnar 15298d9c66aSIngo Molnar Its aim is to be parsed by the /scripts/bootgraph.pl tool to 15398d9c66aSIngo Molnar produce pretty graphics about boot inefficiencies, giving a visual 15498d9c66aSIngo Molnar representation of the delays during initcalls - but the raw 15598d9c66aSIngo Molnar /debug/tracing/trace text output is readable too. 15698d9c66aSIngo Molnar 15798d9c66aSIngo Molnar ( Note that tracing self tests can't be enabled if this tracer is 15898d9c66aSIngo Molnar selected, because the self-tests are an initcall as well and that 15998d9c66aSIngo Molnar would invalidate the boot trace. ) 1601f5c2abbSFrédéric Weisbecker 1612ed84eebSSteven Rostedtconfig TRACE_BRANCH_PROFILING 1621f0d69a9SSteven Rostedt bool "Trace likely/unlikely profiler" 1631f0d69a9SSteven Rostedt depends on DEBUG_KERNEL 1641f0d69a9SSteven Rostedt select TRACING 1651f0d69a9SSteven Rostedt help 1661f0d69a9SSteven Rostedt This tracer profiles all the the likely and unlikely macros 1671f0d69a9SSteven Rostedt in the kernel. It will display the results in: 1681f0d69a9SSteven Rostedt 169*45b79749SSteven Rostedt /debugfs/tracing/profile_annotated_branch 1701f0d69a9SSteven Rostedt 1711f0d69a9SSteven Rostedt Note: this will add a significant overhead, only turn this 1721f0d69a9SSteven Rostedt on if you need to profile the system's use of these macros. 1731f0d69a9SSteven Rostedt 1741f0d69a9SSteven Rostedt Say N if unsure. 1751f0d69a9SSteven Rostedt 1762ed84eebSSteven Rostedtconfig TRACING_BRANCHES 17752f232cbSSteven Rostedt bool 17852f232cbSSteven Rostedt help 17952f232cbSSteven Rostedt Selected by tracers that will trace the likely and unlikely 18052f232cbSSteven Rostedt conditions. This prevents the tracers themselves from being 18152f232cbSSteven Rostedt profiled. Profiling the tracing infrastructure can only happen 18252f232cbSSteven Rostedt when the likelys and unlikelys are not being traced. 18352f232cbSSteven Rostedt 1842ed84eebSSteven Rostedtconfig BRANCH_TRACER 18552f232cbSSteven Rostedt bool "Trace likely/unlikely instances" 1862ed84eebSSteven Rostedt depends on TRACE_BRANCH_PROFILING 1872ed84eebSSteven Rostedt select TRACING_BRANCHES 18852f232cbSSteven Rostedt help 18952f232cbSSteven Rostedt This traces the events of likely and unlikely condition 19052f232cbSSteven Rostedt calls in the kernel. The difference between this and the 19152f232cbSSteven Rostedt "Trace likely/unlikely profiler" is that this is not a 19252f232cbSSteven Rostedt histogram of the callers, but actually places the calling 19352f232cbSSteven Rostedt events into a running trace buffer to see when and where the 19452f232cbSSteven Rostedt events happened, as well as their results. 19552f232cbSSteven Rostedt 19652f232cbSSteven Rostedt Say N if unsure. 19752f232cbSSteven Rostedt 198e5a81b62SSteven Rostedtconfig STACK_TRACER 199e5a81b62SSteven Rostedt bool "Trace max stack" 200606576ceSSteven Rostedt depends on HAVE_FUNCTION_TRACER 2012ff01c6aSIngo Molnar depends on DEBUG_KERNEL 202606576ceSSteven Rostedt select FUNCTION_TRACER 203e5a81b62SSteven Rostedt select STACKTRACE 204e5a81b62SSteven Rostedt help 2054519d9e5SIngo Molnar This special tracer records the maximum stack footprint of the 2064519d9e5SIngo Molnar kernel and displays it in debugfs/tracing/stack_trace. 2074519d9e5SIngo Molnar 2084519d9e5SIngo Molnar This tracer works by hooking into every function call that the 2094519d9e5SIngo Molnar kernel executes, and keeping a maximum stack depth value and 2104519d9e5SIngo Molnar stack-trace saved. Because this logic has to execute in every 2114519d9e5SIngo Molnar kernel function, all the time, this option can slow down the 2124519d9e5SIngo Molnar kernel measurably and is generally intended for kernel 2134519d9e5SIngo Molnar developers only. 2144519d9e5SIngo Molnar 2154519d9e5SIngo Molnar Say N if unsure. 216e5a81b62SSteven Rostedt 2173d083395SSteven Rostedtconfig DYNAMIC_FTRACE 2183d083395SSteven Rostedt bool "enable/disable ftrace tracepoints dynamically" 219606576ceSSteven Rostedt depends on FUNCTION_TRACER 220677aa9f7SSteven Rostedt depends on HAVE_DYNAMIC_FTRACE 221d3ee6d99SIngo Molnar depends on DEBUG_KERNEL 2223d083395SSteven Rostedt default y 2233d083395SSteven Rostedt help 2243d083395SSteven Rostedt This option will modify all the calls to ftrace dynamically 2253d083395SSteven Rostedt (will patch them out of the binary image and replaces them 2263d083395SSteven Rostedt with a No-Op instruction) as they are called. A table is 2273d083395SSteven Rostedt created to dynamically enable them again. 2283d083395SSteven Rostedt 229606576ceSSteven Rostedt This way a CONFIG_FUNCTION_TRACER kernel is slightly larger, but otherwise 2303d083395SSteven Rostedt has native performance as long as no tracing is active. 2313d083395SSteven Rostedt 2323d083395SSteven Rostedt The changes to the code are done by a kernel thread that 2333d083395SSteven Rostedt wakes up once a second and checks to see if any ftrace calls 2343d083395SSteven Rostedt were made. If so, it runs stop_machine (stops all CPUS) 2353d083395SSteven Rostedt and modifies the code to jump over the call to ftrace. 23660a11774SSteven Rostedt 2378da3821bSSteven Rostedtconfig FTRACE_MCOUNT_RECORD 2388da3821bSSteven Rostedt def_bool y 2398da3821bSSteven Rostedt depends on DYNAMIC_FTRACE 2408da3821bSSteven Rostedt depends on HAVE_FTRACE_MCOUNT_RECORD 2418da3821bSSteven Rostedt 24260a11774SSteven Rostedtconfig FTRACE_SELFTEST 24360a11774SSteven Rostedt bool 24460a11774SSteven Rostedt 24560a11774SSteven Rostedtconfig FTRACE_STARTUP_TEST 24660a11774SSteven Rostedt bool "Perform a startup test on ftrace" 2473ce2b920SFrédéric Weisbecker depends on TRACING && DEBUG_KERNEL && !BOOT_TRACER 24860a11774SSteven Rostedt select FTRACE_SELFTEST 24960a11774SSteven Rostedt help 25060a11774SSteven Rostedt This option performs a series of startup tests on ftrace. On bootup 25160a11774SSteven Rostedt a series of tests are made to verify that the tracer is 25260a11774SSteven Rostedt functioning properly. It will do tests on all the configured 25360a11774SSteven Rostedt tracers of ftrace. 25417d80fd0SPeter Zijlstra 25517d80fd0SPeter Zijlstraendmenu 256