目录
一、概述
在 kernel 驱动代码中,使用动态输出是系统内核调试的重要手段之一,printk
打印是全局的,只能设置输出等级,而且使用 printk
每次都要重新编译内核,很不方便。。而动态输出可以在不需要重新编译内核的情况下,方便的打印出内核的 debug 信息。动态输出可以动态选择打开某个内核子系统的输出,可以有选择性地打开某些模块的输出,printk
被 dev_info
,dev_dbg
,dev_err
之类的函数代替,dev_xxx
函数的本质还是使用 printk
打印的,只是对 printk
进行了一层包装。
在系统运行时候,动态打印可以由系统维护者动态打开内核子系统的打印,可以有选择性地打开某些模块的打印。要使用动态打印,必须在内核配置时打开 CONFIG_DYNAMIC_DEBUG
宏。
CONFIG_DEBUG_FS=y
CONFIG_DYNAMIC_DEBUG=y
CONFIG_DYNAMIC_DEBUG
是配置动态输出,它依赖于 CONFIG_DEBUG_FS
,而 CONFIG_DEBUG_FS
是 debugfs
文件系统。debugfs默认会挂载到 /sys/kernel/debug
,如果没有挂载,可以执行以下命令挂载:
$ mount -t debugfs none /sys/kernel/debug
二、printk
1、printk 消息级别
Linux 内核共提供了八种不同的消息级别,分为级别 0~7。数值越大,表示级别越低,对应的消息越不重要。相应的宏定义在 include/linux/kern_levels.h
文件中。
#define KERN_SOH "\001" /* ASCII Start Of Header */
#define KERN_SOH_ASCII '\001'
#define KERN_EMERG KERN_SOH "0" /* system is unusable */
#define KERN_ALERT KERN_SOH "1" /* action must be taken immediately */
#define KERN_CRIT KERN_SOH "2" /* critical conditions */
#define KERN_ERR KERN_SOH "3" /* error conditions */
#define KERN_WARNING KERN_SOH "4" /* warning conditions */
#define KERN_NOTICE KERN_SOH "5" /* normal but significant condition */
#define KERN_INFO KERN_SOH "6" /* informational */
#define KERN_DEBUG KERN_SOH "7" /* debug-level messages */
- KERN_EMERG