Printk相关总结归纳

一、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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值