文件打开时内核权限检查流程

本文详细介绍了在Linux内核4.15版本中,文件打开时的权限检查流程,涉及到DAC自主访问控制、do_sys_open、inode_permission及acl_permission_check等关键步骤。在DAC检查中,会根据文件所有者的uid、gid与当前进程的身份进行对比,决定是否允许访问,并可能涉及CAP_DAC_*能力的检查。同时,用户组信息可通过setgroups系统调用来设置。
摘要由CSDN通过智能技术生成

内核版本(4.15)

DAC:  Discretionary access control   自主访问控制 .  
DAC是传统的Linux的访问控制方式,DAC可以对文件、文件夹、共享资源等进行访问控制。 在DAC这种模型中,文件客体的所有者(或者管理员)负责管理访问控制。DAC使用了ACL(Access Control List,访问控制列表)来给非管理者用户提供不同的权限,而root用户对文件系统有完全自由的控制权。

do_sys_open
        do_filp_open
                get_empty_filp 
                        const struct cred *cred = current_cred();
                        f->f_cred = get_cred(cred);   // 当前进程的 cred赋值给打开的文件句柄
                path_openat
                        link_path_walk
                                may_lookup
                                        inode_permission
                                                __inode_permission
                                                        do_inode_permission
                                                                generic_permission
     

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值