printk
内核通过 printk() 输出的信息具有日志级别,日志级别是通过在 printk() 输出的字符串前加一个带尖括号的整数来控制的,如 printk("<6>Hello, world!/n");。内核中共提供了八种不同的日志级别,在 linux/kernel.h 中有相应的宏对应。
define KERN_EMERG "<0>" /* system is unusable */
define KERN_ALERT "<1>" /* action must be taken immediately */
define KERN_CRIT "<2>" /* critical conditions */
define KERN_ERR "<3>" /* error conditions */
define KERN_WARNING "<4>" /* warning conditions */
define KERN_NOTICE "<5>" /* normal but significant */
define KERN_INFO "<6>" /* informational */
define KERN_DEBUG "<7>" /* debug-level messages */
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>" 调试信息
从这里也可以看出他们的优先级是数值越小,其紧急和严重程度就越高。
CopyRight @Widic 2017
Mail:widicjane@163.com