一、Printk日志级别
(1)查看和设定控制台日志级别
cat /proc/sys/kernel/printk
4 4 1 7
第一个参数:当前控制台日志级别,小于4的日志可以被打印
第二个参数:默认的消息日志级别(即printk打印消息的时候未指定日志级别时候使用的级别)
第三个参数:最低的控制台日志级别
第四个参数:引导时默认的控制台日志级别
值越小,优先级越高
只有当printk的日志级别小于console_loglevel时,消息才能显示出来
通过下面命令修改控制台日志级别:
echo 7 > /proc/sys/kernel/printk
将控制台日志级别修改为7:
7 4 1 7
(2)忽略日志级别
Grub中添加ignore_loglevel可以忽略日志级别
static bool __read_mostly ignore_loglevel;
/*通过grub设置忽略log level*/
static int __init ignore_loglevel_setup(char *str)
{
ignore_loglevel = 1;
pr_info("debug: ignoring loglevel setting.\n");
return 0;
}
early_param("ignore_loglevel", ignore_loglevel_setup);
module_param(ignore_loglevel, bool, S_IRUGO | S_IWUSR);
MODULE_PARM_DESC(ignore_loglevel, "ignore loglevel setting, to"
"print all kernel messages to the console.");
二、Printk buff
kernel/printk/printk.c
(1)make menuconfig设置printk log buf的长度:
/*make menuconfig中配置CONFIG_LOG_BUF_SHIFT*/
#define __LOG_BUF_LEN (1 << CONFIG_LOG_BUF_SHIFT)
static char __log_buf[__LOG_BUF_LEN] __aligned(LOG_ALIGN);
static char *log_buf = __log_buf;
static u32 log_buf_len = __LOG_BUF_LEN;
make menuconfig
General setup
Kernel log buffer size
(18) Kernel log buffer size (16 => 64KB, 17 => 128KB)
(2)grub中设定log buf的长度,如果Grub设定的log buf长度大于kernel默认设置的长度,那么就按照grub设定的长度设定log buf的长度:log_buf_len = 10G
/* requested log_buf_len from kernel cmdline */
static unsigned long __initdata new_log_buf_len;
/* save requested log_buf_len since it's too early to process it */
static int __init log_buf_len_setup(char *str)
{
unsigned size = memparse(str, &str);
if (size)
size = roundup_pow_of_two(size);
/*log_buf_len是内核默认设置的log buf length
*如果grub中要求设置的log buf length>kernel默认设置的长度
*那么就需要重新设置log buf的长度
*/
if (size > log_buf_len)
new_log_buf_len = size;
return 0;
}
early_param("log_buf_len", log_buf_len_setup);
/*可以设定K,M,G级别的长度*/
log_buf_len=n[KMG]
Sets the size of the printk ring buffer, in bytes. n must be a power of two. The default
size is set in the kernel config file.
三、printk参考
1、https://www.ibm.com/developerworks/cn/linux/l-kernel-logging-apis/index.html