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 428da3821bSSteven Rostedtconfig HAVE_FTRACE_MCOUNT_RECORD 438da3821bSSteven Rostedt bool 44555f386cSMike Frysinger help 4540892367SRandy Dunlap See Documentation/trace/ftrace-design.txt 468da3821bSSteven Rostedt 4766700001SJosh Stoneconfig HAVE_SYSCALL_TRACEPOINTS 48ee08c6ecSFrederic Weisbecker bool 49555f386cSMike Frysinger help 5040892367SRandy Dunlap See Documentation/trace/ftrace-design.txt 51ee08c6ecSFrederic Weisbecker 52cf4db259SSteven Rostedtconfig HAVE_C_RECORDMCOUNT 5372441cb1SSteven Rostedt bool 5472441cb1SSteven Rostedt help 5572441cb1SSteven Rostedt C version of recordmcount available? 5672441cb1SSteven Rostedt 57352ad25aSSteven Rostedtconfig TRACER_MAX_TRACE 58352ad25aSSteven Rostedt bool 59352ad25aSSteven Rostedt 607a8e76a3SSteven Rostedtconfig RING_BUFFER 617a8e76a3SSteven Rostedt bool 627a8e76a3SSteven Rostedt 6378d904b4SSteven Rostedtconfig FTRACE_NMI_ENTER 6478d904b4SSteven Rostedt bool 6578d904b4SSteven Rostedt depends on HAVE_FTRACE_NMI_ENTER 6678d904b4SSteven Rostedt default y 6778d904b4SSteven Rostedt 685f77a88bSTom Zanussiconfig EVENT_TRACING 69b11c53e1SZhaolei select CONTEXT_SWITCH_TRACER 70b11c53e1SZhaolei bool 71b11c53e1SZhaolei 7225e41933SThomas Renningerconfig EVENT_POWER_TRACING_DEPRECATED 7325e41933SThomas Renninger depends on EVENT_TRACING 7425e41933SThomas Renninger bool "Deprecated power event trace API, to be removed" 7525e41933SThomas Renninger default y 7625e41933SThomas Renninger help 7725e41933SThomas Renninger Provides old power event types: 7825e41933SThomas Renninger C-state/idle accounting events: 7925e41933SThomas Renninger power:power_start 8025e41933SThomas Renninger power:power_end 8125e41933SThomas Renninger and old cpufreq accounting event: 8225e41933SThomas Renninger power:power_frequency 8325e41933SThomas Renninger This is for userspace compatibility 8425e41933SThomas Renninger and will vanish after 5 kernel iterations, 85f629299bSJesper Juhl namely 3.1. 8625e41933SThomas Renninger 87b11c53e1SZhaoleiconfig CONTEXT_SWITCH_TRACER 885f77a88bSTom Zanussi bool 895f77a88bSTom Zanussi 9085bac32cSSteven Rostedtconfig RING_BUFFER_ALLOW_SWAP 9185bac32cSSteven Rostedt bool 9285bac32cSSteven Rostedt help 9385bac32cSSteven Rostedt Allow the use of ring_buffer_swap_cpu. 9485bac32cSSteven Rostedt Adds a very slight overhead to tracing when enabled. 9585bac32cSSteven Rostedt 965e0a0939SSteven Rostedt# All tracer options should select GENERIC_TRACER. For those options that are 975e0a0939SSteven Rostedt# enabled by all tracers (context switch and event tracer) they select TRACING. 985e0a0939SSteven Rostedt# This allows those options to appear when no other tracer is selected. But the 995e0a0939SSteven Rostedt# options do not appear when something else selects it. We need the two options 1005e0a0939SSteven Rostedt# GENERIC_TRACER and TRACING to avoid circular dependencies to accomplish the 10140892367SRandy Dunlap# hiding of the automatic options. 1025e0a0939SSteven Rostedt 103bc0c38d1SSteven Rostedtconfig TRACING 104bc0c38d1SSteven Rostedt bool 105bc0c38d1SSteven Rostedt select DEBUG_FS 1067a8e76a3SSteven Rostedt select RING_BUFFER 107c2c80529SAl Viro select STACKTRACE if STACKTRACE_SUPPORT 1085f87f112SIngo Molnar select TRACEPOINTS 109f3384b28SSteven Rostedt select NOP_TRACER 110769b0441SFrederic Weisbecker select BINARY_PRINTF 1115f77a88bSTom Zanussi select EVENT_TRACING 112bc0c38d1SSteven Rostedt 1135e0a0939SSteven Rostedtconfig GENERIC_TRACER 1145e0a0939SSteven Rostedt bool 1155e0a0939SSteven Rostedt select TRACING 1165e0a0939SSteven Rostedt 11740ada30fSIngo Molnar# 11840ada30fSIngo Molnar# Minimum requirements an architecture has to meet for us to 11940ada30fSIngo Molnar# be able to offer generic tracing facilities: 12040ada30fSIngo Molnar# 12140ada30fSIngo Molnarconfig TRACING_SUPPORT 12240ada30fSIngo Molnar bool 12345b95608SAnton Vorontsov # PPC32 has no irqflags tracing support, but it can use most of the 12445b95608SAnton Vorontsov # tracers anyway, they were tested to build and work. Note that new 12545b95608SAnton Vorontsov # exceptions to this list aren't welcomed, better implement the 12645b95608SAnton Vorontsov # irqflags tracing for your architecture. 12745b95608SAnton Vorontsov depends on TRACE_IRQFLAGS_SUPPORT || PPC32 12840ada30fSIngo Molnar depends on STACKTRACE_SUPPORT 129422d3c7aSKOSAKI Motohiro default y 13040ada30fSIngo Molnar 13140ada30fSIngo Molnarif TRACING_SUPPORT 13240ada30fSIngo Molnar 1334ed9f071SSteven Rostedtmenuconfig FTRACE 1344ed9f071SSteven Rostedt bool "Tracers" 13565b77242SSteven Rostedt default y if DEBUG_KERNEL 1364ed9f071SSteven Rostedt help 1374ed9f071SSteven Rostedt Enable the kernel tracing infrastructure. 1384ed9f071SSteven Rostedt 1394ed9f071SSteven Rostedtif FTRACE 14017d80fd0SPeter Zijlstra 141606576ceSSteven Rostedtconfig FUNCTION_TRACER 1421b29b018SSteven Rostedt bool "Kernel Function Tracer" 143606576ceSSteven Rostedt depends on HAVE_FUNCTION_TRACER 1448c9cf542SGerlando Falauto select FRAME_POINTER if !ARM_UNWIND && !PPC && !S390 && !MICROBLAZE 1454d7a077cSSteven Rostedt select KALLSYMS 1465e0a0939SSteven Rostedt select GENERIC_TRACER 14735e8e302SSteven Rostedt select CONTEXT_SWITCH_TRACER 1481b29b018SSteven Rostedt help 1491b29b018SSteven Rostedt Enable the kernel to trace every kernel function. This is done 1501b29b018SSteven Rostedt by using a compiler feature to insert a small, 5-byte No-Operation 15140892367SRandy Dunlap instruction at the beginning of every kernel function, which NOP 1521b29b018SSteven Rostedt sequence is then dynamically patched into a tracer call when 1531b29b018SSteven Rostedt tracing is enabled by the administrator. If it's runtime disabled 1541b29b018SSteven Rostedt (the bootup default), then the overhead of the instructions is very 1551b29b018SSteven Rostedt small and not measurable even in micro-benchmarks. 15635e8e302SSteven Rostedt 157fb52607aSFrederic Weisbeckerconfig FUNCTION_GRAPH_TRACER 158fb52607aSFrederic Weisbecker bool "Kernel Function Graph Tracer" 159fb52607aSFrederic Weisbecker depends on HAVE_FUNCTION_GRAPH_TRACER 16015e6cb36SFrederic Weisbecker depends on FUNCTION_TRACER 161eb4a0378SSteven Rostedt depends on !X86_32 || !CC_OPTIMIZE_FOR_SIZE 162764f3b95SIngo Molnar default y 16315e6cb36SFrederic Weisbecker help 164fb52607aSFrederic Weisbecker Enable the kernel to trace a function at both its return 165fb52607aSFrederic Weisbecker and its entry. 166692105b8SMatt LaPlante Its first purpose is to trace the duration of functions and 167692105b8SMatt LaPlante draw a call graph for each thread with some information like 168692105b8SMatt LaPlante the return value. This is done by setting the current return 169692105b8SMatt LaPlante address on the current task structure into a stack of calls. 17015e6cb36SFrederic Weisbecker 171bac429f0SSteven Rostedt 17281d68a96SSteven Rostedtconfig IRQSOFF_TRACER 17381d68a96SSteven Rostedt bool "Interrupts-off Latency Tracer" 17481d68a96SSteven Rostedt default n 17581d68a96SSteven Rostedt depends on TRACE_IRQFLAGS_SUPPORT 176592913ecSJohn Stultz depends on !ARCH_USES_GETTIMEOFFSET 17781d68a96SSteven Rostedt select TRACE_IRQFLAGS 1785e0a0939SSteven Rostedt select GENERIC_TRACER 17981d68a96SSteven Rostedt select TRACER_MAX_TRACE 18085bac32cSSteven Rostedt select RING_BUFFER_ALLOW_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 2036cd8a4bbSSteven Rostedt help 20440892367SRandy Dunlap This option measures the time spent in preemption-off critical 2056cd8a4bbSSteven Rostedt sections, with microsecond accuracy. 2066cd8a4bbSSteven Rostedt 2076cd8a4bbSSteven Rostedt The default measurement method is a maximum search, which is 2086cd8a4bbSSteven Rostedt disabled by default and can be runtime (re-)started 2096cd8a4bbSSteven Rostedt via: 2106cd8a4bbSSteven Rostedt 211156f5a78SGeunSik Lim echo 0 > /sys/kernel/debug/tracing/tracing_max_latency 2126cd8a4bbSSteven Rostedt 21340892367SRandy Dunlap (Note that kernel size and overhead increase with this option 2146cd8a4bbSSteven Rostedt enabled. This option and the irqs-off timing option can be 2156cd8a4bbSSteven Rostedt used together or separately.) 2166cd8a4bbSSteven Rostedt 217352ad25aSSteven Rostedtconfig SCHED_TRACER 218352ad25aSSteven Rostedt bool "Scheduling Latency Tracer" 2195e0a0939SSteven Rostedt select GENERIC_TRACER 220352ad25aSSteven Rostedt select CONTEXT_SWITCH_TRACER 221352ad25aSSteven Rostedt select TRACER_MAX_TRACE 222352ad25aSSteven Rostedt help 223352ad25aSSteven Rostedt This tracer tracks the latency of the highest priority task 224352ad25aSSteven Rostedt to be scheduled in, starting from the point it has woken up. 225352ad25aSSteven Rostedt 226897f17a6SSteven Rostedtconfig ENABLE_DEFAULT_TRACERS 227897f17a6SSteven Rostedt bool "Trace process context switches and events" 2285e0a0939SSteven Rostedt depends on !GENERIC_TRACER 229b77e38aaSSteven Rostedt select TRACING 230b77e38aaSSteven Rostedt help 23140892367SRandy Dunlap This tracer hooks to various trace points in the kernel, 232b77e38aaSSteven Rostedt allowing the user to pick and choose which trace point they 233897f17a6SSteven Rostedt want to trace. It also includes the sched_switch tracer plugin. 234a7abe97fSSteven Rostedt 235ee08c6ecSFrederic Weisbeckerconfig FTRACE_SYSCALLS 236ee08c6ecSFrederic Weisbecker bool "Trace syscalls" 23766700001SJosh Stone depends on HAVE_SYSCALL_TRACEPOINTS 2385e0a0939SSteven Rostedt select GENERIC_TRACER 2390ea1c415SFrederic Weisbecker select KALLSYMS 240ee08c6ecSFrederic Weisbecker help 241ee08c6ecSFrederic Weisbecker Basic tracer to catch the syscall entry and exit events. 242ee08c6ecSFrederic Weisbecker 2432ed84eebSSteven Rostedtconfig TRACE_BRANCH_PROFILING 2449ae5b879SSteven Rostedt bool 2455e0a0939SSteven Rostedt select GENERIC_TRACER 2469ae5b879SSteven Rostedt 2479ae5b879SSteven Rostedtchoice 2489ae5b879SSteven Rostedt prompt "Branch Profiling" 2499ae5b879SSteven Rostedt default BRANCH_PROFILE_NONE 2509ae5b879SSteven Rostedt help 2519ae5b879SSteven Rostedt The branch profiling is a software profiler. It will add hooks 2529ae5b879SSteven Rostedt into the C conditionals to test which path a branch takes. 2539ae5b879SSteven Rostedt 2549ae5b879SSteven Rostedt The likely/unlikely profiler only looks at the conditions that 2559ae5b879SSteven Rostedt are annotated with a likely or unlikely macro. 2569ae5b879SSteven Rostedt 25740892367SRandy Dunlap The "all branch" profiler will profile every if-statement in the 2589ae5b879SSteven Rostedt kernel. This profiler will also enable the likely/unlikely 25940892367SRandy Dunlap profiler. 2609ae5b879SSteven Rostedt 26140892367SRandy Dunlap Either of the above profilers adds a bit of overhead to the system. 26240892367SRandy Dunlap If unsure, choose "No branch profiling". 2639ae5b879SSteven Rostedt 2649ae5b879SSteven Rostedtconfig BRANCH_PROFILE_NONE 2659ae5b879SSteven Rostedt bool "No branch profiling" 2669ae5b879SSteven Rostedt help 2679ae5b879SSteven Rostedt No branch profiling. Branch profiling adds a bit of overhead. 2689ae5b879SSteven Rostedt Only enable it if you want to analyse the branching behavior. 2699ae5b879SSteven Rostedt Otherwise keep it disabled. 2709ae5b879SSteven Rostedt 2719ae5b879SSteven Rostedtconfig PROFILE_ANNOTATED_BRANCHES 2729ae5b879SSteven Rostedt bool "Trace likely/unlikely profiler" 2739ae5b879SSteven Rostedt select TRACE_BRANCH_PROFILING 2741f0d69a9SSteven Rostedt help 2751f0d69a9SSteven Rostedt This tracer profiles all the the likely and unlikely macros 2761f0d69a9SSteven Rostedt in the kernel. It will display the results in: 2771f0d69a9SSteven Rostedt 27813e5befaSDavid Rientjes /sys/kernel/debug/tracing/trace_stat/branch_annotated 2791f0d69a9SSteven Rostedt 28040892367SRandy Dunlap Note: this will add a significant overhead; only turn this 2811f0d69a9SSteven Rostedt on if you need to profile the system's use of these macros. 2821f0d69a9SSteven Rostedt 2832bcd521aSSteven Rostedtconfig PROFILE_ALL_BRANCHES 2842bcd521aSSteven Rostedt bool "Profile all if conditionals" 2859ae5b879SSteven Rostedt select TRACE_BRANCH_PROFILING 2862bcd521aSSteven Rostedt help 2872bcd521aSSteven Rostedt This tracer profiles all branch conditions. Every if () 2882bcd521aSSteven Rostedt taken in the kernel is recorded whether it hit or miss. 2892bcd521aSSteven Rostedt The results will be displayed in: 2902bcd521aSSteven Rostedt 29113e5befaSDavid Rientjes /sys/kernel/debug/tracing/trace_stat/branch_all 2922bcd521aSSteven Rostedt 2939ae5b879SSteven Rostedt This option also enables the likely/unlikely profiler. 2949ae5b879SSteven Rostedt 2952bcd521aSSteven Rostedt This configuration, when enabled, will impose a great overhead 2962bcd521aSSteven Rostedt on the system. This should only be enabled when the system 29740892367SRandy Dunlap is to be analyzed in much detail. 2989ae5b879SSteven Rostedtendchoice 2992bcd521aSSteven Rostedt 3002ed84eebSSteven Rostedtconfig TRACING_BRANCHES 30152f232cbSSteven Rostedt bool 30252f232cbSSteven Rostedt help 30352f232cbSSteven Rostedt Selected by tracers that will trace the likely and unlikely 30452f232cbSSteven Rostedt conditions. This prevents the tracers themselves from being 30552f232cbSSteven Rostedt profiled. Profiling the tracing infrastructure can only happen 30652f232cbSSteven Rostedt when the likelys and unlikelys are not being traced. 30752f232cbSSteven Rostedt 3082ed84eebSSteven Rostedtconfig BRANCH_TRACER 30952f232cbSSteven Rostedt bool "Trace likely/unlikely instances" 3102ed84eebSSteven Rostedt depends on TRACE_BRANCH_PROFILING 3112ed84eebSSteven Rostedt select TRACING_BRANCHES 31252f232cbSSteven Rostedt help 31352f232cbSSteven Rostedt This traces the events of likely and unlikely condition 31452f232cbSSteven Rostedt calls in the kernel. The difference between this and the 31552f232cbSSteven Rostedt "Trace likely/unlikely profiler" is that this is not a 31652f232cbSSteven Rostedt histogram of the callers, but actually places the calling 31752f232cbSSteven Rostedt events into a running trace buffer to see when and where the 31852f232cbSSteven Rostedt events happened, as well as their results. 31952f232cbSSteven Rostedt 32052f232cbSSteven Rostedt Say N if unsure. 32152f232cbSSteven Rostedt 322e5a81b62SSteven Rostedtconfig STACK_TRACER 323e5a81b62SSteven Rostedt bool "Trace max stack" 324606576ceSSteven Rostedt depends on HAVE_FUNCTION_TRACER 325606576ceSSteven Rostedt select FUNCTION_TRACER 326e5a81b62SSteven Rostedt select STACKTRACE 3274d7a077cSSteven Rostedt select KALLSYMS 328e5a81b62SSteven Rostedt help 3294519d9e5SIngo Molnar This special tracer records the maximum stack footprint of the 330156f5a78SGeunSik Lim kernel and displays it in /sys/kernel/debug/tracing/stack_trace. 3314519d9e5SIngo Molnar 3324519d9e5SIngo Molnar This tracer works by hooking into every function call that the 3334519d9e5SIngo Molnar kernel executes, and keeping a maximum stack depth value and 334f38f1d2aSSteven Rostedt stack-trace saved. If this is configured with DYNAMIC_FTRACE 335f38f1d2aSSteven Rostedt then it will not have any overhead while the stack tracer 336f38f1d2aSSteven Rostedt is disabled. 337f38f1d2aSSteven Rostedt 338f38f1d2aSSteven Rostedt To enable the stack tracer on bootup, pass in 'stacktrace' 339f38f1d2aSSteven Rostedt on the kernel command line. 340f38f1d2aSSteven Rostedt 341f38f1d2aSSteven Rostedt The stack tracer can also be enabled or disabled via the 342f38f1d2aSSteven Rostedt sysctl kernel.stack_tracer_enabled 3434519d9e5SIngo Molnar 3444519d9e5SIngo Molnar Say N if unsure. 345e5a81b62SSteven Rostedt 3462db270a8SFrederic Weisbeckerconfig BLK_DEV_IO_TRACE 34740892367SRandy Dunlap bool "Support for tracing block IO actions" 3482db270a8SFrederic Weisbecker depends on SYSFS 3491dfba05dSIngo Molnar depends on BLOCK 3502db270a8SFrederic Weisbecker select RELAY 3512db270a8SFrederic Weisbecker select DEBUG_FS 3522db270a8SFrederic Weisbecker select TRACEPOINTS 3535e0a0939SSteven Rostedt select GENERIC_TRACER 3542db270a8SFrederic Weisbecker select STACKTRACE 3552db270a8SFrederic Weisbecker help 3562db270a8SFrederic Weisbecker Say Y here if you want to be able to trace the block layer actions 3572db270a8SFrederic Weisbecker on a given queue. Tracing allows you to see any traffic happening 3582db270a8SFrederic Weisbecker on a block device queue. For more information (and the userspace 3592db270a8SFrederic Weisbecker support tools needed), fetch the blktrace tools from: 3602db270a8SFrederic Weisbecker 3612db270a8SFrederic Weisbecker git://git.kernel.dk/blktrace.git 3622db270a8SFrederic Weisbecker 3632db270a8SFrederic Weisbecker Tracing also is possible using the ftrace interface, e.g.: 3642db270a8SFrederic Weisbecker 3652db270a8SFrederic Weisbecker echo 1 > /sys/block/sda/sda1/trace/enable 3662db270a8SFrederic Weisbecker echo blk > /sys/kernel/debug/tracing/current_tracer 3672db270a8SFrederic Weisbecker cat /sys/kernel/debug/tracing/trace_pipe 3682db270a8SFrederic Weisbecker 3692db270a8SFrederic Weisbecker If unsure, say N. 37036994e58SFrederic Weisbecker 37177b44d1bSMasami Hiramatsuconfig KPROBE_EVENT 372413d37d1SMasami Hiramatsu depends on KPROBES 373f850c30cSHeiko Carstens depends on HAVE_REGS_AND_STACK_ACCESS_API 37477b44d1bSMasami Hiramatsu bool "Enable kprobes-based dynamic events" 375413d37d1SMasami Hiramatsu select TRACING 376*8ab83f56SSrikar Dronamraju select PROBE_EVENTS 37777b44d1bSMasami Hiramatsu default y 378413d37d1SMasami Hiramatsu help 37940892367SRandy Dunlap This allows the user to add tracing events (similar to tracepoints) 38040892367SRandy Dunlap on the fly via the ftrace interface. See 38140892367SRandy Dunlap Documentation/trace/kprobetrace.txt for more details. 38277b44d1bSMasami Hiramatsu 38377b44d1bSMasami Hiramatsu Those events can be inserted wherever kprobes can probe, and record 38477b44d1bSMasami Hiramatsu various register and memory values. 38577b44d1bSMasami Hiramatsu 38640892367SRandy Dunlap This option is also required by perf-probe subcommand of perf tools. 38740892367SRandy Dunlap If you want to use perf tools, this option is strongly recommended. 388413d37d1SMasami Hiramatsu 389*8ab83f56SSrikar Dronamrajuconfig PROBE_EVENTS 390*8ab83f56SSrikar Dronamraju def_bool n 391*8ab83f56SSrikar Dronamraju 3923d083395SSteven Rostedtconfig DYNAMIC_FTRACE 3933d083395SSteven Rostedt bool "enable/disable ftrace tracepoints dynamically" 394606576ceSSteven Rostedt depends on FUNCTION_TRACER 395677aa9f7SSteven Rostedt depends on HAVE_DYNAMIC_FTRACE 3963d083395SSteven Rostedt default y 3973d083395SSteven Rostedt help 3983d083395SSteven Rostedt This option will modify all the calls to ftrace dynamically 39940892367SRandy Dunlap (will patch them out of the binary image and replace them 4003d083395SSteven Rostedt with a No-Op instruction) as they are called. A table is 4013d083395SSteven Rostedt created to dynamically enable them again. 4023d083395SSteven Rostedt 40340892367SRandy Dunlap This way a CONFIG_FUNCTION_TRACER kernel is slightly larger, but 40440892367SRandy Dunlap otherwise has native performance as long as no tracing is active. 4053d083395SSteven Rostedt 4063d083395SSteven Rostedt The changes to the code are done by a kernel thread that 4073d083395SSteven Rostedt wakes up once a second and checks to see if any ftrace calls 4083d083395SSteven Rostedt were made. If so, it runs stop_machine (stops all CPUS) 4093d083395SSteven Rostedt and modifies the code to jump over the call to ftrace. 41060a11774SSteven Rostedt 411bac429f0SSteven Rostedtconfig FUNCTION_PROFILER 412bac429f0SSteven Rostedt bool "Kernel function profiler" 413493762fcSSteven Rostedt depends on FUNCTION_TRACER 414bac429f0SSteven Rostedt default n 415bac429f0SSteven Rostedt help 416493762fcSSteven Rostedt This option enables the kernel function profiler. A file is created 417493762fcSSteven Rostedt in debugfs called function_profile_enabled which defaults to zero. 418bac429f0SSteven Rostedt When a 1 is echoed into this file profiling begins, and when a 41940892367SRandy Dunlap zero is entered, profiling stops. A "functions" file is created in 42040892367SRandy Dunlap the trace_stats directory; this file shows the list of functions that 421bac429f0SSteven Rostedt have been hit and their counters. 422bac429f0SSteven Rostedt 42340892367SRandy Dunlap If in doubt, say N. 424bac429f0SSteven Rostedt 4258da3821bSSteven Rostedtconfig FTRACE_MCOUNT_RECORD 4268da3821bSSteven Rostedt def_bool y 4278da3821bSSteven Rostedt depends on DYNAMIC_FTRACE 4288da3821bSSteven Rostedt depends on HAVE_FTRACE_MCOUNT_RECORD 4298da3821bSSteven Rostedt 43060a11774SSteven Rostedtconfig FTRACE_SELFTEST 43160a11774SSteven Rostedt bool 43260a11774SSteven Rostedt 43360a11774SSteven Rostedtconfig FTRACE_STARTUP_TEST 43460a11774SSteven Rostedt bool "Perform a startup test on ftrace" 4355e0a0939SSteven Rostedt depends on GENERIC_TRACER 43660a11774SSteven Rostedt select FTRACE_SELFTEST 43760a11774SSteven Rostedt help 43860a11774SSteven Rostedt This option performs a series of startup tests on ftrace. On bootup 43960a11774SSteven Rostedt a series of tests are made to verify that the tracer is 44060a11774SSteven Rostedt functioning properly. It will do tests on all the configured 44160a11774SSteven Rostedt tracers of ftrace. 44217d80fd0SPeter Zijlstra 4431f5a6b45SSteven Rostedtconfig EVENT_TRACE_TEST_SYSCALLS 4441f5a6b45SSteven Rostedt bool "Run selftest on syscall events" 4451f5a6b45SSteven Rostedt depends on FTRACE_STARTUP_TEST 4461f5a6b45SSteven Rostedt help 4471f5a6b45SSteven Rostedt This option will also enable testing every syscall event. 4481f5a6b45SSteven Rostedt It only enables the event and disables it and runs various loads 4491f5a6b45SSteven Rostedt with the event enabled. This adds a bit more time for kernel boot 4501f5a6b45SSteven Rostedt up since it runs this on every system call defined. 4511f5a6b45SSteven Rostedt 4521f5a6b45SSteven Rostedt TBD - enable a way to actually call the syscalls as we test their 4531f5a6b45SSteven Rostedt events 4541f5a6b45SSteven Rostedt 455fe6f90e5SPekka Paalanenconfig MMIOTRACE 456fe6f90e5SPekka Paalanen bool "Memory mapped IO tracing" 45740ada30fSIngo Molnar depends on HAVE_MMIOTRACE_SUPPORT && PCI 4585e0a0939SSteven Rostedt select GENERIC_TRACER 459fe6f90e5SPekka Paalanen help 460fe6f90e5SPekka Paalanen Mmiotrace traces Memory Mapped I/O access and is meant for 461fe6f90e5SPekka Paalanen debugging and reverse engineering. It is called from the ioremap 462fe6f90e5SPekka Paalanen implementation and works via page faults. Tracing is disabled by 463fe6f90e5SPekka Paalanen default and can be enabled at run-time. 464fe6f90e5SPekka Paalanen 4654d1f4372SLi Zefan See Documentation/trace/mmiotrace.txt. 466fe6f90e5SPekka Paalanen If you are not helping to develop drivers, say N. 467fe6f90e5SPekka Paalanen 468fe6f90e5SPekka Paalanenconfig MMIOTRACE_TEST 469fe6f90e5SPekka Paalanen tristate "Test module for mmiotrace" 470fe6f90e5SPekka Paalanen depends on MMIOTRACE && m 471fe6f90e5SPekka Paalanen help 472fe6f90e5SPekka Paalanen This is a dumb module for testing mmiotrace. It is very dangerous 473fe6f90e5SPekka Paalanen as it will write garbage to IO memory starting at a given address. 474fe6f90e5SPekka Paalanen However, it should be safe to use on e.g. unused portion of VRAM. 475fe6f90e5SPekka Paalanen 476fe6f90e5SPekka Paalanen Say N, unless you absolutely know what you are doing. 477fe6f90e5SPekka Paalanen 4785092dbc9SSteven Rostedtconfig RING_BUFFER_BENCHMARK 4795092dbc9SSteven Rostedt tristate "Ring buffer benchmark stress tester" 4805092dbc9SSteven Rostedt depends on RING_BUFFER 4815092dbc9SSteven Rostedt help 4825092dbc9SSteven Rostedt This option creates a test to stress the ring buffer and benchmark it. 48340892367SRandy Dunlap It creates its own ring buffer such that it will not interfere with 4845092dbc9SSteven Rostedt any other users of the ring buffer (such as ftrace). It then creates 4855092dbc9SSteven Rostedt a producer and consumer that will run for 10 seconds and sleep for 4865092dbc9SSteven Rostedt 10 seconds. Each interval it will print out the number of events 4875092dbc9SSteven Rostedt it recorded and give a rough estimate of how long each iteration took. 4885092dbc9SSteven Rostedt 4895092dbc9SSteven Rostedt It does not disable interrupts or raise its priority, so it may be 4905092dbc9SSteven Rostedt affected by processes that are running. 4915092dbc9SSteven Rostedt 49240892367SRandy Dunlap If unsure, say N. 4935092dbc9SSteven Rostedt 4944ed9f071SSteven Rostedtendif # FTRACE 49540ada30fSIngo Molnar 49640ada30fSIngo Molnarendif # TRACING_SUPPORT 49740ada30fSIngo Molnar 498