zoukankan      html  css  js  c++  java
  • Linux驱动开发 -- 打开dev_dbg() 【转】

    转自:http://blog.chinaunix.net/uid-20672559-id-3383042.html

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

  • 相关阅读:
    Aop——面向切面编程
    认识界上最流行的Api框架——swagger
    手把手SSM框架实战
    面试题
    重新拾起JavaSE的日子
    使用IntelliJ IDEA创建第一个Maven项目
    Java面试必考题
    Vue项目——去哪网(首页部分)
    Vue项目的准备
    vue.js ③
  • 原文地址:https://www.cnblogs.com/sky-heaven/p/5729729.html
Copyright © 2011-2022 走看看