switch xfs_swapext() to fget_light()
authorAl Viro <viro@zeniv.linux.org.uk>
Mon, 27 Aug 2012 16:57:12 +0000 (12:57 -0400)
committerAl Viro <viro@zeniv.linux.org.uk>
Thu, 27 Sep 2012 01:10:11 +0000 (21:10 -0400)
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
fs/xfs/xfs_dfrag.c

index e00de08dc8aca858f8715691c2e0d20046194104..e6cdf224d7eac744cb665a1018030059c4b81f28 100644 (file)
@@ -49,10 +49,10 @@ xfs_swapext(
 {
        xfs_inode_t     *ip, *tip;
        struct file     *file, *tmp_file;
-       int             error = 0;
+       int             error = 0, fput_needed, fput_needed_tmp;
 
        /* Pull information for the target fd */
-       file = fget((int)sxp->sx_fdtarget);
+       file = fget_light((int)sxp->sx_fdtarget, &fput_needed);
        if (!file) {
                error = XFS_ERROR(EINVAL);
                goto out;
@@ -65,7 +65,7 @@ xfs_swapext(
                goto out_put_file;
        }
 
-       tmp_file = fget((int)sxp->sx_fdtmp);
+       tmp_file = fget_light((int)sxp->sx_fdtmp, &fput_needed_tmp);
        if (!tmp_file) {
                error = XFS_ERROR(EINVAL);
                goto out_put_file;
@@ -105,9 +105,9 @@ xfs_swapext(
        error = xfs_swap_extents(ip, tip, sxp);
 
  out_put_tmp_file:
-       fput(tmp_file);
+       fput_light(tmp_file, fput_needed_tmp);
  out_put_file:
-       fput(file);
+       fput_light(file, fput_needed);
  out:
        return error;
 }