修改kernel log level

提高kernel log level 有两种方法。
一种是通过bootloader传递参数给kernel,可以传的参数为debug和quiet。分别对应CONSOLE_LOGLEVEL_DEBUG 和 CONSOLE_LOGLEVEL_QUIET 两种level
static int __init debug_kernel(char *str)
{
    console_loglevel = CONSOLE_LOGLEVEL_DEBUG;
    return 0;
}

static int __init quiet_kernel(char *str)
{
    console_loglevel = CONSOLE_LOGLEVEL_QUIET;
    return 0;
}

early_param("debug", debug_kernel);
early_param("quiet", quiet_kernel);

第二中是通过proc文件系统修改.
echo 10       4       1      7 > /proc/sys/kernel/printk
上面这条语句可以同第一种通过bootloader传递debug达到一样的效果.
具体实现在sysctl.c 中
{
        .procname    = "printk",
        .data        = &console_loglevel,
        .maxlen        = 4*sizeof(int),
        .mode        = 0644,
        .proc_handler    = proc_dointvec,
}
int proc_dointvec(struct ctl_table *table, int write,
             void __user *buffer, size_t *lenp, loff_t *ppos)
{
    return do_proc_dointvec(table, write, buffer, lenp, ppos, NULL, NULL);
}
int proc_douintvec(struct ctl_table *table, int write,
             void __user *buffer, size_t *lenp, loff_t *ppos)
{
    return do_proc_dointvec(table, write, buffer, lenp, ppos,
                do_proc_douintvec_conv, NULL);
}
可见处理函数是do_proc_douintvec_conv
static int do_proc_douintvec_conv(bool *negp, unsigned long *lvalp,
                 int *valp,
                 int write, void *data)
{
    if (write) {
        if (*negp)
            return -EINVAL;
        *valp = *lvalp;
    } else {
        unsigned int val = *valp;
        *lvalp = (unsigned long)val;
    }
    return 0;
}
这里write=1,所以执行*valp = *lvalp;
而valp指向的是console_loglevel,而lvalp就是通过echo写入的值.
注意起data为console_loglevel,最终通过proc_handler 来修改console_loglevel的值.

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值