mdbx: internal cleanup (rename, etc).

This commit is contained in:
Leo Yuriev 2017-04-26 18:13:48 +03:00
parent 953c6962ea
commit 333e5fada3
2 changed files with 44 additions and 44 deletions

View File

@ -104,10 +104,10 @@ int mdbx_lck_init(MDB_env *env) {
goto bailout; goto bailout;
#endif /* PTHREAD_PRIO_INHERIT */ #endif /* PTHREAD_PRIO_INHERIT */
rc = pthread_mutex_init(&env->me_txns->mti_rmutex, &ma); rc = pthread_mutex_init(&env->me_lck->mti_rmutex, &ma);
if (rc) if (rc)
goto bailout; goto bailout;
rc = pthread_mutex_init(&env->me_txns->mti_wmutex, &ma); rc = pthread_mutex_init(&env->me_lck->mti_wmutex, &ma);
bailout: bailout:
pthread_mutexattr_destroy(&ma); pthread_mutexattr_destroy(&ma);
@ -117,12 +117,12 @@ bailout:
void mdbx_lck_destroy(MDB_env *env) { void mdbx_lck_destroy(MDB_env *env) {
if (env->me_lfd != INVALID_HANDLE_VALUE) { if (env->me_lfd != INVALID_HANDLE_VALUE) {
/* try get exclusive access */ /* try get exclusive access */
if (env->me_txns && if (env->me_lck &&
mdbx_lck_op(env->me_lfd, F_SETLK, F_WRLCK, 0, LCK_WHOLE) == 0) { mdbx_lck_op(env->me_lfd, F_SETLK, F_WRLCK, 0, LCK_WHOLE) == 0) {
/* got exclusive, drown mutexes */ /* got exclusive, drown mutexes */
int rc = pthread_mutex_destroy(&env->me_txns->mti_rmutex); int rc = pthread_mutex_destroy(&env->me_lck->mti_rmutex);
if (rc == 0) if (rc == 0)
rc = pthread_mutex_destroy(&env->me_txns->mti_wmutex); rc = pthread_mutex_destroy(&env->me_lck->mti_wmutex);
assert(rc == 0); assert(rc == 0);
(void)rc; (void)rc;
/* lock would be released (by kernel) while the me_lfd will be closed */ /* lock would be released (by kernel) while the me_lfd will be closed */
@ -145,22 +145,22 @@ static int mdbx_robust_unlock(MDB_env *env, pthread_mutex_t *mutex) {
} }
int mdbx_rdt_lock(MDB_env *env) { int mdbx_rdt_lock(MDB_env *env) {
return mdbx_robust_lock(env, &env->me_txns->mti_rmutex); return mdbx_robust_lock(env, &env->me_lck->mti_rmutex);
} }
void mdbx_rdt_unlock(MDB_env *env) { void mdbx_rdt_unlock(MDB_env *env) {
int rc = mdbx_robust_unlock(env, &env->me_txns->mti_rmutex); int rc = mdbx_robust_unlock(env, &env->me_lck->mti_rmutex);
if (unlikely(MDBX_IS_ERROR(rc))) if (unlikely(MDBX_IS_ERROR(rc)))
mdbx_panic("%s() failed: errcode %d\n", mdbx_func_, rc); mdbx_panic("%s() failed: errcode %d\n", mdbx_func_, rc);
} }
int mdbx_txn_lock(MDB_env *env) { int mdbx_txn_lock(MDB_env *env) {
int rc = mdbx_robust_lock(env, &env->me_txns->mti_wmutex); int rc = mdbx_robust_lock(env, &env->me_lck->mti_wmutex);
return MDBX_IS_ERROR(rc) ? rc : MDB_SUCCESS; return MDBX_IS_ERROR(rc) ? rc : MDB_SUCCESS;
} }
void mdbx_txn_unlock(MDB_env *env) { void mdbx_txn_unlock(MDB_env *env) {
int rc = mdbx_robust_unlock(env, &env->me_txns->mti_wmutex); int rc = mdbx_robust_unlock(env, &env->me_lck->mti_wmutex);
if (unlikely(MDBX_IS_ERROR(rc))) if (unlikely(MDBX_IS_ERROR(rc)))
mdbx_panic("%s() failed: errcode %d\n", mdbx_func_, rc); mdbx_panic("%s() failed: errcode %d\n", mdbx_func_, rc);
} }
@ -253,7 +253,7 @@ static int __cold mdbx_mutex_failed(MDB_env *env, mdbx_mutex_t *mutex, int rc) {
if (rc == EOWNERDEAD) { if (rc == EOWNERDEAD) {
/* We own the mutex. Clean up after dead previous owner. */ /* We own the mutex. Clean up after dead previous owner. */
int rlocked = (mutex == &env->me_txns->mti_rmutex); int rlocked = (mutex == &env->me_lck->mti_rmutex);
rc = MDB_SUCCESS; rc = MDB_SUCCESS;
if (!rlocked) { if (!rlocked) {
if (unlikely(env->me_txn)) { if (unlikely(env->me_txn)) {

View File

@ -1409,8 +1409,8 @@ static txnid_t mdbx_find_oldest(MDB_env *env, int *laggard) {
txnid_t oldest = mdbx_meta_lt(a, b) ? b->mm_txnid : a->mm_txnid; txnid_t oldest = mdbx_meta_lt(a, b) ? b->mm_txnid : a->mm_txnid;
int i, reader; int i, reader;
const MDB_reader *const r = env->me_txns->mti_readers; const MDB_reader *const r = env->me_lck->mti_readers;
for (reader = -1, i = env->me_txns->mti_numreaders; --i >= 0;) { for (reader = -1, i = env->me_lck->mti_numreaders; --i >= 0;) {
if (r[i].mr_pid) { if (r[i].mr_pid) {
txnid_t snap = r[i].mr_txnid; txnid_t snap = r[i].mr_txnid;
if (oldest > snap) { if (oldest > snap) {
@ -1971,7 +1971,7 @@ int mdbx_env_sync(MDB_env *env, int force) {
if (unlikely(env->me_signature != MDBX_ME_SIGNATURE)) if (unlikely(env->me_signature != MDBX_ME_SIGNATURE))
return MDBX_EBADSIGN; return MDBX_EBADSIGN;
if (unlikely(!env->me_txns)) if (unlikely(!env->me_lck))
return MDB_PANIC; return MDB_PANIC;
flags = env->me_flags & ~MDB_NOMETASYNC; flags = env->me_flags & ~MDB_NOMETASYNC;
@ -2149,9 +2149,9 @@ static int mdbx_txn_renew0(MDB_txn *txn, unsigned flags) {
} }
for (;;) { for (;;) {
nr = env->me_txns->mti_numreaders; nr = env->me_lck->mti_numreaders;
for (i = 0; i < nr; i++) for (i = 0; i < nr; i++)
if (env->me_txns->mti_readers[i].mr_pid == 0) if (env->me_lck->mti_readers[i].mr_pid == 0)
break; break;
if (likely(i < env->me_maxreaders)) if (likely(i < env->me_maxreaders))
@ -2164,7 +2164,7 @@ static int mdbx_txn_renew0(MDB_txn *txn, unsigned flags) {
} }
} }
r = &env->me_txns->mti_readers[i]; r = &env->me_lck->mti_readers[i];
/* Claim the reader slot, carefully since other code /* Claim the reader slot, carefully since other code
* uses the reader table un-mutexed: First reset the * uses the reader table un-mutexed: First reset the
* slot, next publish it in mtb.mti_numreaders. After * slot, next publish it in mtb.mti_numreaders. After
@ -2175,7 +2175,7 @@ static int mdbx_txn_renew0(MDB_txn *txn, unsigned flags) {
r->mr_tid = tid; r->mr_tid = tid;
mdbx_coherent_barrier(); mdbx_coherent_barrier();
if (i == nr) if (i == nr)
env->me_txns->mti_numreaders = ++nr; env->me_lck->mti_numreaders = ++nr;
if (env->me_close_readers < nr) if (env->me_close_readers < nr)
env->me_close_readers = nr; env->me_close_readers = nr;
r->mr_pid = pid; r->mr_pid = pid;
@ -3831,49 +3831,49 @@ static int __cold mdbx_setup_lck(MDB_env *env, char *lck_pathname, int mode) {
err = mdbx_mmap(&addr, size, true, env->me_lfd); err = mdbx_mmap(&addr, size, true, env->me_lfd);
if (unlikely(err != MDB_SUCCESS)) if (unlikely(err != MDB_SUCCESS))
return err; return err;
env->me_txns = addr; env->me_lck = addr;
#ifdef MADV_NOHUGEPAGE #ifdef MADV_NOHUGEPAGE
(void)madvise(env->me_txns, size, MADV_NOHUGEPAGE); (void)madvise(env->me_lck, size, MADV_NOHUGEPAGE);
#endif #endif
#ifdef MADV_DODUMP #ifdef MADV_DODUMP
(void)madvise(env->me_txns, size, MADV_DODUMP); (void)madvise(env->me_lck, size, MADV_DODUMP);
#endif #endif
#ifdef MADV_DONTFORK #ifdef MADV_DONTFORK
if (madvise(env->me_txns, size, MADV_DONTFORK) < 0) if (madvise(env->me_lck, size, MADV_DONTFORK) < 0)
return errno; return errno;
#endif #endif
#ifdef MADV_WILLNEED #ifdef MADV_WILLNEED
if (madvise(env->me_txns, size, MADV_WILLNEED) < 0) if (madvise(env->me_lck, size, MADV_WILLNEED) < 0)
return errno; return errno;
#endif #endif
#ifdef MADV_RANDOM #ifdef MADV_RANDOM
if (madvise(env->me_txns, size, MADV_RANDOM) < 0) if (madvise(env->me_lck, size, MADV_RANDOM) < 0)
return errno; return errno;
#endif #endif
if (rc == MDBX_RESULT_TRUE) { if (rc == MDBX_RESULT_TRUE) {
/* LY: exlcusive mode, init lck */ /* LY: exlcusive mode, init lck */
memset(env->me_txns, 0, sizeof(MDBX_lockinfo)); memset(env->me_lck, 0, sizeof(MDBX_lockinfo));
err = mdbx_lck_init(env); err = mdbx_lck_init(env);
if (err) if (err)
return err; return err;
env->me_txns->mti_magic = MDB_MAGIC; env->me_lck->mti_magic = MDB_MAGIC;
env->me_txns->mti_format = MDB_LOCK_FORMAT; env->me_lck->mti_format = MDB_LOCK_FORMAT;
} else { } else {
if (env->me_txns->mti_magic != MDB_MAGIC) { if (env->me_lck->mti_magic != MDB_MAGIC) {
mdbx_debug("lock region has invalid magic"); mdbx_debug("lock region has invalid magic");
return MDB_INVALID; return MDB_INVALID;
} }
if (env->me_txns->mti_format != MDB_LOCK_FORMAT) { if (env->me_lck->mti_format != MDB_LOCK_FORMAT) {
mdbx_debug("lock region has format+version 0x%" PRIx64 mdbx_debug("lock region has format+version 0x%" PRIx64
", expected 0x%" PRIx64, ", expected 0x%" PRIx64,
env->me_txns->mti_format, MDB_LOCK_FORMAT); env->me_lck->mti_format, MDB_LOCK_FORMAT);
return MDB_VERSION_MISMATCH; return MDB_VERSION_MISMATCH;
} }
} }
@ -3983,7 +3983,7 @@ int __cold mdbx_env_open_ex(MDB_env *env, const char *path, unsigned flags,
const unsigned mode_flags = const unsigned mode_flags =
MDB_WRITEMAP | MDB_NOSYNC | MDB_NOMETASYNC | MDB_MAPASYNC; MDB_WRITEMAP | MDB_NOSYNC | MDB_NOMETASYNC | MDB_MAPASYNC;
if (lck_rc == MDBX_RESULT_TRUE) { if (lck_rc == MDBX_RESULT_TRUE) {
env->me_txns->mti_envmode = env->me_flags & mode_flags; env->me_lck->mti_envmode = env->me_flags & mode_flags;
if (exclusive == NULL || *exclusive < 2) { if (exclusive == NULL || *exclusive < 2) {
/* LY: downgrade lock only if exclusive access not requested. /* LY: downgrade lock only if exclusive access not requested.
* in case exclusive==1, just leave value as is. */ * in case exclusive==1, just leave value as is. */
@ -3996,7 +3996,7 @@ int __cold mdbx_env_open_ex(MDB_env *env, const char *path, unsigned flags,
/* LY: just indicate that is not an exclusive access. */ /* LY: just indicate that is not an exclusive access. */
*exclusive = 0; *exclusive = 0;
} }
if ((env->me_txns->mti_envmode ^ env->me_flags) & mode_flags) { if ((env->me_lck->mti_envmode ^ env->me_flags) & mode_flags) {
/* LY: Current mode/flags incompatible with requested. */ /* LY: Current mode/flags incompatible with requested. */
rc = MDB_INCOMPATIBLE; rc = MDB_INCOMPATIBLE;
goto bailout; goto bailout;
@ -4004,8 +4004,8 @@ int __cold mdbx_env_open_ex(MDB_env *env, const char *path, unsigned flags,
} }
if ((env->me_flags & MDB_NOTLS) == 0) { if ((env->me_flags & MDB_NOTLS) == 0) {
rc = mdbx_rthc_alloc(&env->me_txkey, &env->me_txns->mti_readers[0], rc = mdbx_rthc_alloc(&env->me_txkey, &env->me_lck->mti_readers[0],
&env->me_txns->mti_readers[env->me_maxreaders]); &env->me_lck->mti_readers[env->me_maxreaders]);
if (unlikely(rc != MDB_SUCCESS)) if (unlikely(rc != MDB_SUCCESS))
return rc; return rc;
env->me_flags |= MDB_ENV_TXKEY; env->me_flags |= MDB_ENV_TXKEY;
@ -4101,10 +4101,10 @@ static void __cold mdbx_env_close0(MDB_env *env) {
env->me_fd = INVALID_HANDLE_VALUE; env->me_fd = INVALID_HANDLE_VALUE;
} }
mdbx_munmap((void *)env->me_txns, mdbx_munmap((void *)env->me_lck,
(env->me_maxreaders - 1) * sizeof(MDB_reader) + (env->me_maxreaders - 1) * sizeof(MDB_reader) +
sizeof(MDBX_lockinfo)); sizeof(MDBX_lockinfo));
env->me_txns = NULL; env->me_lck = NULL;
env->me_pid = 0; env->me_pid = 0;
mdbx_lck_destroy(env); mdbx_lck_destroy(env);
@ -4123,7 +4123,7 @@ int __cold mdbx_env_close_ex(MDB_env *env, int dont_sync) {
if (unlikely(env->me_signature != MDBX_ME_SIGNATURE)) if (unlikely(env->me_signature != MDBX_ME_SIGNATURE))
return MDBX_EBADSIGN; return MDBX_EBADSIGN;
if (!dont_sync && env->me_txns) if (!dont_sync && env->me_lck)
rc = mdbx_env_sync(env, 1); rc = mdbx_env_sync(env, 1);
VALGRIND_DESTROY_MEMPOOL(env); VALGRIND_DESTROY_MEMPOOL(env);
@ -8622,10 +8622,10 @@ int __cold mdbx_env_info(MDB_env *env, MDBX_envinfo *arg, size_t bytes) {
arg->me_mapsize = env->me_mapsize; arg->me_mapsize = env->me_mapsize;
arg->me_maxreaders = env->me_maxreaders; arg->me_maxreaders = env->me_maxreaders;
arg->me_numreaders = env->me_txns->mti_numreaders; arg->me_numreaders = env->me_lck->mti_numreaders;
arg->me_tail_txnid = 0; arg->me_tail_txnid = 0;
r = env->me_txns->mti_readers; r = env->me_lck->mti_readers;
arg->me_tail_txnid = arg->me_last_txnid; arg->me_tail_txnid = arg->me_last_txnid;
for (i = 0; i < arg->me_numreaders; ++i) { for (i = 0; i < arg->me_numreaders; ++i) {
if (r[i].mr_pid) { if (r[i].mr_pid) {
@ -9036,8 +9036,8 @@ int __cold mdbx_reader_list(MDB_env *env, MDB_msg_func *func, void *ctx) {
if (unlikely(env->me_signature != MDBX_ME_SIGNATURE)) if (unlikely(env->me_signature != MDBX_ME_SIGNATURE))
return MDBX_EBADSIGN; return MDBX_EBADSIGN;
snap_nreaders = env->me_txns->mti_numreaders; snap_nreaders = env->me_lck->mti_numreaders;
mr = env->me_txns->mti_readers; mr = env->me_lck->mti_readers;
for (i = 0; i < snap_nreaders; i++) { for (i = 0; i < snap_nreaders; i++) {
if (mr[i].mr_pid) { if (mr[i].mr_pid) {
txnid_t txnid = mr[i].mr_txnid; txnid_t txnid = mr[i].mr_txnid;
@ -9117,12 +9117,12 @@ int __cold mdbx_reader_check0(MDB_env *env, int rdt_locked, int *dead) {
return MDB_PANIC; return MDB_PANIC;
} }
unsigned snap_nreaders = env->me_txns->mti_numreaders; unsigned snap_nreaders = env->me_lck->mti_numreaders;
mdbx_pid_t *pids = alloca((snap_nreaders + 1) * sizeof(mdbx_pid_t)); mdbx_pid_t *pids = alloca((snap_nreaders + 1) * sizeof(mdbx_pid_t));
pids[0] = 0; pids[0] = 0;
int rc = MDBX_RESULT_FALSE, count = 0; int rc = MDBX_RESULT_FALSE, count = 0;
MDB_reader *mr = env->me_txns->mti_readers; MDB_reader *mr = env->me_lck->mti_readers;
for (unsigned i = 0; i < snap_nreaders; i++) { for (unsigned i = 0; i < snap_nreaders; i++) {
const mdbx_pid_t pid = mr[i].mr_pid; const mdbx_pid_t pid = mr[i].mr_pid;
@ -9512,7 +9512,7 @@ static txnid_t __cold mdbx_oomkick(MDB_env *env, txnid_t oldest) {
if (!env->me_oom_func) if (!env->me_oom_func)
break; break;
r = &env->me_txns->mti_readers[reader]; r = &env->me_lck->mti_readers[reader];
pid = r->mr_pid; pid = r->mr_pid;
tid = r->mr_tid; tid = r->mr_tid;
if (r->mr_txnid != oldest || pid <= 0) if (r->mr_txnid != oldest || pid <= 0)
@ -9769,7 +9769,7 @@ int mdbx_canary_put(MDB_txn *txn, const mdbx_canary *canary) {
if (likely(canary)) { if (likely(canary)) {
if (txn->mt_canary.x == canary->x && txn->mt_canary.y == canary->y && if (txn->mt_canary.x == canary->x && txn->mt_canary.y == canary->y &&
txn->mt_canary.z == canary->z && txn->mt_canary.v == canary->v) txn->mt_canary.z == canary->z)
return MDB_SUCCESS; return MDB_SUCCESS;
txn->mt_canary.x = canary->x; txn->mt_canary.x = canary->x;
txn->mt_canary.y = canary->y; txn->mt_canary.y = canary->y;