mdbx: rename roundup_powerof2() to ceil_powerof2().

Change-Id: Ie22f10ffa6637ef74f2c705fad5fc45a8d19d22e
This commit is contained in:
Leonid Yuriev 2020-04-07 03:19:35 +03:00
parent 4ad1c2daed
commit a846fb0d21
3 changed files with 28 additions and 29 deletions

View File

@ -489,7 +489,7 @@ static __pure_function __always_inline pgno_t bytes2pgno(const MDBX_env *env,
static __pure_function size_t pgno_align2os_bytes(const MDBX_env *env, static __pure_function size_t pgno_align2os_bytes(const MDBX_env *env,
pgno_t pgno) { pgno_t pgno) {
return roundup_powerof2(pgno2bytes(env, pgno), env->me_os_psize); return ceil_powerof2(pgno2bytes(env, pgno), env->me_os_psize);
} }
static __pure_function pgno_t pgno_align2os_pgno(const MDBX_env *env, static __pure_function pgno_t pgno_align2os_pgno(const MDBX_env *env,
@ -499,8 +499,7 @@ static __pure_function pgno_t pgno_align2os_pgno(const MDBX_env *env,
static __pure_function size_t bytes_align2os_bytes(const MDBX_env *env, static __pure_function size_t bytes_align2os_bytes(const MDBX_env *env,
size_t bytes) { size_t bytes) {
return roundup_powerof2(roundup_powerof2(bytes, env->me_psize), return ceil_powerof2(ceil_powerof2(bytes, env->me_psize), env->me_os_psize);
env->me_os_psize);
} }
/* Address of first usable data byte in a page, after the header */ /* Address of first usable data byte in a page, after the header */
@ -2535,10 +2534,10 @@ static int lcklist_detach_locked(MDBX_env *env) {
static __always_inline size_t pnl2bytes(const size_t size) { static __always_inline size_t pnl2bytes(const size_t size) {
assert(size > 0 && size <= MDBX_PNL_MAX * 2); assert(size > 0 && size <= MDBX_PNL_MAX * 2);
size_t bytes = roundup_powerof2(MDBX_ASSUME_MALLOC_OVERHEAD + size_t bytes =
sizeof(pgno_t) * (size + 2), ceil_powerof2(MDBX_ASSUME_MALLOC_OVERHEAD + sizeof(pgno_t) * (size + 2),
MDBX_PNL_GRANULATE * sizeof(pgno_t)) - MDBX_PNL_GRANULATE * sizeof(pgno_t)) -
MDBX_ASSUME_MALLOC_OVERHEAD; MDBX_ASSUME_MALLOC_OVERHEAD;
return bytes; return bytes;
} }
@ -2802,10 +2801,10 @@ static __hot unsigned mdbx_pnl_exist(MDBX_PNL pnl, pgno_t id) {
static __always_inline size_t txl2bytes(const size_t size) { static __always_inline size_t txl2bytes(const size_t size) {
assert(size > 0 && size <= MDBX_TXL_MAX * 2); assert(size > 0 && size <= MDBX_TXL_MAX * 2);
size_t bytes = roundup_powerof2(MDBX_ASSUME_MALLOC_OVERHEAD + size_t bytes =
sizeof(txnid_t) * (size + 2), ceil_powerof2(MDBX_ASSUME_MALLOC_OVERHEAD + sizeof(txnid_t) * (size + 2),
MDBX_TXL_GRANULATE * sizeof(txnid_t)) - MDBX_TXL_GRANULATE * sizeof(txnid_t)) -
MDBX_ASSUME_MALLOC_OVERHEAD; MDBX_ASSUME_MALLOC_OVERHEAD;
return bytes; return bytes;
} }
@ -5349,7 +5348,7 @@ __hot static void mdbx_page_copy(MDBX_page *dst, MDBX_page *src, size_t psize) {
/* If page isn't full, just copy the used portion. Adjust /* If page isn't full, just copy the used portion. Adjust
* alignment so memcpy may copy words instead of bytes. */ * alignment so memcpy may copy words instead of bytes. */
if (unused >= MDBX_CACHELINE_SIZE * 2) { if (unused >= MDBX_CACHELINE_SIZE * 2) {
lower = roundup_powerof2(lower + PAGEHDRSZ, sizeof(void *)); lower = ceil_powerof2(lower + PAGEHDRSZ, sizeof(void *));
upper = (upper + PAGEHDRSZ) & ~(sizeof(void *) - 1); upper = (upper + PAGEHDRSZ) & ~(sizeof(void *) - 1);
memcpy(dst, src, lower); memcpy(dst, src, lower);
dst = (void *)((char *)dst + upper); dst = (void *)((char *)dst + upper);
@ -8142,7 +8141,7 @@ static int __cold mdbx_validate_meta(MDBX_env *env, MDBX_meta *const meta,
const uint64_t mapsize_max = meta->mm_geo.upper * (uint64_t)meta->mm_psize; const uint64_t mapsize_max = meta->mm_geo.upper * (uint64_t)meta->mm_psize;
STATIC_ASSERT(MIN_MAPSIZE < MAX_MAPSIZE); STATIC_ASSERT(MIN_MAPSIZE < MAX_MAPSIZE);
if (mapsize_max > MAX_MAPSIZE || if (mapsize_max > MAX_MAPSIZE ||
MAX_PAGENO < roundup_powerof2((size_t)mapsize_max, env->me_os_psize) / MAX_PAGENO < ceil_powerof2((size_t)mapsize_max, env->me_os_psize) /
(size_t)meta->mm_psize) { (size_t)meta->mm_psize) {
if (meta->mm_geo.next - 1 > MAX_PAGENO || used_bytes > MAX_MAPSIZE) { if (meta->mm_geo.next - 1 > MAX_PAGENO || used_bytes > MAX_MAPSIZE) {
mdbx_notice("meta[%u] has too large max-mapsize (%" PRIu64 "), skip it", mdbx_notice("meta[%u] has too large max-mapsize (%" PRIu64 "), skip it",
@ -8923,9 +8922,9 @@ mdbx_env_set_geometry(MDBX_env *env, intptr_t size_lower, intptr_t size_now,
const size_t unit = const size_t unit =
(env->me_os_psize > (size_t)pagesize) ? env->me_os_psize : pagesize; (env->me_os_psize > (size_t)pagesize) ? env->me_os_psize : pagesize;
size_lower = roundup_powerof2(size_lower, unit); size_lower = ceil_powerof2(size_lower, unit);
size_upper = roundup_powerof2(size_upper, unit); size_upper = ceil_powerof2(size_upper, unit);
size_now = roundup_powerof2(size_now, unit); size_now = ceil_powerof2(size_now, unit);
/* LY: подбираем значение size_upper: /* LY: подбираем значение size_upper:
* - кратное размеру страницы * - кратное размеру страницы
@ -8960,13 +8959,13 @@ mdbx_env_set_geometry(MDBX_env *env, intptr_t size_lower, intptr_t size_now,
} }
if (growth_step == 0 && shrink_threshold > 0) if (growth_step == 0 && shrink_threshold > 0)
growth_step = 1; growth_step = 1;
growth_step = roundup_powerof2(growth_step, unit); growth_step = ceil_powerof2(growth_step, unit);
if (bytes2pgno(env, growth_step) > UINT16_MAX) if (bytes2pgno(env, growth_step) > UINT16_MAX)
growth_step = pgno2bytes(env, UINT16_MAX); growth_step = pgno2bytes(env, UINT16_MAX);
if (shrink_threshold < 0) if (shrink_threshold < 0)
shrink_threshold = growth_step + growth_step; shrink_threshold = growth_step + growth_step;
shrink_threshold = roundup_powerof2(shrink_threshold, unit); shrink_threshold = ceil_powerof2(shrink_threshold, unit);
if (bytes2pgno(env, shrink_threshold) > UINT16_MAX) if (bytes2pgno(env, shrink_threshold) > UINT16_MAX)
shrink_threshold = pgno2bytes(env, UINT16_MAX); shrink_threshold = pgno2bytes(env, UINT16_MAX);
@ -9206,7 +9205,7 @@ static int __cold mdbx_setup_dxb(MDBX_env *env, const int lck_rc) {
mdbx_setup_pagesize(env, meta.mm_psize); mdbx_setup_pagesize(env, meta.mm_psize);
const size_t used_bytes = pgno2bytes(env, meta.mm_geo.next); const size_t used_bytes = pgno2bytes(env, meta.mm_geo.next);
const size_t used_aligned2os_bytes = const size_t used_aligned2os_bytes =
roundup_powerof2(used_bytes, env->me_os_psize); ceil_powerof2(used_bytes, env->me_os_psize);
if ((env->me_flags & MDBX_RDONLY) /* readonly */ if ((env->me_flags & MDBX_RDONLY) /* readonly */
|| lck_rc != MDBX_RESULT_TRUE /* not exclusive */) { || lck_rc != MDBX_RESULT_TRUE /* not exclusive */) {
/* use present params from db */ /* use present params from db */
@ -9432,7 +9431,7 @@ static int __cold mdbx_setup_dxb(MDBX_env *env, const int lck_rc) {
head->mm_txnid_b.inconsistent = undo_txnid; head->mm_txnid_b.inconsistent = undo_txnid;
const size_t offset = (uint8_t *)data_page(head) - env->me_dxb_mmap.dxb; const size_t offset = (uint8_t *)data_page(head) - env->me_dxb_mmap.dxb;
const size_t paged_offset = offset & ~(env->me_os_psize - 1); const size_t paged_offset = offset & ~(env->me_os_psize - 1);
const size_t paged_length = roundup_powerof2( const size_t paged_length = ceil_powerof2(
env->me_psize + offset - paged_offset, env->me_os_psize); env->me_psize + offset - paged_offset, env->me_os_psize);
err = mdbx_msync(&env->me_dxb_mmap, paged_offset, paged_length, false); err = mdbx_msync(&env->me_dxb_mmap, paged_offset, paged_length, false);
} else { } else {
@ -9662,9 +9661,9 @@ static int __cold mdbx_setup_lck(MDBX_env *env, char *lck_pathname,
goto bailout; goto bailout;
if (lck_seize_rc == MDBX_RESULT_TRUE) { if (lck_seize_rc == MDBX_RESULT_TRUE) {
size = roundup_powerof2(env->me_maxreaders * sizeof(MDBX_reader) + size = ceil_powerof2(env->me_maxreaders * sizeof(MDBX_reader) +
sizeof(MDBX_lockinfo), sizeof(MDBX_lockinfo),
env->me_os_psize); env->me_os_psize);
mdbx_jitter4testing(false); mdbx_jitter4testing(false);
} else { } else {
if (env->me_flags & MDBX_EXCLUSIVE) { if (env->me_flags & MDBX_EXCLUSIVE) {
@ -15174,7 +15173,7 @@ static int __cold mdbx_env_compact(MDBX_env *env, MDBX_txn *read_txn,
const bool dest_is_pipe) { const bool dest_is_pipe) {
const size_t meta_bytes = pgno2bytes(env, NUM_METAS); const size_t meta_bytes = pgno2bytes(env, NUM_METAS);
uint8_t *const data_buffer = uint8_t *const data_buffer =
buffer + roundup_powerof2(meta_bytes, env->me_os_psize); buffer + ceil_powerof2(meta_bytes, env->me_os_psize);
MDBX_meta *const meta = mdbx_init_metas(env, buffer); MDBX_meta *const meta = mdbx_init_metas(env, buffer);
/* copy canary sequenses if present */ /* copy canary sequenses if present */
if (read_txn->mt_canary.v) { if (read_txn->mt_canary.v) {
@ -15340,7 +15339,7 @@ static int __cold mdbx_env_copy_asis(MDBX_env *env, MDBX_txn *read_txn,
rc = mdbx_write(fd, buffer, meta_bytes); rc = mdbx_write(fd, buffer, meta_bytes);
uint8_t *const data_buffer = uint8_t *const data_buffer =
buffer + roundup_powerof2(meta_bytes, env->me_os_psize); buffer + ceil_powerof2(meta_bytes, env->me_os_psize);
for (size_t offset = meta_bytes; rc == MDBX_SUCCESS && offset < used_size;) { for (size_t offset = meta_bytes; rc == MDBX_SUCCESS && offset < used_size;) {
if (dest_is_pipe) { if (dest_is_pipe) {
#if defined(__linux__) || defined(__gnu_linux__) && !defined(MDBX_SAFE4QEMU) #if defined(__linux__) || defined(__gnu_linux__) && !defined(MDBX_SAFE4QEMU)
@ -15417,8 +15416,8 @@ int __cold mdbx_env_copy2fd(MDBX_env *env, mdbx_filehandle_t fd,
const size_t buffer_size = const size_t buffer_size =
pgno_align2os_bytes(env, NUM_METAS) + pgno_align2os_bytes(env, NUM_METAS) +
roundup_powerof2(((flags & MDBX_CP_COMPACT) ? MDBX_WBUF * 2 : MDBX_WBUF), ceil_powerof2(((flags & MDBX_CP_COMPACT) ? MDBX_WBUF * 2 : MDBX_WBUF),
env->me_os_psize); env->me_os_psize);
uint8_t *buffer = NULL; uint8_t *buffer = NULL;
int rc = mdbx_memalign_alloc(env->me_os_psize, buffer_size, (void **)&buffer); int rc = mdbx_memalign_alloc(env->me_os_psize, buffer_size, (void **)&buffer);

View File

@ -1325,7 +1325,7 @@ is_powerof2(size_t x) {
} }
static __pure_function __always_inline __maybe_unused size_t static __pure_function __always_inline __maybe_unused size_t
roundup_powerof2(size_t value, size_t granularity) { ceil_powerof2(size_t value, size_t granularity) {
assert(is_powerof2(granularity)); assert(is_powerof2(granularity));
return (value + granularity - 1) & ~(granularity - 1); return (value + granularity - 1) & ~(granularity - 1);
} }

View File

@ -313,7 +313,7 @@ MDBX_INTERNAL_FUNC int mdbx_memalign_alloc(size_t alignment, size_t bytes,
*result = VirtualAlloc(NULL, bytes, MEM_COMMIT | MEM_RESERVE, PAGE_READWRITE); *result = VirtualAlloc(NULL, bytes, MEM_COMMIT | MEM_RESERVE, PAGE_READWRITE);
return *result ? MDBX_SUCCESS : MDBX_ENOMEM /* ERROR_OUTOFMEMORY */; return *result ? MDBX_SUCCESS : MDBX_ENOMEM /* ERROR_OUTOFMEMORY */;
#elif defined(_ISOC11_SOURCE) #elif defined(_ISOC11_SOURCE)
*result = aligned_alloc(alignment, roundup_powerof2(bytes, alignment)); *result = aligned_alloc(alignment, ceil_powerof2(bytes, alignment));
return *result ? MDBX_SUCCESS : errno; return *result ? MDBX_SUCCESS : errno;
#elif _POSIX_VERSION >= 200112L #elif _POSIX_VERSION >= 200112L
*result = nullptr; *result = nullptr;