提交 2e149670 编写于 作者: S Serge E. Hallyn 提交者: Linus Torvalds

userns: rename is_owner_or_cap to inode_owner_or_capable

And give it a kernel-doc comment.

[akpm@linux-foundation.org: btrfs changed in linux-next]
Signed-off-by: NSerge E. Hallyn <serge.hallyn@canonical.com>
Cc: "Eric W. Biederman" <ebiederm@xmission.com>
Cc: Daniel Lezcano <daniel.lezcano@free.fr>
Acked-by: NDavid Howells <dhowells@redhat.com>
Cc: James Morris <jmorris@namei.org>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 e795b717
...@@ -323,7 +323,7 @@ static int v9fs_xattr_set_acl(struct dentry *dentry, const char *name, ...@@ -323,7 +323,7 @@ static int v9fs_xattr_set_acl(struct dentry *dentry, const char *name,
if (S_ISLNK(inode->i_mode)) if (S_ISLNK(inode->i_mode))
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
if (value) { if (value) {
/* update the cached acl value */ /* update the cached acl value */
......
...@@ -59,7 +59,7 @@ int inode_change_ok(const struct inode *inode, struct iattr *attr) ...@@ -59,7 +59,7 @@ int inode_change_ok(const struct inode *inode, struct iattr *attr)
/* Make sure a caller can chmod. */ /* Make sure a caller can chmod. */
if (ia_valid & ATTR_MODE) { if (ia_valid & ATTR_MODE) {
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
/* Also check the setgid bit! */ /* Also check the setgid bit! */
if (!in_group_p((ia_valid & ATTR_GID) ? attr->ia_gid : if (!in_group_p((ia_valid & ATTR_GID) ? attr->ia_gid :
...@@ -69,7 +69,7 @@ int inode_change_ok(const struct inode *inode, struct iattr *attr) ...@@ -69,7 +69,7 @@ int inode_change_ok(const struct inode *inode, struct iattr *attr)
/* Check for setting the inode time. */ /* Check for setting the inode time. */
if (ia_valid & (ATTR_MTIME_SET | ATTR_ATIME_SET | ATTR_TIMES_SET)) { if (ia_valid & (ATTR_MTIME_SET | ATTR_ATIME_SET | ATTR_TIMES_SET)) {
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
} }
......
...@@ -170,7 +170,7 @@ static int btrfs_xattr_acl_set(struct dentry *dentry, const char *name, ...@@ -170,7 +170,7 @@ static int btrfs_xattr_acl_set(struct dentry *dentry, const char *name,
int ret; int ret;
struct posix_acl *acl = NULL; struct posix_acl *acl = NULL;
if (!is_owner_or_cap(dentry->d_inode)) if (!inode_owner_or_capable(dentry->d_inode))
return -EPERM; return -EPERM;
if (!IS_POSIXACL(dentry->d_inode)) if (!IS_POSIXACL(dentry->d_inode))
......
...@@ -158,7 +158,7 @@ static int btrfs_ioctl_setflags(struct file *file, void __user *arg) ...@@ -158,7 +158,7 @@ static int btrfs_ioctl_setflags(struct file *file, void __user *arg)
FS_SYNC_FL | FS_DIRSYNC_FL)) FS_SYNC_FL | FS_DIRSYNC_FL))
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EACCES; return -EACCES;
mutex_lock(&inode->i_mutex); mutex_lock(&inode->i_mutex);
...@@ -1077,7 +1077,7 @@ static noinline int btrfs_ioctl_subvol_setflags(struct file *file, ...@@ -1077,7 +1077,7 @@ static noinline int btrfs_ioctl_subvol_setflags(struct file *file,
if (flags & ~BTRFS_SUBVOL_RDONLY) if (flags & ~BTRFS_SUBVOL_RDONLY)
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EACCES; return -EACCES;
down_write(&root->fs_info->subvol_sem); down_write(&root->fs_info->subvol_sem);
......
...@@ -406,7 +406,7 @@ ext2_xattr_set_acl(struct dentry *dentry, const char *name, const void *value, ...@@ -406,7 +406,7 @@ ext2_xattr_set_acl(struct dentry *dentry, const char *name, const void *value,
return -EINVAL; return -EINVAL;
if (!test_opt(dentry->d_sb, POSIX_ACL)) if (!test_opt(dentry->d_sb, POSIX_ACL))
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (!is_owner_or_cap(dentry->d_inode)) if (!inode_owner_or_capable(dentry->d_inode))
return -EPERM; return -EPERM;
if (value) { if (value) {
......
...@@ -39,7 +39,7 @@ long ext2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) ...@@ -39,7 +39,7 @@ long ext2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
if (ret) if (ret)
return ret; return ret;
if (!is_owner_or_cap(inode)) { if (!inode_owner_or_capable(inode)) {
ret = -EACCES; ret = -EACCES;
goto setflags_out; goto setflags_out;
} }
...@@ -89,7 +89,7 @@ long ext2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) ...@@ -89,7 +89,7 @@ long ext2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
case EXT2_IOC_GETVERSION: case EXT2_IOC_GETVERSION:
return put_user(inode->i_generation, (int __user *) arg); return put_user(inode->i_generation, (int __user *) arg);
case EXT2_IOC_SETVERSION: case EXT2_IOC_SETVERSION:
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
ret = mnt_want_write(filp->f_path.mnt); ret = mnt_want_write(filp->f_path.mnt);
if (ret) if (ret)
...@@ -115,7 +115,7 @@ long ext2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) ...@@ -115,7 +115,7 @@ long ext2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
if (!test_opt(inode->i_sb, RESERVATION) ||!S_ISREG(inode->i_mode)) if (!test_opt(inode->i_sb, RESERVATION) ||!S_ISREG(inode->i_mode))
return -ENOTTY; return -ENOTTY;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EACCES; return -EACCES;
if (get_user(rsv_window_size, (int __user *)arg)) if (get_user(rsv_window_size, (int __user *)arg))
......
...@@ -435,7 +435,7 @@ ext3_xattr_set_acl(struct dentry *dentry, const char *name, const void *value, ...@@ -435,7 +435,7 @@ ext3_xattr_set_acl(struct dentry *dentry, const char *name, const void *value,
return -EINVAL; return -EINVAL;
if (!test_opt(inode->i_sb, POSIX_ACL)) if (!test_opt(inode->i_sb, POSIX_ACL))
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
if (value) { if (value) {
......
...@@ -38,7 +38,7 @@ long ext3_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) ...@@ -38,7 +38,7 @@ long ext3_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
unsigned int oldflags; unsigned int oldflags;
unsigned int jflag; unsigned int jflag;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EACCES; return -EACCES;
if (get_user(flags, (int __user *) arg)) if (get_user(flags, (int __user *) arg))
...@@ -123,7 +123,7 @@ long ext3_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) ...@@ -123,7 +123,7 @@ long ext3_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
__u32 generation; __u32 generation;
int err; int err;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
err = mnt_want_write(filp->f_path.mnt); err = mnt_want_write(filp->f_path.mnt);
...@@ -192,7 +192,7 @@ long ext3_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) ...@@ -192,7 +192,7 @@ long ext3_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
if (err) if (err)
return err; return err;
if (!is_owner_or_cap(inode)) { if (!inode_owner_or_capable(inode)) {
err = -EACCES; err = -EACCES;
goto setrsvsz_out; goto setrsvsz_out;
} }
......
...@@ -433,7 +433,7 @@ ext4_xattr_set_acl(struct dentry *dentry, const char *name, const void *value, ...@@ -433,7 +433,7 @@ ext4_xattr_set_acl(struct dentry *dentry, const char *name, const void *value,
return -EINVAL; return -EINVAL;
if (!test_opt(inode->i_sb, POSIX_ACL)) if (!test_opt(inode->i_sb, POSIX_ACL))
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
if (value) { if (value) {
......
...@@ -38,7 +38,7 @@ long ext4_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) ...@@ -38,7 +38,7 @@ long ext4_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
unsigned int oldflags; unsigned int oldflags;
unsigned int jflag; unsigned int jflag;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EACCES; return -EACCES;
if (get_user(flags, (int __user *) arg)) if (get_user(flags, (int __user *) arg))
...@@ -146,7 +146,7 @@ long ext4_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) ...@@ -146,7 +146,7 @@ long ext4_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
__u32 generation; __u32 generation;
int err; int err;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
err = mnt_want_write(filp->f_path.mnt); err = mnt_want_write(filp->f_path.mnt);
...@@ -298,7 +298,7 @@ long ext4_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) ...@@ -298,7 +298,7 @@ long ext4_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
case EXT4_IOC_MIGRATE: case EXT4_IOC_MIGRATE:
{ {
int err; int err;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EACCES; return -EACCES;
err = mnt_want_write(filp->f_path.mnt); err = mnt_want_write(filp->f_path.mnt);
...@@ -320,7 +320,7 @@ long ext4_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) ...@@ -320,7 +320,7 @@ long ext4_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
case EXT4_IOC_ALLOC_DA_BLKS: case EXT4_IOC_ALLOC_DA_BLKS:
{ {
int err; int err;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EACCES; return -EACCES;
err = mnt_want_write(filp->f_path.mnt); err = mnt_want_write(filp->f_path.mnt);
......
...@@ -159,7 +159,7 @@ static int setfl(int fd, struct file * filp, unsigned long arg) ...@@ -159,7 +159,7 @@ static int setfl(int fd, struct file * filp, unsigned long arg)
/* O_NOATIME can only be set by the owner or superuser */ /* O_NOATIME can only be set by the owner or superuser */
if ((arg & O_NOATIME) && !(filp->f_flags & O_NOATIME)) if ((arg & O_NOATIME) && !(filp->f_flags & O_NOATIME))
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
/* required for strict SunOS emulation */ /* required for strict SunOS emulation */
......
...@@ -74,7 +74,7 @@ generic_acl_set(struct dentry *dentry, const char *name, const void *value, ...@@ -74,7 +74,7 @@ generic_acl_set(struct dentry *dentry, const char *name, const void *value,
return -EINVAL; return -EINVAL;
if (S_ISLNK(inode->i_mode)) if (S_ISLNK(inode->i_mode))
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
if (value) { if (value) {
acl = posix_acl_from_xattr(value, size); acl = posix_acl_from_xattr(value, size);
......
...@@ -221,7 +221,7 @@ static int do_gfs2_set_flags(struct file *filp, u32 reqflags, u32 mask) ...@@ -221,7 +221,7 @@ static int do_gfs2_set_flags(struct file *filp, u32 reqflags, u32 mask)
goto out_drop_write; goto out_drop_write;
error = -EACCES; error = -EACCES;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
goto out; goto out;
error = 0; error = 0;
......
...@@ -47,7 +47,7 @@ static int hfsplus_ioctl_setflags(struct file *file, int __user *user_flags) ...@@ -47,7 +47,7 @@ static int hfsplus_ioctl_setflags(struct file *file, int __user *user_flags)
if (err) if (err)
goto out; goto out;
if (!is_owner_or_cap(inode)) { if (!inode_owner_or_capable(inode)) {
err = -EACCES; err = -EACCES;
goto out_drop_write; goto out_drop_write;
} }
......
...@@ -1735,11 +1735,14 @@ void inode_init_owner(struct inode *inode, const struct inode *dir, ...@@ -1735,11 +1735,14 @@ void inode_init_owner(struct inode *inode, const struct inode *dir,
} }
EXPORT_SYMBOL(inode_init_owner); EXPORT_SYMBOL(inode_init_owner);
/* /**
* return true if current either has CAP_FOWNER to the * inode_owner_or_capable - check current task permissions to inode
* file, or owns the file. * @inode: inode being checked
*
* Return true if current either has CAP_FOWNER to the inode, or
* owns the file.
*/ */
bool is_owner_or_cap(const struct inode *inode) bool inode_owner_or_capable(const struct inode *inode)
{ {
struct user_namespace *ns = inode_userns(inode); struct user_namespace *ns = inode_userns(inode);
...@@ -1749,4 +1752,4 @@ bool is_owner_or_cap(const struct inode *inode) ...@@ -1749,4 +1752,4 @@ bool is_owner_or_cap(const struct inode *inode)
return true; return true;
return false; return false;
} }
EXPORT_SYMBOL(is_owner_or_cap); EXPORT_SYMBOL(inode_owner_or_capable);
...@@ -402,7 +402,7 @@ static int jffs2_acl_setxattr(struct dentry *dentry, const char *name, ...@@ -402,7 +402,7 @@ static int jffs2_acl_setxattr(struct dentry *dentry, const char *name,
if (name[0] != '\0') if (name[0] != '\0')
return -EINVAL; return -EINVAL;
if (!is_owner_or_cap(dentry->d_inode)) if (!inode_owner_or_capable(dentry->d_inode))
return -EPERM; return -EPERM;
if (value) { if (value) {
......
...@@ -72,7 +72,7 @@ long jfs_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) ...@@ -72,7 +72,7 @@ long jfs_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
if (err) if (err)
return err; return err;
if (!is_owner_or_cap(inode)) { if (!inode_owner_or_capable(inode)) {
err = -EACCES; err = -EACCES;
goto setflags_out; goto setflags_out;
} }
......
...@@ -678,7 +678,7 @@ static int can_set_system_xattr(struct inode *inode, const char *name, ...@@ -678,7 +678,7 @@ static int can_set_system_xattr(struct inode *inode, const char *name,
struct posix_acl *acl; struct posix_acl *acl;
int rc; int rc;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
/* /*
......
...@@ -196,7 +196,7 @@ long logfs_ioctl(struct file *file, unsigned int cmd, unsigned long arg) ...@@ -196,7 +196,7 @@ long logfs_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
if (IS_RDONLY(inode)) if (IS_RDONLY(inode))
return -EROFS; return -EROFS;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EACCES; return -EACCES;
err = get_user(flags, (int __user *)arg); err = get_user(flags, (int __user *)arg);
......
...@@ -2036,7 +2036,7 @@ static int may_open(struct path *path, int acc_mode, int flag) ...@@ -2036,7 +2036,7 @@ static int may_open(struct path *path, int acc_mode, int flag)
} }
/* O_NOATIME can only be set by the owner or superuser */ /* O_NOATIME can only be set by the owner or superuser */
if (flag & O_NOATIME && !is_owner_or_cap(inode)) if (flag & O_NOATIME && !inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
/* /*
......
...@@ -113,7 +113,7 @@ static int nilfs_ioctl_setflags(struct inode *inode, struct file *filp, ...@@ -113,7 +113,7 @@ static int nilfs_ioctl_setflags(struct inode *inode, struct file *filp,
unsigned int flags, oldflags; unsigned int flags, oldflags;
int ret; int ret;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EACCES; return -EACCES;
if (get_user(flags, (int __user *)argp)) if (get_user(flags, (int __user *)argp))
......
...@@ -497,7 +497,7 @@ static int ocfs2_xattr_set_acl(struct dentry *dentry, const char *name, ...@@ -497,7 +497,7 @@ static int ocfs2_xattr_set_acl(struct dentry *dentry, const char *name,
if (!(osb->s_mount_opt & OCFS2_MOUNT_POSIX_ACL)) if (!(osb->s_mount_opt & OCFS2_MOUNT_POSIX_ACL))
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
if (value) { if (value) {
......
...@@ -82,7 +82,7 @@ static int ocfs2_set_inode_attr(struct inode *inode, unsigned flags, ...@@ -82,7 +82,7 @@ static int ocfs2_set_inode_attr(struct inode *inode, unsigned flags,
} }
status = -EACCES; status = -EACCES;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
goto bail_unlock; goto bail_unlock;
if (!S_ISDIR(inode->i_mode)) if (!S_ISDIR(inode->i_mode))
......
...@@ -59,7 +59,7 @@ long reiserfs_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) ...@@ -59,7 +59,7 @@ long reiserfs_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
if (err) if (err)
break; break;
if (!is_owner_or_cap(inode)) { if (!inode_owner_or_capable(inode)) {
err = -EPERM; err = -EPERM;
goto setflags_out; goto setflags_out;
} }
...@@ -103,7 +103,7 @@ long reiserfs_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) ...@@ -103,7 +103,7 @@ long reiserfs_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
err = put_user(inode->i_generation, (int __user *)arg); err = put_user(inode->i_generation, (int __user *)arg);
break; break;
case REISERFS_IOC_SETVERSION: case REISERFS_IOC_SETVERSION:
if (!is_owner_or_cap(inode)) { if (!inode_owner_or_capable(inode)) {
err = -EPERM; err = -EPERM;
break; break;
} }
......
...@@ -26,7 +26,7 @@ posix_acl_set(struct dentry *dentry, const char *name, const void *value, ...@@ -26,7 +26,7 @@ posix_acl_set(struct dentry *dentry, const char *name, const void *value,
size_t jcreate_blocks; size_t jcreate_blocks;
if (!reiserfs_posixacl(inode->i_sb)) if (!reiserfs_posixacl(inode->i_sb))
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
if (value) { if (value) {
......
...@@ -160,7 +160,7 @@ long ubifs_ioctl(struct file *file, unsigned int cmd, unsigned long arg) ...@@ -160,7 +160,7 @@ long ubifs_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
if (IS_RDONLY(inode)) if (IS_RDONLY(inode))
return -EROFS; return -EROFS;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EACCES; return -EACCES;
if (get_user(flags, (int __user *) arg)) if (get_user(flags, (int __user *) arg))
......
...@@ -95,7 +95,7 @@ static int utimes_common(struct path *path, struct timespec *times) ...@@ -95,7 +95,7 @@ static int utimes_common(struct path *path, struct timespec *times)
if (IS_IMMUTABLE(inode)) if (IS_IMMUTABLE(inode))
goto mnt_drop_write_and_out; goto mnt_drop_write_and_out;
if (!is_owner_or_cap(inode)) { if (!inode_owner_or_capable(inode)) {
error = inode_permission(inode, MAY_WRITE); error = inode_permission(inode, MAY_WRITE);
if (error) if (error)
goto mnt_drop_write_and_out; goto mnt_drop_write_and_out;
......
...@@ -59,7 +59,7 @@ xattr_permission(struct inode *inode, const char *name, int mask) ...@@ -59,7 +59,7 @@ xattr_permission(struct inode *inode, const char *name, int mask)
if (!S_ISREG(inode->i_mode) && !S_ISDIR(inode->i_mode)) if (!S_ISREG(inode->i_mode) && !S_ISDIR(inode->i_mode))
return -EPERM; return -EPERM;
if (S_ISDIR(inode->i_mode) && (inode->i_mode & S_ISVTX) && if (S_ISDIR(inode->i_mode) && (inode->i_mode & S_ISVTX) &&
(mask & MAY_WRITE) && !is_owner_or_cap(inode)) (mask & MAY_WRITE) && !inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
} }
......
...@@ -1463,7 +1463,7 @@ enum { ...@@ -1463,7 +1463,7 @@ enum {
*/ */
extern struct user_namespace init_user_ns; extern struct user_namespace init_user_ns;
#define inode_userns(inode) (&init_user_ns) #define inode_userns(inode) (&init_user_ns)
extern bool is_owner_or_cap(const struct inode *inode); extern bool inode_owner_or_capable(const struct inode *inode);
/* not quite ready to be deprecated, but... */ /* not quite ready to be deprecated, but... */
extern void lock_super(struct super_block *); extern void lock_super(struct super_block *);
......
...@@ -2725,7 +2725,7 @@ static int selinux_inode_setxattr(struct dentry *dentry, const char *name, ...@@ -2725,7 +2725,7 @@ static int selinux_inode_setxattr(struct dentry *dentry, const char *name,
if (!(sbsec->flags & SE_SBLABELSUPP)) if (!(sbsec->flags & SE_SBLABELSUPP))
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (!is_owner_or_cap(inode)) if (!inode_owner_or_capable(inode))
return -EPERM; return -EPERM;
COMMON_AUDIT_DATA_INIT(&ad, FS); COMMON_AUDIT_DATA_INIT(&ad, FS);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册