mdbx: clarify mdbx_env_set_flags().

Change-Id: I45d9af8cbaf9710e78c93d157c70fc2d305f3100
This commit is contained in:
Leonid Yuriev 2019-09-28 20:10:29 +03:00
parent 87f8c01ac4
commit 91ee841fc2
2 changed files with 15 additions and 5 deletions

12
mdbx.h
View File

@ -1717,11 +1717,15 @@ LIBMDBX_API int mdbx_env_close(MDBX_env *env);
/* Set environment flags. /* Set environment flags.
* *
* This may be used to set some flags in addition to those from * This may be used to set some flags in addition to those from
* mdbx_env_open(), or to unset these flags. If several threads * mdbx_env_open(), or to unset these flags.
* change the flags at the same time, the result is undefined.
* *
* [in] env An environment handle returned by mdbx_env_create() * NOTE: In contrast to LMDB, the MDBX serialize threads via mutex while
* [in] flags The flags to change, bitwise OR'ed together * changing the flags. Therefore this function will be blocked while a write
* transaction running by other thread, or MDBX_BUSY will be returned if
* function called within a write transaction.
*
* [in] env An environment handle returned by mdbx_env_create().
* [in] flags The flags to change, bitwise OR'ed together.
* [in] onoff A non-zero value sets the flags, zero clears them. * [in] onoff A non-zero value sets the flags, zero clears them.
* *
* Returns A non-zero error value on failure and 0 on success, some * Returns A non-zero error value on failure and 0 on success, some

View File

@ -12806,7 +12806,13 @@ int __cold mdbx_env_set_flags(MDBX_env *env, unsigned flags, int onoff) {
return MDBX_EBADSIGN; return MDBX_EBADSIGN;
if (unlikely(flags & ~CHANGEABLE)) if (unlikely(flags & ~CHANGEABLE))
return MDBX_EINVAL; return MDBX_EPERM;
if (unlikely(env->me_flags & MDBX_RDONLY))
return MDBX_EACCESS;
if (unlikely(env->me_txn0->mt_owner == mdbx_thread_self()))
return MDBX_BUSY;
int rc = mdbx_txn_lock(env, false); int rc = mdbx_txn_lock(env, false);
if (unlikely(rc)) if (unlikely(rc))