diff options
author | Chandan Babu R <chandanrlinux@gmail.com> | 2021-03-26 18:52:56 +0100 |
---|---|---|
committer | Darrick J. Wong <djwong@kernel.org> | 2021-04-07 23:36:34 +0200 |
commit | e773f88029b179ea03855c22d5052e2e90362a81 (patch) | |
tree | c2af25e8fc5d0fe4900caf8e08d4e5b1b4377ab0 /fs/xfs/scrub | |
parent | xfs: Initialize xfs_alloc_arg->total correctly when allocating minlen extents (diff) | |
download | linux-e773f88029b179ea03855c22d5052e2e90362a81.tar.xz linux-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>
Diffstat (limited to 'fs/xfs/scrub')
-rw-r--r-- | fs/xfs/scrub/dir.c | 9 |
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; |