您的位置:首页 > 运维架构 > Linux

Linux驱动开发 -- 打开dev_dbg()

2015-11-28 00:00 706 查看
linux设备驱动调试,我们在内核中看到内核使用dev_dbg来控制输出信息,这个函数的实质是调用printk(KERN_DEBUG )来输出打印信息。要打开这个开关需要下面两步。

1、打开调试开关:你调试的文件中必然包含了,或者,后者包含了前者,在包含此头文件之前,使用#define DEBUG 1 来打开调试开关:例如

#include

#include

#include

#include

#define DEBUG 1

#include

在linux/device.h文件中:

#define dev_printk(level, dev, format, arg...) \

printk(level "%s %s: " format , dev_driver_string(dev) , (dev)->bus_id , ## arg)

#ifdef DEBUG

#define dev_dbg(dev, format, arg...) \

dev_printk(KERN_DEBUG , dev , format , ## arg)

#else

static inline int __attribute__ ((format (printf, 2, 3)))

dev_dbg(struct device * dev, const char * fmt, ...)

{

return 0;

}

#endif

但是这个打开了之后,也不能顺利的输出信息,原因是printk有默认的信息级别。

linux/kernel文件中

#define KERN_EMERG "<0>"

#define KERN_ALERT "<1>"

#define KERN_CRIT "<2>"

#define KERN_ERR "<3>"

#define KERN_WARNING "<4>"

#define KERN_NOTICE "<5>"

#define KERN_INFO "<6>"

#define KERN_DEBUG "<7>"

可以看到KERN_DEBUG是级别最低的。

2、修改文件kernel/printk文件

#define DEFAULT_MESSAGE_LOGLEVEL 4

#define MINIMUM_CONSOLE_LOGLEVEL 1

#define DEFAULT_CONSOLE_LOGLEVEL 8

其中DEFAULT_CONSOLE_LOGLEVEL 为终端console输出的最低级别,比这严重的都将输出。原来该值为7,则调试信息无法输出,修改为8则全部有输出。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  include linux 开关 信息