Commit 59a2af90 authored by Darrick J. Wong's avatar Darrick J. Wong

xfs: check parent pointer xattrs when scrubbing

Check parent pointer xattrs as part of scrubbing xattrs.
Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
parent 77ede5f4
...@@ -17,6 +17,7 @@ ...@@ -17,6 +17,7 @@
#include "xfs_attr.h" #include "xfs_attr.h"
#include "xfs_attr_leaf.h" #include "xfs_attr_leaf.h"
#include "xfs_attr_sf.h" #include "xfs_attr_sf.h"
#include "xfs_parent.h"
#include "scrub/scrub.h" #include "scrub/scrub.h"
#include "scrub/common.h" #include "scrub/common.h"
#include "scrub/dabtree.h" #include "scrub/dabtree.h"
...@@ -208,6 +209,13 @@ xchk_xattr_actor( ...@@ -208,6 +209,13 @@ xchk_xattr_actor(
return -ECANCELED; return -ECANCELED;
} }
/* Check parent pointer record. */
if ((attr_flags & XFS_ATTR_PARENT) &&
!xfs_parent_valuecheck(sc->mp, value, valuelen)) {
xchk_fblock_set_corrupt(sc, XFS_ATTR_FORK, args.blkno);
return -ECANCELED;
}
/* /*
* Try to allocate enough memory to extract the attr value. If that * Try to allocate enough memory to extract the attr value. If that
* doesn't work, return -EDEADLOCK as a signal to try again with a * doesn't work, return -EDEADLOCK as a signal to try again with a
...@@ -219,6 +227,14 @@ xchk_xattr_actor( ...@@ -219,6 +227,14 @@ xchk_xattr_actor(
if (error) if (error)
return error; return error;
/*
* Parent pointers are matched on attr name and value, so we must
* supply the xfs_parent_rec here when confirming that the dabtree
* indexing works correctly.
*/
if (attr_flags & XFS_ATTR_PARENT)
memcpy(ab->value, value, valuelen);
args.value = ab->value; args.value = ab->value;
/* /*
......
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