xref: /openbmc/linux/Documentation/trace/boottime-trace.rst (revision a8f4fcdd8ba7d191c29ae87a2315906fe90368d6)
1.. SPDX-License-Identifier: GPL-2.0
2
3=================
4Boot-time tracing
5=================
6
7:Author: Masami Hiramatsu <mhiramat@kernel.org>
8
9Overview
10========
11
12Boot-time tracing allows users to trace boot-time process including
13device initialization with full features of ftrace including per-event
14filter and actions, histograms, kprobe-events and synthetic-events,
15and trace instances.
16Since kernel command line is not enough to control these complex features,
17this uses bootconfig file to describe tracing feature programming.
18
19Options in the Boot Config
20==========================
21
22Here is the list of available options list for boot time tracing in
23boot config file [1]_. All options are under "ftrace." or "kernel."
24prefix. See kernel parameters for the options which starts
25with "kernel." prefix [2]_.
26
27.. [1] See :ref:`Documentation/admin-guide/bootconfig.rst <bootconfig>`
28.. [2] See :ref:`Documentation/admin-guide/kernel-parameters.rst <kernelparameters>`
29
30Ftrace Global Options
31---------------------
32
33Ftrace global options have "kernel." prefix in boot config, which means
34these options are passed as a part of kernel legacy command line.
35
36kernel.tp_printk
37   Output trace-event data on printk buffer too.
38
39kernel.dump_on_oops [= MODE]
40   Dump ftrace on Oops. If MODE = 1 or omitted, dump trace buffer
41   on all CPUs. If MODE = 2, dump a buffer on a CPU which kicks Oops.
42
43kernel.traceoff_on_warning
44   Stop tracing if WARN_ON() occurs.
45
46kernel.fgraph_max_depth = MAX_DEPTH
47   Set MAX_DEPTH to maximum depth of fgraph tracer.
48
49kernel.fgraph_filters = FILTER[, FILTER2...]
50   Add fgraph tracing function filters.
51
52kernel.fgraph_notraces = FILTER[, FILTER2...]
53   Add fgraph non-tracing function filters.
54
55
56Ftrace Per-instance Options
57---------------------------
58
59These options can be used for each instance including global ftrace node.
60
61ftrace.[instance.INSTANCE.]options = OPT1[, OPT2[...]]
62   Enable given ftrace options.
63
64ftrace.[instance.INSTANCE.]tracing_on = 0|1
65   Enable/Disable tracing on this instance when starting boot-time tracing.
66   (you can enable it by the "traceon" event trigger action)
67
68ftrace.[instance.INSTANCE.]trace_clock = CLOCK
69   Set given CLOCK to ftrace's trace_clock.
70
71ftrace.[instance.INSTANCE.]buffer_size = SIZE
72   Configure ftrace buffer size to SIZE. You can use "KB" or "MB"
73   for that SIZE.
74
75ftrace.[instance.INSTANCE.]alloc_snapshot
76   Allocate snapshot buffer.
77
78ftrace.[instance.INSTANCE.]cpumask = CPUMASK
79   Set CPUMASK as trace cpu-mask.
80
81ftrace.[instance.INSTANCE.]events = EVENT[, EVENT2[...]]
82   Enable given events on boot. You can use a wild card in EVENT.
83
84ftrace.[instance.INSTANCE.]tracer = TRACER
85   Set TRACER to current tracer on boot. (e.g. function)
86
87ftrace.[instance.INSTANCE.]ftrace.filters
88   This will take an array of tracing function filter rules.
89
90ftrace.[instance.INSTANCE.]ftrace.notraces
91   This will take an array of NON-tracing function filter rules.
92
93
94Ftrace Per-Event Options
95------------------------
96
97These options are setting per-event options.
98
99ftrace.[instance.INSTANCE.]event.GROUP.EVENT.enable
100   Enable GROUP:EVENT tracing.
101
102ftrace.[instance.INSTANCE.]event.GROUP.enable
103   Enable all event tracing within GROUP.
104
105ftrace.[instance.INSTANCE.]event.enable
106   Enable all event tracing.
107
108ftrace.[instance.INSTANCE.]event.GROUP.EVENT.filter = FILTER
109   Set FILTER rule to the GROUP:EVENT.
110
111ftrace.[instance.INSTANCE.]event.GROUP.EVENT.actions = ACTION[, ACTION2[...]]
112   Set ACTIONs to the GROUP:EVENT.
113
114ftrace.[instance.INSTANCE.]event.kprobes.EVENT.probes = PROBE[, PROBE2[...]]
115   Defines new kprobe event based on PROBEs. It is able to define
116   multiple probes on one event, but those must have same type of
117   arguments. This option is available only for the event which
118   group name is "kprobes".
119
120ftrace.[instance.INSTANCE.]event.synthetic.EVENT.fields = FIELD[, FIELD2[...]]
121   Defines new synthetic event with FIELDs. Each field should be
122   "type varname".
123
124Note that kprobe and synthetic event definitions can be written under
125instance node, but those are also visible from other instances. So please
126take care for event name conflict.
127
128Ftrace Histogram Options
129------------------------
130
131Since it is too long to write a histogram action as a string for per-event
132action option, there are tree-style options under per-event 'hist' subkey
133for the histogram actions. For the detail of the each parameter,
134please read the event histogram document [3]_.
135
136.. [3] See :ref:`Documentation/trace/histogram.rst <histogram>`
137
138ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.[N.]keys = KEY1[, KEY2[...]]
139  Set histogram key parameters. (Mandatory)
140  The 'N' is a digit string for the multiple histogram. You can omit it
141  if there is one histogram on the event.
142
143ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.[N.]values = VAL1[, VAL2[...]]
144  Set histogram value parameters.
145
146ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.[N.]sort = SORT1[, SORT2[...]]
147  Set histogram sort parameter options.
148
149ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.[N.]size = NR_ENTRIES
150  Set histogram size (number of entries).
151
152ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.[N.]name = NAME
153  Set histogram name.
154
155ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.[N.]var.VARIABLE = EXPR
156  Define a new VARIABLE by EXPR expression.
157
158ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.[N.]<pause|continue|clear>
159  Set histogram control parameter. You can set one of them.
160
161ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.[N.]onmatch.[M.]event = GROUP.EVENT
162  Set histogram 'onmatch' handler matching event parameter.
163  The 'M' is a digit string for the multiple 'onmatch' handler. You can omit it
164  if there is one 'onmatch' handler on this histogram.
165
166ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.[N.]onmatch.[M.]trace = EVENT[, ARG1[...]]
167  Set histogram 'trace' action for 'onmatch'.
168  EVENT must be a synthetic event name, and ARG1... are parameters
169  for that event. Mandatory if 'onmatch.event' option is set.
170
171ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.[N.]onmax.[M.]var = VAR
172  Set histogram 'onmax' handler variable parameter.
173
174ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.[N.]onchange.[M.]var = VAR
175  Set histogram 'onchange' handler variable parameter.
176
177ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.[N.]<onmax|onchange>.[M.]save = ARG1[, ARG2[...]]
178  Set histogram 'save' action parameters for 'onmax' or 'onchange' handler.
179  This option or below 'snapshot' option is mandatory if 'onmax.var' or
180  'onchange.var' option is set.
181
182ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.[N.]<onmax|onchange>.[M.]snapshot
183  Set histogram 'snapshot' action for 'onmax' or 'onchange' handler.
184  This option or above 'save' option is mandatory if 'onmax.var' or
185  'onchange.var' option is set.
186
187ftrace.[instance.INSTANCE.]event.GROUP.EVENT.hist.filter = FILTER_EXPR
188  Set histogram filter expression. You don't need 'if' in the FILTER_EXPR.
189
190Note that this 'hist' option can conflict with the per-event 'actions'
191option if the 'actions' option has a histogram action.
192
193
194When to Start
195=============
196
197All boot-time tracing options starting with ``ftrace`` will be enabled at the
198end of core_initcall. This means you can trace the events from postcore_initcall.
199Most of the subsystems and architecture dependent drivers will be initialized
200after that (arch_initcall or subsys_initcall). Thus, you can trace those with
201boot-time tracing.
202If you want to trace events before core_initcall, you can use the options
203starting with ``kernel``. Some of them will be enabled eariler than the initcall
204processing (for example,. ``kernel.ftrace=function`` and ``kernel.trace_event``
205will start before the initcall.)
206
207
208Examples
209========
210
211For example, to add filter and actions for each event, define kprobe
212events, and synthetic events with histogram, write a boot config like
213below::
214
215  ftrace.event {
216        task.task_newtask {
217                filter = "pid < 128"
218                enable
219        }
220        kprobes.vfs_read {
221                probes = "vfs_read $arg1 $arg2"
222                filter = "common_pid < 200"
223                enable
224        }
225        synthetic.initcall_latency {
226                fields = "unsigned long func", "u64 lat"
227                hist {
228                        keys = func.sym, lat
229                        values = lat
230                        sort = lat
231                }
232        }
233        initcall.initcall_start.hist {
234                keys = func
235                var.ts0 = common_timestamp.usecs
236        }
237        initcall.initcall_finish.hist {
238                keys = func
239                var.lat = common_timestamp.usecs - $ts0
240                onmatch {
241                        event = initcall.initcall_start
242                        trace = initcall_latency, func, $lat
243                }
244        }
245  }
246
247Also, boot-time tracing supports "instance" node, which allows us to run
248several tracers for different purpose at once. For example, one tracer
249is for tracing functions starting with "user\_", and others tracing
250"kernel\_" functions, you can write boot config as below::
251
252  ftrace.instance {
253        foo {
254                tracer = "function"
255                ftrace.filters = "user_*"
256        }
257        bar {
258                tracer = "function"
259                ftrace.filters = "kernel_*"
260        }
261  }
262
263The instance node also accepts event nodes so that each instance
264can customize its event tracing.
265
266With the trigger action and kprobes, you can trace function-graph while
267a function is called. For example, this will trace all function calls in
268the pci_proc_init()::
269
270  ftrace {
271        tracing_on = 0
272        tracer = function_graph
273        event.kprobes {
274                start_event {
275                        probes = "pci_proc_init"
276                        actions = "traceon"
277                }
278                end_event {
279                        probes = "pci_proc_init%return"
280                        actions = "traceoff"
281                }
282        }
283  }
284
285
286This boot-time tracing also supports ftrace kernel parameters via boot
287config.
288For example, following kernel parameters::
289
290 trace_options=sym-addr trace_event=initcall:* tp_printk trace_buf_size=1M ftrace=function ftrace_filter="vfs*"
291
292This can be written in boot config like below::
293
294  kernel {
295        trace_options = sym-addr
296        trace_event = "initcall:*"
297        tp_printk
298        trace_buf_size = 1M
299        ftrace = function
300        ftrace_filter = "vfs*"
301  }
302
303Note that parameters start with "kernel" prefix instead of "ftrace".
304