mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-22 08:48:21 +08:00
mdbx: refine mdbx_page_search().
Change-Id: I9c87ae2ffe317538813ebec971ad093936f4c504
This commit is contained in:
parent
9318e4cabb
commit
91bc3129d5
68
src/mdbx.c
68
src/mdbx.c
@ -4952,45 +4952,45 @@ static int mdbx_page_search(MDBX_cursor *mc, MDBX_val *key, int flags) {
|
|||||||
if (unlikely(mc->mc_txn->mt_flags & MDBX_TXN_BLOCKED)) {
|
if (unlikely(mc->mc_txn->mt_flags & MDBX_TXN_BLOCKED)) {
|
||||||
mdbx_debug("transaction has failed, must abort");
|
mdbx_debug("transaction has failed, must abort");
|
||||||
return MDBX_BAD_TXN;
|
return MDBX_BAD_TXN;
|
||||||
} else {
|
}
|
||||||
/* Make sure we're using an up-to-date root */
|
|
||||||
if (unlikely(*mc->mc_dbflag & DB_STALE)) {
|
/* Make sure we're using an up-to-date root */
|
||||||
MDBX_cursor mc2;
|
if (unlikely(*mc->mc_dbflag & DB_STALE)) {
|
||||||
if (unlikely(TXN_DBI_CHANGED(mc->mc_txn, mc->mc_dbi)))
|
MDBX_cursor mc2;
|
||||||
return MDBX_BAD_DBI;
|
if (unlikely(TXN_DBI_CHANGED(mc->mc_txn, mc->mc_dbi)))
|
||||||
mdbx_cursor_init(&mc2, mc->mc_txn, MAIN_DBI, NULL);
|
return MDBX_BAD_DBI;
|
||||||
rc = mdbx_page_search(&mc2, &mc->mc_dbx->md_name, 0);
|
mdbx_cursor_init(&mc2, mc->mc_txn, MAIN_DBI, NULL);
|
||||||
|
rc = mdbx_page_search(&mc2, &mc->mc_dbx->md_name, 0);
|
||||||
|
if (rc)
|
||||||
|
return rc;
|
||||||
|
{
|
||||||
|
MDBX_val data;
|
||||||
|
int exact = 0;
|
||||||
|
MDBX_node *leaf = mdbx_node_search(&mc2, &mc->mc_dbx->md_name, &exact);
|
||||||
|
if (!exact)
|
||||||
|
return MDBX_NOTFOUND;
|
||||||
|
if (unlikely((leaf->mn_flags & (F_DUPDATA | F_SUBDATA)) != F_SUBDATA))
|
||||||
|
return MDBX_INCOMPATIBLE; /* not a named DB */
|
||||||
|
rc = mdbx_node_read(&mc2, leaf, &data);
|
||||||
if (rc)
|
if (rc)
|
||||||
return rc;
|
return rc;
|
||||||
{
|
|
||||||
MDBX_val data;
|
|
||||||
int exact = 0;
|
|
||||||
MDBX_node *leaf = mdbx_node_search(&mc2, &mc->mc_dbx->md_name, &exact);
|
|
||||||
if (!exact)
|
|
||||||
return MDBX_NOTFOUND;
|
|
||||||
if (unlikely((leaf->mn_flags & (F_DUPDATA | F_SUBDATA)) != F_SUBDATA))
|
|
||||||
return MDBX_INCOMPATIBLE; /* not a named DB */
|
|
||||||
rc = mdbx_node_read(&mc2, leaf, &data);
|
|
||||||
if (rc)
|
|
||||||
return rc;
|
|
||||||
|
|
||||||
uint16_t md_flags;
|
uint16_t md_flags;
|
||||||
memcpy(&md_flags, ((char *)data.iov_base + offsetof(MDBX_db, md_flags)),
|
memcpy(&md_flags, ((char *)data.iov_base + offsetof(MDBX_db, md_flags)),
|
||||||
sizeof(uint16_t));
|
sizeof(uint16_t));
|
||||||
/* The txn may not know this DBI, or another process may
|
/* The txn may not know this DBI, or another process may
|
||||||
* have dropped and recreated the DB with other flags. */
|
* have dropped and recreated the DB with other flags. */
|
||||||
if (unlikely((mc->mc_db->md_flags & PERSISTENT_FLAGS) != md_flags))
|
if (unlikely((mc->mc_db->md_flags & PERSISTENT_FLAGS) != md_flags))
|
||||||
return MDBX_INCOMPATIBLE;
|
return MDBX_INCOMPATIBLE;
|
||||||
memcpy(mc->mc_db, data.iov_base, sizeof(MDBX_db));
|
memcpy(mc->mc_db, data.iov_base, sizeof(MDBX_db));
|
||||||
}
|
|
||||||
*mc->mc_dbflag &= ~DB_STALE;
|
|
||||||
}
|
}
|
||||||
root = mc->mc_db->md_root;
|
*mc->mc_dbflag &= ~DB_STALE;
|
||||||
|
}
|
||||||
|
root = mc->mc_db->md_root;
|
||||||
|
|
||||||
if (unlikely(root == P_INVALID)) { /* Tree is empty. */
|
if (unlikely(root == P_INVALID)) { /* Tree is empty. */
|
||||||
mdbx_debug("tree is empty");
|
mdbx_debug("tree is empty");
|
||||||
return MDBX_NOTFOUND;
|
return MDBX_NOTFOUND;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
mdbx_cassert(mc, root >= NUM_METAS);
|
mdbx_cassert(mc, root >= NUM_METAS);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user