为了确认内核打印等级以及prink 参数对打印的分级,在led驱动初始化代码【以及exit出口】加入如下代码。

每次insmod 、rmmod led模块时,根据打印等级的设置,得到不同的打印结果:

  1. static int __init s3c24xx_leds_init()
  2. {
  3.     int ret ;
  4.     int minor = 0 ;
  5.  
  6.    printk(KERN_EMERG " 1111111 KERN_EMERG\n");
  7.    printk(KERN_ALERT " 2222 KERN_ALERT\n");
  8.    printk(KERN_CRIT " 3333333 KERN_CRIT\n");
  9.    printk(KERN_ERR " 44444444 KERN_ERR\n");
  10.    printk(KERN_WARNING " 55555 KERN_WARNING\n");
  11.    printk(KERN_NOTICE " 66666 KERN_NOTICE\n");
  12.    printk(KERN_INFO " 77777 KERN_INFO\n");
  13.    printk(KERN_DEBUG " 888888 KERN_DEBUG\n");
  14.    printk(" 9999 no_fix\n");
  15. }

操作:

一次性地设置编译内核源码时默认的打印级数:【它们在kernel/printk.c中定义】

echo 8 4 1 7 > /proc/sys/kernel/printk

8. 为KERN_DEBUG

# echo 8 4 1 7 > /proc/sys/kernel/printk

# insmod myleds_new.ko

1111111 KERN_EMERG

2222 KERN_ALERT

3333333 KERN_CRIT

44444444 KERN_ERR

55555 KERN_WARNING

66666 KERN_NOTICE

77777 KERN_INFO

888888 KERN_DEBUG

9999 no_fix

7. 为默认

#cat /proc/sys/kernel/printk

  #7 4 1 7

打印结果:

111111 KERN_EMERG

2222 KERN_ALERT

3333333 KERN_CRIT

44444444 KERN_ERR

55555 KERN_WARNING

66666 KERN_NOTICE

77777 KERN_INFO

9999 no_fix

6.

# echo 6 4 1 7 > /proc/sys/kernel/printk

# insmod myleds_new.ko

1111111 KERN_EMERG

2222 KERN_ALERT

3333333 KERN_CRIT

44444444 KERN_ERR

55555 KERN_WARNING

66666 KERN_NOTICE

9999 no_fix

5.

# echo 5 1 4 7 > /proc/sys/kernel/printk

# rmmod myleds_new.ko

1111111 KERN_EMERG

2222 KERN_ALERT

3333333 KERN_CRIT

44444444 KERN_ERR

55555 KERN_WARNING

9999 no_fix

4.

# echo 4 4 1 7 > /proc/sys/kernel/printk

# insmod myleds_new.ko

1111111 KERN_EMERG

2222 KERN_ALERT

3333333 KERN_CRIT

44444444 KERN_ERR

3.

# echo 3 4 1 7 > /proc/sys/kernel/printk

# rmmod myleds_new.ko

1111111 KERN_EMERG

2222 KERN_ALERT

3333333 KERN_CRIT

2.

# echo 2 4 1 7 > /proc/sys/kernel/printk

# insmod myleds_new.ko

1111111 KERN_EMERG

2222 KERN_ALERT

1.

# echo 1 4 1 7 > /proc/sys/kernel/printk

# insmod myleds_new.ko

1111111 KERN_EMERG

分析:

手动设置打印等级为5 1 4 7 及其以上时(重启会失效),会打印KERN_WARNING 以及没有加格式参数的printk打印信息。

KERN_DEBUG优先级最低。

KERN_EMERG优先级最高。

其它的,按级数递推。

假设要默认打印无fix的printk,

kernel/printk.c

#define DEFAULT_CONSOLE_LOGLEVEL (XX); xx >=5

假设要默认打印KERN_DEBUG信息

#define DEFAULT_CONSOLE_LOGLEVEL (XX); xx=8

//上述操作,一次性的可以使用echo xx 4 1 7 > /proc/sys/kernel/printk

源代码参考:

kernel/printk.c

  1. /* printk's without a loglevel use this.. */
  2. #define DEFAULT_MESSAGE_LOGLEVEL 4 /* KERN_WARNING */
  3.  
  4. /* We show everything that is MORE important than this.. */
  5. #define MINIMUM_CONSOLE_LOGLEVEL 1 /* Minimum loglevel we let people use */
  6. #define DEFAULT_CONSOLE_LOGLEVEL 7 /* anything MORE serious than KERN_DEBUG */
  7.  
  8. DECLARE_WAIT_QUEUE_HEAD(log_wait);
  9.  
  10. int console_printk[4] = {
  11.    DEFAULT_CONSOLE_LOGLEVEL, /* console_loglevel */
  12.    DEFAULT_MESSAGE_LOGLEVEL, /* default_message_loglevel */
  13.    MINIMUM_CONSOLE_LOGLEVEL, /* minimum_console_loglevel */
  14.    DEFAULT_CONSOLE_LOGLEVEL, /* default_console_loglevel */
  15. };

Include/linux/kernel.h

  1. #define KERN_EMERG "<0>" /* system is unusable */
  2. #define KERN_ALERT "<1>" /* action must be taken immediately */
  3. #define KERN_CRIT "<2>" /* critical conditions */
  4. #define KERN_ERR "<3>" /* error conditions */
  5. #define KERN_WARNING "<4>" /* warning conditions */
  6. #define KERN_NOTICE "<5>" /* normal but significant condition */
  7. #define KERN_INFO "<6>" /* informational */
  8. #define KERN_DEBUG "<7>" /* debug-level messages */

内核printk打印等级的更多相关文章

  1. 终端下更改printk打印级别

    如何去更改printk的打印级别? 1.查看当前控制台的打印级别 # cat /proc/sys/kernel/printk 该文件有4个数字值,它们根据日志记录消息的重要性,定义将其发送到何处,上面 ...

  2. C语言:类似linux内核的分等级DEBUG宏(打印宏)

    总结几种log打印printf函数的宏定义 http://blog.chinaunix.net/uid-20564848-id-73402.html #include <stdio.h> ...

  3. 更改printk打印级别

    1.查看当前控制台的打印级别 cat /proc/sys/kernel/printk 4    4    1    7 其中第一个"4"表示内核打印函数printk的打印级别,只有 ...

  4. 41.Linux应用调试-修改内核来打印用户态的oops

    1.在之前第36章里,我们学习了通过驱动的oops定位错误代码行 第36章的oops代码如下所示: Unable to handle kernel paging request at //无法处理内核 ...

  5. 限制printk打印频率函数printk_ratelimit【转】

    转自:http://blog.csdn.net/lkkey80/article/details/45190095 版权声明:博文地址 http://blog.csdn.net/lkkey80?view ...

  6. 更改printk打印级别【转】

    本文转载自:http://blog.csdn.net/weed_hz/article/details/8949140 1.查看当前控制台的打印级别 cat /proc/sys/kernel/print ...

  7. printk打印级别

    默认级别 # cat /proc/sys/kernel/printk 4 4 1 7 分别是:控制台日志级别.默认的消息日志级别.最低的控制台日志级别和默认的控制台日志级别 举例 # echo 0 & ...

  8. 调整busybox中syslogd读取内核printk信息长度

    busybox 默认读取内核printk信息长度256, 通过CONFIG_FEATURE_SYSLOGD_READ_BUFFER_SIZE宏可调整, 如下: #cd busybox-1.21.1#m ...

  9. Nginx之旅系列 - Nginx日志功能 PK Linux内核printk

    题记:Nginx之旅系列是用来记录Nginx从使用到源码学习的点点滴滴,分享学习Nginx的快乐 Nginx 首页: http://nginx.org/ Nginx日志功能 PK Linux内核pri ...

随机推荐

  1. Spring配置机制的优缺点 - Annotation vs XML

    转自 http://tianzongqi.iteye.com/blog/1458002 XML配置的优缺点: 优点: XML配置方式进一步降低了耦合,使得应用更加容易扩展,即使对配置文件进一步修改也不 ...

  2. Yii2.0中文开发向导——删除数据

    直接 model 删除 $model = User::find($id); $model->delete(); 带有条件的删除 $connection ->createCommand() ...

  3. Mongodb备份(mongodump)和恢复(mongorestore)

    1.备份: mongodump -d DbName -o /data/backup 2. 恢复: mongorestore -d newDB --drop data/backup/DbName/

  4. HDU 3584 Cube

    题目大意:给定一个体积为N*N*N立方体,每个单位小立方体A[x][y][z]里有一个值,初始值全部为0,我们可以对立方体进行一下两种操作: 0表示查询A[x][y][z]的奇偶性 1表示对子立方体的 ...

  5. SSH 配置日记

    1   注意struts2-spring-plugin.jar的导入.    Unable to load configuration. - action  异常.需要导入这个包 2  很久都跑不通的 ...

  6. [C++ Basic] Const 用法

    定义: const 主要用于声明常量.当常量为对象时,对象值不可改变:当常量为指针时,该指针不可移动或重新赋值,但我们可以通过它去修改该指针的指向对象的值(前提是无需移动指针的修改).所谓的形参.返回 ...

  7. Android 通过Dom, Sax, Pull解析网络xml数据

    这篇文章不是完全原创,XML解析的部分参考了 liuhe688 的文章.文章地址:http://blog.csdn.net/liuhe688/article/details/6415593 这是一个几 ...

  8. 看java源代码

    不会看JDK源代码,相当于没学过Java. 网上不容易找到一篇帮助我解决了如何在Eclipse下查看JDK源代码 的文章. 核心提示:在Eclipse中查看JDK类库的源代码!!! 设置: 1.点 w ...

  9. Ubuntu 12.10 安装JDK7

    1.首先到oracle下载上下载jdk-7u25-linux-i586.tar.gz 2.将jdk-7u25-linux-i586.tar.gz复制到/usr/lib/jvm/目录以下,这里假设没有j ...

  10. [置顶] 局部加权回归、最小二乘的概率解释、逻辑斯蒂回归、感知器算法——斯坦福ML公开课笔记3

    转载请注明:http://blog.csdn.net/xinzhangyanxiang/article/details/9113681 最近在看Ng的机器学习公开课,Ng的讲法循循善诱,感觉提高了不少 ...