xfs: pass struct da_args to xfs_attr_calc_size
authorChristoph Hellwig <hch@lst.de>
Tue, 13 May 2014 06:40:19 +0000 (16:40 +1000)
committerDave Chinner <david@fromorbit.com>
Tue, 13 May 2014 06:40:19 +0000 (16:40 +1000)
And remove a very confused comment.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Brian Foster <bfoster@redhat.com>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Signed-off-by: Dave Chinner <david@fromorbit.com>
fs/xfs/xfs_attr.c

index 120862139a63c2859b6d53da2579a7c4525f7d79..86f482e5798fced6e9a5f9892666d32b22d0f258 100644 (file)
@@ -162,12 +162,10 @@ xfs_attr_get(
  */
 STATIC int
 xfs_attr_calc_size(
-       struct xfs_inode        *ip,
-       int                     namelen,
-       int                     valuelen,
+       struct xfs_da_args      *args,
        int                     *local)
 {
-       struct xfs_mount        *mp = ip->i_mount;
+       struct xfs_mount        *mp = args->dp->i_mount;
        int                     size;
        int                     nblks;
 
@@ -175,7 +173,7 @@ xfs_attr_calc_size(
         * Determine space new attribute will use, and if it would be
         * "local" or "remote" (note: local != inline).
         */
-       size = xfs_attr_leaf_newentsize(namelen, valuelen,
+       size = xfs_attr_leaf_newentsize(args->namelen, args->valuelen,
                                        mp->m_sb.sb_blocksize, local);
 
        nblks = XFS_DAENTER_SPACE_RES(mp, XFS_ATTR_FORK);
@@ -189,7 +187,7 @@ xfs_attr_calc_size(
                 * Out of line attribute, cannot double split, but
                 * make room for the attribute value itself.
                 */
-               uint    dblocks = XFS_B_TO_FSB(mp, valuelen);
+               uint    dblocks = XFS_B_TO_FSB(mp, args->valuelen);
                nblks += dblocks;
                nblks += XFS_NEXTENTADD_SPACE_RES(mp, dblocks, XFS_ATTR_FORK);
        }
@@ -227,9 +225,7 @@ xfs_attr_set(
        args.firstblock = &firstblock;
        args.flist = &flist;
        args.op_flags = XFS_DA_OP_ADDNAME | XFS_DA_OP_OKNOENT;
-
-       /* Size is now blocks for attribute data */
-       args.total = xfs_attr_calc_size(dp, args.namelen, valuelen, &local);
+       args.total = xfs_attr_calc_size(&args, &local);
 
        error = xfs_qm_dqattach(dp, 0);
        if (error)