xref: /linux/kernel/trace/Kconfig (revision 8ab83f56475ec9151645a888dfe1941f4a92091d)
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