mdbx: fix mdbx_env_info_ex() for a non-open environment case.

Fix the https://github.com/erthink/libmdbx/issues/171.

Change-Id: Iad3d0186ef40dfd40fad1c3ae0dd97f9c1161c16
This commit is contained in:
Leonid Yuriev 2021-03-13 17:05:43 +03:00
parent a96b6f79c6
commit e43cf081f1
2 changed files with 26 additions and 0 deletions

View File

@ -34,6 +34,7 @@ Fixes:
- Fixed performance regression due non-optimal C11 atomics usage (https://github.com/erthink/libmdbx/issues/160). - Fixed performance regression due non-optimal C11 atomics usage (https://github.com/erthink/libmdbx/issues/160).
- Fixed "reincarnation" of subDB after it deletion (https://github.com/erthink/libmdbx/issues/168). - Fixed "reincarnation" of subDB after it deletion (https://github.com/erthink/libmdbx/issues/168).
- Fixed (disallowing) implicit subDB deletion via operations on `@MAIN`'s DBI-handle. - Fixed (disallowing) implicit subDB deletion via operations on `@MAIN`'s DBI-handle.
- Fixed a crash of `mdbx_env_info_ex()` in case of a call for a non-open environment (https://github.com/erthink/libmdbx/issues/171).
## v0.9.3 at 2021-02-02 ## v0.9.3 at 2021-02-02

View File

@ -18444,6 +18444,31 @@ __cold int mdbx_env_info_ex(const MDBX_env *env, const MDBX_txn *txn,
if (unlikely(bytes != sizeof(MDBX_envinfo)) && bytes != size_before_bootid) if (unlikely(bytes != sizeof(MDBX_envinfo)) && bytes != size_before_bootid)
return MDBX_EINVAL; return MDBX_EINVAL;
/* is the environment open? (https://github.com/erthink/libmdbx/issues/171) */
if (unlikely(!env->me_map)) {
/* environment not yet opened */
#if 1
/* default behavior: returns the available info but zeroed the rest */
memset(arg, 0, bytes);
arg->mi_geo.lower = env->me_dbgeo.lower;
arg->mi_geo.upper = env->me_dbgeo.upper;
arg->mi_geo.shrink = env->me_dbgeo.shrink;
arg->mi_geo.grow = env->me_dbgeo.grow;
arg->mi_geo.current = env->me_dbgeo.now;
arg->mi_maxreaders = env->me_maxreaders;
arg->mi_dxb_pagesize = env->me_psize;
arg->mi_sys_pagesize = env->me_os_psize;
if (likely(bytes > size_before_bootid)) {
arg->mi_bootid.current.x = bootid.x;
arg->mi_bootid.current.y = bootid.y;
}
return MDBX_SUCCESS;
#else
/* some users may prefer this behavior: return appropriate error */
return MDBX_EPERM;
#endif
}
const MDBX_meta *const meta0 = METAPAGE(env, 0); const MDBX_meta *const meta0 = METAPAGE(env, 0);
const MDBX_meta *const meta1 = METAPAGE(env, 1); const MDBX_meta *const meta1 = METAPAGE(env, 1);
const MDBX_meta *const meta2 = METAPAGE(env, 2); const MDBX_meta *const meta2 = METAPAGE(env, 2);