Commit 44af6c7e authored by Darrick J. Wong's avatar Darrick J. Wong

xfs: don't load local xattr values during scrub

Local extended attributes store their values within the same leaf block.
There's no header for the values themselves, nor are they separately
checksummed.  Hence we can save a bit of time in the attr scrubber by
not wasting time retrieving the values.

Regrettably, shortform attributes do not set XFS_ATTR_LOCAL so this
offers us no advantage there, but at least there are very few attrs in
that case.
Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
Reviewed-by: default avatarDave Chinner <dchinner@redhat.com>
parent 674f0d0d
...@@ -200,6 +200,14 @@ xchk_xattr_listent( ...@@ -200,6 +200,14 @@ xchk_xattr_listent(
goto fail_xref; goto fail_xref;
} }
/*
* Local xattr values are stored in the attr leaf block, so we don't
* need to retrieve the value from a remote block to detect corruption
* problems.
*/
if (flags & XFS_ATTR_LOCAL)
goto fail_xref;
/* /*
* Try to allocate enough memory to extrat the attr value. If that * Try to allocate enough memory to extrat the attr value. If that
* doesn't work, we overload the seen_enough variable to convey * doesn't work, we overload the seen_enough variable to convey
......
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