Users have come to expect that the space accounting information in
statfs and getquota reports are fairly accurate.  Now that we inactivate
inodes from a background queue, these numbers can be thrown off by
whatever resources are singly-owned by the inodes in the queue.  Flush
the pending inactivations when userspace asks for a space usage report.
Signed-off-by: Darrick J. Wong <djwong@kernel.org>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
        struct xfs_dquot        *dqp;
        int                     error;
 
+       /* Flush inodegc work at the start of a quota reporting scan. */
+       if (id == 0)
+               xfs_inodegc_flush(mp);
+
        /*
         * Try to get the dquot. We don't want it allocated on disk, so don't
         * set doalloc. If it doesn't exist, we'll get ENOENT back.
        struct xfs_dquot        *dqp;
        int                     error;
 
+       /* Flush inodegc work at the start of a quota reporting scan. */
+       if (*id == 0)
+               xfs_inodegc_flush(mp);
+
        error = xfs_qm_dqget_next(mp, *id, type, &dqp);
        if (error)
                return error;
 
        xfs_extlen_t            lsize;
        int64_t                 ffree;
 
+       /* Wait for whatever inactivations are in progress. */
+       xfs_inodegc_flush(mp);
+
        statp->f_type = XFS_SUPER_MAGIC;
        statp->f_namelen = MAXNAMELEN - 1;