linux 下面dev文件,Linux驱动开发 -- 打开dev_dbg()

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则全部有输出。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值