mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-02 00:34:13 +08:00
mdbx: rename/reorganize internal fields for clarity.
Change-Id: I9b23a8ca271f30ebedda9cd8d21094b4797f8bb3
This commit is contained in:
parent
8ee3c6ddb0
commit
a238179c23
108
src/core.c
108
src/core.c
@ -4090,7 +4090,7 @@ mark_done:
|
|||||||
if (all) {
|
if (all) {
|
||||||
/* Mark dirty root pages */
|
/* Mark dirty root pages */
|
||||||
for (i = 0; i < txn->mt_numdbs; i++) {
|
for (i = 0; i < txn->mt_numdbs; i++) {
|
||||||
if (txn->mt_dbflags[i] & DB_DIRTY) {
|
if (txn->mt_dbstate[i] & DB_DIRTY) {
|
||||||
pgno_t pgno = txn->mt_dbs[i].md_root;
|
pgno_t pgno = txn->mt_dbs[i].md_root;
|
||||||
if (pgno == P_INVALID)
|
if (pgno == P_INVALID)
|
||||||
continue;
|
continue;
|
||||||
@ -5673,7 +5673,7 @@ static int mdbx_cursor_shadow(MDBX_txn *src, MDBX_txn *dst) {
|
|||||||
* user may not use mc until dst ends. But we need a valid
|
* user may not use mc until dst ends. But we need a valid
|
||||||
* txn pointer here for cursor fixups to keep working. */
|
* txn pointer here for cursor fixups to keep working. */
|
||||||
mc->mc_txn = dst;
|
mc->mc_txn = dst;
|
||||||
mc->mc_dbflag = &dst->mt_dbflags[i];
|
mc->mc_dbstate = &dst->mt_dbstate[i];
|
||||||
if ((mx = mc->mc_xcursor) != NULL) {
|
if ((mx = mc->mc_xcursor) != NULL) {
|
||||||
*(MDBX_xcursor *)(bk + 1) = *mx;
|
*(MDBX_xcursor *)(bk + 1) = *mx;
|
||||||
mx->mx_cursor.mc_txn = dst;
|
mx->mx_cursor.mc_txn = dst;
|
||||||
@ -5712,7 +5712,7 @@ static void mdbx_cursors_eot(MDBX_txn *txn, unsigned merge) {
|
|||||||
mc->mc_backup = bk->mc_backup;
|
mc->mc_backup = bk->mc_backup;
|
||||||
mc->mc_txn = bk->mc_txn;
|
mc->mc_txn = bk->mc_txn;
|
||||||
mc->mc_db = bk->mc_db;
|
mc->mc_db = bk->mc_db;
|
||||||
mc->mc_dbflag = bk->mc_dbflag;
|
mc->mc_dbstate = bk->mc_dbstate;
|
||||||
if ((mx = mc->mc_xcursor) != NULL)
|
if ((mx = mc->mc_xcursor) != NULL)
|
||||||
mx->mx_cursor.mc_txn = bk->mc_txn;
|
mx->mx_cursor.mc_txn = bk->mc_txn;
|
||||||
} else {
|
} else {
|
||||||
@ -6045,11 +6045,11 @@ static int mdbx_txn_renew0(MDBX_txn *txn, unsigned flags) {
|
|||||||
for (unsigned i = CORE_DBS; i < txn->mt_numdbs; i++) {
|
for (unsigned i = CORE_DBS; i < txn->mt_numdbs; i++) {
|
||||||
unsigned x = env->me_dbflags[i];
|
unsigned x = env->me_dbflags[i];
|
||||||
txn->mt_dbs[i].md_flags = x & PERSISTENT_FLAGS;
|
txn->mt_dbs[i].md_flags = x & PERSISTENT_FLAGS;
|
||||||
txn->mt_dbflags[i] =
|
txn->mt_dbstate[i] =
|
||||||
(x & MDBX_VALID) ? DB_VALID | DB_USRVALID | DB_STALE : 0;
|
(x & MDBX_VALID) ? DB_VALID | DB_USRVALID | DB_STALE : 0;
|
||||||
}
|
}
|
||||||
txn->mt_dbflags[MAIN_DBI] = DB_VALID | DB_USRVALID;
|
txn->mt_dbstate[MAIN_DBI] = DB_VALID | DB_USRVALID;
|
||||||
txn->mt_dbflags[FREE_DBI] = DB_VALID;
|
txn->mt_dbstate[FREE_DBI] = DB_VALID;
|
||||||
|
|
||||||
if (unlikely(env->me_flags & MDBX_FATAL_ERROR)) {
|
if (unlikely(env->me_flags & MDBX_FATAL_ERROR)) {
|
||||||
mdbx_warning("%s", "environment had fatal error, must shutdown!");
|
mdbx_warning("%s", "environment had fatal error, must shutdown!");
|
||||||
@ -6242,7 +6242,7 @@ int mdbx_txn_begin(MDBX_env *env, MDBX_txn *parent, unsigned flags,
|
|||||||
memset(txn, 0, tsize);
|
memset(txn, 0, tsize);
|
||||||
txn->mt_dbxs = env->me_dbxs; /* static */
|
txn->mt_dbxs = env->me_dbxs; /* static */
|
||||||
txn->mt_dbs = (MDBX_db *)((char *)txn + tsize);
|
txn->mt_dbs = (MDBX_db *)((char *)txn + tsize);
|
||||||
txn->mt_dbflags = (uint8_t *)txn + size - env->me_maxdbs;
|
txn->mt_dbstate = (uint8_t *)txn + size - env->me_maxdbs;
|
||||||
txn->mt_flags = flags;
|
txn->mt_flags = flags;
|
||||||
txn->mt_env = env;
|
txn->mt_env = env;
|
||||||
|
|
||||||
@ -6290,9 +6290,9 @@ int mdbx_txn_begin(MDBX_env *env, MDBX_txn *parent, unsigned flags,
|
|||||||
txn->mt_numdbs = parent->mt_numdbs;
|
txn->mt_numdbs = parent->mt_numdbs;
|
||||||
txn->mt_owner = parent->mt_owner;
|
txn->mt_owner = parent->mt_owner;
|
||||||
memcpy(txn->mt_dbs, parent->mt_dbs, txn->mt_numdbs * sizeof(MDBX_db));
|
memcpy(txn->mt_dbs, parent->mt_dbs, txn->mt_numdbs * sizeof(MDBX_db));
|
||||||
/* Copy parent's mt_dbflags, but clear DB_NEW */
|
/* Copy parent's mt_dbstate, but clear DB_NEW */
|
||||||
for (unsigned i = 0; i < txn->mt_numdbs; i++)
|
for (unsigned i = 0; i < txn->mt_numdbs; i++)
|
||||||
txn->mt_dbflags[i] = parent->mt_dbflags[i] & ~(DB_FRESH | DB_CREAT);
|
txn->mt_dbstate[i] = parent->mt_dbstate[i] & ~(DB_FRESH | DB_CREAT);
|
||||||
mdbx_tassert(parent,
|
mdbx_tassert(parent,
|
||||||
parent->mt_parent ||
|
parent->mt_parent ||
|
||||||
parent->tw.dirtyroom + parent->tw.dirtylist->length ==
|
parent->tw.dirtyroom + parent->tw.dirtylist->length ==
|
||||||
@ -6466,7 +6466,7 @@ static void mdbx_dbis_update(MDBX_txn *txn, int keep) {
|
|||||||
if (n) {
|
if (n) {
|
||||||
bool locked = false;
|
bool locked = false;
|
||||||
MDBX_env *env = txn->mt_env;
|
MDBX_env *env = txn->mt_env;
|
||||||
uint8_t *tdbflags = txn->mt_dbflags;
|
uint8_t *tdbflags = txn->mt_dbstate;
|
||||||
|
|
||||||
for (unsigned i = n; --i >= CORE_DBS;) {
|
for (unsigned i = n; --i >= CORE_DBS;) {
|
||||||
if (likely((tdbflags[i] & DB_CREAT) == 0))
|
if (likely((tdbflags[i] & DB_CREAT) == 0))
|
||||||
@ -6718,16 +6718,16 @@ static __cold int mdbx_audit_ex(MDBX_txn *txn, unsigned retired_stored,
|
|||||||
mdbx_tassert(txn, rc == MDBX_NOTFOUND);
|
mdbx_tassert(txn, rc == MDBX_NOTFOUND);
|
||||||
|
|
||||||
for (MDBX_dbi i = FREE_DBI; i < txn->mt_numdbs; i++)
|
for (MDBX_dbi i = FREE_DBI; i < txn->mt_numdbs; i++)
|
||||||
txn->mt_dbflags[i] &= ~DB_AUDITED;
|
txn->mt_dbstate[i] &= ~DB_AUDITED;
|
||||||
|
|
||||||
pgno_t count = 0;
|
pgno_t count = 0;
|
||||||
for (MDBX_dbi i = FREE_DBI; i <= MAIN_DBI; i++) {
|
for (MDBX_dbi i = FREE_DBI; i <= MAIN_DBI; i++) {
|
||||||
if (!(txn->mt_dbflags[i] & DB_VALID))
|
if (!(txn->mt_dbstate[i] & DB_VALID))
|
||||||
continue;
|
continue;
|
||||||
rc = mdbx_cursor_init(&cx.outer, txn, i);
|
rc = mdbx_cursor_init(&cx.outer, txn, i);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
return rc;
|
return rc;
|
||||||
txn->mt_dbflags[i] |= DB_AUDITED;
|
txn->mt_dbstate[i] |= DB_AUDITED;
|
||||||
if (txn->mt_dbs[i].md_root == P_INVALID)
|
if (txn->mt_dbs[i].md_root == P_INVALID)
|
||||||
continue;
|
continue;
|
||||||
count += txn->mt_dbs[i].md_branch_pages + txn->mt_dbs[i].md_leaf_pages +
|
count += txn->mt_dbs[i].md_branch_pages + txn->mt_dbs[i].md_leaf_pages +
|
||||||
@ -6747,14 +6747,14 @@ static __cold int mdbx_audit_ex(MDBX_txn *txn, unsigned retired_stored,
|
|||||||
memcpy(db = &db_copy, node_data(node), sizeof(db_copy));
|
memcpy(db = &db_copy, node_data(node), sizeof(db_copy));
|
||||||
if ((txn->mt_flags & MDBX_RDONLY) == 0) {
|
if ((txn->mt_flags & MDBX_RDONLY) == 0) {
|
||||||
for (MDBX_dbi k = txn->mt_numdbs; --k > MAIN_DBI;) {
|
for (MDBX_dbi k = txn->mt_numdbs; --k > MAIN_DBI;) {
|
||||||
if ((txn->mt_dbflags[k] & DB_VALID) &&
|
if ((txn->mt_dbstate[k] & DB_VALID) &&
|
||||||
/* txn->mt_dbxs[k].md_name.iov_len > 0 && */
|
/* txn->mt_dbxs[k].md_name.iov_len > 0 && */
|
||||||
node_ks(node) == txn->mt_dbxs[k].md_name.iov_len &&
|
node_ks(node) == txn->mt_dbxs[k].md_name.iov_len &&
|
||||||
memcmp(node_key(node), txn->mt_dbxs[k].md_name.iov_base,
|
memcmp(node_key(node), txn->mt_dbxs[k].md_name.iov_base,
|
||||||
node_ks(node)) == 0) {
|
node_ks(node)) == 0) {
|
||||||
txn->mt_dbflags[k] |= DB_AUDITED;
|
txn->mt_dbstate[k] |= DB_AUDITED;
|
||||||
if (txn->mt_dbflags[k] & DB_DIRTY) {
|
if (txn->mt_dbstate[k] & DB_DIRTY) {
|
||||||
mdbx_tassert(txn, (txn->mt_dbflags[k] & DB_STALE) == 0);
|
mdbx_tassert(txn, (txn->mt_dbstate[k] & DB_STALE) == 0);
|
||||||
db = txn->mt_dbs + k;
|
db = txn->mt_dbs + k;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -6771,9 +6771,9 @@ static __cold int mdbx_audit_ex(MDBX_txn *txn, unsigned retired_stored,
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (MDBX_dbi i = FREE_DBI; i < txn->mt_numdbs; i++) {
|
for (MDBX_dbi i = FREE_DBI; i < txn->mt_numdbs; i++) {
|
||||||
if ((txn->mt_dbflags[i] & (DB_VALID | DB_AUDITED | DB_STALE)) != DB_VALID)
|
if ((txn->mt_dbstate[i] & (DB_VALID | DB_AUDITED | DB_STALE)) != DB_VALID)
|
||||||
continue;
|
continue;
|
||||||
if (F_ISSET(txn->mt_dbflags[i], DB_DIRTY | DB_CREAT)) {
|
if (F_ISSET(txn->mt_dbstate[i], DB_DIRTY | DB_CREAT)) {
|
||||||
count += txn->mt_dbs[i].md_branch_pages + txn->mt_dbs[i].md_leaf_pages +
|
count += txn->mt_dbs[i].md_branch_pages + txn->mt_dbs[i].md_leaf_pages +
|
||||||
txn->mt_dbs[i].md_overflow_pages;
|
txn->mt_dbs[i].md_overflow_pages;
|
||||||
} else {
|
} else {
|
||||||
@ -6782,7 +6782,7 @@ static __cold int mdbx_audit_ex(MDBX_txn *txn, unsigned retired_stored,
|
|||||||
txn->mt_parent ? "nested-" : "", txn->mt_txnid, i,
|
txn->mt_parent ? "nested-" : "", txn->mt_txnid, i,
|
||||||
(int)txn->mt_dbxs[i].md_name.iov_len,
|
(int)txn->mt_dbxs[i].md_name.iov_len,
|
||||||
(const char *)txn->mt_dbxs[i].md_name.iov_base,
|
(const char *)txn->mt_dbxs[i].md_name.iov_base,
|
||||||
txn->mt_dbflags[i]);
|
txn->mt_dbstate[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -7653,24 +7653,24 @@ static __cold bool mdbx_txn_import_dbi(MDBX_txn *txn, MDBX_dbi dbi) {
|
|||||||
mdbx_compiler_barrier();
|
mdbx_compiler_barrier();
|
||||||
for (unsigned i = CORE_DBS; i < snap_numdbs; ++i) {
|
for (unsigned i = CORE_DBS; i < snap_numdbs; ++i) {
|
||||||
if (i >= txn->mt_numdbs)
|
if (i >= txn->mt_numdbs)
|
||||||
txn->mt_dbflags[i] = 0;
|
txn->mt_dbstate[i] = 0;
|
||||||
if (!(txn->mt_dbflags[i] & DB_USRVALID) &&
|
if (!(txn->mt_dbstate[i] & DB_USRVALID) &&
|
||||||
(env->me_dbflags[i] & MDBX_VALID)) {
|
(env->me_dbflags[i] & MDBX_VALID)) {
|
||||||
txn->mt_dbs[i].md_flags = env->me_dbflags[i] & PERSISTENT_FLAGS;
|
txn->mt_dbs[i].md_flags = env->me_dbflags[i] & PERSISTENT_FLAGS;
|
||||||
txn->mt_dbflags[i] = DB_VALID | DB_USRVALID | DB_STALE;
|
txn->mt_dbstate[i] = DB_VALID | DB_USRVALID | DB_STALE;
|
||||||
mdbx_tassert(txn, txn->mt_dbxs[i].md_cmp != NULL);
|
mdbx_tassert(txn, txn->mt_dbxs[i].md_cmp != NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
txn->mt_numdbs = snap_numdbs;
|
txn->mt_numdbs = snap_numdbs;
|
||||||
|
|
||||||
mdbx_ensure(env, mdbx_fastmutex_release(&env->me_dbi_lock) == MDBX_SUCCESS);
|
mdbx_ensure(env, mdbx_fastmutex_release(&env->me_dbi_lock) == MDBX_SUCCESS);
|
||||||
return txn->mt_dbflags[dbi] & DB_USRVALID;
|
return txn->mt_dbstate[dbi] & DB_USRVALID;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check txn and dbi arguments to a function */
|
/* Check txn and dbi arguments to a function */
|
||||||
static __always_inline bool mdbx_txn_dbi_exists(MDBX_txn *txn, MDBX_dbi dbi,
|
static __always_inline bool mdbx_txn_dbi_exists(MDBX_txn *txn, MDBX_dbi dbi,
|
||||||
unsigned validity) {
|
unsigned validity) {
|
||||||
if (likely(dbi < txn->mt_numdbs && (txn->mt_dbflags[dbi] & validity)))
|
if (likely(dbi < txn->mt_numdbs && (txn->mt_dbstate[dbi] & validity)))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
return mdbx_txn_import_dbi(txn, dbi);
|
return mdbx_txn_import_dbi(txn, dbi);
|
||||||
@ -7751,12 +7751,12 @@ int mdbx_txn_commit(MDBX_txn *txn) {
|
|||||||
/* Update parent's DB table. */
|
/* Update parent's DB table. */
|
||||||
memcpy(parent->mt_dbs, txn->mt_dbs, txn->mt_numdbs * sizeof(MDBX_db));
|
memcpy(parent->mt_dbs, txn->mt_dbs, txn->mt_numdbs * sizeof(MDBX_db));
|
||||||
parent->mt_numdbs = txn->mt_numdbs;
|
parent->mt_numdbs = txn->mt_numdbs;
|
||||||
parent->mt_dbflags[FREE_DBI] = txn->mt_dbflags[FREE_DBI];
|
parent->mt_dbstate[FREE_DBI] = txn->mt_dbstate[FREE_DBI];
|
||||||
parent->mt_dbflags[MAIN_DBI] = txn->mt_dbflags[MAIN_DBI];
|
parent->mt_dbstate[MAIN_DBI] = txn->mt_dbstate[MAIN_DBI];
|
||||||
for (unsigned i = CORE_DBS; i < txn->mt_numdbs; i++) {
|
for (unsigned i = CORE_DBS; i < txn->mt_numdbs; i++) {
|
||||||
/* preserve parent's DB_NEW status */
|
/* preserve parent's DB_NEW status */
|
||||||
parent->mt_dbflags[i] =
|
parent->mt_dbstate[i] =
|
||||||
txn->mt_dbflags[i] | (parent->mt_dbflags[i] & (DB_CREAT | DB_FRESH));
|
txn->mt_dbstate[i] | (parent->mt_dbstate[i] & (DB_CREAT | DB_FRESH));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Remove refunded pages from parent's dirty & spill lists */
|
/* Remove refunded pages from parent's dirty & spill lists */
|
||||||
@ -7973,7 +7973,7 @@ int mdbx_txn_commit(MDBX_txn *txn) {
|
|||||||
if (txn->tw.dirtylist->length == 0 &&
|
if (txn->tw.dirtylist->length == 0 &&
|
||||||
(txn->mt_flags & (MDBX_TXN_DIRTY | MDBX_TXN_SPILLS)) == 0) {
|
(txn->mt_flags & (MDBX_TXN_DIRTY | MDBX_TXN_SPILLS)) == 0) {
|
||||||
for (int i = txn->mt_numdbs; --i >= 0;)
|
for (int i = txn->mt_numdbs; --i >= 0;)
|
||||||
mdbx_tassert(txn, (txn->mt_dbflags[i] & DB_DIRTY) == 0);
|
mdbx_tassert(txn, (txn->mt_dbstate[i] & DB_DIRTY) == 0);
|
||||||
rc = MDBX_SUCCESS;
|
rc = MDBX_SUCCESS;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
@ -7993,7 +7993,7 @@ int mdbx_txn_commit(MDBX_txn *txn) {
|
|||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
goto fail;
|
goto fail;
|
||||||
for (MDBX_dbi i = CORE_DBS; i < txn->mt_numdbs; i++) {
|
for (MDBX_dbi i = CORE_DBS; i < txn->mt_numdbs; i++) {
|
||||||
if (txn->mt_dbflags[i] & DB_DIRTY) {
|
if (txn->mt_dbstate[i] & DB_DIRTY) {
|
||||||
if (unlikely(TXN_DBI_CHANGED(txn, i))) {
|
if (unlikely(TXN_DBI_CHANGED(txn, i))) {
|
||||||
rc = MDBX_BAD_DBI;
|
rc = MDBX_BAD_DBI;
|
||||||
goto fail;
|
goto fail;
|
||||||
@ -10205,7 +10205,7 @@ int __cold mdbx_env_open(MDBX_env *env, const char *pathname, unsigned flags,
|
|||||||
txn->mt_dbs = (MDBX_db *)((char *)txn + tsize);
|
txn->mt_dbs = (MDBX_db *)((char *)txn + tsize);
|
||||||
txn->mt_cursors = (MDBX_cursor **)(txn->mt_dbs + env->me_maxdbs);
|
txn->mt_cursors = (MDBX_cursor **)(txn->mt_dbs + env->me_maxdbs);
|
||||||
txn->mt_dbiseqs = (unsigned *)(txn->mt_cursors + env->me_maxdbs);
|
txn->mt_dbiseqs = (unsigned *)(txn->mt_cursors + env->me_maxdbs);
|
||||||
txn->mt_dbflags = (uint8_t *)(txn->mt_dbiseqs + env->me_maxdbs);
|
txn->mt_dbstate = (uint8_t *)(txn->mt_dbiseqs + env->me_maxdbs);
|
||||||
txn->mt_env = env;
|
txn->mt_env = env;
|
||||||
txn->mt_dbxs = env->me_dbxs;
|
txn->mt_dbxs = env->me_dbxs;
|
||||||
txn->mt_flags = MDBX_TXN_FINISHED;
|
txn->mt_flags = MDBX_TXN_FINISHED;
|
||||||
@ -10830,7 +10830,7 @@ static int mdbx_fetch_sdb(MDBX_txn *txn, MDBX_dbi dbi) {
|
|||||||
return MDBX_INCOMPATIBLE;
|
return MDBX_INCOMPATIBLE;
|
||||||
|
|
||||||
memcpy(&txn->mt_dbs[dbi], data.iov_base, sizeof(MDBX_db));
|
memcpy(&txn->mt_dbs[dbi], data.iov_base, sizeof(MDBX_db));
|
||||||
txn->mt_dbflags[dbi] &= ~DB_STALE;
|
txn->mt_dbstate[dbi] &= ~DB_STALE;
|
||||||
return MDBX_SUCCESS;
|
return MDBX_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -10880,7 +10880,7 @@ __hot static int mdbx_page_search(MDBX_cursor *mc, MDBX_val *key, int flags) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Make sure we're using an up-to-date root */
|
/* Make sure we're using an up-to-date root */
|
||||||
if (unlikely(*mc->mc_dbflag & DB_STALE)) {
|
if (unlikely(*mc->mc_dbstate & DB_STALE)) {
|
||||||
rc = mdbx_fetch_sdb(mc->mc_txn, mc->mc_dbi);
|
rc = mdbx_fetch_sdb(mc->mc_txn, mc->mc_dbi);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
return rc;
|
return rc;
|
||||||
@ -11757,7 +11757,7 @@ static int mdbx_cursor_touch(MDBX_cursor *mc) {
|
|||||||
int rc = MDBX_SUCCESS;
|
int rc = MDBX_SUCCESS;
|
||||||
|
|
||||||
if (mc->mc_dbi >= CORE_DBS &&
|
if (mc->mc_dbi >= CORE_DBS &&
|
||||||
(*mc->mc_dbflag & (DB_DIRTY | DB_DUPDATA)) == 0) {
|
(*mc->mc_dbstate & (DB_DIRTY | DB_DUPDATA)) == 0) {
|
||||||
mdbx_cassert(mc, (mc->mc_flags & C_RECLAIMING) == 0);
|
mdbx_cassert(mc, (mc->mc_flags & C_RECLAIMING) == 0);
|
||||||
/* Touch DB record of named DB */
|
/* Touch DB record of named DB */
|
||||||
MDBX_cursor_couple cx;
|
MDBX_cursor_couple cx;
|
||||||
@ -11769,7 +11769,7 @@ static int mdbx_cursor_touch(MDBX_cursor *mc) {
|
|||||||
rc = mdbx_page_search(&cx.outer, &mc->mc_dbx->md_name, MDBX_PS_MODIFY);
|
rc = mdbx_page_search(&cx.outer, &mc->mc_dbx->md_name, MDBX_PS_MODIFY);
|
||||||
if (unlikely(rc))
|
if (unlikely(rc))
|
||||||
return rc;
|
return rc;
|
||||||
*mc->mc_dbflag |= DB_DIRTY;
|
*mc->mc_dbstate |= DB_DIRTY;
|
||||||
}
|
}
|
||||||
mc->mc_top = 0;
|
mc->mc_top = 0;
|
||||||
if (mc->mc_snum) {
|
if (mc->mc_snum) {
|
||||||
@ -11976,7 +11976,7 @@ int mdbx_cursor_put(MDBX_cursor *mc, const MDBX_val *key, MDBX_val *data,
|
|||||||
return rc2;
|
return rc2;
|
||||||
mc->mc_db->md_root = np->mp_pgno;
|
mc->mc_db->md_root = np->mp_pgno;
|
||||||
mc->mc_db->md_depth++;
|
mc->mc_db->md_depth++;
|
||||||
*mc->mc_dbflag |= DB_DIRTY;
|
*mc->mc_dbstate |= DB_DIRTY;
|
||||||
if ((mc->mc_db->md_flags & (MDBX_DUPSORT | MDBX_DUPFIXED)) == MDBX_DUPFIXED)
|
if ((mc->mc_db->md_flags & (MDBX_DUPSORT | MDBX_DUPFIXED)) == MDBX_DUPFIXED)
|
||||||
np->mp_flags |= P_LEAF2;
|
np->mp_flags |= P_LEAF2;
|
||||||
mc->mc_flags |= C_INITIALIZED;
|
mc->mc_flags |= C_INITIALIZED;
|
||||||
@ -12917,7 +12917,7 @@ static int mdbx_xcursor_init0(MDBX_cursor *mc) {
|
|||||||
mx->mx_cursor.mc_db = &mx->mx_db;
|
mx->mx_cursor.mc_db = &mx->mx_db;
|
||||||
mx->mx_cursor.mc_dbx = &mx->mx_dbx;
|
mx->mx_cursor.mc_dbx = &mx->mx_dbx;
|
||||||
mx->mx_cursor.mc_dbi = mc->mc_dbi;
|
mx->mx_cursor.mc_dbi = mc->mc_dbi;
|
||||||
mx->mx_cursor.mc_dbflag = &mx->mx_dbflag;
|
mx->mx_cursor.mc_dbstate = &mx->mx_dbstate;
|
||||||
mx->mx_cursor.mc_snum = 0;
|
mx->mx_cursor.mc_snum = 0;
|
||||||
mx->mx_cursor.mc_top = 0;
|
mx->mx_cursor.mc_top = 0;
|
||||||
mx->mx_cursor.mc_flags = C_SUB;
|
mx->mx_cursor.mc_flags = C_SUB;
|
||||||
@ -12971,7 +12971,7 @@ static int mdbx_xcursor_init1(MDBX_cursor *mc, MDBX_node *node) {
|
|||||||
}
|
}
|
||||||
mdbx_debug("Sub-db -%u root page %" PRIaPGNO, mx->mx_cursor.mc_dbi,
|
mdbx_debug("Sub-db -%u root page %" PRIaPGNO, mx->mx_cursor.mc_dbi,
|
||||||
mx->mx_db.md_root);
|
mx->mx_db.md_root);
|
||||||
mx->mx_dbflag = DB_VALID | DB_USRVALID | DB_DUPDATA;
|
mx->mx_dbstate = DB_VALID | DB_USRVALID | DB_DUPDATA;
|
||||||
return MDBX_SUCCESS;
|
return MDBX_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -12993,7 +12993,7 @@ static int mdbx_xcursor_init2(MDBX_cursor *mc, MDBX_xcursor *src_mx,
|
|||||||
mx->mx_cursor.mc_top = 0;
|
mx->mx_cursor.mc_top = 0;
|
||||||
mx->mx_cursor.mc_flags |= C_INITIALIZED;
|
mx->mx_cursor.mc_flags |= C_INITIALIZED;
|
||||||
mx->mx_cursor.mc_ki[0] = 0;
|
mx->mx_cursor.mc_ki[0] = 0;
|
||||||
mx->mx_dbflag = DB_VALID | DB_USRVALID | DB_DUPDATA;
|
mx->mx_dbstate = DB_VALID | DB_USRVALID | DB_DUPDATA;
|
||||||
mx->mx_dbx.md_cmp = src_mx->mx_dbx.md_cmp;
|
mx->mx_dbx.md_cmp = src_mx->mx_dbx.md_cmp;
|
||||||
} else if (!(mx->mx_cursor.mc_flags & C_INITIALIZED)) {
|
} else if (!(mx->mx_cursor.mc_flags & C_INITIALIZED)) {
|
||||||
return MDBX_SUCCESS;
|
return MDBX_SUCCESS;
|
||||||
@ -13014,7 +13014,7 @@ static int mdbx_cursor_init(MDBX_cursor *mc, MDBX_txn *txn, MDBX_dbi dbi) {
|
|||||||
mc->mc_txn = txn;
|
mc->mc_txn = txn;
|
||||||
mc->mc_db = &txn->mt_dbs[dbi];
|
mc->mc_db = &txn->mt_dbs[dbi];
|
||||||
mc->mc_dbx = &txn->mt_dbxs[dbi];
|
mc->mc_dbx = &txn->mt_dbxs[dbi];
|
||||||
mc->mc_dbflag = &txn->mt_dbflags[dbi];
|
mc->mc_dbstate = &txn->mt_dbstate[dbi];
|
||||||
mc->mc_snum = 0;
|
mc->mc_snum = 0;
|
||||||
mc->mc_top = 0;
|
mc->mc_top = 0;
|
||||||
mc->mc_pg[0] = 0;
|
mc->mc_pg[0] = 0;
|
||||||
@ -13034,7 +13034,7 @@ static int mdbx_cursor_init(MDBX_cursor *mc, MDBX_txn *txn, MDBX_dbi dbi) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int rc = MDBX_SUCCESS;
|
int rc = MDBX_SUCCESS;
|
||||||
if (unlikely(*mc->mc_dbflag & DB_STALE)) {
|
if (unlikely(*mc->mc_dbstate & DB_STALE)) {
|
||||||
rc = mdbx_page_search(mc, NULL, MDBX_PS_ROOTONLY);
|
rc = mdbx_page_search(mc, NULL, MDBX_PS_ROOTONLY);
|
||||||
rc = (rc != MDBX_NOTFOUND) ? rc : MDBX_SUCCESS;
|
rc = (rc != MDBX_NOTFOUND) ? rc : MDBX_SUCCESS;
|
||||||
}
|
}
|
||||||
@ -14233,7 +14233,7 @@ static __cold int mdbx_cursor_check(MDBX_cursor *mc, bool pending) {
|
|||||||
: mc->mc_snum != mc->mc_db->md_depth))
|
: mc->mc_snum != mc->mc_db->md_depth))
|
||||||
return MDBX_CURSOR_FULL;
|
return MDBX_CURSOR_FULL;
|
||||||
|
|
||||||
for (int n = 0; n < mc->mc_snum; ++n) {
|
for (int n = 0; n < (int)mc->mc_snum; ++n) {
|
||||||
MDBX_page *mp = mc->mc_pg[n];
|
MDBX_page *mp = mc->mc_pg[n];
|
||||||
const unsigned nkeys = page_numkeys(mp);
|
const unsigned nkeys = page_numkeys(mp);
|
||||||
const bool expect_branch = (n < mc->mc_db->md_depth - 1) ? true : false;
|
const bool expect_branch = (n < mc->mc_db->md_depth - 1) ? true : false;
|
||||||
@ -14734,7 +14734,7 @@ static int mdbx_page_split(MDBX_cursor *mc, const MDBX_val *newkey,
|
|||||||
mn, rc = mdbx_page_split(&mn, &sepkey, NULL, rp->mp_pgno, 0));
|
mn, rc = mdbx_page_split(&mn, &sepkey, NULL, rp->mp_pgno, 0));
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
goto done;
|
goto done;
|
||||||
mdbx_cassert(mc, mc->mc_snum - snum == mc->mc_db->md_depth - depth);
|
mdbx_cassert(mc, (int)mc->mc_snum - snum == mc->mc_db->md_depth - depth);
|
||||||
if (mdbx_audit_enabled()) {
|
if (mdbx_audit_enabled()) {
|
||||||
rc = mdbx_cursor_check(mc, true);
|
rc = mdbx_cursor_check(mc, true);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
@ -16120,10 +16120,10 @@ int mdbx_dbi_open_ex(MDBX_txn *txn, const char *table_name, unsigned user_flags,
|
|||||||
if (txn->mt_numdbs < env->me_numdbs) {
|
if (txn->mt_numdbs < env->me_numdbs) {
|
||||||
/* Import handles from env */
|
/* Import handles from env */
|
||||||
for (unsigned i = txn->mt_numdbs; i < env->me_numdbs; ++i) {
|
for (unsigned i = txn->mt_numdbs; i < env->me_numdbs; ++i) {
|
||||||
txn->mt_dbflags[i] = 0;
|
txn->mt_dbstate[i] = 0;
|
||||||
if (env->me_dbflags[i] & MDBX_VALID) {
|
if (env->me_dbflags[i] & MDBX_VALID) {
|
||||||
txn->mt_dbs[i].md_flags = env->me_dbflags[i] & PERSISTENT_FLAGS;
|
txn->mt_dbs[i].md_flags = env->me_dbflags[i] & PERSISTENT_FLAGS;
|
||||||
txn->mt_dbflags[i] = DB_VALID | DB_USRVALID | DB_STALE;
|
txn->mt_dbstate[i] = DB_VALID | DB_USRVALID | DB_STALE;
|
||||||
mdbx_tassert(txn, txn->mt_dbxs[i].md_cmp != NULL);
|
mdbx_tassert(txn, txn->mt_dbxs[i].md_cmp != NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -16185,7 +16185,7 @@ int mdbx_dbi_open_ex(MDBX_txn *txn, const char *table_name, unsigned user_flags,
|
|||||||
later_exit:
|
later_exit:
|
||||||
mdbx_free(namedup);
|
mdbx_free(namedup);
|
||||||
} else {
|
} else {
|
||||||
txn->mt_dbflags[slot] = (uint8_t)dbflag;
|
txn->mt_dbstate[slot] = (uint8_t)dbflag;
|
||||||
txn->mt_dbxs[slot].md_name.iov_base = namedup;
|
txn->mt_dbxs[slot].md_name.iov_base = namedup;
|
||||||
txn->mt_dbxs[slot].md_name.iov_len = len;
|
txn->mt_dbxs[slot].md_name.iov_len = len;
|
||||||
txn->mt_numdbs += (slot == txn->mt_numdbs);
|
txn->mt_numdbs += (slot == txn->mt_numdbs);
|
||||||
@ -16229,7 +16229,7 @@ int __cold mdbx_dbi_stat(MDBX_txn *txn, MDBX_dbi dbi, MDBX_stat *dest,
|
|||||||
if (unlikely(txn->mt_flags & MDBX_TXN_BLOCKED))
|
if (unlikely(txn->mt_flags & MDBX_TXN_BLOCKED))
|
||||||
return MDBX_BAD_TXN;
|
return MDBX_BAD_TXN;
|
||||||
|
|
||||||
if (unlikely(txn->mt_dbflags[dbi] & DB_STALE)) {
|
if (unlikely(txn->mt_dbstate[dbi] & DB_STALE)) {
|
||||||
rc = mdbx_fetch_sdb(txn, dbi);
|
rc = mdbx_fetch_sdb(txn, dbi);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
return rc;
|
return rc;
|
||||||
@ -16288,7 +16288,7 @@ int mdbx_dbi_flags_ex(MDBX_txn *txn, MDBX_dbi dbi, unsigned *flags,
|
|||||||
return MDBX_EINVAL;
|
return MDBX_EINVAL;
|
||||||
|
|
||||||
*flags = txn->mt_dbs[dbi].md_flags & PERSISTENT_FLAGS;
|
*flags = txn->mt_dbs[dbi].md_flags & PERSISTENT_FLAGS;
|
||||||
*state = txn->mt_dbflags[dbi] & (DB_FRESH | DB_CREAT | DB_DIRTY | DB_STALE);
|
*state = txn->mt_dbstate[dbi] & (DB_FRESH | DB_CREAT | DB_DIRTY | DB_STALE);
|
||||||
|
|
||||||
return MDBX_SUCCESS;
|
return MDBX_SUCCESS;
|
||||||
}
|
}
|
||||||
@ -16430,7 +16430,7 @@ int mdbx_drop(MDBX_txn *txn, MDBX_dbi dbi, int del) {
|
|||||||
if (del && dbi >= CORE_DBS) {
|
if (del && dbi >= CORE_DBS) {
|
||||||
rc = mdbx_del0(txn, MAIN_DBI, &mc->mc_dbx->md_name, NULL, F_SUBDATA);
|
rc = mdbx_del0(txn, MAIN_DBI, &mc->mc_dbx->md_name, NULL, F_SUBDATA);
|
||||||
if (likely(rc == MDBX_SUCCESS)) {
|
if (likely(rc == MDBX_SUCCESS)) {
|
||||||
txn->mt_dbflags[dbi] = DB_STALE;
|
txn->mt_dbstate[dbi] = DB_STALE;
|
||||||
MDBX_env *env = txn->mt_env;
|
MDBX_env *env = txn->mt_env;
|
||||||
rc = mdbx_fastmutex_acquire(&env->me_dbi_lock);
|
rc = mdbx_fastmutex_acquire(&env->me_dbi_lock);
|
||||||
if (unlikely(rc != MDBX_SUCCESS)) {
|
if (unlikely(rc != MDBX_SUCCESS)) {
|
||||||
@ -16445,7 +16445,7 @@ int mdbx_drop(MDBX_txn *txn, MDBX_dbi dbi, int del) {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
/* reset the DB record, mark it dirty */
|
/* reset the DB record, mark it dirty */
|
||||||
txn->mt_dbflags[dbi] |= DB_DIRTY;
|
txn->mt_dbstate[dbi] |= DB_DIRTY;
|
||||||
txn->mt_dbs[dbi].md_depth = 0;
|
txn->mt_dbs[dbi].md_depth = 0;
|
||||||
txn->mt_dbs[dbi].md_branch_pages = 0;
|
txn->mt_dbs[dbi].md_branch_pages = 0;
|
||||||
txn->mt_dbs[dbi].md_leaf_pages = 0;
|
txn->mt_dbs[dbi].md_leaf_pages = 0;
|
||||||
@ -17270,7 +17270,7 @@ int mdbx_cursor_eof(const MDBX_cursor *mc) {
|
|||||||
|
|
||||||
struct diff_result {
|
struct diff_result {
|
||||||
ptrdiff_t diff;
|
ptrdiff_t diff;
|
||||||
int level;
|
unsigned level;
|
||||||
int root_nkeys;
|
int root_nkeys;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -17894,7 +17894,7 @@ int mdbx_dbi_sequence(MDBX_txn *txn, MDBX_dbi dbi, uint64_t *result,
|
|||||||
if (unlikely(TXN_DBI_CHANGED(txn, dbi)))
|
if (unlikely(TXN_DBI_CHANGED(txn, dbi)))
|
||||||
return MDBX_BAD_DBI;
|
return MDBX_BAD_DBI;
|
||||||
|
|
||||||
if (unlikely(txn->mt_dbflags[dbi] & DB_STALE)) {
|
if (unlikely(txn->mt_dbstate[dbi] & DB_STALE)) {
|
||||||
rc = mdbx_fetch_sdb(txn, dbi);
|
rc = mdbx_fetch_sdb(txn, dbi);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
return rc;
|
return rc;
|
||||||
@ -17915,7 +17915,7 @@ int mdbx_dbi_sequence(MDBX_txn *txn, MDBX_dbi dbi, uint64_t *result,
|
|||||||
mdbx_tassert(txn, new > dbs->md_seq);
|
mdbx_tassert(txn, new > dbs->md_seq);
|
||||||
dbs->md_seq = new;
|
dbs->md_seq = new;
|
||||||
txn->mt_flags |= MDBX_TXN_DIRTY;
|
txn->mt_flags |= MDBX_TXN_DIRTY;
|
||||||
txn->mt_dbflags[dbi] |= DB_DIRTY;
|
txn->mt_dbstate[dbi] |= DB_DIRTY;
|
||||||
}
|
}
|
||||||
|
|
||||||
return MDBX_SUCCESS;
|
return MDBX_SUCCESS;
|
||||||
|
@ -726,6 +726,8 @@ struct MDBX_txn {
|
|||||||
MDBX_db *mt_dbs;
|
MDBX_db *mt_dbs;
|
||||||
/* Array of sequence numbers for each DB handle */
|
/* Array of sequence numbers for each DB handle */
|
||||||
unsigned *mt_dbiseqs;
|
unsigned *mt_dbiseqs;
|
||||||
|
/* In write txns, array of cursors for each DB */
|
||||||
|
MDBX_cursor **mt_cursors;
|
||||||
|
|
||||||
/* Transaction DB Flags */
|
/* Transaction DB Flags */
|
||||||
#define DB_DIRTY MDBX_TBL_DIRTY /* DB was written in this txn */
|
#define DB_DIRTY MDBX_TBL_DIRTY /* DB was written in this txn */
|
||||||
@ -736,10 +738,8 @@ struct MDBX_txn {
|
|||||||
#define DB_USRVALID 0x20 /* As DB_VALID, but not set for FREE_DBI */
|
#define DB_USRVALID 0x20 /* As DB_VALID, but not set for FREE_DBI */
|
||||||
#define DB_DUPDATA 0x40 /* DB is MDBX_DUPSORT data */
|
#define DB_DUPDATA 0x40 /* DB is MDBX_DUPSORT data */
|
||||||
#define DB_AUDITED 0x80 /* Internal flag for accounting during audit */
|
#define DB_AUDITED 0x80 /* Internal flag for accounting during audit */
|
||||||
/* In write txns, array of cursors for each DB */
|
|
||||||
MDBX_cursor **mt_cursors;
|
|
||||||
/* Array of flags for each DB */
|
/* Array of flags for each DB */
|
||||||
uint8_t *mt_dbflags;
|
uint8_t *mt_dbstate;
|
||||||
/* Number of DB records in use, or 0 when the txn is finished.
|
/* Number of DB records in use, or 0 when the txn is finished.
|
||||||
* This number only ever increments until the txn finishes; we
|
* This number only ever increments until the txn finishes; we
|
||||||
* don't decrement it when individual DB handles are closed. */
|
* don't decrement it when individual DB handles are closed. */
|
||||||
@ -822,10 +822,10 @@ struct MDBX_cursor {
|
|||||||
MDBX_db *mc_db;
|
MDBX_db *mc_db;
|
||||||
/* The database auxiliary record for this cursor */
|
/* The database auxiliary record for this cursor */
|
||||||
MDBX_dbx *mc_dbx;
|
MDBX_dbx *mc_dbx;
|
||||||
/* The mt_dbflag for this database */
|
/* The mt_dbstate for this database */
|
||||||
uint8_t *mc_dbflag;
|
uint8_t *mc_dbstate;
|
||||||
uint16_t mc_snum; /* number of pushed pages */
|
unsigned mc_snum; /* number of pushed pages */
|
||||||
uint16_t mc_top; /* index of top page, normally mc_snum-1 */
|
unsigned mc_top; /* index of top page, normally mc_snum-1 */
|
||||||
/* Cursor state flags. */
|
/* Cursor state flags. */
|
||||||
#define C_INITIALIZED 0x01 /* cursor has been initialized and is valid */
|
#define C_INITIALIZED 0x01 /* cursor has been initialized and is valid */
|
||||||
#define C_EOF 0x02 /* No more data */
|
#define C_EOF 0x02 /* No more data */
|
||||||
@ -850,8 +850,8 @@ typedef struct MDBX_xcursor {
|
|||||||
MDBX_db mx_db;
|
MDBX_db mx_db;
|
||||||
/* The auxiliary DB record for this Dup DB */
|
/* The auxiliary DB record for this Dup DB */
|
||||||
MDBX_dbx mx_dbx;
|
MDBX_dbx mx_dbx;
|
||||||
/* The mt_dbflag for this Dup DB */
|
/* The mt_dbstate for this Dup DB */
|
||||||
uint8_t mx_dbflag;
|
uint8_t mx_dbstate;
|
||||||
} MDBX_xcursor;
|
} MDBX_xcursor;
|
||||||
|
|
||||||
typedef struct MDBX_cursor_couple {
|
typedef struct MDBX_cursor_couple {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user