背景
printk 只能支持7个等级,并且是全局统一开关。粒度太粗。如何做到动态开关某个文件的debug?
linux内核提供了dynamic debug的机制(后文称dd)。
本文以pci驱动中的probe.c为例子介绍 开启内核中已使用了dd模块并且并已编译到内核的模块如何直接开启打印。
使用方法
在内核源码中driver/pci/probe.c中使用了`dev_dbg`的打印函数。该函数是dev.h提供的,封装的是`dynamic_dev_debug`。该函数是dynamic_debug.h提供的动态打印函数。类似的还有给`pr_debug`的`dynamic_pr_debug`和给netdev的`dynamic_netdev_debug`。
比如probe中有函数打印了`dev_debug("scanning bus"`,需要linux运行中动态打开它。操作方式
echo -n 'file probe.c +p' > /sys/kernel/debug/dynamic_debug/control
dmesg | grep scanning
这样就打开了
如果要开启某个模块的就用module xxx 替换其中的file xxx
开启后,在dmesg中就会打开