On Mon, Jul 01, 2019 at 01:26:29PM -0700, Eric Biggers wrote:
> From: Eric Biggers <[email protected]>
> 
> Make the f2fs implementation of FS_IOC_FSSETXATTR use the new VFS helper
> function vfs_ioc_fssetxattr_check(), and remove the project quota check
> since it's now done by the helper function.
> 
> This is based on a patch from Darrick Wong, but reworked to apply after
> commit 360985573b55 ("f2fs: separate f2fs i_flags from fs_flags and ext4
> i_flags").
> 
> Originally-from: Darrick J. Wong <[email protected]>
> Signed-off-by: Eric Biggers <[email protected]>

Looks ok,
Reviewed-by: Darrick J. Wong <[email protected]>

--D

> ---
>  fs/f2fs/file.c | 45 ++++++++++++++-------------------------------
>  1 file changed, 14 insertions(+), 31 deletions(-)
> 
> diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c
> index b5b941e6448657..ae1a54ecc9fccc 100644
> --- a/fs/f2fs/file.c
> +++ b/fs/f2fs/file.c
> @@ -2857,52 +2857,32 @@ static inline u32 f2fs_xflags_to_iflags(u32 xflags)
>       return iflags;
>  }
>  
> -static int f2fs_ioc_fsgetxattr(struct file *filp, unsigned long arg)
> +static void f2fs_fill_fsxattr(struct inode *inode, struct fsxattr *fa)
>  {
> -     struct inode *inode = file_inode(filp);
>       struct f2fs_inode_info *fi = F2FS_I(inode);
> -     struct fsxattr fa;
>  
> -     memset(&fa, 0, sizeof(struct fsxattr));
> -     fa.fsx_xflags = f2fs_iflags_to_xflags(fi->i_flags);
> +     simple_fill_fsxattr(fa, f2fs_iflags_to_xflags(fi->i_flags));
>  
>       if (f2fs_sb_has_project_quota(F2FS_I_SB(inode)))
> -             fa.fsx_projid = (__u32)from_kprojid(&init_user_ns,
> -                                                     fi->i_projid);
> -
> -     if (copy_to_user((struct fsxattr __user *)arg, &fa, sizeof(fa)))
> -             return -EFAULT;
> -     return 0;
> +             fa->fsx_projid = from_kprojid(&init_user_ns, fi->i_projid);
>  }
>  
> -static int f2fs_ioctl_check_project(struct inode *inode, struct fsxattr *fa)
> +static int f2fs_ioc_fsgetxattr(struct file *filp, unsigned long arg)
>  {
> -     /*
> -      * Project Quota ID state is only allowed to change from within the init
> -      * namespace. Enforce that restriction only if we are trying to change
> -      * the quota ID state. Everything else is allowed in user namespaces.
> -      */
> -     if (current_user_ns() == &init_user_ns)
> -             return 0;
> -
> -     if (__kprojid_val(F2FS_I(inode)->i_projid) != fa->fsx_projid)
> -             return -EINVAL;
> +     struct inode *inode = file_inode(filp);
> +     struct fsxattr fa;
>  
> -     if (F2FS_I(inode)->i_flags & F2FS_PROJINHERIT_FL) {
> -             if (!(fa->fsx_xflags & FS_XFLAG_PROJINHERIT))
> -                     return -EINVAL;
> -     } else {
> -             if (fa->fsx_xflags & FS_XFLAG_PROJINHERIT)
> -                     return -EINVAL;
> -     }
> +     f2fs_fill_fsxattr(inode, &fa);
>  
> +     if (copy_to_user((struct fsxattr __user *)arg, &fa, sizeof(fa)))
> +             return -EFAULT;
>       return 0;
>  }
>  
>  static int f2fs_ioc_fssetxattr(struct file *filp, unsigned long arg)
>  {
>       struct inode *inode = file_inode(filp);
> -     struct fsxattr fa;
> +     struct fsxattr fa, old_fa;
>       u32 iflags;
>       int err;
>  
> @@ -2925,9 +2905,12 @@ static int f2fs_ioc_fssetxattr(struct file *filp, 
> unsigned long arg)
>               return err;
>  
>       inode_lock(inode);
> -     err = f2fs_ioctl_check_project(inode, &fa);
> +
> +     f2fs_fill_fsxattr(inode, &old_fa);
> +     err = vfs_ioc_fssetxattr_check(inode, &old_fa, &fa);
>       if (err)
>               goto out;
> +
>       err = f2fs_setflags_common(inode, iflags,
>                       f2fs_xflags_to_iflags(F2FS_SUPPORTED_XFLAGS));
>       if (err)
> -- 
> 2.22.0.410.gd8fdbe21b5-goog
> 


_______________________________________________
Linux-f2fs-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel

Reply via email to