mdbx: fix SIGSEGV/invalid-deref/invalid-free inside env_close() when mdbx_env_open() failed in re-open case (backport).

Thanks to [@leisim](https://t.me/leisim) for [reporting](https://t.me/libmdbx/3946) this issue.
This commit is contained in:
Леонид Юрьев (Leonid Yuriev) 2022-11-23 00:57:02 +03:00
parent 30f292d496
commit 6139443ef1
2 changed files with 6 additions and 1 deletions

View File

@ -7,6 +7,10 @@ Fixes:
- Fixed insignificant typo of `||` inside `#if` byte-order condition (backport).
- Fixed`SIGSEGV` or an erroneous call to `free()` in situations where
errors occur when reopening by `mdbx_env_open()` of a previously used
environment (backport).
## v0.11.13 (Swashplate) at 2022-11-10

View File

@ -13447,9 +13447,10 @@ __cold static int mdbx_env_close0(MDBX_env *env) {
}
if (env->me_dbxs) {
for (unsigned i = env->me_numdbs; --i >= CORE_DBS;)
for (unsigned i = CORE_DBS; i < env->me_numdbs; ++i)
mdbx_free(env->me_dbxs[i].md_name.iov_base);
mdbx_free(env->me_dbxs);
env->me_numdbs = CORE_DBS;
env->me_dbxs = nullptr;
}
if (env->me_pbuf) {