mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-04 18:14:12 +08:00
mdbx: исправление неожиданного MDBX_BUSY
из mdbx_env_set_option()
(backport).
This commit is contained in:
parent
5dcc0171fa
commit
1b3b6e4479
37
src/core.c
37
src/core.c
@ -22670,14 +22670,17 @@ __cold int mdbx_env_set_option(MDBX_env *env, const MDBX_option_t option,
|
||||
return MDBX_EPERM;
|
||||
if (unlikely(value > SIZE_MAX - 65536))
|
||||
return MDBX_TOO_LARGE;
|
||||
if (atomic_store32(&env->me_lck->mti_autosync_threshold,
|
||||
bytes2pgno(env, (size_t)value + env->me_psize - 1),
|
||||
mo_Relaxed) != 0 &&
|
||||
(env->me_flags & MDBX_ENV_ACTIVE)) {
|
||||
err = mdbx_env_sync_poll(env);
|
||||
if (unlikely(MDBX_IS_ERROR(err)))
|
||||
return err;
|
||||
err = MDBX_SUCCESS;
|
||||
value = bytes2pgno(env, (size_t)value + env->me_psize - 1);
|
||||
if ((uint32_t)value != atomic_load32(&env->me_lck->mti_autosync_threshold,
|
||||
mo_AcquireRelease) &&
|
||||
atomic_store32(&env->me_lck->mti_autosync_threshold, (uint32_t)value,
|
||||
mo_Relaxed)
|
||||
/* Дергаем sync(force=off) только если задано новое не-нулевое значение
|
||||
* и мы вне транзакции */
|
||||
&& lock_needed) {
|
||||
err = mdbx_env_sync_internal(env, false, false);
|
||||
if (err == /* нечего сбрасывать на диск */ MDBX_RESULT_TRUE)
|
||||
err = MDBX_SUCCESS;
|
||||
}
|
||||
break;
|
||||
|
||||
@ -22690,14 +22693,16 @@ __cold int mdbx_env_set_option(MDBX_env *env, const MDBX_option_t option,
|
||||
return MDBX_EPERM;
|
||||
if (unlikely(value > UINT32_MAX))
|
||||
return MDBX_TOO_LARGE;
|
||||
if (atomic_store64(&env->me_lck->mti_autosync_period,
|
||||
mdbx_osal_16dot16_to_monotime((uint32_t)value),
|
||||
mo_Relaxed) != 0 &&
|
||||
(env->me_flags & MDBX_ENV_ACTIVE)) {
|
||||
err = mdbx_env_sync_poll(env);
|
||||
if (unlikely(MDBX_IS_ERROR(err)))
|
||||
return err;
|
||||
err = MDBX_SUCCESS;
|
||||
value = mdbx_osal_16dot16_to_monotime((uint32_t)value);
|
||||
if (value != atomic_load64(&env->me_lck->mti_autosync_period,
|
||||
mo_AcquireRelease) &&
|
||||
atomic_store64(&env->me_lck->mti_autosync_period, value, mo_Relaxed)
|
||||
/* Дергаем sync(force=off) только если задано новое не-нулевое значение
|
||||
* и мы вне транзакции */
|
||||
&& lock_needed) {
|
||||
err = mdbx_env_sync_internal(env, false, false);
|
||||
if (err == /* нечего сбрасывать на диск */ MDBX_RESULT_TRUE)
|
||||
err = MDBX_SUCCESS;
|
||||
}
|
||||
break;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user