内核打印printk优先级
来源:互联网 发布:lte网络优化工程师初级 编辑:程序博客网 时间:2024/05/11 01:11
printk是内核态信息打印函数,功能和比准C库的printf类似。
printk还有信息打印级别。
函数原型:
int printk(const char *fmt, ...)
需要的头文件:
#include<linux/kernel.h>
消息打印级别:
fmt----消息级别:
#defineKERN_EMERG
#defineKERN_ALERT
#defineKERN_CRIT
#defineKERN_ERR
#define KERN_WARNING
#defineKERN_NOTICE
#defineKERN_INFO
#defineKERN_DEBUG
不同级别使用不同字符串表示,数字越小,级别越高。
printk输出跟输出的日志级别有关系,当输出日志级别比控制台的级别高时,就会显示在控制台上,当比控制台低时,则会记录在/var/log/message中.但是当系统同时运行了klogd和syslogd时,都追加到/var/log/message.在/proc/sys/kernel/printk文件中,前两个整数为当前的日志级别和默认的日志级别(默认的日志级别即为printk的输出级别).
注意:
需要开启klogd和syslogd服务才能正常输出。通过klogd可以改变系统消息输出级别。
(1)
printk是内核输出,在终端是看不见的。
不管你可能怎么想,printk()
并不是设计用来同用户交互的,虽然我们在hello-1就是出于这样的目的使用它!它实际上是为内核提供日志功能,记录内核信息或用来给出警告。因此,每个printk()
声明都会带一个优先级,就像你看到的<1>和KERN_ALERT 那样。内核总共定义了八个优先级的宏, 所以你不必使用晦涩的数字代码,并且你可以从文件 linux/kernel.h查看这些宏和它们的意义。如果你不指明优先级,默认的优先级DEFAULT_MESSAGE_LOGLEVEL将被采用。
阅读一下这些优先级的宏。头文件同时也描述了每个优先级的意义。在实际中, 使用宏而不要使用数字,就像<4>。总是使用宏,就像KERN_WARNING。
当优先级低于intconsole_loglevel,信息将直接打印在你的终端上。如果同时syslogd和klogd都在运行,信息也同时添加在文件/var/log/messages,而不管是否显示在控制台上与否。我们使用像KERN_ALERT这样的高优先级,来确保printk()
将信息输出到控制台而不是只是添加到日志文件中。 当你编写真正的实用的模块时,你应该针对可能遇到的情况使用合 适的优先级。
- 内核打印printk优先级
- printk与内核日志打印优先级设置
- Printk打印优先级设定
- 内核级打印Printk
- linux内核打印--printk
- 内核打印函数printk
- 手动调整内核printk打印级别 && 内核模块初始化入口函数的优先级
- 内核printk打印级别设置
- 设置内核printk打印级别
- Linux内核printk打印格式
- 禁止内核打印内核信息(printk)
- 内核中的printk, <0>的优先级最高,<7>优先级最低
- Linux内核打印函数printk的使用说明
- 手动调整内核printk打印级别
- Linux内核打印函数printk的使用说明 .
- 手动调整内核printk打印级别
- 调整内核printk的打印级别
- linux内核打印的各种设置-----printk
- ubuntu 12.04 build android的问题
- u-boot2011.09启动内核分析
- KMP字符串匹配算法
- Dell推ARM架构服务器 未来发展迅猛
- uboot中mkconfig详细分析-- 转载
- 内核打印printk优先级
- junit批量测试
- 求两个数的最大公约数和最小公倍数
- dump命令1——ITL文件dump
- mfc 为对话框工程添加工具条时,实现工具条的按下状态与菜单标记的同步实例
- 如何往SqlServer下载到vfp的临时表添加字段问题?(已解决!分享!)
- flex做的一个实用的广告滚动效果
- UNIX/Linux:向进程发信号的3种方式
- java实用总结日期/数字