zoukankan      html  css  js  c++  java
  • 内核打印等级

    内核打印日志等级配置存放在/proc/sys/kernel/printk,默认6   4   1   7

    上面显示的4个数据分别对应:

    控制台日志级别:优先级高于该值的消息将被打印至控制台

    默认的消息日志级别:将用该优先级来打印没有优先级的消息

    最低的控制台日志级别:控制台日志级别可被设置的最小值(最高优先级)

    默认的控制台日志级别:控制台日志级别的缺省值

    数值越小,优先级越高

                    其实这四个值是在kernel/printk.c 中被定义的,如下:

    int console_printk[4] = {

                    DEFAULT_CONSOLE_LOGLEVEL,       /* console_loglevel */

                    DEFAULT_MESSAGE_LOGLEVEL,       /* default_message_loglevel */

                    MINIMUM_CONSOLE_LOGLEVEL,     /* minimum_console_loglevel */

                    DEFAULT_CONSOLE_LOGLEVEL,       /* default_console_loglevel */

    };

    内核通过printk() 输出的信息具有日志级别,日志级别是通过在printk() 输出的字符串前加一个带尖括号的整数来控制的,如printk("<6>Hello, world! ");。内核中共提供了八种不同的日志级别,在 linux/kernel.h 中有相应的宏对应。

    #define KERN_EMERG  "<0>"   /* systemis unusable */

    #define KERN_ALERT  "<1>"   /* actionmust be taken immediately */

    #define KERN_CRIT    "<2>"   /*critical conditions */

    #define KERN_ERR     "<3>"   /* errorconditions */

    #define KERN_WARNING "<4>"   /* warning conditions */

    #define KERN_NOTICE  "<5>"   /* normalbut significant */

    #define KERN_INFO    "<6>"   /*informational */

    #define KERN_DEBUG   "<7>"   /*debug-level messages */

    所以printk() 可以这样用:printk(KERN_INFO"Hello, world! ");。

    未指定日志级别的printk() 采用的默认级别是DEFAULT_MESSAGE_LOGLEVEL,这个宏在kernel/printk.c 中被定义为整数4,即对应KERN_WARNING。

    如果要想在内核启动过程中打印少的信息,就可以根据自己的需要在kernel/printk.c中修改以上数值,重新编译即可!

    /* printk's without a loglevel use this.. */

    #define DEFAULT_MESSAGE_LOGLEVEL 4 /* KERN_WARNING */


  • 相关阅读:
    mongodb 数据库操作--备份 还原 导出 导入
    括号匹配算法求解(用栈实现)
    最短路径(图中两点间最短路径)
    城市之间的最短总距离(最小生成树算法)
    简单的约瑟夫环算法
    动态数组排序实例
    折半查找算法
    对字符串进行快速排序(即字符数组排序)
    字符串数组排序的快速排序实现
    插入排序反序排序
  • 原文地址:https://www.cnblogs.com/enki-fang/p/8672204.html
Copyright © 2011-2022 走看看