ftrace--------------trace points

本文介绍了Linux内核的ftrace功能,包括如何开启ftrace,以及tracing目录下的主要文件。重点讲解了动态跟踪点(kprobe_events)的设置和使用,通过示例展示了如何设置跟踪点并解析跟踪信息。同时,也提到了静态跟踪点的存在及其操作方式。通过触发和清除跟踪点,以及使用trigger文件进行更复杂的跟踪操作,如堆栈跟踪。
摘要由CSDN通过智能技术生成

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值