mdbx: минорное исправление для устранения срабатывания проверочного утверждения в отладочных сборках.

Ассерт мог срабатывать из-за отсутствия бита P_LEAF2 в передаваемом проверочном значении.
На что-либо другое не влияло, но не следует понять почему этот недочет ны был выявлен тестами раньше.
This commit is contained in:
Леонид Юрьев (Leonid Yuriev) 2022-10-08 17:29:29 +03:00
parent db72763de0
commit ad09164604

View File

@ -4127,8 +4127,8 @@ static int page_retire_ex(MDBX_cursor *mc, const pgno_t pgno,
check = page_get_any(mc, pgno, txn->mt_front); check = page_get_any(mc, pgno, txn->mt_front);
if (unlikely(check.err != MDBX_SUCCESS)) if (unlikely(check.err != MDBX_SUCCESS))
return check.err; return check.err;
tASSERT(txn, (check.page->mp_flags & ~(P_LEAF2 | P_SPILLED)) == tASSERT(txn,
(pageflags & ~P_FROZEN)); (check.page->mp_flags & ~P_SPILLED) == (pageflags & ~P_FROZEN));
tASSERT(txn, !(pageflags & P_FROZEN) || IS_FROZEN(txn, check.page)); tASSERT(txn, !(pageflags & P_FROZEN) || IS_FROZEN(txn, check.page));
} }
if (pageflags & P_FROZEN) { if (pageflags & P_FROZEN) {
@ -21483,9 +21483,10 @@ static int drop_tree(MDBX_cursor *mc, const bool may_have_subDBs) {
} else { } else {
cASSERT(mc, mc->mc_snum < mc->mc_db->md_depth); cASSERT(mc, mc->mc_snum < mc->mc_db->md_depth);
mc->mc_checking |= CC_RETIRING; mc->mc_checking |= CC_RETIRING;
const unsigned pagetype = const unsigned pagetype = (IS_FROZEN(txn, mp) ? P_FROZEN : 0) +
(IS_FROZEN(txn, mp) ? P_FROZEN : 0) + ((mc->mc_snum + 1 == mc->mc_db->md_depth)
((mc->mc_snum + 1 == mc->mc_db->md_depth) ? P_LEAF : P_BRANCH); ? (mc->mc_checking & (P_LEAF | P_LEAF2))
: P_BRANCH);
for (size_t i = 0; i < nkeys; i++) { for (size_t i = 0; i < nkeys; i++) {
MDBX_node *node = page_node(mp, i); MDBX_node *node = page_node(mp, i);
tASSERT(txn, (node_flags(node) & tASSERT(txn, (node_flags(node) &