zoukankan      html  css  js  c++  java
  • printk 驱动调试

                                                                                                    驱动的调试,printk()添加调试信息

    printk相当于printf的孪生姐妹,它们一个运行在用户态,另一个则在内核态。

    需要包含<linux/device.h>或者<linux/platform_device.h>

    在包含上述头文件之前需要使用#define DEBUG 1 来打开调试开关

    原型:int printk(const char * fmt,…);

    用printk,内核会根据日志级别,可能把消息打印到当前控制台上。这些消息正常输出的前提是:日志输出级别小于console_loglevel(在内核中数字越小优先级越高)。

    没有指定日志级别的printk语句默认采用的级别是 DEFAULT_ MESSAGE_LOGLEVEL(这个默认级别一般为<4>,即与KERN_WARNING在一个级别上),其定义在linux26/kernel/printk.c中可以找到.
    日志级别一共有8个级别,printk的日志级别定义如下(在include/linux/kernel.h中):
      #define KERN_EMERG 0/*紧急事件消息,系统崩溃之前提示,表示系统不可用*/
      #define KERN_ALERT 1/*报告消息,表示必须立即采取措施*/
      #define KERN_CRIT 2/*临界条件,通常涉及严重的硬件或软件操作失败*/
        #define KERN_ERR 3/*错误条件,驱动程序常用KERN_ERR来报告硬件的错误*/
      #define KERN_WARNING 4/*警告条件,对可能出现问题的情况进行警告*/
      #define KERN_NOTICE 5/*正常但又重要的条件,用于提醒*/
      #define KERN_INFO 6/*提示信息,如驱动程序启动时,打印硬件信息*/
      #define KERN_DEBUG 7/*调试级别的消息*/

    其实printk始终是能输出信息的,只不过不一定是到了终端上。我们可以去
      /var/log/messages这个文件里面去查看。
      如果klogd没有运行,消息不会传递到用户空间,只能查看/proc/kmsg
      通过读写/proc/sys/kernel/printk文件可读取和修改控制台的日志级别。查看这个文件的方法如下:
      #cat /proc/sys/kernel/printk 6 4 1 7
      上面显示的4个数据分别对应控制台日志级别、默认的消息日志级别、最低的控制台日志级别和默认的控制台日志级别。
      可用下面的命令设置当前日志级别:
      # echo 8 > /proc/sys/kernel/printk
      这样所有级别<8,(0-7)的消息都可以显示在控制台上.

  • 相关阅读:
    form表单介绍
    if条件语句
    表格.html
    列表.html
    CSS Js链接HTML文件
    DQL
    mysql介绍
    第一次接触mysql
    逻辑运算、作用域问题、DOM
    Js数据类型具体分析
  • 原文地址:https://www.cnblogs.com/thinkinglife/p/4960415.html
Copyright © 2011-2022 走看看