dynamic debug

本文介绍了如何在Linux内核中使用dynamicdebug功能,包括开启和关闭文件的调试打印,以及遇到的问题和解决方案。作者发现输出可能被临时隐藏在kmsg和dmesg中,但最终问题得到了解决。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

设置dynamic debug

kernel source code中有很多pr_debug()/dev_dbg()/print_hex_dump_debug()等,之前问过大佬,给出了这样的调试方法:

开启某个文件中的pr_debug或dev_dbg

echo 'file $file_name +p' > /sys/kernel/debug/dynaminc_debug/control

如下图所示:

停止某个文件中的dynamic debug打印

echo 'file $file_name -p' > /sys/kernel/debug/dynaminc_debug/control

例如:上一次+p打印到1357行,然后设置-p,触发条件后还是打印在1357行

查看自己有没有设置成功

直接cat control | grep mytest,如果有,说明设置成功。

遇见的问题

触发条件后 一直没有输出

cat /proc/kmsg 

发现有输出,然后再dmesg以后就有输出了,这一点很奇怪。不过好在问题解决了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值