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 68d26487fSTörök Edwinconfig USER_STACKTRACE_SUPPORT 78d26487fSTörök Edwin bool 88d26487fSTörök Edwin 92a3a4f66SFrédéric Weisbeckerconfig NOP_TRACER 102a3a4f66SFrédéric Weisbecker bool 112a3a4f66SFrédéric Weisbecker 1278d904b4SSteven Rostedtconfig HAVE_FTRACE_NMI_ENTER 1378d904b4SSteven Rostedt bool 14555f386cSMike Frysinger help 1540892367SRandy Dunlap See Documentation/trace/ftrace-design.txt 1678d904b4SSteven Rostedt 17606576ceSSteven Rostedtconfig HAVE_FUNCTION_TRACER 1816444a8aSArnaldo Carvalho de Melo bool 19555f386cSMike Frysinger help 2040892367SRandy Dunlap See Documentation/trace/ftrace-design.txt 21bc0c38d1SSteven Rostedt 22fb52607aSFrederic Weisbeckerconfig HAVE_FUNCTION_GRAPH_TRACER 2315e6cb36SFrederic Weisbecker bool 24555f386cSMike Frysinger help 2540892367SRandy Dunlap See Documentation/trace/ftrace-design.txt 2615e6cb36SFrederic Weisbecker 2771e308a2SSteven Rostedtconfig HAVE_FUNCTION_GRAPH_FP_TEST 2871e308a2SSteven Rostedt bool 2971e308a2SSteven Rostedt help 3003688970SMike Frysinger See Documentation/trace/ftrace-design.txt 3171e308a2SSteven Rostedt 3260a7ecf4SSteven Rostedtconfig HAVE_FUNCTION_TRACE_MCOUNT_TEST 3360a7ecf4SSteven Rostedt bool 3460a7ecf4SSteven Rostedt help 3540892367SRandy Dunlap See Documentation/trace/ftrace-design.txt 3660a7ecf4SSteven Rostedt 37677aa9f7SSteven Rostedtconfig HAVE_DYNAMIC_FTRACE 38677aa9f7SSteven Rostedt bool 39555f386cSMike Frysinger help 4040892367SRandy Dunlap See Documentation/trace/ftrace-design.txt 41677aa9f7SSteven Rostedt 4206aeaaeaSMasami Hiramatsuconfig HAVE_DYNAMIC_FTRACE_WITH_REGS 4306aeaaeaSMasami Hiramatsu bool 4406aeaaeaSMasami Hiramatsu 458da3821bSSteven Rostedtconfig HAVE_FTRACE_MCOUNT_RECORD 468da3821bSSteven Rostedt bool 47555f386cSMike Frysinger help 4840892367SRandy Dunlap See Documentation/trace/ftrace-design.txt 498da3821bSSteven Rostedt 5066700001SJosh Stoneconfig HAVE_SYSCALL_TRACEPOINTS 51ee08c6ecSFrederic Weisbecker bool 52555f386cSMike Frysinger help 5340892367SRandy Dunlap See Documentation/trace/ftrace-design.txt 54ee08c6ecSFrederic Weisbecker 55a2546faeSSteven Rostedtconfig HAVE_FENTRY 56a2546faeSSteven Rostedt bool 57a2546faeSSteven Rostedt help 58a2546faeSSteven Rostedt Arch supports the gcc options -pg with -mfentry 59a2546faeSSteven Rostedt 60cf4db259SSteven Rostedtconfig HAVE_C_RECORDMCOUNT 6172441cb1SSteven Rostedt bool 6272441cb1SSteven Rostedt help 6372441cb1SSteven Rostedt C version of recordmcount available? 6472441cb1SSteven Rostedt 65352ad25aSSteven Rostedtconfig TRACER_MAX_TRACE 66352ad25aSSteven Rostedt bool 67352ad25aSSteven Rostedt 68ea632e9fSJosh Triplettconfig TRACE_CLOCK 69ea632e9fSJosh Triplett bool 70ea632e9fSJosh Triplett 717a8e76a3SSteven Rostedtconfig RING_BUFFER 727a8e76a3SSteven Rostedt bool 73ea632e9fSJosh Triplett select TRACE_CLOCK 7422287688SSteven Rostedt (Red Hat) select IRQ_WORK 757a8e76a3SSteven Rostedt 7678d904b4SSteven Rostedtconfig FTRACE_NMI_ENTER 7778d904b4SSteven Rostedt bool 7878d904b4SSteven Rostedt depends on HAVE_FTRACE_NMI_ENTER 7978d904b4SSteven Rostedt default y 8078d904b4SSteven Rostedt 815f77a88bSTom Zanussiconfig EVENT_TRACING 82b11c53e1SZhaolei select CONTEXT_SWITCH_TRACER 83b11c53e1SZhaolei bool 84b11c53e1SZhaolei 85b11c53e1SZhaoleiconfig CONTEXT_SWITCH_TRACER 865f77a88bSTom Zanussi bool 875f77a88bSTom Zanussi 8885bac32cSSteven Rostedtconfig RING_BUFFER_ALLOW_SWAP 8985bac32cSSteven Rostedt bool 9085bac32cSSteven Rostedt help 9185bac32cSSteven Rostedt Allow the use of ring_buffer_swap_cpu. 9285bac32cSSteven Rostedt Adds a very slight overhead to tracing when enabled. 9385bac32cSSteven Rostedt 945e0a0939SSteven Rostedt# All tracer options should select GENERIC_TRACER. For those options that are 955e0a0939SSteven Rostedt# enabled by all tracers (context switch and event tracer) they select TRACING. 965e0a0939SSteven Rostedt# This allows those options to appear when no other tracer is selected. But the 975e0a0939SSteven Rostedt# options do not appear when something else selects it. We need the two options 985e0a0939SSteven Rostedt# GENERIC_TRACER and TRACING to avoid circular dependencies to accomplish the 9940892367SRandy Dunlap# hiding of the automatic options. 1005e0a0939SSteven Rostedt 101bc0c38d1SSteven Rostedtconfig TRACING 102bc0c38d1SSteven Rostedt bool 103bc0c38d1SSteven Rostedt select DEBUG_FS 1047a8e76a3SSteven Rostedt select RING_BUFFER 105c2c80529SAl Viro select STACKTRACE if STACKTRACE_SUPPORT 1065f87f112SIngo Molnar select TRACEPOINTS 107f3384b28SSteven Rostedt select NOP_TRACER 108769b0441SFrederic Weisbecker select BINARY_PRINTF 1095f77a88bSTom Zanussi select EVENT_TRACING 110ea632e9fSJosh Triplett select TRACE_CLOCK 111bc0c38d1SSteven Rostedt 1125e0a0939SSteven Rostedtconfig GENERIC_TRACER 1135e0a0939SSteven Rostedt bool 1145e0a0939SSteven Rostedt select TRACING 1155e0a0939SSteven Rostedt 11640ada30fSIngo Molnar# 11740ada30fSIngo Molnar# Minimum requirements an architecture has to meet for us to 11840ada30fSIngo Molnar# be able to offer generic tracing facilities: 11940ada30fSIngo Molnar# 12040ada30fSIngo Molnarconfig TRACING_SUPPORT 12140ada30fSIngo Molnar bool 12245b95608SAnton Vorontsov # PPC32 has no irqflags tracing support, but it can use most of the 12345b95608SAnton Vorontsov # tracers anyway, they were tested to build and work. Note that new 12445b95608SAnton Vorontsov # exceptions to this list aren't welcomed, better implement the 12545b95608SAnton Vorontsov # irqflags tracing for your architecture. 12645b95608SAnton Vorontsov depends on TRACE_IRQFLAGS_SUPPORT || PPC32 12740ada30fSIngo Molnar depends on STACKTRACE_SUPPORT 128422d3c7aSKOSAKI Motohiro default y 12940ada30fSIngo Molnar 13040ada30fSIngo Molnarif TRACING_SUPPORT 13140ada30fSIngo Molnar 1324ed9f071SSteven Rostedtmenuconfig FTRACE 1334ed9f071SSteven Rostedt bool "Tracers" 13465b77242SSteven Rostedt default y if DEBUG_KERNEL 1354ed9f071SSteven Rostedt help 1364ed9f071SSteven Rostedt Enable the kernel tracing infrastructure. 1374ed9f071SSteven Rostedt 1384ed9f071SSteven Rostedtif FTRACE 13917d80fd0SPeter Zijlstra 140606576ceSSteven Rostedtconfig FUNCTION_TRACER 1411b29b018SSteven Rostedt bool "Kernel Function Tracer" 142606576ceSSteven Rostedt depends on HAVE_FUNCTION_TRACER 1434d7a077cSSteven Rostedt select KALLSYMS 1445e0a0939SSteven Rostedt select GENERIC_TRACER 14535e8e302SSteven Rostedt select CONTEXT_SWITCH_TRACER 1461b29b018SSteven Rostedt help 1471b29b018SSteven Rostedt Enable the kernel to trace every kernel function. This is done 1481b29b018SSteven Rostedt by using a compiler feature to insert a small, 5-byte No-Operation 14940892367SRandy Dunlap instruction at the beginning of every kernel function, which NOP 1501b29b018SSteven Rostedt sequence is then dynamically patched into a tracer call when 1511b29b018SSteven Rostedt tracing is enabled by the administrator. If it's runtime disabled 1521b29b018SSteven Rostedt (the bootup default), then the overhead of the instructions is very 1531b29b018SSteven Rostedt small and not measurable even in micro-benchmarks. 15435e8e302SSteven Rostedt 155fb52607aSFrederic Weisbeckerconfig FUNCTION_GRAPH_TRACER 156fb52607aSFrederic Weisbecker bool "Kernel Function Graph Tracer" 157fb52607aSFrederic Weisbecker depends on HAVE_FUNCTION_GRAPH_TRACER 15815e6cb36SFrederic Weisbecker depends on FUNCTION_TRACER 159eb4a0378SSteven Rostedt depends on !X86_32 || !CC_OPTIMIZE_FOR_SIZE 160764f3b95SIngo Molnar default y 16115e6cb36SFrederic Weisbecker help 162fb52607aSFrederic Weisbecker Enable the kernel to trace a function at both its return 163fb52607aSFrederic Weisbecker and its entry. 164692105b8SMatt LaPlante Its first purpose is to trace the duration of functions and 165692105b8SMatt LaPlante draw a call graph for each thread with some information like 166692105b8SMatt LaPlante the return value. This is done by setting the current return 167692105b8SMatt LaPlante address on the current task structure into a stack of calls. 16815e6cb36SFrederic Weisbecker 169bac429f0SSteven Rostedt 17081d68a96SSteven Rostedtconfig IRQSOFF_TRACER 17181d68a96SSteven Rostedt bool "Interrupts-off Latency Tracer" 17281d68a96SSteven Rostedt default n 17381d68a96SSteven Rostedt depends on TRACE_IRQFLAGS_SUPPORT 174592913ecSJohn Stultz depends on !ARCH_USES_GETTIMEOFFSET 17581d68a96SSteven Rostedt select TRACE_IRQFLAGS 1765e0a0939SSteven Rostedt select GENERIC_TRACER 17781d68a96SSteven Rostedt select TRACER_MAX_TRACE 17885bac32cSSteven Rostedt select RING_BUFFER_ALLOW_SWAP 17922cffc2bSSteven Rostedt (Red Hat) select TRACER_SNAPSHOT 1800b85ffc2SSteven Rostedt (Red Hat) select TRACER_SNAPSHOT_PER_CPU_SWAP 18181d68a96SSteven Rostedt help 18281d68a96SSteven Rostedt This option measures the time spent in irqs-off critical 18381d68a96SSteven Rostedt sections, with microsecond accuracy. 18481d68a96SSteven Rostedt 18581d68a96SSteven Rostedt The default measurement method is a maximum search, which is 18681d68a96SSteven Rostedt disabled by default and can be runtime (re-)started 18781d68a96SSteven Rostedt via: 18881d68a96SSteven Rostedt 189156f5a78SGeunSik Lim echo 0 > /sys/kernel/debug/tracing/tracing_max_latency 19081d68a96SSteven Rostedt 19140892367SRandy Dunlap (Note that kernel size and overhead increase with this option 1926cd8a4bbSSteven Rostedt enabled. This option and the preempt-off timing option can be 1936cd8a4bbSSteven Rostedt used together or separately.) 1946cd8a4bbSSteven Rostedt 1956cd8a4bbSSteven Rostedtconfig PREEMPT_TRACER 1966cd8a4bbSSteven Rostedt bool "Preemption-off Latency Tracer" 1976cd8a4bbSSteven Rostedt default n 198592913ecSJohn Stultz depends on !ARCH_USES_GETTIMEOFFSET 1996cd8a4bbSSteven Rostedt depends on PREEMPT 2005e0a0939SSteven Rostedt select GENERIC_TRACER 2016cd8a4bbSSteven Rostedt select TRACER_MAX_TRACE 20285bac32cSSteven Rostedt select RING_BUFFER_ALLOW_SWAP 20322cffc2bSSteven Rostedt (Red Hat) select TRACER_SNAPSHOT 2040b85ffc2SSteven Rostedt (Red Hat) select TRACER_SNAPSHOT_PER_CPU_SWAP 2056cd8a4bbSSteven Rostedt help 20640892367SRandy Dunlap This option measures the time spent in preemption-off critical 2076cd8a4bbSSteven Rostedt sections, with microsecond accuracy. 2086cd8a4bbSSteven Rostedt 2096cd8a4bbSSteven Rostedt The default measurement method is a maximum search, which is 2106cd8a4bbSSteven Rostedt disabled by default and can be runtime (re-)started 2116cd8a4bbSSteven Rostedt via: 2126cd8a4bbSSteven Rostedt 213156f5a78SGeunSik Lim echo 0 > /sys/kernel/debug/tracing/tracing_max_latency 2146cd8a4bbSSteven Rostedt 21540892367SRandy Dunlap (Note that kernel size and overhead increase with this option 2166cd8a4bbSSteven Rostedt enabled. This option and the irqs-off timing option can be 2176cd8a4bbSSteven Rostedt used together or separately.) 2186cd8a4bbSSteven Rostedt 219352ad25aSSteven Rostedtconfig SCHED_TRACER 220352ad25aSSteven Rostedt bool "Scheduling Latency Tracer" 2215e0a0939SSteven Rostedt select GENERIC_TRACER 222352ad25aSSteven Rostedt select CONTEXT_SWITCH_TRACER 223352ad25aSSteven Rostedt select TRACER_MAX_TRACE 22422cffc2bSSteven Rostedt (Red Hat) select TRACER_SNAPSHOT 225352ad25aSSteven Rostedt help 226352ad25aSSteven Rostedt This tracer tracks the latency of the highest priority task 227352ad25aSSteven Rostedt to be scheduled in, starting from the point it has woken up. 228352ad25aSSteven Rostedt 229897f17a6SSteven Rostedtconfig ENABLE_DEFAULT_TRACERS 230897f17a6SSteven Rostedt bool "Trace process context switches and events" 2315e0a0939SSteven Rostedt depends on !GENERIC_TRACER 232b77e38aaSSteven Rostedt select TRACING 233b77e38aaSSteven Rostedt help 23440892367SRandy Dunlap This tracer hooks to various trace points in the kernel, 235b77e38aaSSteven Rostedt allowing the user to pick and choose which trace point they 236897f17a6SSteven Rostedt want to trace. It also includes the sched_switch tracer plugin. 237a7abe97fSSteven Rostedt 238ee08c6ecSFrederic Weisbeckerconfig FTRACE_SYSCALLS 239ee08c6ecSFrederic Weisbecker bool "Trace syscalls" 24066700001SJosh Stone depends on HAVE_SYSCALL_TRACEPOINTS 2415e0a0939SSteven Rostedt select GENERIC_TRACER 2420ea1c415SFrederic Weisbecker select KALLSYMS 243ee08c6ecSFrederic Weisbecker help 244ee08c6ecSFrederic Weisbecker Basic tracer to catch the syscall entry and exit events. 245ee08c6ecSFrederic Weisbecker 246debdd57fSHiraku Toyookaconfig TRACER_SNAPSHOT 247debdd57fSHiraku Toyooka bool "Create a snapshot trace buffer" 248debdd57fSHiraku Toyooka select TRACER_MAX_TRACE 249debdd57fSHiraku Toyooka help 250debdd57fSHiraku Toyooka Allow tracing users to take snapshot of the current buffer using the 251debdd57fSHiraku Toyooka ftrace interface, e.g.: 252debdd57fSHiraku Toyooka 253debdd57fSHiraku Toyooka echo 1 > /sys/kernel/debug/tracing/snapshot 254debdd57fSHiraku Toyooka cat snapshot 255debdd57fSHiraku Toyooka 2560b85ffc2SSteven Rostedt (Red Hat)config TRACER_SNAPSHOT_PER_CPU_SWAP 2570b85ffc2SSteven Rostedt (Red Hat) bool "Allow snapshot to swap per CPU" 2580b85ffc2SSteven Rostedt (Red Hat) depends on TRACER_SNAPSHOT 2590b85ffc2SSteven Rostedt (Red Hat) select RING_BUFFER_ALLOW_SWAP 2600b85ffc2SSteven Rostedt (Red Hat) help 2610b85ffc2SSteven Rostedt (Red Hat) Allow doing a snapshot of a single CPU buffer instead of a 2620b85ffc2SSteven Rostedt (Red Hat) full swap (all buffers). If this is set, then the following is 2630b85ffc2SSteven Rostedt (Red Hat) allowed: 2640b85ffc2SSteven Rostedt (Red Hat) 2650b85ffc2SSteven Rostedt (Red Hat) echo 1 > /sys/kernel/debug/tracing/per_cpu/cpu2/snapshot 2660b85ffc2SSteven Rostedt (Red Hat) 2670b85ffc2SSteven Rostedt (Red Hat) After which, only the tracing buffer for CPU 2 was swapped with 2680b85ffc2SSteven Rostedt (Red Hat) the main tracing buffer, and the other CPU buffers remain the same. 2690b85ffc2SSteven Rostedt (Red Hat) 2700b85ffc2SSteven Rostedt (Red Hat) When this is enabled, this adds a little more overhead to the 2710b85ffc2SSteven Rostedt (Red Hat) trace recording, as it needs to add some checks to synchronize 2720b85ffc2SSteven Rostedt (Red Hat) recording with swaps. But this does not affect the performance 2730b85ffc2SSteven Rostedt (Red Hat) of the overall system. This is enabled by default when the preempt 2740b85ffc2SSteven Rostedt (Red Hat) or irq latency tracers are enabled, as those need to swap as well 2750b85ffc2SSteven Rostedt (Red Hat) and already adds the overhead (plus a lot more). 2760b85ffc2SSteven Rostedt (Red Hat) 2772ed84eebSSteven Rostedtconfig TRACE_BRANCH_PROFILING 2789ae5b879SSteven Rostedt bool 2795e0a0939SSteven Rostedt select GENERIC_TRACER 2809ae5b879SSteven Rostedt 2819ae5b879SSteven Rostedtchoice 2829ae5b879SSteven Rostedt prompt "Branch Profiling" 2839ae5b879SSteven Rostedt default BRANCH_PROFILE_NONE 2849ae5b879SSteven Rostedt help 2859ae5b879SSteven Rostedt The branch profiling is a software profiler. It will add hooks 2869ae5b879SSteven Rostedt into the C conditionals to test which path a branch takes. 2879ae5b879SSteven Rostedt 2889ae5b879SSteven Rostedt The likely/unlikely profiler only looks at the conditions that 2899ae5b879SSteven Rostedt are annotated with a likely or unlikely macro. 2909ae5b879SSteven Rostedt 29140892367SRandy Dunlap The "all branch" profiler will profile every if-statement in the 2929ae5b879SSteven Rostedt kernel. This profiler will also enable the likely/unlikely 29340892367SRandy Dunlap profiler. 2949ae5b879SSteven Rostedt 29540892367SRandy Dunlap Either of the above profilers adds a bit of overhead to the system. 29640892367SRandy Dunlap If unsure, choose "No branch profiling". 2979ae5b879SSteven Rostedt 2989ae5b879SSteven Rostedtconfig BRANCH_PROFILE_NONE 2999ae5b879SSteven Rostedt bool "No branch profiling" 3009ae5b879SSteven Rostedt help 3019ae5b879SSteven Rostedt No branch profiling. Branch profiling adds a bit of overhead. 3029ae5b879SSteven Rostedt Only enable it if you want to analyse the branching behavior. 3039ae5b879SSteven Rostedt Otherwise keep it disabled. 3049ae5b879SSteven Rostedt 3059ae5b879SSteven Rostedtconfig PROFILE_ANNOTATED_BRANCHES 3069ae5b879SSteven Rostedt bool "Trace likely/unlikely profiler" 3079ae5b879SSteven Rostedt select TRACE_BRANCH_PROFILING 3081f0d69a9SSteven Rostedt help 30959bf8964SMasanari Iida This tracer profiles all likely and unlikely macros 3101f0d69a9SSteven Rostedt in the kernel. It will display the results in: 3111f0d69a9SSteven Rostedt 31213e5befaSDavid Rientjes /sys/kernel/debug/tracing/trace_stat/branch_annotated 3131f0d69a9SSteven Rostedt 31440892367SRandy Dunlap Note: this will add a significant overhead; only turn this 3151f0d69a9SSteven Rostedt on if you need to profile the system's use of these macros. 3161f0d69a9SSteven Rostedt 3172bcd521aSSteven Rostedtconfig PROFILE_ALL_BRANCHES 3182bcd521aSSteven Rostedt bool "Profile all if conditionals" 3199ae5b879SSteven Rostedt select TRACE_BRANCH_PROFILING 3202bcd521aSSteven Rostedt help 3212bcd521aSSteven Rostedt This tracer profiles all branch conditions. Every if () 3222bcd521aSSteven Rostedt taken in the kernel is recorded whether it hit or miss. 3232bcd521aSSteven Rostedt The results will be displayed in: 3242bcd521aSSteven Rostedt 32513e5befaSDavid Rientjes /sys/kernel/debug/tracing/trace_stat/branch_all 3262bcd521aSSteven Rostedt 3279ae5b879SSteven Rostedt This option also enables the likely/unlikely profiler. 3289ae5b879SSteven Rostedt 3292bcd521aSSteven Rostedt This configuration, when enabled, will impose a great overhead 3302bcd521aSSteven Rostedt on the system. This should only be enabled when the system 33140892367SRandy Dunlap is to be analyzed in much detail. 3329ae5b879SSteven Rostedtendchoice 3332bcd521aSSteven Rostedt 3342ed84eebSSteven Rostedtconfig TRACING_BRANCHES 33552f232cbSSteven Rostedt bool 33652f232cbSSteven Rostedt help 33752f232cbSSteven Rostedt Selected by tracers that will trace the likely and unlikely 33852f232cbSSteven Rostedt conditions. This prevents the tracers themselves from being 33952f232cbSSteven Rostedt profiled. Profiling the tracing infrastructure can only happen 34052f232cbSSteven Rostedt when the likelys and unlikelys are not being traced. 34152f232cbSSteven Rostedt 3422ed84eebSSteven Rostedtconfig BRANCH_TRACER 34352f232cbSSteven Rostedt bool "Trace likely/unlikely instances" 3442ed84eebSSteven Rostedt depends on TRACE_BRANCH_PROFILING 3452ed84eebSSteven Rostedt select TRACING_BRANCHES 34652f232cbSSteven Rostedt help 34752f232cbSSteven Rostedt This traces the events of likely and unlikely condition 34852f232cbSSteven Rostedt calls in the kernel. The difference between this and the 34952f232cbSSteven Rostedt "Trace likely/unlikely profiler" is that this is not a 35052f232cbSSteven Rostedt histogram of the callers, but actually places the calling 35152f232cbSSteven Rostedt events into a running trace buffer to see when and where the 35252f232cbSSteven Rostedt events happened, as well as their results. 35352f232cbSSteven Rostedt 35452f232cbSSteven Rostedt Say N if unsure. 35552f232cbSSteven Rostedt 356e5a81b62SSteven Rostedtconfig STACK_TRACER 357e5a81b62SSteven Rostedt bool "Trace max stack" 358606576ceSSteven Rostedt depends on HAVE_FUNCTION_TRACER 359606576ceSSteven Rostedt select FUNCTION_TRACER 360e5a81b62SSteven Rostedt select STACKTRACE 3614d7a077cSSteven Rostedt select KALLSYMS 362e5a81b62SSteven Rostedt help 3634519d9e5SIngo Molnar This special tracer records the maximum stack footprint of the 364156f5a78SGeunSik Lim kernel and displays it in /sys/kernel/debug/tracing/stack_trace. 3654519d9e5SIngo Molnar 3664519d9e5SIngo Molnar This tracer works by hooking into every function call that the 3674519d9e5SIngo Molnar kernel executes, and keeping a maximum stack depth value and 368f38f1d2aSSteven Rostedt stack-trace saved. If this is configured with DYNAMIC_FTRACE 369f38f1d2aSSteven Rostedt then it will not have any overhead while the stack tracer 370f38f1d2aSSteven Rostedt is disabled. 371f38f1d2aSSteven Rostedt 372f38f1d2aSSteven Rostedt To enable the stack tracer on bootup, pass in 'stacktrace' 373f38f1d2aSSteven Rostedt on the kernel command line. 374f38f1d2aSSteven Rostedt 375f38f1d2aSSteven Rostedt The stack tracer can also be enabled or disabled via the 376f38f1d2aSSteven Rostedt sysctl kernel.stack_tracer_enabled 3774519d9e5SIngo Molnar 3784519d9e5SIngo Molnar Say N if unsure. 379e5a81b62SSteven Rostedt 3802db270a8SFrederic Weisbeckerconfig BLK_DEV_IO_TRACE 38140892367SRandy Dunlap bool "Support for tracing block IO actions" 3822db270a8SFrederic Weisbecker depends on SYSFS 3831dfba05dSIngo Molnar depends on BLOCK 3842db270a8SFrederic Weisbecker select RELAY 3852db270a8SFrederic Weisbecker select DEBUG_FS 3862db270a8SFrederic Weisbecker select TRACEPOINTS 3875e0a0939SSteven Rostedt select GENERIC_TRACER 3882db270a8SFrederic Weisbecker select STACKTRACE 3892db270a8SFrederic Weisbecker help 3902db270a8SFrederic Weisbecker Say Y here if you want to be able to trace the block layer actions 3912db270a8SFrederic Weisbecker on a given queue. Tracing allows you to see any traffic happening 3922db270a8SFrederic Weisbecker on a block device queue. For more information (and the userspace 3932db270a8SFrederic Weisbecker support tools needed), fetch the blktrace tools from: 3942db270a8SFrederic Weisbecker 3952db270a8SFrederic Weisbecker git://git.kernel.dk/blktrace.git 3962db270a8SFrederic Weisbecker 3972db270a8SFrederic Weisbecker Tracing also is possible using the ftrace interface, e.g.: 3982db270a8SFrederic Weisbecker 3992db270a8SFrederic Weisbecker echo 1 > /sys/block/sda/sda1/trace/enable 4002db270a8SFrederic Weisbecker echo blk > /sys/kernel/debug/tracing/current_tracer 4012db270a8SFrederic Weisbecker cat /sys/kernel/debug/tracing/trace_pipe 4022db270a8SFrederic Weisbecker 4032db270a8SFrederic Weisbecker If unsure, say N. 40436994e58SFrederic Weisbecker 40577b44d1bSMasami Hiramatsuconfig KPROBE_EVENT 406413d37d1SMasami Hiramatsu depends on KPROBES 407f850c30cSHeiko Carstens depends on HAVE_REGS_AND_STACK_ACCESS_API 40877b44d1bSMasami Hiramatsu bool "Enable kprobes-based dynamic events" 409413d37d1SMasami Hiramatsu select TRACING 4108ab83f56SSrikar Dronamraju select PROBE_EVENTS 41177b44d1bSMasami Hiramatsu default y 412413d37d1SMasami Hiramatsu help 41340892367SRandy Dunlap This allows the user to add tracing events (similar to tracepoints) 41440892367SRandy Dunlap on the fly via the ftrace interface. See 41540892367SRandy Dunlap Documentation/trace/kprobetrace.txt for more details. 41677b44d1bSMasami Hiramatsu 41777b44d1bSMasami Hiramatsu Those events can be inserted wherever kprobes can probe, and record 41877b44d1bSMasami Hiramatsu various register and memory values. 41977b44d1bSMasami Hiramatsu 42040892367SRandy Dunlap This option is also required by perf-probe subcommand of perf tools. 42140892367SRandy Dunlap If you want to use perf tools, this option is strongly recommended. 422413d37d1SMasami Hiramatsu 423f3f096cfSSrikar Dronamrajuconfig UPROBE_EVENT 424f3f096cfSSrikar Dronamraju bool "Enable uprobes-based dynamic events" 425f3f096cfSSrikar Dronamraju depends on ARCH_SUPPORTS_UPROBES 426f3f096cfSSrikar Dronamraju depends on MMU 42709294e31SDavid A. Long depends on PERF_EVENTS 428f3f096cfSSrikar Dronamraju select UPROBES 429f3f096cfSSrikar Dronamraju select PROBE_EVENTS 430f3f096cfSSrikar Dronamraju select TRACING 431f3f096cfSSrikar Dronamraju default n 432f3f096cfSSrikar Dronamraju help 433f3f096cfSSrikar Dronamraju This allows the user to add tracing events on top of userspace 434f3f096cfSSrikar Dronamraju dynamic events (similar to tracepoints) on the fly via the trace 435f3f096cfSSrikar Dronamraju events interface. Those events can be inserted wherever uprobes 436f3f096cfSSrikar Dronamraju can probe, and record various registers. 437f3f096cfSSrikar Dronamraju This option is required if you plan to use perf-probe subcommand 438f3f096cfSSrikar Dronamraju of perf tools on user space applications. 439f3f096cfSSrikar Dronamraju 4408ab83f56SSrikar Dronamrajuconfig PROBE_EVENTS 4418ab83f56SSrikar Dronamraju def_bool n 4428ab83f56SSrikar Dronamraju 4433d083395SSteven Rostedtconfig DYNAMIC_FTRACE 444db05021dSSteven Rostedt bool "enable/disable function tracing dynamically" 445606576ceSSteven Rostedt depends on FUNCTION_TRACER 446677aa9f7SSteven Rostedt depends on HAVE_DYNAMIC_FTRACE 4473d083395SSteven Rostedt default y 4483d083395SSteven Rostedt help 449db05021dSSteven Rostedt This option will modify all the calls to function tracing 450db05021dSSteven Rostedt dynamically (will patch them out of the binary image and 451db05021dSSteven Rostedt replace them with a No-Op instruction) on boot up. During 452db05021dSSteven Rostedt compile time, a table is made of all the locations that ftrace 453db05021dSSteven Rostedt can function trace, and this table is linked into the kernel 454db05021dSSteven Rostedt image. When this is enabled, functions can be individually 455db05021dSSteven Rostedt enabled, and the functions not enabled will not affect 456db05021dSSteven Rostedt performance of the system. 457db05021dSSteven Rostedt 458db05021dSSteven Rostedt See the files in /sys/kernel/debug/tracing: 459db05021dSSteven Rostedt available_filter_functions 460db05021dSSteven Rostedt set_ftrace_filter 461db05021dSSteven Rostedt set_ftrace_notrace 4623d083395SSteven Rostedt 46340892367SRandy Dunlap This way a CONFIG_FUNCTION_TRACER kernel is slightly larger, but 46440892367SRandy Dunlap otherwise has native performance as long as no tracing is active. 4653d083395SSteven Rostedt 46606aeaaeaSMasami Hiramatsuconfig DYNAMIC_FTRACE_WITH_REGS 46706aeaaeaSMasami Hiramatsu def_bool y 46806aeaaeaSMasami Hiramatsu depends on DYNAMIC_FTRACE 46906aeaaeaSMasami Hiramatsu depends on HAVE_DYNAMIC_FTRACE_WITH_REGS 47006aeaaeaSMasami Hiramatsu 471bac429f0SSteven Rostedtconfig FUNCTION_PROFILER 472bac429f0SSteven Rostedt bool "Kernel function profiler" 473493762fcSSteven Rostedt depends on FUNCTION_TRACER 474bac429f0SSteven Rostedt default n 475bac429f0SSteven Rostedt help 476493762fcSSteven Rostedt This option enables the kernel function profiler. A file is created 477493762fcSSteven Rostedt in debugfs called function_profile_enabled which defaults to zero. 478bac429f0SSteven Rostedt When a 1 is echoed into this file profiling begins, and when a 47940892367SRandy Dunlap zero is entered, profiling stops. A "functions" file is created in 48040892367SRandy Dunlap the trace_stats directory; this file shows the list of functions that 481bac429f0SSteven Rostedt have been hit and their counters. 482bac429f0SSteven Rostedt 48340892367SRandy Dunlap If in doubt, say N. 484bac429f0SSteven Rostedt 4858da3821bSSteven Rostedtconfig FTRACE_MCOUNT_RECORD 4868da3821bSSteven Rostedt def_bool y 4878da3821bSSteven Rostedt depends on DYNAMIC_FTRACE 4888da3821bSSteven Rostedt depends on HAVE_FTRACE_MCOUNT_RECORD 4898da3821bSSteven Rostedt 49060a11774SSteven Rostedtconfig FTRACE_SELFTEST 49160a11774SSteven Rostedt bool 49260a11774SSteven Rostedt 49360a11774SSteven Rostedtconfig FTRACE_STARTUP_TEST 49460a11774SSteven Rostedt bool "Perform a startup test on ftrace" 4955e0a0939SSteven Rostedt depends on GENERIC_TRACER 49660a11774SSteven Rostedt select FTRACE_SELFTEST 49760a11774SSteven Rostedt help 49860a11774SSteven Rostedt This option performs a series of startup tests on ftrace. On bootup 49960a11774SSteven Rostedt a series of tests are made to verify that the tracer is 50060a11774SSteven Rostedt functioning properly. It will do tests on all the configured 50160a11774SSteven Rostedt tracers of ftrace. 50217d80fd0SPeter Zijlstra 5031f5a6b45SSteven Rostedtconfig EVENT_TRACE_TEST_SYSCALLS 5041f5a6b45SSteven Rostedt bool "Run selftest on syscall events" 5051f5a6b45SSteven Rostedt depends on FTRACE_STARTUP_TEST 5061f5a6b45SSteven Rostedt help 5071f5a6b45SSteven Rostedt This option will also enable testing every syscall event. 5081f5a6b45SSteven Rostedt It only enables the event and disables it and runs various loads 5091f5a6b45SSteven Rostedt with the event enabled. This adds a bit more time for kernel boot 5101f5a6b45SSteven Rostedt up since it runs this on every system call defined. 5111f5a6b45SSteven Rostedt 5121f5a6b45SSteven Rostedt TBD - enable a way to actually call the syscalls as we test their 5131f5a6b45SSteven Rostedt events 5141f5a6b45SSteven Rostedt 515fe6f90e5SPekka Paalanenconfig MMIOTRACE 516fe6f90e5SPekka Paalanen bool "Memory mapped IO tracing" 51740ada30fSIngo Molnar depends on HAVE_MMIOTRACE_SUPPORT && PCI 5185e0a0939SSteven Rostedt select GENERIC_TRACER 519fe6f90e5SPekka Paalanen help 520fe6f90e5SPekka Paalanen Mmiotrace traces Memory Mapped I/O access and is meant for 521fe6f90e5SPekka Paalanen debugging and reverse engineering. It is called from the ioremap 522fe6f90e5SPekka Paalanen implementation and works via page faults. Tracing is disabled by 523fe6f90e5SPekka Paalanen default and can be enabled at run-time. 524fe6f90e5SPekka Paalanen 5254d1f4372SLi Zefan See Documentation/trace/mmiotrace.txt. 526fe6f90e5SPekka Paalanen If you are not helping to develop drivers, say N. 527fe6f90e5SPekka Paalanen 528fe6f90e5SPekka Paalanenconfig MMIOTRACE_TEST 529fe6f90e5SPekka Paalanen tristate "Test module for mmiotrace" 530fe6f90e5SPekka Paalanen depends on MMIOTRACE && m 531fe6f90e5SPekka Paalanen help 532fe6f90e5SPekka Paalanen This is a dumb module for testing mmiotrace. It is very dangerous 533fe6f90e5SPekka Paalanen as it will write garbage to IO memory starting at a given address. 534fe6f90e5SPekka Paalanen However, it should be safe to use on e.g. unused portion of VRAM. 535fe6f90e5SPekka Paalanen 536fe6f90e5SPekka Paalanen Say N, unless you absolutely know what you are doing. 537fe6f90e5SPekka Paalanen 538*81dc9f0eSSteven Rostedt (Red Hat)config TRACEPOINT_BENCHMARK 539*81dc9f0eSSteven Rostedt (Red Hat) bool "Add tracepoint that benchmarks tracepoints" 540*81dc9f0eSSteven Rostedt (Red Hat) help 541*81dc9f0eSSteven Rostedt (Red Hat) This option creates the tracepoint "benchmark:benchmark_event". 542*81dc9f0eSSteven Rostedt (Red Hat) When the tracepoint is enabled, it kicks off a kernel thread that 543*81dc9f0eSSteven Rostedt (Red Hat) goes into an infinite loop (calling cond_sched() to let other tasks 544*81dc9f0eSSteven Rostedt (Red Hat) run), and calls the tracepoint. Each iteration will record the time 545*81dc9f0eSSteven Rostedt (Red Hat) it took to write to the tracepoint and the next iteration that 546*81dc9f0eSSteven Rostedt (Red Hat) data will be passed to the tracepoint itself. That is, the tracepoint 547*81dc9f0eSSteven Rostedt (Red Hat) will report the time it took to do the previous tracepoint. 548*81dc9f0eSSteven Rostedt (Red Hat) The string written to the tracepoint is a static string of 128 bytes 549*81dc9f0eSSteven Rostedt (Red Hat) to keep the time the same. The initial string is simply a write of 550*81dc9f0eSSteven Rostedt (Red Hat) "START". The second string records the cold cache time of the first 551*81dc9f0eSSteven Rostedt (Red Hat) write which is not added to the rest of the calculations. 552*81dc9f0eSSteven Rostedt (Red Hat) 553*81dc9f0eSSteven Rostedt (Red Hat) As it is a tight loop, it benchmarks as hot cache. That's fine because 554*81dc9f0eSSteven Rostedt (Red Hat) we care most about hot paths that are probably in cache already. 555*81dc9f0eSSteven Rostedt (Red Hat) 556*81dc9f0eSSteven Rostedt (Red Hat) An example of the output: 557*81dc9f0eSSteven Rostedt (Red Hat) 558*81dc9f0eSSteven Rostedt (Red Hat) START 559*81dc9f0eSSteven Rostedt (Red Hat) first=3672 [COLD CACHED] 560*81dc9f0eSSteven Rostedt (Red Hat) last=632 first=3672 max=632 min=632 avg=316 std=446 std^2=199712 561*81dc9f0eSSteven Rostedt (Red Hat) last=278 first=3672 max=632 min=278 avg=303 std=316 std^2=100337 562*81dc9f0eSSteven Rostedt (Red Hat) last=277 first=3672 max=632 min=277 avg=296 std=258 std^2=67064 563*81dc9f0eSSteven Rostedt (Red Hat) last=273 first=3672 max=632 min=273 avg=292 std=224 std^2=50411 564*81dc9f0eSSteven Rostedt (Red Hat) last=273 first=3672 max=632 min=273 avg=288 std=200 std^2=40389 565*81dc9f0eSSteven Rostedt (Red Hat) last=281 first=3672 max=632 min=273 avg=287 std=183 std^2=33666 566*81dc9f0eSSteven Rostedt (Red Hat) 567*81dc9f0eSSteven Rostedt (Red Hat) 5685092dbc9SSteven Rostedtconfig RING_BUFFER_BENCHMARK 5695092dbc9SSteven Rostedt tristate "Ring buffer benchmark stress tester" 5705092dbc9SSteven Rostedt depends on RING_BUFFER 5715092dbc9SSteven Rostedt help 5725092dbc9SSteven Rostedt This option creates a test to stress the ring buffer and benchmark it. 57340892367SRandy Dunlap It creates its own ring buffer such that it will not interfere with 5745092dbc9SSteven Rostedt any other users of the ring buffer (such as ftrace). It then creates 5755092dbc9SSteven Rostedt a producer and consumer that will run for 10 seconds and sleep for 5765092dbc9SSteven Rostedt 10 seconds. Each interval it will print out the number of events 5775092dbc9SSteven Rostedt it recorded and give a rough estimate of how long each iteration took. 5785092dbc9SSteven Rostedt 5795092dbc9SSteven Rostedt It does not disable interrupts or raise its priority, so it may be 5805092dbc9SSteven Rostedt affected by processes that are running. 5815092dbc9SSteven Rostedt 58240892367SRandy Dunlap If unsure, say N. 5835092dbc9SSteven Rostedt 5846c43e554SSteven Rostedt (Red Hat)config RING_BUFFER_STARTUP_TEST 5856c43e554SSteven Rostedt (Red Hat) bool "Ring buffer startup self test" 5866c43e554SSteven Rostedt (Red Hat) depends on RING_BUFFER 5876c43e554SSteven Rostedt (Red Hat) help 5886c43e554SSteven Rostedt (Red Hat) Run a simple self test on the ring buffer on boot up. Late in the 5896c43e554SSteven Rostedt (Red Hat) kernel boot sequence, the test will start that kicks off 5906c43e554SSteven Rostedt (Red Hat) a thread per cpu. Each thread will write various size events 5916c43e554SSteven Rostedt (Red Hat) into the ring buffer. Another thread is created to send IPIs 5926c43e554SSteven Rostedt (Red Hat) to each of the threads, where the IPI handler will also write 5936c43e554SSteven Rostedt (Red Hat) to the ring buffer, to test/stress the nesting ability. 5946c43e554SSteven Rostedt (Red Hat) If any anomalies are discovered, a warning will be displayed 5956c43e554SSteven Rostedt (Red Hat) and all ring buffers will be disabled. 5966c43e554SSteven Rostedt (Red Hat) 5976c43e554SSteven Rostedt (Red Hat) The test runs for 10 seconds. This will slow your boot time 5986c43e554SSteven Rostedt (Red Hat) by at least 10 more seconds. 5996c43e554SSteven Rostedt (Red Hat) 6006c43e554SSteven Rostedt (Red Hat) At the end of the test, statics and more checks are done. 6016c43e554SSteven Rostedt (Red Hat) It will output the stats of each per cpu buffer. What 6026c43e554SSteven Rostedt (Red Hat) was written, the sizes, what was read, what was lost, and 6036c43e554SSteven Rostedt (Red Hat) other similar details. 6046c43e554SSteven Rostedt (Red Hat) 6056c43e554SSteven Rostedt (Red Hat) If unsure, say N 6066c43e554SSteven Rostedt (Red Hat) 6074ed9f071SSteven Rostedtendif # FTRACE 60840ada30fSIngo Molnar 60940ada30fSIngo Molnarendif # TRACING_SUPPORT 61040ada30fSIngo Molnar 611