mdbx: cleanup mdbx_mutex_failed().

This commit is contained in:
Leo Yuriev 2017-04-21 19:00:07 +03:00
parent ebb404e5bc
commit 36f1491ba8

View File

@ -208,11 +208,9 @@ static int mdbx_lck_op(mdbx_filehandle_t fd, int op, int lck, off_t offset) {
static int __cold mdbx_mutex_failed(MDB_env *env, mdbx_mutex_t *mutex, int rc) { static int __cold mdbx_mutex_failed(MDB_env *env, mdbx_mutex_t *mutex, int rc) {
#if MDB_USE_ROBUST #if MDB_USE_ROBUST
if (unlikely(rc == EOWNERDEAD)) { if (unlikely(rc == EOWNERDEAD)) {
int rlocked, rc2;
/* We own the mutex. Clean up after dead previous owner. */ /* We own the mutex. Clean up after dead previous owner. */
rc = MDBX_RESULT_TRUE; rc = MDB_SUCCESS;
rlocked = (mutex == &env->me_txns->mti_rmutex); int rlocked = (mutex == &env->me_txns->mti_rmutex);
if (!rlocked) { if (!rlocked) {
/* env is hosed if the dead thread was ours */ /* env is hosed if the dead thread was ours */
if (env->me_txn) { if (env->me_txn) {
@ -223,7 +221,7 @@ static int __cold mdbx_mutex_failed(MDB_env *env, mdbx_mutex_t *mutex, int rc) {
} }
mdbx_debug("%cmutex owner died, %s", (rlocked ? 'r' : 'w'), mdbx_debug("%cmutex owner died, %s", (rlocked ? 'r' : 'w'),
(rc ? "this process' env is hosed" : "recovering")); (rc ? "this process' env is hosed" : "recovering"));
rc2 = mdbx_reader_check0(env, rlocked, NULL); int rc2 = mdbx_reader_check0(env, rlocked, NULL);
if (rc2 == 0) if (rc2 == 0)
#if __GLIBC_PREREQ(2, 12) #if __GLIBC_PREREQ(2, 12)
rc2 = pthread_mutex_consistent(mutex); rc2 = pthread_mutex_consistent(mutex);