提交 b77b0646 编写于 作者: A Al Viro

[PATCH] pass MAY_OPEN to vfs_permission() explicitly

... and get rid of the last "let's deduce mask from nameidata->flags"
bit.
Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
上级 a110343f
...@@ -118,7 +118,7 @@ asmlinkage long sys_uselib(const char __user * library) ...@@ -118,7 +118,7 @@ asmlinkage long sys_uselib(const char __user * library)
if (!S_ISREG(nd.path.dentry->d_inode->i_mode)) if (!S_ISREG(nd.path.dentry->d_inode->i_mode))
goto exit; goto exit;
error = vfs_permission(&nd, MAY_READ | MAY_EXEC); error = vfs_permission(&nd, MAY_READ | MAY_EXEC | MAY_OPEN);
if (error) if (error)
goto exit; goto exit;
...@@ -666,7 +666,7 @@ struct file *open_exec(const char *name) ...@@ -666,7 +666,7 @@ struct file *open_exec(const char *name)
struct inode *inode = nd.path.dentry->d_inode; struct inode *inode = nd.path.dentry->d_inode;
file = ERR_PTR(-EACCES); file = ERR_PTR(-EACCES);
if (S_ISREG(inode->i_mode)) { if (S_ISREG(inode->i_mode)) {
int err = vfs_permission(&nd, MAY_EXEC); int err = vfs_permission(&nd, MAY_EXEC | MAY_OPEN);
file = ERR_PTR(err); file = ERR_PTR(err);
if (!err) { if (!err) {
file = nameidata_to_filp(&nd, file = nameidata_to_filp(&nd,
......
...@@ -263,12 +263,7 @@ int permission(struct inode *inode, int mask, struct nameidata *nd) ...@@ -263,12 +263,7 @@ int permission(struct inode *inode, int mask, struct nameidata *nd)
/* Ordinary permission routines do not understand MAY_APPEND. */ /* Ordinary permission routines do not understand MAY_APPEND. */
if (inode->i_op && inode->i_op->permission) { if (inode->i_op && inode->i_op->permission) {
int extra = 0; retval = inode->i_op->permission(inode, mask);
if (nd) {
if (nd->flags & LOOKUP_OPEN)
extra |= MAY_OPEN;
}
retval = inode->i_op->permission(inode, mask | extra);
if (!retval) { if (!retval) {
/* /*
* Exec permission on a regular file is denied if none * Exec permission on a regular file is denied if none
...@@ -292,7 +287,7 @@ int permission(struct inode *inode, int mask, struct nameidata *nd) ...@@ -292,7 +287,7 @@ int permission(struct inode *inode, int mask, struct nameidata *nd)
return retval; return retval;
return security_inode_permission(inode, return security_inode_permission(inode,
mask & (MAY_READ|MAY_WRITE|MAY_EXEC), nd); mask & (MAY_READ|MAY_WRITE|MAY_EXEC));
} }
/** /**
...@@ -492,7 +487,7 @@ static int exec_permission_lite(struct inode *inode, ...@@ -492,7 +487,7 @@ static int exec_permission_lite(struct inode *inode,
return -EACCES; return -EACCES;
ok: ok:
return security_inode_permission(inode, MAY_EXEC, nd); return security_inode_permission(inode, MAY_EXEC);
} }
/* /*
...@@ -1692,7 +1687,7 @@ struct file *do_filp_open(int dfd, const char *pathname, ...@@ -1692,7 +1687,7 @@ struct file *do_filp_open(int dfd, const char *pathname,
int will_write; int will_write;
int flag = open_to_namei_flags(open_flag); int flag = open_to_namei_flags(open_flag);
acc_mode = ACC_MODE(flag); acc_mode = MAY_OPEN | ACC_MODE(flag);
/* O_TRUNC implies we need access checks for write permissions */ /* O_TRUNC implies we need access checks for write permissions */
if (flag & O_TRUNC) if (flag & O_TRUNC)
......
...@@ -1362,7 +1362,7 @@ struct security_operations { ...@@ -1362,7 +1362,7 @@ struct security_operations {
struct inode *new_dir, struct dentry *new_dentry); struct inode *new_dir, struct dentry *new_dentry);
int (*inode_readlink) (struct dentry *dentry); int (*inode_readlink) (struct dentry *dentry);
int (*inode_follow_link) (struct dentry *dentry, struct nameidata *nd); int (*inode_follow_link) (struct dentry *dentry, struct nameidata *nd);
int (*inode_permission) (struct inode *inode, int mask, struct nameidata *nd); int (*inode_permission) (struct inode *inode, int mask);
int (*inode_setattr) (struct dentry *dentry, struct iattr *attr); int (*inode_setattr) (struct dentry *dentry, struct iattr *attr);
int (*inode_getattr) (struct vfsmount *mnt, struct dentry *dentry); int (*inode_getattr) (struct vfsmount *mnt, struct dentry *dentry);
void (*inode_delete) (struct inode *inode); void (*inode_delete) (struct inode *inode);
...@@ -1628,7 +1628,7 @@ int security_inode_rename(struct inode *old_dir, struct dentry *old_dentry, ...@@ -1628,7 +1628,7 @@ int security_inode_rename(struct inode *old_dir, struct dentry *old_dentry,
struct inode *new_dir, struct dentry *new_dentry); struct inode *new_dir, struct dentry *new_dentry);
int security_inode_readlink(struct dentry *dentry); int security_inode_readlink(struct dentry *dentry);
int security_inode_follow_link(struct dentry *dentry, struct nameidata *nd); int security_inode_follow_link(struct dentry *dentry, struct nameidata *nd);
int security_inode_permission(struct inode *inode, int mask, struct nameidata *nd); int security_inode_permission(struct inode *inode, int mask);
int security_inode_setattr(struct dentry *dentry, struct iattr *attr); int security_inode_setattr(struct dentry *dentry, struct iattr *attr);
int security_inode_getattr(struct vfsmount *mnt, struct dentry *dentry); int security_inode_getattr(struct vfsmount *mnt, struct dentry *dentry);
void security_inode_delete(struct inode *inode); void security_inode_delete(struct inode *inode);
...@@ -2021,8 +2021,7 @@ static inline int security_inode_follow_link(struct dentry *dentry, ...@@ -2021,8 +2021,7 @@ static inline int security_inode_follow_link(struct dentry *dentry,
return 0; return 0;
} }
static inline int security_inode_permission(struct inode *inode, int mask, static inline int security_inode_permission(struct inode *inode, int mask)
struct nameidata *nd)
{ {
return 0; return 0;
} }
......
...@@ -211,8 +211,7 @@ static int cap_inode_follow_link(struct dentry *dentry, ...@@ -211,8 +211,7 @@ static int cap_inode_follow_link(struct dentry *dentry,
return 0; return 0;
} }
static int cap_inode_permission(struct inode *inode, int mask, static int cap_inode_permission(struct inode *inode, int mask)
struct nameidata *nd)
{ {
return 0; return 0;
} }
......
...@@ -429,11 +429,11 @@ int security_inode_follow_link(struct dentry *dentry, struct nameidata *nd) ...@@ -429,11 +429,11 @@ int security_inode_follow_link(struct dentry *dentry, struct nameidata *nd)
return security_ops->inode_follow_link(dentry, nd); return security_ops->inode_follow_link(dentry, nd);
} }
int security_inode_permission(struct inode *inode, int mask, struct nameidata *nd) int security_inode_permission(struct inode *inode, int mask)
{ {
if (unlikely(IS_PRIVATE(inode))) if (unlikely(IS_PRIVATE(inode)))
return 0; return 0;
return security_ops->inode_permission(inode, mask, nd); return security_ops->inode_permission(inode, mask);
} }
int security_inode_setattr(struct dentry *dentry, struct iattr *attr) int security_inode_setattr(struct dentry *dentry, struct iattr *attr)
......
...@@ -2624,12 +2624,11 @@ static int selinux_inode_follow_link(struct dentry *dentry, struct nameidata *na ...@@ -2624,12 +2624,11 @@ static int selinux_inode_follow_link(struct dentry *dentry, struct nameidata *na
return dentry_has_perm(current, NULL, dentry, FILE__READ); return dentry_has_perm(current, NULL, dentry, FILE__READ);
} }
static int selinux_inode_permission(struct inode *inode, int mask, static int selinux_inode_permission(struct inode *inode, int mask)
struct nameidata *nd)
{ {
int rc; int rc;
rc = secondary_ops->inode_permission(inode, mask, nd); rc = secondary_ops->inode_permission(inode, mask);
if (rc) if (rc)
return rc; return rc;
......
...@@ -522,8 +522,7 @@ static int smack_inode_rename(struct inode *old_inode, ...@@ -522,8 +522,7 @@ static int smack_inode_rename(struct inode *old_inode,
* *
* Returns 0 if access is permitted, -EACCES otherwise * Returns 0 if access is permitted, -EACCES otherwise
*/ */
static int smack_inode_permission(struct inode *inode, int mask, static int smack_inode_permission(struct inode *inode, int mask)
struct nameidata *nd)
{ {
/* /*
* No permission to check. Existence test. Yup, it's there. * No permission to check. Existence test. Yup, it's there.
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册