mdbx: fix selecting/adjustment values inside mdbx_env_set_geometry() for implicit out-of-range cases.

Fixes https://github.com/erthink/libmdbx/issues/170.

Change-Id: Ibc8754811aa3d9077447220f9fec7a5543e40cc4
This commit is contained in:
Leonid Yuriev 2021-03-13 19:55:19 +03:00
parent 439cccf65f
commit 55620c1d13
2 changed files with 13 additions and 2 deletions

View File

@ -35,6 +35,7 @@ Fixes:
- 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). - 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).
- Fixed the selecting/adjustment values inside `mdbx_env_set_geometry()` for implicit out-of-range cases (https://github.com/erthink/libmdbx/issues/170).
## v0.9.3 at 2021-02-02 ## v0.9.3 at 2021-02-02

View File

@ -10594,8 +10594,11 @@ mdbx_env_set_geometry(MDBX_env *env, intptr_t size_lower, intptr_t size_now,
if (MIN_MAPSIZE / pagesize < MIN_PAGENO) if (MIN_MAPSIZE / pagesize < MIN_PAGENO)
size_lower = MIN_PAGENO * pagesize; size_lower = MIN_PAGENO * pagesize;
} }
if (size_lower == INTPTR_MAX) if (size_lower >= INTPTR_MAX) {
size_lower = MAX_MAPSIZE; size_lower = MAX_MAPSIZE;
if ((size_t)size_lower / pagesize > MAX_PAGENO)
size_lower = pagesize * MAX_PAGENO;
}
if (size_now <= 0) { if (size_now <= 0) {
size_now = DEFAULT_MAPSIZE; size_now = DEFAULT_MAPSIZE;
@ -10604,8 +10607,11 @@ mdbx_env_set_geometry(MDBX_env *env, intptr_t size_lower, intptr_t size_now,
if (size_upper >= size_lower && size_now > size_upper) if (size_upper >= size_lower && size_now > size_upper)
size_now = size_upper; size_now = size_upper;
} }
if (size_now == INTPTR_MAX) if (size_now >= INTPTR_MAX) {
size_now = MAX_MAPSIZE; size_now = MAX_MAPSIZE;
if ((size_t)size_now / pagesize > MAX_PAGENO)
size_now = pagesize * MAX_PAGENO;
}
if (size_upper <= 0) { if (size_upper <= 0) {
if ((size_t)size_now >= MAX_MAPSIZE / 2) if ((size_t)size_now >= MAX_MAPSIZE / 2)
@ -10621,6 +10627,10 @@ mdbx_env_set_geometry(MDBX_env *env, intptr_t size_lower, intptr_t size_now,
} }
if ((size_t)size_upper / pagesize > MAX_PAGENO) if ((size_t)size_upper / pagesize > MAX_PAGENO)
size_upper = pagesize * MAX_PAGENO; size_upper = pagesize * MAX_PAGENO;
} else if (size_upper >= INTPTR_MAX) {
size_upper = MAX_MAPSIZE;
if ((size_t)size_upper / pagesize > MAX_PAGENO)
size_upper = pagesize * MAX_PAGENO;
} }
if (unlikely(size_lower < (intptr_t)MIN_MAPSIZE || size_lower > size_upper)) { if (unlikely(size_lower < (intptr_t)MIN_MAPSIZE || size_lower > size_upper)) {