mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-04 18:04:13 +08:00
mdbx: minor refine get_reasonable_db_maxsize()
.
Change-Id: I5d654940a325c0c3966a59a37615820587c52c78
This commit is contained in:
parent
7f5cbf7dd8
commit
20299f87cb
19
src/core.c
19
src/core.c
@ -10532,20 +10532,15 @@ __cold static intptr_t get_reasonable_db_maxsize(intptr_t *cached_result) {
|
|||||||
*cached_result = (intptr_t)((size_t)total_ram_pages * 207 >> 7) * pagesize;
|
*cached_result = (intptr_t)((size_t)total_ram_pages * 207 >> 7) * pagesize;
|
||||||
|
|
||||||
/* Round to the nearest human-readable granulation. */
|
/* Round to the nearest human-readable granulation. */
|
||||||
for (int i = 10; i < MDBX_WORDBITS - 1; i += 10) {
|
for (size_t unit = MEGABYTE; unit; unit <<= 5) {
|
||||||
const size_t unit = (size_t)1 << i;
|
|
||||||
const size_t floor = floor_powerof2(*cached_result, unit);
|
const size_t floor = floor_powerof2(*cached_result, unit);
|
||||||
const size_t ceil = ceil_powerof2(*cached_result, unit);
|
const size_t ceil = ceil_powerof2(*cached_result, unit);
|
||||||
if (*cached_result - floor < ceil - *cached_result ||
|
const size_t threshold = (size_t)*cached_result >> 4;
|
||||||
ceil > MAX_MAPSIZE) {
|
const bool down =
|
||||||
if (*cached_result - floor > (size_t)*cached_result / 16)
|
*cached_result - floor < ceil - *cached_result || ceil > MAX_MAPSIZE;
|
||||||
break;
|
if (threshold < (down ? *cached_result - floor : ceil - *cached_result))
|
||||||
*cached_result = floor;
|
break;
|
||||||
} else {
|
*cached_result = down ? floor : ceil;
|
||||||
if (ceil - *cached_result > (size_t)*cached_result / 16)
|
|
||||||
break;
|
|
||||||
*cached_result = ceil;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return *cached_result;
|
return *cached_result;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user