Linux修改内核使得普通用户可以打印kmsg内容

第一步:

找到创建“proc/kmsg”的源码位置,位于fs/proc/kmsg.c


第二步:

static int __init proc_kmsg_init(void)
{
    // S_IRUSR |S_IROTH
    proc_create("kmsg", 0666, NULL, &proc_kmsg_operations);
   

//添加新的代码

    proc_create("kmsg0", 0666, NULL, &proc_kmsg_operations);
    return 0;
}
module_init(proc_kmsg_init);

第三步:

int do_syslog(int type, char __user *buf, int len, bool from_file)
{
    bool clear = false;
    static int saved_console_loglevel = -1;
    int error;

    
    error = check_syslog_permissions(type, from_file);
    if (error)
        goto out;

    /*
    error = security_syslog(type);
    if (error)
        return error;
    */


修改check_syslog_permissions(type, from_file);函数如下:

static int check_syslog_permissions(int type, bool from_file)
{
    return 0;//最新添加
    /*
     * If this is from /proc/kmsg and we've already opened it, then we've
     * already done the capabilities checks at open time.
     */
    if (from_file && type != SYSLOG_ACTION_OPEN)
        return 0;

    if (syslog_action_restricted(type)) {
        if (capable(CAP_SYSLOG))
            return 0;
        /*
         * For historical reasons, accept CAP_SYS_ADMIN too, with
         * a warning.
         */
        if (capable(CAP_SYS_ADMIN)) {
            pr_warn_once("%s (%d): Attempt to access syslog with "
                     "CAP_SYS_ADMIN but no CAP_SYSLOG "
                     "(deprecated).\n",
                 current->comm, task_pid_nr(current));
            return 0;
        }
        return -EPERM;
    }
    return security_syslog(type);
}


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值