linux内核打开了ftrace之后,系统启动的时候会自动创建/sys/kernel/tracing录。
/sys/kernel/tracing目录有以下文件或者目录:
tracing_on:决定是否像ring_buff写入数据,这个跟跟踪是否开启没关系,跟踪即使开启了这个关闭,每次跟踪被触发也不会写入到/sys/kernel/tracing/trace文件里面。
trace:显示跟踪信息的文件可以使用cat等数据去读取。
trace_pipe:类似trace,每次读取完成之后会继续等待下一次数据到来。
trace_options:显示tracer打开了哪些特性。options:目录里是这些特性的开关。
buffer_size_kb:缓冲区大小,kb为单位。
buffer_total_size_kb:所有设置跟踪点的缓冲区大小。\
tracing_cpumask:设置被跟踪的cpu掩码,即使设置跟踪点,只有在掩码内的cpu触发跟踪点才会打印。
动态跟踪点:
kprobe_events:动态跟踪点设置。
kprobe_profile:所有已经设置的动态跟踪点信息。
./Documentation/trace/kprobetrace.rst,内核文档
/sys/kernel/debug/tracing/kprobe_events文件是可以设置动态跟踪点。
echo %s > /sys/kernel/debug/tracing/kprobe_events 即可设置动态跟踪点且%s可以打印进ring_buff参数信息。
%s 格式说明:
p[:[GRP/]EVENT] [MOD:]SYM[+offs]|MEMADDR [FETCHARGS] : Set a probe
r[MAXACTIVE][:[GR