Linux进程的权限检查

34 篇文章 0 订阅 ¥299.90 ¥99.00

如何检查一个进程是否有权限使用驱动程序提供的服务能力?

/*以下的参数cap用来指定对当前进程进行检查的权能数值*/
static bool ns_capable_common(struct user_namespace *ns,
                  int cap,
                  unsigned int opts)
{
    int capable;
    /*内核再include/linux/capability.h中定义了多个权能数值,其中的
    cap_valid函数用来检查cap所表示的权能值是否在内核事先定义的权限范围之内*/
    if (unlikely(!cap_valid(cap))) {
        pr_crit("capable() called with invalid cap=%u\n", cap);
        BUG();
    }
    /*真正的权能检查,其中的宏current_cred用来获得当前进程的一个权能证书,展开就是
    current->cred*/
    capable = security_capable(current_cred(), ns, cap, opts);
    if (capable == 0) {
        /*如果进程具有指定的权能,那么函数将在当前进程的flag上设置PF_SUPERPRIV标志
        着一个超级用户的身份,同时返回1*/
        current->flags |= PF_SUPERPRIV;
        return true;
    }
    return false;
}

真正的权能检查在security_cap

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张帅峰_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值