summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChandan Babu R <chandanrlinux@gmail.com>2021-03-26 10:52:56 -0700
committerDarrick J. Wong <djwong@kernel.org>2021-04-07 14:36:34 -0700
commite773f88029b179ea03855c22d5052e2e90362a81 (patch)
treec2af25e8fc5d0fe4900caf8e08d4e5b1b4377ab0
parent6e8bd39d7227747f13c891bc5a5fea00373d4bb9 (diff)
downloadlwn-e773f88029b179ea03855c22d5052e2e90362a81.tar.gz
lwn-e773f88029b179ea03855c22d5052e2e90362a81.zip
xfs: scrub: Remove incorrect check executed on block format directories
A directory with one directory block which in turns consists of two or more fs blocks is incorrectly flagged as corrupt by scrub since it assumes that "Block" format directories have a data fork single extent spanning the file offset range of [0, Dir block size - 1]. This commit fixes the bug by removing the incorrect check. Signed-off-by: Chandan Babu R <chandanrlinux@gmail.com> Reviewed-by: Darrick J. Wong <djwong@kernel.org> Signed-off-by: Darrick J. Wong <djwong@kernel.org>
-rw-r--r--fs/xfs/scrub/dir.c9
1 files changed, 0 insertions, 9 deletions
diff --git a/fs/xfs/scrub/dir.c b/fs/xfs/scrub/dir.c
index 178b3455a170..3ec6290c78bb 100644
--- a/fs/xfs/scrub/dir.c
+++ b/fs/xfs/scrub/dir.c
@@ -694,15 +694,6 @@ xchk_directory_blocks(
/* Iterate all the data extents in the directory... */
found = xfs_iext_lookup_extent(sc->ip, ifp, lblk, &icur, &got);
while (found && !(sc->sm->sm_flags & XFS_SCRUB_OFLAG_CORRUPT)) {
- /* Block directories only have a single block at offset 0. */
- if (is_block &&
- (got.br_startoff > 0 ||
- got.br_blockcount != args.geo->fsbcount)) {
- xchk_fblock_set_corrupt(sc, XFS_DATA_FORK,
- got.br_startoff);
- break;
- }
-
/* No more data blocks... */
if (got.br_startoff >= leaf_lblk)
break;