diff options
author | Darrick J. Wong <darrick.wong@oracle.com> | 2019-03-19 11:16:22 -0400 |
---|---|---|
committer | Darrick J. Wong <darrick.wong@oracle.com> | 2019-03-19 11:16:41 -0400 |
commit | a72e9d8d69e7ca848ddd4c4db72d3ab280c1775d (patch) | |
tree | f087519884ca80bdce715aa5475ecab35fd257f4 | |
parent | 228de124f290e6b981b2c61fbd78215e11264044 (diff) |
xfs: fix btree scrub checking with regards to root-in-inode
In xchk_btree_check_owner, we can be passed a null buffer pointer. This
should only happen for the root of a root-in-inode btree type, but we
should program defensively in case the btree cursor state ever gets
screwed up and we get a null buffer anyway.
Coverity-id: 1438713
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: Brian Foster <bfoster@redhat.com>
-rw-r--r-- | fs/xfs/scrub/btree.c | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/fs/xfs/scrub/btree.c b/fs/xfs/scrub/btree.c index 6f94d1f7322d..117910db51b8 100644 --- a/fs/xfs/scrub/btree.c +++ b/fs/xfs/scrub/btree.c | |||
@@ -415,8 +415,17 @@ xchk_btree_check_owner( | |||
415 | struct xfs_btree_cur *cur = bs->cur; | 415 | struct xfs_btree_cur *cur = bs->cur; |
416 | struct check_owner *co; | 416 | struct check_owner *co; |
417 | 417 | ||
418 | if ((cur->bc_flags & XFS_BTREE_ROOT_IN_INODE) && bp == NULL) | 418 | /* |
419 | * In theory, xfs_btree_get_block should only give us a null buffer | ||
420 | * pointer for the root of a root-in-inode btree type, but we need | ||
421 | * to check defensively here in case the cursor state is also screwed | ||
422 | * up. | ||
423 | */ | ||
424 | if (bp == NULL) { | ||
425 | if (!(cur->bc_flags & XFS_BTREE_ROOT_IN_INODE)) | ||
426 | xchk_btree_set_corrupt(bs->sc, bs->cur, level); | ||
419 | return 0; | 427 | return 0; |
428 | } | ||
420 | 429 | ||
421 | /* | 430 | /* |
422 | * We want to cross-reference each btree block with the bnobt | 431 | * We want to cross-reference each btree block with the bnobt |