天天看點

如何控制核心列印級别

printk and console log level.

printk is used in kernel programming to print messages into the kernel logs.

The syntax of printk is

printk ("log level" "message", <arguments>);

The log levels decide the importance of the message being printed, kernel defines 8 log levels in the file printk.h

#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>"

We can see each log level corresponds to a number and the lower the number higher the importance of the message.

The levels are useful in deciding what should be displayed to the user on the console and what should not be.

Every console has log level called as the the console log level and any message with a log level number lesser than the console log level gets displayed on the console, and other messages which have a log level number higher or equal to the console log level are logged in the kernel log which can be looked into using the command "dmesg".

The console loglevel can be found by looking into the file /proc/sys/kernel/printk

$ cat /proc/sys/kernel/printk

4 4 1 7

The first number in the output is the console log level, the second is the default log level, third is the minimum log level and fourth is the maximum log level.

Log level 4 corresponds to KERN_WARNING. Thus all the messages with log levels 3,2,1 and 0 will get displayed on the screen as well as logged and the messages with log level 4,5,6,7 only get logged and can be viewed using "dmesg".

The console log level can be changed by writing into the proc entry

$ echo "6" > /proc/sys/kernel/printk

$ cat /proc/sys/kernel/printk

6 4 1 7

Now the console log level is set to 6, which is KERN_INFO.

可以用dmesg -n level 設定printk輸出級别。

繼續閱讀