转载:http://blog.chinaunix.net/u1/38038/showart_1359825.html
linux设备驱动调试,我们在内核中看到内核使用dev_dbg来控制输出信息,这个函数的实质是调用printk(KERN_DEBUG
)来输出打印信息。要打开这个开关需要下面两步。
DEBUG 1 来打开调试开关:例如
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/clk.h>
#include <linux/module.h>
#define DEBUG
#include <linux/platform_device.h>
#define dev_printk(level, dev, format, arg...)
#ifdef DEBUG
#define dev_dbg(dev, format, arg...)
#else
static inline int __attribute__ ((format (printf, 2, 3)))
dev_dbg(struct device * dev, const char * fmt, ...)
{
}
#endif
但是这个打开了之后,也不能顺利的输出信息,原因是printk有默认的信息级别。
#define
#define
#define
#define
#define
#define
#define
#define
可以看到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则全部有输出。