Linux驅動開發 -- 打開dev_dbg()

linux設備驅動調試,咱們在內核中看到內核使用dev_dbg來控制輸出信息,這個函數的實質是調用printk(KERN_DEBUG )來輸出打印信息。要打開這個開關須要下面兩步。linux


一、打開調試開關:你調試的文件中必然包含了,或者,後者包含了前者,在包含此頭文件以前,使用#define DEBUG 1 來打開調試開關:例如函數

#include調試

#includeorm

#includestring

#includeconsole

#define DEBUG    1form

#include終端


在linux/device.h文件中:static

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

    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是級別最低的。


二、修改文件kernel/printk文件


#define DEFAULT_MESSAGE_LOGLEVEL 4


#define MINIMUM_CONSOLE_LOGLEVEL 1

#define DEFAULT_CONSOLE_LOGLEVEL 8

其中DEFAULT_CONSOLE_LOGLEVEL 爲終端console輸出的最低級別,比這嚴重的都將輸出。原來該值爲7,則調試信息沒法輸出,修改成8則所有有輸出。

相關文章
相關標籤/搜索