linux内核trace_begin和trace_end使用分析

1,strace/ftrace的实现和使用

echo 1 > /sys/kernel/debug/tracing/tracing_on
   echo function > /sys/kernel/debug/tracing/current_tracer

2, 手动插入追踪点

在内核代码中,可以使用trace_printk函数手动插入追踪点,标记代码段的开始和结束:

   trace_printk("trace_begin: function_name started\n");
   // 关键代码
   trace_printk("trace_end: function_name ended\n");

通过/sys/kernel/debug/tracing/trace文件可以查看输出。

3,调用关系

   #include <linux/kernel.h>

   #include <linux/module.h>

   static int __init trace_example_init(void) {

       trace_printk("trace_begin: trace_example_init started\n");

      &n

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

陌上花开缓缓归以

你的鼓励将是我创作的最大动力,

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值