Commit 674f0d0d authored by Darrick J. Wong's avatar Darrick J. Wong

xfs: only allocate free space bitmap for xattr scrub if needed

The free space bitmap is only required if we're going to check the
bestfree space at the end of an xattr leaf block.  Therefore, we can
reduce the memory requirements of this scrubber if we can determine that
the xattr is in short format.
Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
Reviewed-by: default avatarDave Chinner <dchinner@redhat.com>
parent 6cee51e6
...@@ -37,6 +37,29 @@ xchk_xattr_buf_cleanup( ...@@ -37,6 +37,29 @@ xchk_xattr_buf_cleanup(
ab->value_sz = 0; ab->value_sz = 0;
} }
/*
* Allocate the free space bitmap if we're trying harder; there are leaf blocks
* in the attr fork; or we can't tell if there are leaf blocks.
*/
static inline bool
xchk_xattr_want_freemap(
struct xfs_scrub *sc)
{
struct xfs_ifork *ifp;
if (sc->flags & XCHK_TRY_HARDER)
return true;
if (!sc->ip)
return true;
ifp = xfs_ifork_ptr(sc->ip, XFS_ATTR_FORK);
if (!ifp)
return false;
return xfs_ifork_has_extents(ifp);
}
/* /*
* Allocate enough memory to hold an attr value and attr block bitmaps, * Allocate enough memory to hold an attr value and attr block bitmaps,
* reallocating the buffer if necessary. Buffer contents are not preserved * reallocating the buffer if necessary. Buffer contents are not preserved
...@@ -66,9 +89,11 @@ xchk_setup_xattr_buf( ...@@ -66,9 +89,11 @@ xchk_setup_xattr_buf(
if (!ab->usedmap) if (!ab->usedmap)
return -ENOMEM; return -ENOMEM;
if (xchk_xattr_want_freemap(sc)) {
ab->freemap = kvmalloc(bmp_sz, XCHK_GFP_FLAGS); ab->freemap = kvmalloc(bmp_sz, XCHK_GFP_FLAGS);
if (!ab->freemap) if (!ab->freemap)
return -ENOMEM; return -ENOMEM;
}
resize_value: resize_value:
if (ab->value_sz >= value_size) if (ab->value_sz >= value_size)
......
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