提交 4cbae4b8 编写于 作者: D Darrick J. Wong

xfs: introduce xfs_btree_debug_check_ptr

Make xfs_btree_check_ptr a non-debug function and introduce a new _debug
version that only runs when #ifdef DEBUG.   This will enable us to reuse
the checking logic with other parts of the btree code.
Signed-off-by: NDarrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: NDave Chinner <dchinner@redhat.com>
上级 e4f45eff
...@@ -234,7 +234,6 @@ xfs_btree_check_sptr( ...@@ -234,7 +234,6 @@ xfs_btree_check_sptr(
return xfs_verify_agbno(cur->bc_mp, cur->bc_private.a.agno, agbno); return xfs_verify_agbno(cur->bc_mp, cur->bc_private.a.agno, agbno);
} }
#ifdef DEBUG
/* /*
* Check that a given (indexed) btree pointer at a certain level of a * Check that a given (indexed) btree pointer at a certain level of a
* btree is valid and doesn't point past where it should. * btree is valid and doesn't point past where it should.
...@@ -258,6 +257,11 @@ xfs_btree_check_ptr( ...@@ -258,6 +257,11 @@ xfs_btree_check_ptr(
return 0; return 0;
} }
#ifdef DEBUG
# define xfs_btree_debug_check_ptr xfs_btree_check_ptr
#else
# define xfs_btree_debug_check_ptr(...) (0)
#endif #endif
/* /*
...@@ -1951,11 +1955,10 @@ xfs_btree_lookup( ...@@ -1951,11 +1955,10 @@ xfs_btree_lookup(
keyno = 1; keyno = 1;
pp = xfs_btree_ptr_addr(cur, keyno, block); pp = xfs_btree_ptr_addr(cur, keyno, block);
#ifdef DEBUG error = xfs_btree_debug_check_ptr(cur, pp, 0, level);
error = xfs_btree_check_ptr(cur, pp, 0, level);
if (error) if (error)
goto error0; goto error0;
#endif
cur->bc_ptrs[level] = keyno; cur->bc_ptrs[level] = keyno;
} }
} }
...@@ -2359,11 +2362,11 @@ xfs_btree_lshift( ...@@ -2359,11 +2362,11 @@ xfs_btree_lshift(
lpp = xfs_btree_ptr_addr(cur, lrecs, left); lpp = xfs_btree_ptr_addr(cur, lrecs, left);
rpp = xfs_btree_ptr_addr(cur, 1, right); rpp = xfs_btree_ptr_addr(cur, 1, right);
#ifdef DEBUG
error = xfs_btree_check_ptr(cur, rpp, 0, level); error = xfs_btree_debug_check_ptr(cur, rpp, 0, level);
if (error) if (error)
goto error0; goto error0;
#endif
xfs_btree_copy_keys(cur, lkp, rkp, 1); xfs_btree_copy_keys(cur, lkp, rkp, 1);
xfs_btree_copy_ptrs(cur, lpp, rpp, 1); xfs_btree_copy_ptrs(cur, lpp, rpp, 1);
...@@ -2398,15 +2401,14 @@ xfs_btree_lshift( ...@@ -2398,15 +2401,14 @@ xfs_btree_lshift(
XFS_BTREE_STATS_ADD(cur, moves, rrecs - 1); XFS_BTREE_STATS_ADD(cur, moves, rrecs - 1);
if (level > 0) { if (level > 0) {
/* It's a nonleaf. operate on keys and ptrs */ /* It's a nonleaf. operate on keys and ptrs */
#ifdef DEBUG
int i; /* loop index */ int i; /* loop index */
for (i = 0; i < rrecs; i++) { for (i = 0; i < rrecs; i++) {
error = xfs_btree_check_ptr(cur, rpp, i + 1, level); error = xfs_btree_debug_check_ptr(cur, rpp, i + 1, level);
if (error) if (error)
goto error0; goto error0;
} }
#endif
xfs_btree_shift_keys(cur, xfs_btree_shift_keys(cur,
xfs_btree_key_addr(cur, 2, right), xfs_btree_key_addr(cur, 2, right),
-1, rrecs); -1, rrecs);
...@@ -2546,22 +2548,18 @@ xfs_btree_rshift( ...@@ -2546,22 +2548,18 @@ xfs_btree_rshift(
rkp = xfs_btree_key_addr(cur, 1, right); rkp = xfs_btree_key_addr(cur, 1, right);
rpp = xfs_btree_ptr_addr(cur, 1, right); rpp = xfs_btree_ptr_addr(cur, 1, right);
#ifdef DEBUG
for (i = rrecs - 1; i >= 0; i--) { for (i = rrecs - 1; i >= 0; i--) {
error = xfs_btree_check_ptr(cur, rpp, i, level); error = xfs_btree_debug_check_ptr(cur, rpp, i, level);
if (error) if (error)
goto error0; goto error0;
} }
#endif
xfs_btree_shift_keys(cur, rkp, 1, rrecs); xfs_btree_shift_keys(cur, rkp, 1, rrecs);
xfs_btree_shift_ptrs(cur, rpp, 1, rrecs); xfs_btree_shift_ptrs(cur, rpp, 1, rrecs);
#ifdef DEBUG error = xfs_btree_debug_check_ptr(cur, lpp, 0, level);
error = xfs_btree_check_ptr(cur, lpp, 0, level);
if (error) if (error)
goto error0; goto error0;
#endif
/* Now put the new data in, and log it. */ /* Now put the new data in, and log it. */
xfs_btree_copy_keys(cur, rkp, lkp, 1); xfs_btree_copy_keys(cur, rkp, lkp, 1);
...@@ -2666,9 +2664,7 @@ __xfs_btree_split( ...@@ -2666,9 +2664,7 @@ __xfs_btree_split(
int rrecs; int rrecs;
int src_index; int src_index;
int error; /* error return value */ int error; /* error return value */
#ifdef DEBUG
int i; int i;
#endif
XFS_BTREE_STATS_INC(cur, split); XFS_BTREE_STATS_INC(cur, split);
...@@ -2734,13 +2730,11 @@ __xfs_btree_split( ...@@ -2734,13 +2730,11 @@ __xfs_btree_split(
rkp = xfs_btree_key_addr(cur, 1, right); rkp = xfs_btree_key_addr(cur, 1, right);
rpp = xfs_btree_ptr_addr(cur, 1, right); rpp = xfs_btree_ptr_addr(cur, 1, right);
#ifdef DEBUG
for (i = src_index; i < rrecs; i++) { for (i = src_index; i < rrecs; i++) {
error = xfs_btree_check_ptr(cur, lpp, i, level); error = xfs_btree_debug_check_ptr(cur, lpp, i, level);
if (error) if (error)
goto error0; goto error0;
} }
#endif
/* Copy the keys & pointers to the new block. */ /* Copy the keys & pointers to the new block. */
xfs_btree_copy_keys(cur, rkp, lkp, rrecs); xfs_btree_copy_keys(cur, rkp, lkp, rrecs);
...@@ -2928,9 +2922,7 @@ xfs_btree_new_iroot( ...@@ -2928,9 +2922,7 @@ xfs_btree_new_iroot(
union xfs_btree_ptr nptr; /* new block addr */ union xfs_btree_ptr nptr; /* new block addr */
int level; /* btree level */ int level; /* btree level */
int error; /* error return code */ int error; /* error return code */
#ifdef DEBUG
int i; /* loop counter */ int i; /* loop counter */
#endif
XFS_BTREE_STATS_INC(cur, newroot); XFS_BTREE_STATS_INC(cur, newroot);
...@@ -2977,20 +2969,18 @@ xfs_btree_new_iroot( ...@@ -2977,20 +2969,18 @@ xfs_btree_new_iroot(
xfs_btree_copy_keys(cur, ckp, kp, xfs_btree_get_numrecs(cblock)); xfs_btree_copy_keys(cur, ckp, kp, xfs_btree_get_numrecs(cblock));
cpp = xfs_btree_ptr_addr(cur, 1, cblock); cpp = xfs_btree_ptr_addr(cur, 1, cblock);
#ifdef DEBUG
for (i = 0; i < be16_to_cpu(cblock->bb_numrecs); i++) { for (i = 0; i < be16_to_cpu(cblock->bb_numrecs); i++) {
error = xfs_btree_check_ptr(cur, pp, i, level); error = xfs_btree_debug_check_ptr(cur, pp, i, level);
if (error) if (error)
goto error0; goto error0;
} }
#endif
xfs_btree_copy_ptrs(cur, cpp, pp, xfs_btree_get_numrecs(cblock)); xfs_btree_copy_ptrs(cur, cpp, pp, xfs_btree_get_numrecs(cblock));
#ifdef DEBUG error = xfs_btree_debug_check_ptr(cur, &nptr, 0, level);
error = xfs_btree_check_ptr(cur, &nptr, 0, level);
if (error) if (error)
goto error0; goto error0;
#endif
xfs_btree_copy_ptrs(cur, pp, &nptr, 1); xfs_btree_copy_ptrs(cur, pp, &nptr, 1);
xfs_iroot_realloc(cur->bc_private.b.ip, xfs_iroot_realloc(cur->bc_private.b.ip,
...@@ -3234,9 +3224,7 @@ xfs_btree_insrec( ...@@ -3234,9 +3224,7 @@ xfs_btree_insrec(
int ptr; /* key/record index */ int ptr; /* key/record index */
int numrecs;/* number of records */ int numrecs;/* number of records */
int error; /* error return value */ int error; /* error return value */
#ifdef DEBUG
int i; int i;
#endif
xfs_daddr_t old_bn; xfs_daddr_t old_bn;
ncur = NULL; ncur = NULL;
...@@ -3326,22 +3314,18 @@ xfs_btree_insrec( ...@@ -3326,22 +3314,18 @@ xfs_btree_insrec(
kp = xfs_btree_key_addr(cur, ptr, block); kp = xfs_btree_key_addr(cur, ptr, block);
pp = xfs_btree_ptr_addr(cur, ptr, block); pp = xfs_btree_ptr_addr(cur, ptr, block);
#ifdef DEBUG
for (i = numrecs - ptr; i >= 0; i--) { for (i = numrecs - ptr; i >= 0; i--) {
error = xfs_btree_check_ptr(cur, pp, i, level); error = xfs_btree_debug_check_ptr(cur, pp, i, level);
if (error) if (error)
return error; return error;
} }
#endif
xfs_btree_shift_keys(cur, kp, 1, numrecs - ptr + 1); xfs_btree_shift_keys(cur, kp, 1, numrecs - ptr + 1);
xfs_btree_shift_ptrs(cur, pp, 1, numrecs - ptr + 1); xfs_btree_shift_ptrs(cur, pp, 1, numrecs - ptr + 1);
#ifdef DEBUG error = xfs_btree_debug_check_ptr(cur, ptrp, 0, level);
error = xfs_btree_check_ptr(cur, ptrp, 0, level);
if (error) if (error)
goto error0; goto error0;
#endif
/* Now put the new data in, bump numrecs and log it. */ /* Now put the new data in, bump numrecs and log it. */
xfs_btree_copy_keys(cur, kp, key, 1); xfs_btree_copy_keys(cur, kp, key, 1);
...@@ -3529,8 +3513,8 @@ xfs_btree_kill_iroot( ...@@ -3529,8 +3513,8 @@ xfs_btree_kill_iroot(
int error; int error;
#ifdef DEBUG #ifdef DEBUG
union xfs_btree_ptr ptr; union xfs_btree_ptr ptr;
int i;
#endif #endif
int i;
ASSERT(cur->bc_flags & XFS_BTREE_ROOT_IN_INODE); ASSERT(cur->bc_flags & XFS_BTREE_ROOT_IN_INODE);
ASSERT(cur->bc_nlevels > 1); ASSERT(cur->bc_nlevels > 1);
...@@ -3586,13 +3570,13 @@ xfs_btree_kill_iroot( ...@@ -3586,13 +3570,13 @@ xfs_btree_kill_iroot(
pp = xfs_btree_ptr_addr(cur, 1, block); pp = xfs_btree_ptr_addr(cur, 1, block);
cpp = xfs_btree_ptr_addr(cur, 1, cblock); cpp = xfs_btree_ptr_addr(cur, 1, cblock);
#ifdef DEBUG
for (i = 0; i < numrecs; i++) { for (i = 0; i < numrecs; i++) {
error = xfs_btree_check_ptr(cur, cpp, i, level - 1); error = xfs_btree_debug_check_ptr(cur, cpp, i, level - 1);
if (error) if (error)
return error; return error;
} }
#endif
xfs_btree_copy_ptrs(cur, pp, cpp, numrecs); xfs_btree_copy_ptrs(cur, pp, cpp, numrecs);
error = xfs_btree_free_block(cur, cbp); error = xfs_btree_free_block(cur, cbp);
...@@ -3726,13 +3710,11 @@ xfs_btree_delrec( ...@@ -3726,13 +3710,11 @@ xfs_btree_delrec(
lkp = xfs_btree_key_addr(cur, ptr + 1, block); lkp = xfs_btree_key_addr(cur, ptr + 1, block);
lpp = xfs_btree_ptr_addr(cur, ptr + 1, block); lpp = xfs_btree_ptr_addr(cur, ptr + 1, block);
#ifdef DEBUG
for (i = 0; i < numrecs - ptr; i++) { for (i = 0; i < numrecs - ptr; i++) {
error = xfs_btree_check_ptr(cur, lpp, i, level); error = xfs_btree_debug_check_ptr(cur, lpp, i, level);
if (error) if (error)
goto error0; goto error0;
} }
#endif
if (ptr < numrecs) { if (ptr < numrecs) {
xfs_btree_shift_keys(cur, lkp, -1, numrecs - ptr); xfs_btree_shift_keys(cur, lkp, -1, numrecs - ptr);
...@@ -4065,13 +4047,13 @@ xfs_btree_delrec( ...@@ -4065,13 +4047,13 @@ xfs_btree_delrec(
lpp = xfs_btree_ptr_addr(cur, lrecs + 1, left); lpp = xfs_btree_ptr_addr(cur, lrecs + 1, left);
rkp = xfs_btree_key_addr(cur, 1, right); rkp = xfs_btree_key_addr(cur, 1, right);
rpp = xfs_btree_ptr_addr(cur, 1, right); rpp = xfs_btree_ptr_addr(cur, 1, right);
#ifdef DEBUG
for (i = 1; i < rrecs; i++) { for (i = 1; i < rrecs; i++) {
error = xfs_btree_check_ptr(cur, rpp, i, level); error = xfs_btree_debug_check_ptr(cur, rpp, i, level);
if (error) if (error)
goto error0; goto error0;
} }
#endif
xfs_btree_copy_keys(cur, lkp, rkp, rrecs); xfs_btree_copy_keys(cur, lkp, rkp, rrecs);
xfs_btree_copy_ptrs(cur, lpp, rpp, rrecs); xfs_btree_copy_ptrs(cur, lpp, rpp, rrecs);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册