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 747a8e76a3SSteven Rostedt 7578d904b4SSteven Rostedtconfig FTRACE_NMI_ENTER 7678d904b4SSteven Rostedt bool 7778d904b4SSteven Rostedt depends on HAVE_FTRACE_NMI_ENTER 7878d904b4SSteven Rostedt default y 7978d904b4SSteven Rostedt 805f77a88bSTom Zanussiconfig EVENT_TRACING 81b11c53e1SZhaolei select CONTEXT_SWITCH_TRACER 82b11c53e1SZhaolei bool 83b11c53e1SZhaolei 8425e41933SThomas Renningerconfig EVENT_POWER_TRACING_DEPRECATED 8525e41933SThomas Renninger depends on EVENT_TRACING 8625e41933SThomas Renninger bool "Deprecated power event trace API, to be removed" 8725e41933SThomas Renninger default y 8825e41933SThomas Renninger help 8925e41933SThomas Renninger Provides old power event types: 9025e41933SThomas Renninger C-state/idle accounting events: 9125e41933SThomas Renninger power:power_start 9225e41933SThomas Renninger power:power_end 9325e41933SThomas Renninger and old cpufreq accounting event: 9425e41933SThomas Renninger power:power_frequency 9525e41933SThomas Renninger This is for userspace compatibility 9625e41933SThomas Renninger and will vanish after 5 kernel iterations, 97f629299bSJesper Juhl namely 3.1. 9825e41933SThomas Renninger 99b11c53e1SZhaoleiconfig CONTEXT_SWITCH_TRACER 1005f77a88bSTom Zanussi bool 1015f77a88bSTom Zanussi 10285bac32cSSteven Rostedtconfig RING_BUFFER_ALLOW_SWAP 10385bac32cSSteven Rostedt bool 10485bac32cSSteven Rostedt help 10585bac32cSSteven Rostedt Allow the use of ring_buffer_swap_cpu. 10685bac32cSSteven Rostedt Adds a very slight overhead to tracing when enabled. 10785bac32cSSteven Rostedt 1085e0a0939SSteven Rostedt# All tracer options should select GENERIC_TRACER. For those options that are 1095e0a0939SSteven Rostedt# enabled by all tracers (context switch and event tracer) they select TRACING. 1105e0a0939SSteven Rostedt# This allows those options to appear when no other tracer is selected. But the 1115e0a0939SSteven Rostedt# options do not appear when something else selects it. We need the two options 1125e0a0939SSteven Rostedt# GENERIC_TRACER and TRACING to avoid circular dependencies to accomplish the 11340892367SRandy Dunlap# hiding of the automatic options. 1145e0a0939SSteven Rostedt 115bc0c38d1SSteven Rostedtconfig TRACING 116bc0c38d1SSteven Rostedt bool 117bc0c38d1SSteven Rostedt select DEBUG_FS 1187a8e76a3SSteven Rostedt select RING_BUFFER 119c2c80529SAl Viro select STACKTRACE if STACKTRACE_SUPPORT 1205f87f112SIngo Molnar select TRACEPOINTS 121f3384b28SSteven Rostedt select NOP_TRACER 122769b0441SFrederic Weisbecker select BINARY_PRINTF 1235f77a88bSTom Zanussi select EVENT_TRACING 124ea632e9fSJosh Triplett select TRACE_CLOCK 1250d5c6e1cSSteven Rostedt select IRQ_WORK 126bc0c38d1SSteven Rostedt 1275e0a0939SSteven Rostedtconfig GENERIC_TRACER 1285e0a0939SSteven Rostedt bool 1295e0a0939SSteven Rostedt select TRACING 1305e0a0939SSteven Rostedt 13140ada30fSIngo Molnar# 13240ada30fSIngo Molnar# Minimum requirements an architecture has to meet for us to 13340ada30fSIngo Molnar# be able to offer generic tracing facilities: 13440ada30fSIngo Molnar# 13540ada30fSIngo Molnarconfig TRACING_SUPPORT 13640ada30fSIngo Molnar bool 13745b95608SAnton Vorontsov # PPC32 has no irqflags tracing support, but it can use most of the 13845b95608SAnton Vorontsov # tracers anyway, they were tested to build and work. Note that new 13945b95608SAnton Vorontsov # exceptions to this list aren't welcomed, better implement the 14045b95608SAnton Vorontsov # irqflags tracing for your architecture. 14145b95608SAnton Vorontsov depends on TRACE_IRQFLAGS_SUPPORT || PPC32 14240ada30fSIngo Molnar depends on STACKTRACE_SUPPORT 143422d3c7aSKOSAKI Motohiro default y 14440ada30fSIngo Molnar 14540ada30fSIngo Molnarif TRACING_SUPPORT 14640ada30fSIngo Molnar 1474ed9f071SSteven Rostedtmenuconfig FTRACE 1484ed9f071SSteven Rostedt bool "Tracers" 14965b77242SSteven Rostedt default y if DEBUG_KERNEL 1504ed9f071SSteven Rostedt help 1514ed9f071SSteven Rostedt Enable the kernel tracing infrastructure. 1524ed9f071SSteven Rostedt 1534ed9f071SSteven Rostedtif FTRACE 15417d80fd0SPeter Zijlstra 155606576ceSSteven Rostedtconfig FUNCTION_TRACER 1561b29b018SSteven Rostedt bool "Kernel Function Tracer" 157606576ceSSteven Rostedt depends on HAVE_FUNCTION_TRACER 1584d7a077cSSteven Rostedt select KALLSYMS 1595e0a0939SSteven Rostedt select GENERIC_TRACER 16035e8e302SSteven Rostedt select CONTEXT_SWITCH_TRACER 1611b29b018SSteven Rostedt help 1621b29b018SSteven Rostedt Enable the kernel to trace every kernel function. This is done 1631b29b018SSteven Rostedt by using a compiler feature to insert a small, 5-byte No-Operation 16440892367SRandy Dunlap instruction at the beginning of every kernel function, which NOP 1651b29b018SSteven Rostedt sequence is then dynamically patched into a tracer call when 1661b29b018SSteven Rostedt tracing is enabled by the administrator. If it's runtime disabled 1671b29b018SSteven Rostedt (the bootup default), then the overhead of the instructions is very 1681b29b018SSteven Rostedt small and not measurable even in micro-benchmarks. 16935e8e302SSteven Rostedt 170fb52607aSFrederic Weisbeckerconfig FUNCTION_GRAPH_TRACER 171fb52607aSFrederic Weisbecker bool "Kernel Function Graph Tracer" 172fb52607aSFrederic Weisbecker depends on HAVE_FUNCTION_GRAPH_TRACER 17315e6cb36SFrederic Weisbecker depends on FUNCTION_TRACER 174eb4a0378SSteven Rostedt depends on !X86_32 || !CC_OPTIMIZE_FOR_SIZE 175764f3b95SIngo Molnar default y 17615e6cb36SFrederic Weisbecker help 177fb52607aSFrederic Weisbecker Enable the kernel to trace a function at both its return 178fb52607aSFrederic Weisbecker and its entry. 179692105b8SMatt LaPlante Its first purpose is to trace the duration of functions and 180692105b8SMatt LaPlante draw a call graph for each thread with some information like 181692105b8SMatt LaPlante the return value. This is done by setting the current return 182692105b8SMatt LaPlante address on the current task structure into a stack of calls. 18315e6cb36SFrederic Weisbecker 184bac429f0SSteven Rostedt 18581d68a96SSteven Rostedtconfig IRQSOFF_TRACER 18681d68a96SSteven Rostedt bool "Interrupts-off Latency Tracer" 18781d68a96SSteven Rostedt default n 18881d68a96SSteven Rostedt depends on TRACE_IRQFLAGS_SUPPORT 189592913ecSJohn Stultz depends on !ARCH_USES_GETTIMEOFFSET 19081d68a96SSteven Rostedt select TRACE_IRQFLAGS 1915e0a0939SSteven Rostedt select GENERIC_TRACER 19281d68a96SSteven Rostedt select TRACER_MAX_TRACE 19385bac32cSSteven Rostedt select RING_BUFFER_ALLOW_SWAP 194*22cffc2bSSteven Rostedt (Red Hat) select TRACER_SNAPSHOT 19581d68a96SSteven Rostedt help 19681d68a96SSteven Rostedt This option measures the time spent in irqs-off critical 19781d68a96SSteven Rostedt sections, with microsecond accuracy. 19881d68a96SSteven Rostedt 19981d68a96SSteven Rostedt The default measurement method is a maximum search, which is 20081d68a96SSteven Rostedt disabled by default and can be runtime (re-)started 20181d68a96SSteven Rostedt via: 20281d68a96SSteven Rostedt 203156f5a78SGeunSik Lim echo 0 > /sys/kernel/debug/tracing/tracing_max_latency 20481d68a96SSteven Rostedt 20540892367SRandy Dunlap (Note that kernel size and overhead increase with this option 2066cd8a4bbSSteven Rostedt enabled. This option and the preempt-off timing option can be 2076cd8a4bbSSteven Rostedt used together or separately.) 2086cd8a4bbSSteven Rostedt 2096cd8a4bbSSteven Rostedtconfig PREEMPT_TRACER 2106cd8a4bbSSteven Rostedt bool "Preemption-off Latency Tracer" 2116cd8a4bbSSteven Rostedt default n 212592913ecSJohn Stultz depends on !ARCH_USES_GETTIMEOFFSET 2136cd8a4bbSSteven Rostedt depends on PREEMPT 2145e0a0939SSteven Rostedt select GENERIC_TRACER 2156cd8a4bbSSteven Rostedt select TRACER_MAX_TRACE 21685bac32cSSteven Rostedt select RING_BUFFER_ALLOW_SWAP 217*22cffc2bSSteven Rostedt (Red Hat) select TRACER_SNAPSHOT 2186cd8a4bbSSteven Rostedt help 21940892367SRandy Dunlap This option measures the time spent in preemption-off critical 2206cd8a4bbSSteven Rostedt sections, with microsecond accuracy. 2216cd8a4bbSSteven Rostedt 2226cd8a4bbSSteven Rostedt The default measurement method is a maximum search, which is 2236cd8a4bbSSteven Rostedt disabled by default and can be runtime (re-)started 2246cd8a4bbSSteven Rostedt via: 2256cd8a4bbSSteven Rostedt 226156f5a78SGeunSik Lim echo 0 > /sys/kernel/debug/tracing/tracing_max_latency 2276cd8a4bbSSteven Rostedt 22840892367SRandy Dunlap (Note that kernel size and overhead increase with this option 2296cd8a4bbSSteven Rostedt enabled. This option and the irqs-off timing option can be 2306cd8a4bbSSteven Rostedt used together or separately.) 2316cd8a4bbSSteven Rostedt 232352ad25aSSteven Rostedtconfig SCHED_TRACER 233352ad25aSSteven Rostedt bool "Scheduling Latency Tracer" 2345e0a0939SSteven Rostedt select GENERIC_TRACER 235352ad25aSSteven Rostedt select CONTEXT_SWITCH_TRACER 236352ad25aSSteven Rostedt select TRACER_MAX_TRACE 237*22cffc2bSSteven Rostedt (Red Hat) select TRACER_SNAPSHOT 238352ad25aSSteven Rostedt help 239352ad25aSSteven Rostedt This tracer tracks the latency of the highest priority task 240352ad25aSSteven Rostedt to be scheduled in, starting from the point it has woken up. 241352ad25aSSteven Rostedt 242897f17a6SSteven Rostedtconfig ENABLE_DEFAULT_TRACERS 243897f17a6SSteven Rostedt bool "Trace process context switches and events" 2445e0a0939SSteven Rostedt depends on !GENERIC_TRACER 245b77e38aaSSteven Rostedt select TRACING 246b77e38aaSSteven Rostedt help 24740892367SRandy Dunlap This tracer hooks to various trace points in the kernel, 248b77e38aaSSteven Rostedt allowing the user to pick and choose which trace point they 249897f17a6SSteven Rostedt want to trace. It also includes the sched_switch tracer plugin. 250a7abe97fSSteven Rostedt 251ee08c6ecSFrederic Weisbeckerconfig FTRACE_SYSCALLS 252ee08c6ecSFrederic Weisbecker bool "Trace syscalls" 25366700001SJosh Stone depends on HAVE_SYSCALL_TRACEPOINTS 2545e0a0939SSteven Rostedt select GENERIC_TRACER 2550ea1c415SFrederic Weisbecker select KALLSYMS 256ee08c6ecSFrederic Weisbecker help 257ee08c6ecSFrederic Weisbecker Basic tracer to catch the syscall entry and exit events. 258ee08c6ecSFrederic Weisbecker 259debdd57fSHiraku Toyookaconfig TRACER_SNAPSHOT 260debdd57fSHiraku Toyooka bool "Create a snapshot trace buffer" 261debdd57fSHiraku Toyooka select TRACER_MAX_TRACE 262debdd57fSHiraku Toyooka help 263debdd57fSHiraku Toyooka Allow tracing users to take snapshot of the current buffer using the 264debdd57fSHiraku Toyooka ftrace interface, e.g.: 265debdd57fSHiraku Toyooka 266debdd57fSHiraku Toyooka echo 1 > /sys/kernel/debug/tracing/snapshot 267debdd57fSHiraku Toyooka cat snapshot 268debdd57fSHiraku Toyooka 2692ed84eebSSteven Rostedtconfig TRACE_BRANCH_PROFILING 2709ae5b879SSteven Rostedt bool 2715e0a0939SSteven Rostedt select GENERIC_TRACER 2729ae5b879SSteven Rostedt 2739ae5b879SSteven Rostedtchoice 2749ae5b879SSteven Rostedt prompt "Branch Profiling" 2759ae5b879SSteven Rostedt default BRANCH_PROFILE_NONE 2769ae5b879SSteven Rostedt help 2779ae5b879SSteven Rostedt The branch profiling is a software profiler. It will add hooks 2789ae5b879SSteven Rostedt into the C conditionals to test which path a branch takes. 2799ae5b879SSteven Rostedt 2809ae5b879SSteven Rostedt The likely/unlikely profiler only looks at the conditions that 2819ae5b879SSteven Rostedt are annotated with a likely or unlikely macro. 2829ae5b879SSteven Rostedt 28340892367SRandy Dunlap The "all branch" profiler will profile every if-statement in the 2849ae5b879SSteven Rostedt kernel. This profiler will also enable the likely/unlikely 28540892367SRandy Dunlap profiler. 2869ae5b879SSteven Rostedt 28740892367SRandy Dunlap Either of the above profilers adds a bit of overhead to the system. 28840892367SRandy Dunlap If unsure, choose "No branch profiling". 2899ae5b879SSteven Rostedt 2909ae5b879SSteven Rostedtconfig BRANCH_PROFILE_NONE 2919ae5b879SSteven Rostedt bool "No branch profiling" 2929ae5b879SSteven Rostedt help 2939ae5b879SSteven Rostedt No branch profiling. Branch profiling adds a bit of overhead. 2949ae5b879SSteven Rostedt Only enable it if you want to analyse the branching behavior. 2959ae5b879SSteven Rostedt Otherwise keep it disabled. 2969ae5b879SSteven Rostedt 2979ae5b879SSteven Rostedtconfig PROFILE_ANNOTATED_BRANCHES 2989ae5b879SSteven Rostedt bool "Trace likely/unlikely profiler" 2999ae5b879SSteven Rostedt select TRACE_BRANCH_PROFILING 3001f0d69a9SSteven Rostedt help 30159bf8964SMasanari Iida This tracer profiles all likely and unlikely macros 3021f0d69a9SSteven Rostedt in the kernel. It will display the results in: 3031f0d69a9SSteven Rostedt 30413e5befaSDavid Rientjes /sys/kernel/debug/tracing/trace_stat/branch_annotated 3051f0d69a9SSteven Rostedt 30640892367SRandy Dunlap Note: this will add a significant overhead; only turn this 3071f0d69a9SSteven Rostedt on if you need to profile the system's use of these macros. 3081f0d69a9SSteven Rostedt 3092bcd521aSSteven Rostedtconfig PROFILE_ALL_BRANCHES 3102bcd521aSSteven Rostedt bool "Profile all if conditionals" 3119ae5b879SSteven Rostedt select TRACE_BRANCH_PROFILING 3122bcd521aSSteven Rostedt help 3132bcd521aSSteven Rostedt This tracer profiles all branch conditions. Every if () 3142bcd521aSSteven Rostedt taken in the kernel is recorded whether it hit or miss. 3152bcd521aSSteven Rostedt The results will be displayed in: 3162bcd521aSSteven Rostedt 31713e5befaSDavid Rientjes /sys/kernel/debug/tracing/trace_stat/branch_all 3182bcd521aSSteven Rostedt 3199ae5b879SSteven Rostedt This option also enables the likely/unlikely profiler. 3209ae5b879SSteven Rostedt 3212bcd521aSSteven Rostedt This configuration, when enabled, will impose a great overhead 3222bcd521aSSteven Rostedt on the system. This should only be enabled when the system 32340892367SRandy Dunlap is to be analyzed in much detail. 3249ae5b879SSteven Rostedtendchoice 3252bcd521aSSteven Rostedt 3262ed84eebSSteven Rostedtconfig TRACING_BRANCHES 32752f232cbSSteven Rostedt bool 32852f232cbSSteven Rostedt help 32952f232cbSSteven Rostedt Selected by tracers that will trace the likely and unlikely 33052f232cbSSteven Rostedt conditions. This prevents the tracers themselves from being 33152f232cbSSteven Rostedt profiled. Profiling the tracing infrastructure can only happen 33252f232cbSSteven Rostedt when the likelys and unlikelys are not being traced. 33352f232cbSSteven Rostedt 3342ed84eebSSteven Rostedtconfig BRANCH_TRACER 33552f232cbSSteven Rostedt bool "Trace likely/unlikely instances" 3362ed84eebSSteven Rostedt depends on TRACE_BRANCH_PROFILING 3372ed84eebSSteven Rostedt select TRACING_BRANCHES 33852f232cbSSteven Rostedt help 33952f232cbSSteven Rostedt This traces the events of likely and unlikely condition 34052f232cbSSteven Rostedt calls in the kernel. The difference between this and the 34152f232cbSSteven Rostedt "Trace likely/unlikely profiler" is that this is not a 34252f232cbSSteven Rostedt histogram of the callers, but actually places the calling 34352f232cbSSteven Rostedt events into a running trace buffer to see when and where the 34452f232cbSSteven Rostedt events happened, as well as their results. 34552f232cbSSteven Rostedt 34652f232cbSSteven Rostedt Say N if unsure. 34752f232cbSSteven Rostedt 348e5a81b62SSteven Rostedtconfig STACK_TRACER 349e5a81b62SSteven Rostedt bool "Trace max stack" 350606576ceSSteven Rostedt depends on HAVE_FUNCTION_TRACER 351606576ceSSteven Rostedt select FUNCTION_TRACER 352e5a81b62SSteven Rostedt select STACKTRACE 3534d7a077cSSteven Rostedt select KALLSYMS 354e5a81b62SSteven Rostedt help 3554519d9e5SIngo Molnar This special tracer records the maximum stack footprint of the 356156f5a78SGeunSik Lim kernel and displays it in /sys/kernel/debug/tracing/stack_trace. 3574519d9e5SIngo Molnar 3584519d9e5SIngo Molnar This tracer works by hooking into every function call that the 3594519d9e5SIngo Molnar kernel executes, and keeping a maximum stack depth value and 360f38f1d2aSSteven Rostedt stack-trace saved. If this is configured with DYNAMIC_FTRACE 361f38f1d2aSSteven Rostedt then it will not have any overhead while the stack tracer 362f38f1d2aSSteven Rostedt is disabled. 363f38f1d2aSSteven Rostedt 364f38f1d2aSSteven Rostedt To enable the stack tracer on bootup, pass in 'stacktrace' 365f38f1d2aSSteven Rostedt on the kernel command line. 366f38f1d2aSSteven Rostedt 367f38f1d2aSSteven Rostedt The stack tracer can also be enabled or disabled via the 368f38f1d2aSSteven Rostedt sysctl kernel.stack_tracer_enabled 3694519d9e5SIngo Molnar 3704519d9e5SIngo Molnar Say N if unsure. 371e5a81b62SSteven Rostedt 3722db270a8SFrederic Weisbeckerconfig BLK_DEV_IO_TRACE 37340892367SRandy Dunlap bool "Support for tracing block IO actions" 3742db270a8SFrederic Weisbecker depends on SYSFS 3751dfba05dSIngo Molnar depends on BLOCK 3762db270a8SFrederic Weisbecker select RELAY 3772db270a8SFrederic Weisbecker select DEBUG_FS 3782db270a8SFrederic Weisbecker select TRACEPOINTS 3795e0a0939SSteven Rostedt select GENERIC_TRACER 3802db270a8SFrederic Weisbecker select STACKTRACE 3812db270a8SFrederic Weisbecker help 3822db270a8SFrederic Weisbecker Say Y here if you want to be able to trace the block layer actions 3832db270a8SFrederic Weisbecker on a given queue. Tracing allows you to see any traffic happening 3842db270a8SFrederic Weisbecker on a block device queue. For more information (and the userspace 3852db270a8SFrederic Weisbecker support tools needed), fetch the blktrace tools from: 3862db270a8SFrederic Weisbecker 3872db270a8SFrederic Weisbecker git://git.kernel.dk/blktrace.git 3882db270a8SFrederic Weisbecker 3892db270a8SFrederic Weisbecker Tracing also is possible using the ftrace interface, e.g.: 3902db270a8SFrederic Weisbecker 3912db270a8SFrederic Weisbecker echo 1 > /sys/block/sda/sda1/trace/enable 3922db270a8SFrederic Weisbecker echo blk > /sys/kernel/debug/tracing/current_tracer 3932db270a8SFrederic Weisbecker cat /sys/kernel/debug/tracing/trace_pipe 3942db270a8SFrederic Weisbecker 3952db270a8SFrederic Weisbecker If unsure, say N. 39636994e58SFrederic Weisbecker 39777b44d1bSMasami Hiramatsuconfig KPROBE_EVENT 398413d37d1SMasami Hiramatsu depends on KPROBES 399f850c30cSHeiko Carstens depends on HAVE_REGS_AND_STACK_ACCESS_API 40077b44d1bSMasami Hiramatsu bool "Enable kprobes-based dynamic events" 401413d37d1SMasami Hiramatsu select TRACING 4028ab83f56SSrikar Dronamraju select PROBE_EVENTS 40377b44d1bSMasami Hiramatsu default y 404413d37d1SMasami Hiramatsu help 40540892367SRandy Dunlap This allows the user to add tracing events (similar to tracepoints) 40640892367SRandy Dunlap on the fly via the ftrace interface. See 40740892367SRandy Dunlap Documentation/trace/kprobetrace.txt for more details. 40877b44d1bSMasami Hiramatsu 40977b44d1bSMasami Hiramatsu Those events can be inserted wherever kprobes can probe, and record 41077b44d1bSMasami Hiramatsu various register and memory values. 41177b44d1bSMasami Hiramatsu 41240892367SRandy Dunlap This option is also required by perf-probe subcommand of perf tools. 41340892367SRandy Dunlap If you want to use perf tools, this option is strongly recommended. 414413d37d1SMasami Hiramatsu 415f3f096cfSSrikar Dronamrajuconfig UPROBE_EVENT 416f3f096cfSSrikar Dronamraju bool "Enable uprobes-based dynamic events" 417f3f096cfSSrikar Dronamraju depends on ARCH_SUPPORTS_UPROBES 418f3f096cfSSrikar Dronamraju depends on MMU 419f3f096cfSSrikar Dronamraju select UPROBES 420f3f096cfSSrikar Dronamraju select PROBE_EVENTS 421f3f096cfSSrikar Dronamraju select TRACING 422f3f096cfSSrikar Dronamraju default n 423f3f096cfSSrikar Dronamraju help 424f3f096cfSSrikar Dronamraju This allows the user to add tracing events on top of userspace 425f3f096cfSSrikar Dronamraju dynamic events (similar to tracepoints) on the fly via the trace 426f3f096cfSSrikar Dronamraju events interface. Those events can be inserted wherever uprobes 427f3f096cfSSrikar Dronamraju can probe, and record various registers. 428f3f096cfSSrikar Dronamraju This option is required if you plan to use perf-probe subcommand 429f3f096cfSSrikar Dronamraju of perf tools on user space applications. 430f3f096cfSSrikar Dronamraju 4318ab83f56SSrikar Dronamrajuconfig PROBE_EVENTS 4328ab83f56SSrikar Dronamraju def_bool n 4338ab83f56SSrikar Dronamraju 4343d083395SSteven Rostedtconfig DYNAMIC_FTRACE 435db05021dSSteven Rostedt bool "enable/disable function tracing dynamically" 436606576ceSSteven Rostedt depends on FUNCTION_TRACER 437677aa9f7SSteven Rostedt depends on HAVE_DYNAMIC_FTRACE 4383d083395SSteven Rostedt default y 4393d083395SSteven Rostedt help 440db05021dSSteven Rostedt This option will modify all the calls to function tracing 441db05021dSSteven Rostedt dynamically (will patch them out of the binary image and 442db05021dSSteven Rostedt replace them with a No-Op instruction) on boot up. During 443db05021dSSteven Rostedt compile time, a table is made of all the locations that ftrace 444db05021dSSteven Rostedt can function trace, and this table is linked into the kernel 445db05021dSSteven Rostedt image. When this is enabled, functions can be individually 446db05021dSSteven Rostedt enabled, and the functions not enabled will not affect 447db05021dSSteven Rostedt performance of the system. 448db05021dSSteven Rostedt 449db05021dSSteven Rostedt See the files in /sys/kernel/debug/tracing: 450db05021dSSteven Rostedt available_filter_functions 451db05021dSSteven Rostedt set_ftrace_filter 452db05021dSSteven Rostedt set_ftrace_notrace 4533d083395SSteven Rostedt 45440892367SRandy Dunlap This way a CONFIG_FUNCTION_TRACER kernel is slightly larger, but 45540892367SRandy Dunlap otherwise has native performance as long as no tracing is active. 4563d083395SSteven Rostedt 45706aeaaeaSMasami Hiramatsuconfig DYNAMIC_FTRACE_WITH_REGS 45806aeaaeaSMasami Hiramatsu def_bool y 45906aeaaeaSMasami Hiramatsu depends on DYNAMIC_FTRACE 46006aeaaeaSMasami Hiramatsu depends on HAVE_DYNAMIC_FTRACE_WITH_REGS 46106aeaaeaSMasami Hiramatsu 462bac429f0SSteven Rostedtconfig FUNCTION_PROFILER 463bac429f0SSteven Rostedt bool "Kernel function profiler" 464493762fcSSteven Rostedt depends on FUNCTION_TRACER 465bac429f0SSteven Rostedt default n 466bac429f0SSteven Rostedt help 467493762fcSSteven Rostedt This option enables the kernel function profiler. A file is created 468493762fcSSteven Rostedt in debugfs called function_profile_enabled which defaults to zero. 469bac429f0SSteven Rostedt When a 1 is echoed into this file profiling begins, and when a 47040892367SRandy Dunlap zero is entered, profiling stops. A "functions" file is created in 47140892367SRandy Dunlap the trace_stats directory; this file shows the list of functions that 472bac429f0SSteven Rostedt have been hit and their counters. 473bac429f0SSteven Rostedt 47440892367SRandy Dunlap If in doubt, say N. 475bac429f0SSteven Rostedt 4768da3821bSSteven Rostedtconfig FTRACE_MCOUNT_RECORD 4778da3821bSSteven Rostedt def_bool y 4788da3821bSSteven Rostedt depends on DYNAMIC_FTRACE 4798da3821bSSteven Rostedt depends on HAVE_FTRACE_MCOUNT_RECORD 4808da3821bSSteven Rostedt 48160a11774SSteven Rostedtconfig FTRACE_SELFTEST 48260a11774SSteven Rostedt bool 48360a11774SSteven Rostedt 48460a11774SSteven Rostedtconfig FTRACE_STARTUP_TEST 48560a11774SSteven Rostedt bool "Perform a startup test on ftrace" 4865e0a0939SSteven Rostedt depends on GENERIC_TRACER 48760a11774SSteven Rostedt select FTRACE_SELFTEST 48860a11774SSteven Rostedt help 48960a11774SSteven Rostedt This option performs a series of startup tests on ftrace. On bootup 49060a11774SSteven Rostedt a series of tests are made to verify that the tracer is 49160a11774SSteven Rostedt functioning properly. It will do tests on all the configured 49260a11774SSteven Rostedt tracers of ftrace. 49317d80fd0SPeter Zijlstra 4941f5a6b45SSteven Rostedtconfig EVENT_TRACE_TEST_SYSCALLS 4951f5a6b45SSteven Rostedt bool "Run selftest on syscall events" 4961f5a6b45SSteven Rostedt depends on FTRACE_STARTUP_TEST 4971f5a6b45SSteven Rostedt help 4981f5a6b45SSteven Rostedt This option will also enable testing every syscall event. 4991f5a6b45SSteven Rostedt It only enables the event and disables it and runs various loads 5001f5a6b45SSteven Rostedt with the event enabled. This adds a bit more time for kernel boot 5011f5a6b45SSteven Rostedt up since it runs this on every system call defined. 5021f5a6b45SSteven Rostedt 5031f5a6b45SSteven Rostedt TBD - enable a way to actually call the syscalls as we test their 5041f5a6b45SSteven Rostedt events 5051f5a6b45SSteven Rostedt 506fe6f90e5SPekka Paalanenconfig MMIOTRACE 507fe6f90e5SPekka Paalanen bool "Memory mapped IO tracing" 50840ada30fSIngo Molnar depends on HAVE_MMIOTRACE_SUPPORT && PCI 5095e0a0939SSteven Rostedt select GENERIC_TRACER 510fe6f90e5SPekka Paalanen help 511fe6f90e5SPekka Paalanen Mmiotrace traces Memory Mapped I/O access and is meant for 512fe6f90e5SPekka Paalanen debugging and reverse engineering. It is called from the ioremap 513fe6f90e5SPekka Paalanen implementation and works via page faults. Tracing is disabled by 514fe6f90e5SPekka Paalanen default and can be enabled at run-time. 515fe6f90e5SPekka Paalanen 5164d1f4372SLi Zefan See Documentation/trace/mmiotrace.txt. 517fe6f90e5SPekka Paalanen If you are not helping to develop drivers, say N. 518fe6f90e5SPekka Paalanen 519fe6f90e5SPekka Paalanenconfig MMIOTRACE_TEST 520fe6f90e5SPekka Paalanen tristate "Test module for mmiotrace" 521fe6f90e5SPekka Paalanen depends on MMIOTRACE && m 522fe6f90e5SPekka Paalanen help 523fe6f90e5SPekka Paalanen This is a dumb module for testing mmiotrace. It is very dangerous 524fe6f90e5SPekka Paalanen as it will write garbage to IO memory starting at a given address. 525fe6f90e5SPekka Paalanen However, it should be safe to use on e.g. unused portion of VRAM. 526fe6f90e5SPekka Paalanen 527fe6f90e5SPekka Paalanen Say N, unless you absolutely know what you are doing. 528fe6f90e5SPekka Paalanen 5295092dbc9SSteven Rostedtconfig RING_BUFFER_BENCHMARK 5305092dbc9SSteven Rostedt tristate "Ring buffer benchmark stress tester" 5315092dbc9SSteven Rostedt depends on RING_BUFFER 5325092dbc9SSteven Rostedt help 5335092dbc9SSteven Rostedt This option creates a test to stress the ring buffer and benchmark it. 53440892367SRandy Dunlap It creates its own ring buffer such that it will not interfere with 5355092dbc9SSteven Rostedt any other users of the ring buffer (such as ftrace). It then creates 5365092dbc9SSteven Rostedt a producer and consumer that will run for 10 seconds and sleep for 5375092dbc9SSteven Rostedt 10 seconds. Each interval it will print out the number of events 5385092dbc9SSteven Rostedt it recorded and give a rough estimate of how long each iteration took. 5395092dbc9SSteven Rostedt 5405092dbc9SSteven Rostedt It does not disable interrupts or raise its priority, so it may be 5415092dbc9SSteven Rostedt affected by processes that are running. 5425092dbc9SSteven Rostedt 54340892367SRandy Dunlap If unsure, say N. 5445092dbc9SSteven Rostedt 5454ed9f071SSteven Rostedtendif # FTRACE 54640ada30fSIngo Molnar 54740ada30fSIngo Molnarendif # TRACING_SUPPORT 54840ada30fSIngo Molnar 549