Using the kernel function tracing system
Recent versions of the Linux kernel contain a set of tracers that, by instrumenting the kernel, allow you to analyze different areas such as the following:
- Interrupt latency
- Preemption latency
- Scheduling latency
- Process context switches
- Event tracing
- Syscalls
- Maximum stack
- Block layer
- Functions
The tracers have no performance overhead when not enabled.
Getting ready
The tracing system can be used in a wide variety of debugging scenarios, but one of the most common tracers used is the function tracer. It instruments every kernel function with an NOP call that is replaced and used to trace the kernel functions when a trace point is enabled.
To enable the function tracer in the kernel, use the CONFIG_FUNCTION_TRACER and CONFIG_FUNCTION_GRAPH_TRACER configuration variables.
The kernel tracing system is controlled via a tracing file in the debug filesystem, which is mounted by default on Yocto's default images. If not, you can mount it with the following:
$ mount -t...