mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-08 07:34:12 +08:00
mdbx: minor/insignificant fix checking mdbx_rdt_lock()
result for cases mutex-recovery after EOWNERDEAD
.
Change-Id: Ia5e13ea0d72afc97f7d678832a765a192dfacdff
This commit is contained in:
parent
e14c6646f6
commit
6d2914c99b
12
src/core.c
12
src/core.c
@ -4803,9 +4803,11 @@ static __cold int mdbx_mapresize(MDBX_env *env, const pgno_t used_pgno,
|
|||||||
goto bailout;
|
goto bailout;
|
||||||
|
|
||||||
if (limit_bytes != env->me_dxb_mmap.limit && env->me_lck && !implicit) {
|
if (limit_bytes != env->me_dxb_mmap.limit && env->me_lck && !implicit) {
|
||||||
rc = mdbx_rdt_lock(env) /* lock readers table until remap done */;
|
int err = mdbx_rdt_lock(env) /* lock readers table until remap done */;
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(MDBX_IS_ERROR(err))) {
|
||||||
|
rc = err;
|
||||||
goto bailout;
|
goto bailout;
|
||||||
|
}
|
||||||
|
|
||||||
/* looking for readers from this process */
|
/* looking for readers from this process */
|
||||||
MDBX_lockinfo *const lck = env->me_lck;
|
MDBX_lockinfo *const lck = env->me_lck;
|
||||||
@ -9538,9 +9540,11 @@ mdbx_env_set_geometry(MDBX_env *env, intptr_t size_lower, intptr_t size_now,
|
|||||||
rc = MDBX_EPERM;
|
rc = MDBX_EPERM;
|
||||||
goto bailout;
|
goto bailout;
|
||||||
}
|
}
|
||||||
rc = mdbx_rdt_lock(env);
|
int err = mdbx_rdt_lock(env);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(MDBX_IS_ERROR(err))) {
|
||||||
|
rc = err;
|
||||||
goto bailout;
|
goto bailout;
|
||||||
|
}
|
||||||
|
|
||||||
/* Check if there are any reading threads that do not use the SRWL */
|
/* Check if there are any reading threads that do not use the SRWL */
|
||||||
const size_t CurrentTid = GetCurrentThreadId();
|
const size_t CurrentTid = GetCurrentThreadId();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user