Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3010234
  • 博文数量: 674
  • 博客积分: 17881
  • 博客等级: 上将
  • 技术积分: 4849
  • 用 户 组: 普通用户
  • 注册时间: 2010-03-17 10:15
文章分类

全部博文(674)

文章存档

2013年(34)

2012年(146)

2011年(197)

2010年(297)

分类: LINUX

2013-03-05 11:33:04

linux设备驱动调试,我们在内核中看到内核使用dev_dbg来控制输出信息,这个函数的实质是调用 printk(KERN_DEBUG )来输出打印信息。要打开这个开关需要下面两步。
     1、打开调试开关:你调试的文件中必然包含了,或者《linux /paltforam_device.h》,后者包含了前者,在包含此头文件之前,使用#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则全部有输出。

 

可能比较关键的是DEBUG需要在头文件之前定义!!!

【1】配置Kconfig,添加要调试驱动模块的DDEBUG选项,如

kernel_imx\drivers\mxc\pmic\mc13892\Kconfig

config MXC_PMIC_DEBUG
 bool "Support MXC PMIC DEBUG"
 depends on MXC_PMIC
 

【2】配置Makefile,添加编译支持驱动模块 EXTRA_CFLAGS  += -DDEBUG ,如

kernel_imx\drivers\mxc\pmic\core\Makefile

ifeq ($(CONFIG_MXC_PMIC_DEBUG),y)
 EXTRA_CFLAGS  += -DDEBUG
endif

 

【3】配置内核,使支持动态调试

make menuconfig

  | |        Kernel hacking  --->

  | |    [*] Tracers  --->

  | |          [*]   Trace max stack

  | |    [*] Enable dynamic printk() support

 

  | |        Device Drivers  --->

  | |            MXC support drivers  --->

  | |                MXC PMIC support  ---> 
  | |                       [*] Support MXC PMIC DEBUG

 

【4】重烧内核启动后,改变控制台debug消息显示级别,可以打印printk(DEBUG ...)信息
echo > /proc/sys/kernel/printk "8"


http://blog.sina.com.cn/s/blog_a53598e601015tsy.html

阅读(4337) | 评论(0) | 转发(1) |
0

上一篇:container_of分析

下一篇:Python完全新手教程

给主人留下些什么吧!~~