Commit 2eb66502 authored by Darrick J. Wong's avatar Darrick J. Wong

xfs: inactivate inodes any time we try to free speculative preallocations

Other parts of XFS have learned to call xfs_blockgc_free_{space,quota}
to try to free speculative preallocations when space is tight.  This
means that file writes, transaction reservation failures, quota limit
enforcement, and the EOFBLOCKS ioctl all call this function to free
space when things are tight.

Since inode inactivation is now a background task, this means that the
filesystem can be hanging on to unlinked but not yet freed space.  Add
this to the list of things that xfs_blockgc_free_* makes writer threads
scan for when they cannot reserve space.
Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
Reviewed-by: default avatarDave Chinner <dchinner@redhat.com>
parent 65f03d86
...@@ -1468,16 +1468,24 @@ xfs_blockgc_worker( ...@@ -1468,16 +1468,24 @@ xfs_blockgc_worker(
} }
/* /*
* Try to free space in the filesystem by purging eofblocks and cowblocks. * Try to free space in the filesystem by purging inactive inodes, eofblocks
* and cowblocks.
*/ */
int int
xfs_blockgc_free_space( xfs_blockgc_free_space(
struct xfs_mount *mp, struct xfs_mount *mp,
struct xfs_icwalk *icw) struct xfs_icwalk *icw)
{ {
int error;
trace_xfs_blockgc_free_space(mp, icw, _RET_IP_); trace_xfs_blockgc_free_space(mp, icw, _RET_IP_);
return xfs_icwalk(mp, XFS_ICWALK_BLOCKGC, icw); error = xfs_icwalk(mp, XFS_ICWALK_BLOCKGC, icw);
if (error)
return error;
xfs_inodegc_flush(mp);
return 0;
} }
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment