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 30*03688970SMike 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 428da3821bSSteven Rostedtconfig HAVE_FTRACE_MCOUNT_RECORD 438da3821bSSteven Rostedt bool 44555f386cSMike Frysinger help 4540892367SRandy Dunlap See Documentation/trace/ftrace-design.txt 468da3821bSSteven Rostedt 471e9b51c2SMarkus Metzgerconfig HAVE_HW_BRANCH_TRACER 481e9b51c2SMarkus Metzger bool 491e9b51c2SMarkus Metzger 5066700001SJosh Stoneconfig HAVE_SYSCALL_TRACEPOINTS 51ee08c6ecSFrederic Weisbecker bool 52555f386cSMike Frysinger help 5340892367SRandy Dunlap See Documentation/trace/ftrace-design.txt 54ee08c6ecSFrederic Weisbecker 55352ad25aSSteven Rostedtconfig TRACER_MAX_TRACE 56352ad25aSSteven Rostedt bool 57352ad25aSSteven Rostedt 587a8e76a3SSteven Rostedtconfig RING_BUFFER 597a8e76a3SSteven Rostedt bool 607a8e76a3SSteven Rostedt 6178d904b4SSteven Rostedtconfig FTRACE_NMI_ENTER 6278d904b4SSteven Rostedt bool 6378d904b4SSteven Rostedt depends on HAVE_FTRACE_NMI_ENTER 6478d904b4SSteven Rostedt default y 6578d904b4SSteven Rostedt 665f77a88bSTom Zanussiconfig EVENT_TRACING 67b11c53e1SZhaolei select CONTEXT_SWITCH_TRACER 68b11c53e1SZhaolei bool 69b11c53e1SZhaolei 70b11c53e1SZhaoleiconfig CONTEXT_SWITCH_TRACER 715f77a88bSTom Zanussi bool 725f77a88bSTom Zanussi 7385bac32cSSteven Rostedtconfig RING_BUFFER_ALLOW_SWAP 7485bac32cSSteven Rostedt bool 7585bac32cSSteven Rostedt help 7685bac32cSSteven Rostedt Allow the use of ring_buffer_swap_cpu. 7785bac32cSSteven Rostedt Adds a very slight overhead to tracing when enabled. 7885bac32cSSteven Rostedt 795e0a0939SSteven Rostedt# All tracer options should select GENERIC_TRACER. For those options that are 805e0a0939SSteven Rostedt# enabled by all tracers (context switch and event tracer) they select TRACING. 815e0a0939SSteven Rostedt# This allows those options to appear when no other tracer is selected. But the 825e0a0939SSteven Rostedt# options do not appear when something else selects it. We need the two options 835e0a0939SSteven Rostedt# GENERIC_TRACER and TRACING to avoid circular dependencies to accomplish the 8440892367SRandy Dunlap# hiding of the automatic options. 855e0a0939SSteven Rostedt 86bc0c38d1SSteven Rostedtconfig TRACING 87bc0c38d1SSteven Rostedt bool 88bc0c38d1SSteven Rostedt select DEBUG_FS 897a8e76a3SSteven Rostedt select RING_BUFFER 90c2c80529SAl Viro select STACKTRACE if STACKTRACE_SUPPORT 915f87f112SIngo Molnar select TRACEPOINTS 92f3384b28SSteven Rostedt select NOP_TRACER 93769b0441SFrederic Weisbecker select BINARY_PRINTF 945f77a88bSTom Zanussi select EVENT_TRACING 95bc0c38d1SSteven Rostedt 965e0a0939SSteven Rostedtconfig GENERIC_TRACER 975e0a0939SSteven Rostedt bool 985e0a0939SSteven Rostedt select TRACING 995e0a0939SSteven Rostedt 10040ada30fSIngo Molnar# 10140ada30fSIngo Molnar# Minimum requirements an architecture has to meet for us to 10240ada30fSIngo Molnar# be able to offer generic tracing facilities: 10340ada30fSIngo Molnar# 10440ada30fSIngo Molnarconfig TRACING_SUPPORT 10540ada30fSIngo Molnar bool 10645b95608SAnton Vorontsov # PPC32 has no irqflags tracing support, but it can use most of the 10745b95608SAnton Vorontsov # tracers anyway, they were tested to build and work. Note that new 10845b95608SAnton Vorontsov # exceptions to this list aren't welcomed, better implement the 10945b95608SAnton Vorontsov # irqflags tracing for your architecture. 11045b95608SAnton Vorontsov depends on TRACE_IRQFLAGS_SUPPORT || PPC32 11140ada30fSIngo Molnar depends on STACKTRACE_SUPPORT 112422d3c7aSKOSAKI Motohiro default y 11340ada30fSIngo Molnar 11440ada30fSIngo Molnarif TRACING_SUPPORT 11540ada30fSIngo Molnar 1164ed9f071SSteven Rostedtmenuconfig FTRACE 1174ed9f071SSteven Rostedt bool "Tracers" 11865b77242SSteven Rostedt default y if DEBUG_KERNEL 1194ed9f071SSteven Rostedt help 1204ed9f071SSteven Rostedt Enable the kernel tracing infrastructure. 1214ed9f071SSteven Rostedt 1224ed9f071SSteven Rostedtif FTRACE 12317d80fd0SPeter Zijlstra 124606576ceSSteven Rostedtconfig FUNCTION_TRACER 1251b29b018SSteven Rostedt bool "Kernel Function Tracer" 126606576ceSSteven Rostedt depends on HAVE_FUNCTION_TRACER 1271b29b018SSteven Rostedt select FRAME_POINTER 1284d7a077cSSteven Rostedt select KALLSYMS 1295e0a0939SSteven Rostedt select GENERIC_TRACER 13035e8e302SSteven Rostedt select CONTEXT_SWITCH_TRACER 1311b29b018SSteven Rostedt help 1321b29b018SSteven Rostedt Enable the kernel to trace every kernel function. This is done 1331b29b018SSteven Rostedt by using a compiler feature to insert a small, 5-byte No-Operation 13440892367SRandy Dunlap instruction at the beginning of every kernel function, which NOP 1351b29b018SSteven Rostedt sequence is then dynamically patched into a tracer call when 1361b29b018SSteven Rostedt tracing is enabled by the administrator. If it's runtime disabled 1371b29b018SSteven Rostedt (the bootup default), then the overhead of the instructions is very 1381b29b018SSteven Rostedt small and not measurable even in micro-benchmarks. 13935e8e302SSteven Rostedt 140fb52607aSFrederic Weisbeckerconfig FUNCTION_GRAPH_TRACER 141fb52607aSFrederic Weisbecker bool "Kernel Function Graph Tracer" 142fb52607aSFrederic Weisbecker depends on HAVE_FUNCTION_GRAPH_TRACER 14315e6cb36SFrederic Weisbecker depends on FUNCTION_TRACER 144eb4a0378SSteven Rostedt depends on !X86_32 || !CC_OPTIMIZE_FOR_SIZE 145764f3b95SIngo Molnar default y 14615e6cb36SFrederic Weisbecker help 147fb52607aSFrederic Weisbecker Enable the kernel to trace a function at both its return 148fb52607aSFrederic Weisbecker and its entry. 149692105b8SMatt LaPlante Its first purpose is to trace the duration of functions and 150692105b8SMatt LaPlante draw a call graph for each thread with some information like 151692105b8SMatt LaPlante the return value. This is done by setting the current return 152692105b8SMatt LaPlante address on the current task structure into a stack of calls. 15315e6cb36SFrederic Weisbecker 154bac429f0SSteven Rostedt 15581d68a96SSteven Rostedtconfig IRQSOFF_TRACER 15681d68a96SSteven Rostedt bool "Interrupts-off Latency Tracer" 15781d68a96SSteven Rostedt default n 15881d68a96SSteven Rostedt depends on TRACE_IRQFLAGS_SUPPORT 15981d68a96SSteven Rostedt depends on GENERIC_TIME 16081d68a96SSteven Rostedt select TRACE_IRQFLAGS 1615e0a0939SSteven Rostedt select GENERIC_TRACER 16281d68a96SSteven Rostedt select TRACER_MAX_TRACE 16385bac32cSSteven Rostedt select RING_BUFFER_ALLOW_SWAP 16481d68a96SSteven Rostedt help 16581d68a96SSteven Rostedt This option measures the time spent in irqs-off critical 16681d68a96SSteven Rostedt sections, with microsecond accuracy. 16781d68a96SSteven Rostedt 16881d68a96SSteven Rostedt The default measurement method is a maximum search, which is 16981d68a96SSteven Rostedt disabled by default and can be runtime (re-)started 17081d68a96SSteven Rostedt via: 17181d68a96SSteven Rostedt 172156f5a78SGeunSik Lim echo 0 > /sys/kernel/debug/tracing/tracing_max_latency 17381d68a96SSteven Rostedt 17440892367SRandy Dunlap (Note that kernel size and overhead increase with this option 1756cd8a4bbSSteven Rostedt enabled. This option and the preempt-off timing option can be 1766cd8a4bbSSteven Rostedt used together or separately.) 1776cd8a4bbSSteven Rostedt 1786cd8a4bbSSteven Rostedtconfig PREEMPT_TRACER 1796cd8a4bbSSteven Rostedt bool "Preemption-off Latency Tracer" 1806cd8a4bbSSteven Rostedt default n 1816cd8a4bbSSteven Rostedt depends on GENERIC_TIME 1826cd8a4bbSSteven Rostedt depends on PREEMPT 1835e0a0939SSteven Rostedt select GENERIC_TRACER 1846cd8a4bbSSteven Rostedt select TRACER_MAX_TRACE 18585bac32cSSteven Rostedt select RING_BUFFER_ALLOW_SWAP 1866cd8a4bbSSteven Rostedt help 18740892367SRandy Dunlap This option measures the time spent in preemption-off critical 1886cd8a4bbSSteven Rostedt sections, with microsecond accuracy. 1896cd8a4bbSSteven Rostedt 1906cd8a4bbSSteven Rostedt The default measurement method is a maximum search, which is 1916cd8a4bbSSteven Rostedt disabled by default and can be runtime (re-)started 1926cd8a4bbSSteven Rostedt via: 1936cd8a4bbSSteven Rostedt 194156f5a78SGeunSik Lim echo 0 > /sys/kernel/debug/tracing/tracing_max_latency 1956cd8a4bbSSteven Rostedt 19640892367SRandy Dunlap (Note that kernel size and overhead increase with this option 1976cd8a4bbSSteven Rostedt enabled. This option and the irqs-off timing option can be 1986cd8a4bbSSteven Rostedt used together or separately.) 1996cd8a4bbSSteven Rostedt 200f06c3810SIngo Molnarconfig SYSPROF_TRACER 201f06c3810SIngo Molnar bool "Sysprof Tracer" 2024d2df795SThomas Gleixner depends on X86 2035e0a0939SSteven Rostedt select GENERIC_TRACER 204b22f4858SFrederic Weisbecker select CONTEXT_SWITCH_TRACER 205f06c3810SIngo Molnar help 206f06c3810SIngo Molnar This tracer provides the trace needed by the 'Sysprof' userspace 207f06c3810SIngo Molnar tool. 208f06c3810SIngo Molnar 209352ad25aSSteven Rostedtconfig SCHED_TRACER 210352ad25aSSteven Rostedt bool "Scheduling Latency Tracer" 2115e0a0939SSteven Rostedt select GENERIC_TRACER 212352ad25aSSteven Rostedt select CONTEXT_SWITCH_TRACER 213352ad25aSSteven Rostedt select TRACER_MAX_TRACE 214352ad25aSSteven Rostedt help 215352ad25aSSteven Rostedt This tracer tracks the latency of the highest priority task 216352ad25aSSteven Rostedt to be scheduled in, starting from the point it has woken up. 217352ad25aSSteven Rostedt 218897f17a6SSteven Rostedtconfig ENABLE_DEFAULT_TRACERS 219897f17a6SSteven Rostedt bool "Trace process context switches and events" 2205e0a0939SSteven Rostedt depends on !GENERIC_TRACER 221b77e38aaSSteven Rostedt select TRACING 222b77e38aaSSteven Rostedt help 22340892367SRandy Dunlap This tracer hooks to various trace points in the kernel, 224b77e38aaSSteven Rostedt allowing the user to pick and choose which trace point they 225897f17a6SSteven Rostedt want to trace. It also includes the sched_switch tracer plugin. 226a7abe97fSSteven Rostedt 227ee08c6ecSFrederic Weisbeckerconfig FTRACE_SYSCALLS 228ee08c6ecSFrederic Weisbecker bool "Trace syscalls" 22966700001SJosh Stone depends on HAVE_SYSCALL_TRACEPOINTS 2305e0a0939SSteven Rostedt select GENERIC_TRACER 2310ea1c415SFrederic Weisbecker select KALLSYMS 232ee08c6ecSFrederic Weisbecker help 233ee08c6ecSFrederic Weisbecker Basic tracer to catch the syscall entry and exit events. 234ee08c6ecSFrederic Weisbecker 2351f5c2abbSFrédéric Weisbeckerconfig BOOT_TRACER 2361f5c2abbSFrédéric Weisbecker bool "Trace boot initcalls" 2375e0a0939SSteven Rostedt select GENERIC_TRACER 238ea31e72dSFrederic Weisbecker select CONTEXT_SWITCH_TRACER 2391f5c2abbSFrédéric Weisbecker help 2401f5c2abbSFrédéric Weisbecker This tracer helps developers to optimize boot times: it records 24198d9c66aSIngo Molnar the timings of the initcalls and traces key events and the identity 24298d9c66aSIngo Molnar of tasks that can cause boot delays, such as context-switches. 24398d9c66aSIngo Molnar 244238a24f6SLi Zefan Its aim is to be parsed by the scripts/bootgraph.pl tool to 24598d9c66aSIngo Molnar produce pretty graphics about boot inefficiencies, giving a visual 24698d9c66aSIngo Molnar representation of the delays during initcalls - but the raw 24798d9c66aSIngo Molnar /debug/tracing/trace text output is readable too. 24898d9c66aSIngo Molnar 249238a24f6SLi Zefan You must pass in initcall_debug and ftrace=initcall to the kernel 250238a24f6SLi Zefan command line to enable this on bootup. 2511f5c2abbSFrédéric Weisbecker 2522ed84eebSSteven Rostedtconfig TRACE_BRANCH_PROFILING 2539ae5b879SSteven Rostedt bool 2545e0a0939SSteven Rostedt select GENERIC_TRACER 2559ae5b879SSteven Rostedt 2569ae5b879SSteven Rostedtchoice 2579ae5b879SSteven Rostedt prompt "Branch Profiling" 2589ae5b879SSteven Rostedt default BRANCH_PROFILE_NONE 2599ae5b879SSteven Rostedt help 2609ae5b879SSteven Rostedt The branch profiling is a software profiler. It will add hooks 2619ae5b879SSteven Rostedt into the C conditionals to test which path a branch takes. 2629ae5b879SSteven Rostedt 2639ae5b879SSteven Rostedt The likely/unlikely profiler only looks at the conditions that 2649ae5b879SSteven Rostedt are annotated with a likely or unlikely macro. 2659ae5b879SSteven Rostedt 26640892367SRandy Dunlap The "all branch" profiler will profile every if-statement in the 2679ae5b879SSteven Rostedt kernel. This profiler will also enable the likely/unlikely 26840892367SRandy Dunlap profiler. 2699ae5b879SSteven Rostedt 27040892367SRandy Dunlap Either of the above profilers adds a bit of overhead to the system. 27140892367SRandy Dunlap If unsure, choose "No branch profiling". 2729ae5b879SSteven Rostedt 2739ae5b879SSteven Rostedtconfig BRANCH_PROFILE_NONE 2749ae5b879SSteven Rostedt bool "No branch profiling" 2759ae5b879SSteven Rostedt help 2769ae5b879SSteven Rostedt No branch profiling. Branch profiling adds a bit of overhead. 2779ae5b879SSteven Rostedt Only enable it if you want to analyse the branching behavior. 2789ae5b879SSteven Rostedt Otherwise keep it disabled. 2799ae5b879SSteven Rostedt 2809ae5b879SSteven Rostedtconfig PROFILE_ANNOTATED_BRANCHES 2819ae5b879SSteven Rostedt bool "Trace likely/unlikely profiler" 2829ae5b879SSteven Rostedt select TRACE_BRANCH_PROFILING 2831f0d69a9SSteven Rostedt help 2841f0d69a9SSteven Rostedt This tracer profiles all the the likely and unlikely macros 2851f0d69a9SSteven Rostedt in the kernel. It will display the results in: 2861f0d69a9SSteven Rostedt 287156f5a78SGeunSik Lim /sys/kernel/debug/tracing/profile_annotated_branch 2881f0d69a9SSteven Rostedt 28940892367SRandy Dunlap Note: this will add a significant overhead; only turn this 2901f0d69a9SSteven Rostedt on if you need to profile the system's use of these macros. 2911f0d69a9SSteven Rostedt 2922bcd521aSSteven Rostedtconfig PROFILE_ALL_BRANCHES 2932bcd521aSSteven Rostedt bool "Profile all if conditionals" 2949ae5b879SSteven Rostedt select TRACE_BRANCH_PROFILING 2952bcd521aSSteven Rostedt help 2962bcd521aSSteven Rostedt This tracer profiles all branch conditions. Every if () 2972bcd521aSSteven Rostedt taken in the kernel is recorded whether it hit or miss. 2982bcd521aSSteven Rostedt The results will be displayed in: 2992bcd521aSSteven Rostedt 300156f5a78SGeunSik Lim /sys/kernel/debug/tracing/profile_branch 3012bcd521aSSteven Rostedt 3029ae5b879SSteven Rostedt This option also enables the likely/unlikely profiler. 3039ae5b879SSteven Rostedt 3042bcd521aSSteven Rostedt This configuration, when enabled, will impose a great overhead 3052bcd521aSSteven Rostedt on the system. This should only be enabled when the system 30640892367SRandy Dunlap is to be analyzed in much detail. 3079ae5b879SSteven Rostedtendchoice 3082bcd521aSSteven Rostedt 3092ed84eebSSteven Rostedtconfig TRACING_BRANCHES 31052f232cbSSteven Rostedt bool 31152f232cbSSteven Rostedt help 31252f232cbSSteven Rostedt Selected by tracers that will trace the likely and unlikely 31352f232cbSSteven Rostedt conditions. This prevents the tracers themselves from being 31452f232cbSSteven Rostedt profiled. Profiling the tracing infrastructure can only happen 31552f232cbSSteven Rostedt when the likelys and unlikelys are not being traced. 31652f232cbSSteven Rostedt 3172ed84eebSSteven Rostedtconfig BRANCH_TRACER 31852f232cbSSteven Rostedt bool "Trace likely/unlikely instances" 3192ed84eebSSteven Rostedt depends on TRACE_BRANCH_PROFILING 3202ed84eebSSteven Rostedt select TRACING_BRANCHES 32152f232cbSSteven Rostedt help 32252f232cbSSteven Rostedt This traces the events of likely and unlikely condition 32352f232cbSSteven Rostedt calls in the kernel. The difference between this and the 32452f232cbSSteven Rostedt "Trace likely/unlikely profiler" is that this is not a 32552f232cbSSteven Rostedt histogram of the callers, but actually places the calling 32652f232cbSSteven Rostedt events into a running trace buffer to see when and where the 32752f232cbSSteven Rostedt events happened, as well as their results. 32852f232cbSSteven Rostedt 32952f232cbSSteven Rostedt Say N if unsure. 33052f232cbSSteven Rostedt 331f3f47a67SArjan van de Venconfig POWER_TRACER 332f3f47a67SArjan van de Ven bool "Trace power consumption behavior" 333f3f47a67SArjan van de Ven depends on X86 3345e0a0939SSteven Rostedt select GENERIC_TRACER 335f3f47a67SArjan van de Ven help 33640892367SRandy Dunlap This tracer helps developers to analyze and optimize the kernel's 337f3f47a67SArjan van de Ven power management decisions, specifically the C-state and P-state 338f3f47a67SArjan van de Ven behavior. 339f3f47a67SArjan van de Ven 3400722db01SK.Prasadconfig KSYM_TRACER 3410722db01SK.Prasad bool "Trace read and write access on kernel memory locations" 3420722db01SK.Prasad depends on HAVE_HW_BREAKPOINT 3430722db01SK.Prasad select TRACING 3440722db01SK.Prasad help 3450722db01SK.Prasad This tracer helps find read and write operations on any given kernel 3460722db01SK.Prasad symbol i.e. /proc/kallsyms. 3470722db01SK.Prasad 3480722db01SK.Prasadconfig PROFILE_KSYM_TRACER 3490722db01SK.Prasad bool "Profile all kernel memory accesses on 'watched' variables" 3500722db01SK.Prasad depends on KSYM_TRACER 3510722db01SK.Prasad help 3520722db01SK.Prasad This tracer profiles kernel accesses on variables watched through the 3530722db01SK.Prasad ksym tracer ftrace plugin. Depending upon the hardware, all read 3540722db01SK.Prasad and write operations on kernel variables can be monitored for 3550722db01SK.Prasad accesses. 3560722db01SK.Prasad 3570722db01SK.Prasad The results will be displayed in: 3580722db01SK.Prasad /debugfs/tracing/profile_ksym 3590722db01SK.Prasad 3600722db01SK.Prasad Say N if unsure. 361f3f47a67SArjan van de Ven 362e5a81b62SSteven Rostedtconfig STACK_TRACER 363e5a81b62SSteven Rostedt bool "Trace max stack" 364606576ceSSteven Rostedt depends on HAVE_FUNCTION_TRACER 365606576ceSSteven Rostedt select FUNCTION_TRACER 366e5a81b62SSteven Rostedt select STACKTRACE 3674d7a077cSSteven Rostedt select KALLSYMS 368e5a81b62SSteven Rostedt help 3694519d9e5SIngo Molnar This special tracer records the maximum stack footprint of the 370156f5a78SGeunSik Lim kernel and displays it in /sys/kernel/debug/tracing/stack_trace. 3714519d9e5SIngo Molnar 3724519d9e5SIngo Molnar This tracer works by hooking into every function call that the 3734519d9e5SIngo Molnar kernel executes, and keeping a maximum stack depth value and 374f38f1d2aSSteven Rostedt stack-trace saved. If this is configured with DYNAMIC_FTRACE 375f38f1d2aSSteven Rostedt then it will not have any overhead while the stack tracer 376f38f1d2aSSteven Rostedt is disabled. 377f38f1d2aSSteven Rostedt 378f38f1d2aSSteven Rostedt To enable the stack tracer on bootup, pass in 'stacktrace' 379f38f1d2aSSteven Rostedt on the kernel command line. 380f38f1d2aSSteven Rostedt 381f38f1d2aSSteven Rostedt The stack tracer can also be enabled or disabled via the 382f38f1d2aSSteven Rostedt sysctl kernel.stack_tracer_enabled 3834519d9e5SIngo Molnar 3844519d9e5SIngo Molnar Say N if unsure. 385e5a81b62SSteven Rostedt 386a93751caSMarkus Metzgerconfig HW_BRANCH_TRACER 3871e9b51c2SMarkus Metzger depends on HAVE_HW_BRANCH_TRACER 388a93751caSMarkus Metzger bool "Trace hw branches" 3895e0a0939SSteven Rostedt select GENERIC_TRACER 3901e9b51c2SMarkus Metzger help 3911e9b51c2SMarkus Metzger This tracer records all branches on the system in a circular 39240892367SRandy Dunlap buffer, giving access to the last N branches for each cpu. 3931e9b51c2SMarkus Metzger 39436994e58SFrederic Weisbeckerconfig KMEMTRACE 39536994e58SFrederic Weisbecker bool "Trace SLAB allocations" 3965e0a0939SSteven Rostedt select GENERIC_TRACER 39736994e58SFrederic Weisbecker help 39836994e58SFrederic Weisbecker kmemtrace provides tracing for slab allocator functions, such as 39940892367SRandy Dunlap kmalloc, kfree, kmem_cache_alloc, kmem_cache_free, etc. Collected 40036994e58SFrederic Weisbecker data is then fed to the userspace application in order to analyse 40136994e58SFrederic Weisbecker allocation hotspots, internal fragmentation and so on, making it 40236994e58SFrederic Weisbecker possible to see how well an allocator performs, as well as debug 40336994e58SFrederic Weisbecker and profile kernel code. 40436994e58SFrederic Weisbecker 40536994e58SFrederic Weisbecker This requires an userspace application to use. See 4064d1f4372SLi Zefan Documentation/trace/kmemtrace.txt for more information. 40736994e58SFrederic Weisbecker 40836994e58SFrederic Weisbecker Saying Y will make the kernel somewhat larger and slower. However, 40936994e58SFrederic Weisbecker if you disable kmemtrace at run-time or boot-time, the performance 41036994e58SFrederic Weisbecker impact is minimal (depending on the arch the kernel is built for). 41136994e58SFrederic Weisbecker 41236994e58SFrederic Weisbecker If unsure, say N. 41336994e58SFrederic Weisbecker 414e1d8aa9fSFrederic Weisbeckerconfig WORKQUEUE_TRACER 415e1d8aa9fSFrederic Weisbecker bool "Trace workqueues" 4165e0a0939SSteven Rostedt select GENERIC_TRACER 417e1d8aa9fSFrederic Weisbecker help 41840892367SRandy Dunlap The workqueue tracer provides some statistical information 419e1d8aa9fSFrederic Weisbecker about each cpu workqueue thread such as the number of the 420e1d8aa9fSFrederic Weisbecker works inserted and executed since their creation. It can help 42140892367SRandy Dunlap to evaluate the amount of work each of them has to perform. 422e1d8aa9fSFrederic Weisbecker For example it can help a developer to decide whether he should 42340892367SRandy Dunlap choose a per-cpu workqueue instead of a singlethreaded one. 424e1d8aa9fSFrederic Weisbecker 4252db270a8SFrederic Weisbeckerconfig BLK_DEV_IO_TRACE 42640892367SRandy Dunlap bool "Support for tracing block IO actions" 4272db270a8SFrederic Weisbecker depends on SYSFS 4281dfba05dSIngo Molnar depends on BLOCK 4292db270a8SFrederic Weisbecker select RELAY 4302db270a8SFrederic Weisbecker select DEBUG_FS 4312db270a8SFrederic Weisbecker select TRACEPOINTS 4325e0a0939SSteven Rostedt select GENERIC_TRACER 4332db270a8SFrederic Weisbecker select STACKTRACE 4342db270a8SFrederic Weisbecker help 4352db270a8SFrederic Weisbecker Say Y here if you want to be able to trace the block layer actions 4362db270a8SFrederic Weisbecker on a given queue. Tracing allows you to see any traffic happening 4372db270a8SFrederic Weisbecker on a block device queue. For more information (and the userspace 4382db270a8SFrederic Weisbecker support tools needed), fetch the blktrace tools from: 4392db270a8SFrederic Weisbecker 4402db270a8SFrederic Weisbecker git://git.kernel.dk/blktrace.git 4412db270a8SFrederic Weisbecker 4422db270a8SFrederic Weisbecker Tracing also is possible using the ftrace interface, e.g.: 4432db270a8SFrederic Weisbecker 4442db270a8SFrederic Weisbecker echo 1 > /sys/block/sda/sda1/trace/enable 4452db270a8SFrederic Weisbecker echo blk > /sys/kernel/debug/tracing/current_tracer 4462db270a8SFrederic Weisbecker cat /sys/kernel/debug/tracing/trace_pipe 4472db270a8SFrederic Weisbecker 4482db270a8SFrederic Weisbecker If unsure, say N. 44936994e58SFrederic Weisbecker 45077b44d1bSMasami Hiramatsuconfig KPROBE_EVENT 451413d37d1SMasami Hiramatsu depends on KPROBES 452413d37d1SMasami Hiramatsu depends on X86 45377b44d1bSMasami Hiramatsu bool "Enable kprobes-based dynamic events" 454413d37d1SMasami Hiramatsu select TRACING 45577b44d1bSMasami Hiramatsu default y 456413d37d1SMasami Hiramatsu help 45740892367SRandy Dunlap This allows the user to add tracing events (similar to tracepoints) 45840892367SRandy Dunlap on the fly via the ftrace interface. See 45940892367SRandy Dunlap Documentation/trace/kprobetrace.txt for more details. 46077b44d1bSMasami Hiramatsu 46177b44d1bSMasami Hiramatsu Those events can be inserted wherever kprobes can probe, and record 46277b44d1bSMasami Hiramatsu various register and memory values. 46377b44d1bSMasami Hiramatsu 46440892367SRandy Dunlap This option is also required by perf-probe subcommand of perf tools. 46540892367SRandy Dunlap If you want to use perf tools, this option is strongly recommended. 466413d37d1SMasami Hiramatsu 4673d083395SSteven Rostedtconfig DYNAMIC_FTRACE 4683d083395SSteven Rostedt bool "enable/disable ftrace tracepoints dynamically" 469606576ceSSteven Rostedt depends on FUNCTION_TRACER 470677aa9f7SSteven Rostedt depends on HAVE_DYNAMIC_FTRACE 4713d083395SSteven Rostedt default y 4723d083395SSteven Rostedt help 4733d083395SSteven Rostedt This option will modify all the calls to ftrace dynamically 47440892367SRandy Dunlap (will patch them out of the binary image and replace them 4753d083395SSteven Rostedt with a No-Op instruction) as they are called. A table is 4763d083395SSteven Rostedt created to dynamically enable them again. 4773d083395SSteven Rostedt 47840892367SRandy Dunlap This way a CONFIG_FUNCTION_TRACER kernel is slightly larger, but 47940892367SRandy Dunlap otherwise has native performance as long as no tracing is active. 4803d083395SSteven Rostedt 4813d083395SSteven Rostedt The changes to the code are done by a kernel thread that 4823d083395SSteven Rostedt wakes up once a second and checks to see if any ftrace calls 4833d083395SSteven Rostedt were made. If so, it runs stop_machine (stops all CPUS) 4843d083395SSteven Rostedt and modifies the code to jump over the call to ftrace. 48560a11774SSteven Rostedt 486bac429f0SSteven Rostedtconfig FUNCTION_PROFILER 487bac429f0SSteven Rostedt bool "Kernel function profiler" 488493762fcSSteven Rostedt depends on FUNCTION_TRACER 489bac429f0SSteven Rostedt default n 490bac429f0SSteven Rostedt help 491493762fcSSteven Rostedt This option enables the kernel function profiler. A file is created 492493762fcSSteven Rostedt in debugfs called function_profile_enabled which defaults to zero. 493bac429f0SSteven Rostedt When a 1 is echoed into this file profiling begins, and when a 49440892367SRandy Dunlap zero is entered, profiling stops. A "functions" file is created in 49540892367SRandy Dunlap the trace_stats directory; this file shows the list of functions that 496bac429f0SSteven Rostedt have been hit and their counters. 497bac429f0SSteven Rostedt 49840892367SRandy Dunlap If in doubt, say N. 499bac429f0SSteven Rostedt 5008da3821bSSteven Rostedtconfig FTRACE_MCOUNT_RECORD 5018da3821bSSteven Rostedt def_bool y 5028da3821bSSteven Rostedt depends on DYNAMIC_FTRACE 5038da3821bSSteven Rostedt depends on HAVE_FTRACE_MCOUNT_RECORD 5048da3821bSSteven Rostedt 50560a11774SSteven Rostedtconfig FTRACE_SELFTEST 50660a11774SSteven Rostedt bool 50760a11774SSteven Rostedt 50860a11774SSteven Rostedtconfig FTRACE_STARTUP_TEST 50960a11774SSteven Rostedt bool "Perform a startup test on ftrace" 5105e0a0939SSteven Rostedt depends on GENERIC_TRACER 51160a11774SSteven Rostedt select FTRACE_SELFTEST 51260a11774SSteven Rostedt help 51360a11774SSteven Rostedt This option performs a series of startup tests on ftrace. On bootup 51460a11774SSteven Rostedt a series of tests are made to verify that the tracer is 51560a11774SSteven Rostedt functioning properly. It will do tests on all the configured 51660a11774SSteven Rostedt tracers of ftrace. 51717d80fd0SPeter Zijlstra 5181f5a6b45SSteven Rostedtconfig EVENT_TRACE_TEST_SYSCALLS 5191f5a6b45SSteven Rostedt bool "Run selftest on syscall events" 5201f5a6b45SSteven Rostedt depends on FTRACE_STARTUP_TEST 5211f5a6b45SSteven Rostedt help 5221f5a6b45SSteven Rostedt This option will also enable testing every syscall event. 5231f5a6b45SSteven Rostedt It only enables the event and disables it and runs various loads 5241f5a6b45SSteven Rostedt with the event enabled. This adds a bit more time for kernel boot 5251f5a6b45SSteven Rostedt up since it runs this on every system call defined. 5261f5a6b45SSteven Rostedt 5271f5a6b45SSteven Rostedt TBD - enable a way to actually call the syscalls as we test their 5281f5a6b45SSteven Rostedt events 5291f5a6b45SSteven Rostedt 530fe6f90e5SPekka Paalanenconfig MMIOTRACE 531fe6f90e5SPekka Paalanen bool "Memory mapped IO tracing" 53240ada30fSIngo Molnar depends on HAVE_MMIOTRACE_SUPPORT && PCI 5335e0a0939SSteven Rostedt select GENERIC_TRACER 534fe6f90e5SPekka Paalanen help 535fe6f90e5SPekka Paalanen Mmiotrace traces Memory Mapped I/O access and is meant for 536fe6f90e5SPekka Paalanen debugging and reverse engineering. It is called from the ioremap 537fe6f90e5SPekka Paalanen implementation and works via page faults. Tracing is disabled by 538fe6f90e5SPekka Paalanen default and can be enabled at run-time. 539fe6f90e5SPekka Paalanen 5404d1f4372SLi Zefan See Documentation/trace/mmiotrace.txt. 541fe6f90e5SPekka Paalanen If you are not helping to develop drivers, say N. 542fe6f90e5SPekka Paalanen 543fe6f90e5SPekka Paalanenconfig MMIOTRACE_TEST 544fe6f90e5SPekka Paalanen tristate "Test module for mmiotrace" 545fe6f90e5SPekka Paalanen depends on MMIOTRACE && m 546fe6f90e5SPekka Paalanen help 547fe6f90e5SPekka Paalanen This is a dumb module for testing mmiotrace. It is very dangerous 548fe6f90e5SPekka Paalanen as it will write garbage to IO memory starting at a given address. 549fe6f90e5SPekka Paalanen However, it should be safe to use on e.g. unused portion of VRAM. 550fe6f90e5SPekka Paalanen 551fe6f90e5SPekka Paalanen Say N, unless you absolutely know what you are doing. 552fe6f90e5SPekka Paalanen 5535092dbc9SSteven Rostedtconfig RING_BUFFER_BENCHMARK 5545092dbc9SSteven Rostedt tristate "Ring buffer benchmark stress tester" 5555092dbc9SSteven Rostedt depends on RING_BUFFER 5565092dbc9SSteven Rostedt help 5575092dbc9SSteven Rostedt This option creates a test to stress the ring buffer and benchmark it. 55840892367SRandy Dunlap It creates its own ring buffer such that it will not interfere with 5595092dbc9SSteven Rostedt any other users of the ring buffer (such as ftrace). It then creates 5605092dbc9SSteven Rostedt a producer and consumer that will run for 10 seconds and sleep for 5615092dbc9SSteven Rostedt 10 seconds. Each interval it will print out the number of events 5625092dbc9SSteven Rostedt it recorded and give a rough estimate of how long each iteration took. 5635092dbc9SSteven Rostedt 5645092dbc9SSteven Rostedt It does not disable interrupts or raise its priority, so it may be 5655092dbc9SSteven Rostedt affected by processes that are running. 5665092dbc9SSteven Rostedt 56740892367SRandy Dunlap If unsure, say N. 5685092dbc9SSteven Rostedt 5694ed9f071SSteven Rostedtendif # FTRACE 57040ada30fSIngo Molnar 57140ada30fSIngo Molnarendif # TRACING_SUPPORT 57240ada30fSIngo Molnar 573