echo 8 > /proc/sys/kernel/printk
#cat /proc/sys/kernel/printk
8 4 1 7
上面显示的4个数据分别对应控制台日志级别(console_loglevel)、默认的消息日志级别、最低的控制台日志级别和默认的控制台日志级别。
当日志级别小于console_loglevel时,消息才能显示出来。
printk的日志级别定义如下(在linux26/includelinux/kernel.h中):
#defineKERN_EMERG"<0>"/*紧急事件消息,系统崩溃之前提示,表示系统不可用*/ #defineKERN_ALERT"<1>"/*报告消息,表示必须立即采取措施*/ #defineKERN_CRIT"<2>"/*临界条件,通常涉及严重的硬件或软件操作失败*/ #defineKERN_ERR"<3>"/*错误条件,驱动程序常用KERN_ERR来报告硬件的错误*/ #defineKERN_WARNING"<4>"/*警告条件,对可能出现问题的情况进行警告*/ #defineKERN_NOTICE"<5>"/*正常但又重要的条件,用于提醒。常用于与安全相关的消息*/ #defineKERN_INFO"<6>"/*提示信息,如驱动程序启动时,打印硬件信息*/ #defineKERN_DEBUG"<7>"/*调试级别的消息*/
extern int console_printk[];
#define console_loglevel (console_printk[0]) #define default_message_loglevel (console_printk[1]) #define minimum_console_loglevel (console_printk[2]) #define default_console_loglevel (console_printk[3])
|
日志级别的范围是0~7,没有指定日志级别的printk语句默认采用的级别是 DEFAULT_ MESSAGE_LOGLEVEL,其定义列出如下(在linux26/kernel/printk.c中):