mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-08 05:44:13 +08:00
mdbx: выделение специфической инициализации в osal_ctor()
.
This commit is contained in:
parent
8f8b9f3d2a
commit
28e2e31949
@ -1501,6 +1501,7 @@ __cold void global_dtor(void) {
|
|||||||
workaround_glibc_bug21031();
|
workaround_glibc_bug21031();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
osal_dtor();
|
||||||
TRACE("<< pid %d\n", osal_getpid());
|
TRACE("<< pid %d\n", osal_getpid());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -23946,6 +23947,7 @@ __cold int mdbx_env_warmup(const MDBX_env *env, const MDBX_txn *txn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
__cold void global_ctor(void) {
|
__cold void global_ctor(void) {
|
||||||
|
osal_ctor();
|
||||||
rthc_limit = RTHC_INITIAL_LIMIT;
|
rthc_limit = RTHC_INITIAL_LIMIT;
|
||||||
rthc_table = rthc_table_static;
|
rthc_table = rthc_table_static;
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
|
@ -1464,7 +1464,9 @@ MDBX_INTERNAL_FUNC int rthc_alloc(osal_thread_key_t *key, MDBX_reader *begin,
|
|||||||
MDBX_INTERNAL_FUNC void rthc_remove(const osal_thread_key_t key);
|
MDBX_INTERNAL_FUNC void rthc_remove(const osal_thread_key_t key);
|
||||||
|
|
||||||
MDBX_INTERNAL_FUNC void global_ctor(void);
|
MDBX_INTERNAL_FUNC void global_ctor(void);
|
||||||
|
MDBX_INTERNAL_FUNC void osal_ctor(void);
|
||||||
MDBX_INTERNAL_FUNC void global_dtor(void);
|
MDBX_INTERNAL_FUNC void global_dtor(void);
|
||||||
|
MDBX_INTERNAL_FUNC void osal_dtor(void);
|
||||||
MDBX_INTERNAL_FUNC void thread_dtor(void *ptr);
|
MDBX_INTERNAL_FUNC void thread_dtor(void *ptr);
|
||||||
|
|
||||||
#endif /* !__cplusplus */
|
#endif /* !__cplusplus */
|
||||||
|
120
src/osal.c
120
src/osal.c
@ -623,13 +623,8 @@ MDBX_INTERNAL_FUNC int osal_ioring_create(osal_ioring_t *ior,
|
|||||||
#endif /* !Windows */
|
#endif /* !Windows */
|
||||||
|
|
||||||
#if MDBX_HAVE_PWRITEV && defined(_SC_IOV_MAX)
|
#if MDBX_HAVE_PWRITEV && defined(_SC_IOV_MAX)
|
||||||
if (!osal_iov_max) {
|
assert(osal_iov_max > 0);
|
||||||
osal_iov_max = sysconf(_SC_IOV_MAX);
|
#endif /* MDBX_HAVE_PWRITEV && _SC_IOV_MAX */
|
||||||
if (RUNNING_ON_VALGRIND && osal_iov_max > 64)
|
|
||||||
/* чтобы не описывать все 1024 исключения в valgrind_suppress.txt */
|
|
||||||
osal_iov_max = 64;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
ior->boundary = (char *)(ior->pool + ior->allocated);
|
ior->boundary = (char *)(ior->pool + ior->allocated);
|
||||||
return MDBX_SUCCESS;
|
return MDBX_SUCCESS;
|
||||||
@ -660,7 +655,6 @@ static __inline ior_item_t *ior_next(ior_item_t *item, size_t sgvcnt) {
|
|||||||
|
|
||||||
MDBX_INTERNAL_FUNC int osal_ioring_add(osal_ioring_t *ior, const size_t offset,
|
MDBX_INTERNAL_FUNC int osal_ioring_add(osal_ioring_t *ior, const size_t offset,
|
||||||
void *data, const size_t bytes) {
|
void *data, const size_t bytes) {
|
||||||
|
|
||||||
assert(bytes && data);
|
assert(bytes && data);
|
||||||
assert(bytes % MIN_PAGESIZE == 0 && bytes <= MAX_WRITE);
|
assert(bytes % MIN_PAGESIZE == 0 && bytes <= MAX_WRITE);
|
||||||
assert(offset % MIN_PAGESIZE == 0 && offset + (uint64_t)bytes <= MAX_MAPSIZE);
|
assert(offset % MIN_PAGESIZE == 0 && offset + (uint64_t)bytes <= MAX_MAPSIZE);
|
||||||
@ -2634,10 +2628,15 @@ __cold MDBX_INTERNAL_FUNC void osal_jitter(bool tiny) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*----------------------------------------------------------------------------*/
|
||||||
|
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
|
static LARGE_INTEGER performance_frequency;
|
||||||
#elif defined(__APPLE__) || defined(__MACH__)
|
#elif defined(__APPLE__) || defined(__MACH__)
|
||||||
#include <mach/mach_time.h>
|
#include <mach/mach_time.h>
|
||||||
|
static uint64_t ratio_16dot16_to_monotine;
|
||||||
#elif defined(__linux__) || defined(__gnu_linux__)
|
#elif defined(__linux__) || defined(__gnu_linux__)
|
||||||
|
static clockid_t posix_clockid;
|
||||||
__cold static clockid_t choice_monoclock(void) {
|
__cold static clockid_t choice_monoclock(void) {
|
||||||
struct timespec probe;
|
struct timespec probe;
|
||||||
#if defined(CLOCK_BOOTTIME)
|
#if defined(CLOCK_BOOTTIME)
|
||||||
@ -2652,27 +2651,16 @@ __cold static clockid_t choice_monoclock(void) {
|
|||||||
#endif
|
#endif
|
||||||
return CLOCK_MONOTONIC;
|
return CLOCK_MONOTONIC;
|
||||||
}
|
}
|
||||||
#endif
|
#elif defined(CLOCK_MONOTONIC)
|
||||||
|
#define posix_clockid CLOCK_MONOTONIC
|
||||||
/*----------------------------------------------------------------------------*/
|
#else
|
||||||
|
#define posix_clockid CLOCK_REALTIME
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
|
||||||
static LARGE_INTEGER performance_frequency;
|
|
||||||
#elif defined(__APPLE__) || defined(__MACH__)
|
|
||||||
static uint64_t ratio_16dot16_to_monotine;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
MDBX_INTERNAL_FUNC uint64_t osal_16dot16_to_monotime(uint32_t seconds_16dot16) {
|
MDBX_INTERNAL_FUNC uint64_t osal_16dot16_to_monotime(uint32_t seconds_16dot16) {
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
if (unlikely(performance_frequency.QuadPart == 0))
|
|
||||||
QueryPerformanceFrequency(&performance_frequency);
|
|
||||||
const uint64_t ratio = performance_frequency.QuadPart;
|
const uint64_t ratio = performance_frequency.QuadPart;
|
||||||
#elif defined(__APPLE__) || defined(__MACH__)
|
#elif defined(__APPLE__) || defined(__MACH__)
|
||||||
if (unlikely(ratio_16dot16_to_monotine == 0)) {
|
|
||||||
mach_timebase_info_data_t ti;
|
|
||||||
mach_timebase_info(&ti);
|
|
||||||
ratio_16dot16_to_monotine = UINT64_C(1000000000) * ti.denom / ti.numer;
|
|
||||||
}
|
|
||||||
const uint64_t ratio = ratio_16dot16_to_monotine;
|
const uint64_t ratio = ratio_16dot16_to_monotine;
|
||||||
#else
|
#else
|
||||||
const uint64_t ratio = UINT64_C(1000000000);
|
const uint64_t ratio = UINT64_C(1000000000);
|
||||||
@ -2681,22 +2669,18 @@ MDBX_INTERNAL_FUNC uint64_t osal_16dot16_to_monotime(uint32_t seconds_16dot16) {
|
|||||||
return likely(ret || seconds_16dot16 == 0) ? ret : /* fix underflow */ 1;
|
return likely(ret || seconds_16dot16 == 0) ? ret : /* fix underflow */ 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static uint64_t monotime_limit;
|
||||||
MDBX_INTERNAL_FUNC uint32_t osal_monotime_to_16dot16(uint64_t monotime) {
|
MDBX_INTERNAL_FUNC uint32_t osal_monotime_to_16dot16(uint64_t monotime) {
|
||||||
static uint64_t limit;
|
if (unlikely(monotime > monotime_limit))
|
||||||
if (unlikely(monotime > limit)) {
|
|
||||||
if (likely(limit != 0))
|
|
||||||
return UINT32_MAX;
|
return UINT32_MAX;
|
||||||
limit = osal_16dot16_to_monotime(UINT32_MAX - 1);
|
|
||||||
if (unlikely(monotime > limit))
|
|
||||||
return UINT32_MAX;
|
|
||||||
}
|
|
||||||
const uint32_t ret =
|
const uint32_t ret =
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
(uint32_t)((monotime << 16) / performance_frequency.QuadPart);
|
(uint32_t)((monotime << 16) / performance_frequency.QuadPart);
|
||||||
#elif defined(__APPLE__) || defined(__MACH__)
|
#elif defined(__APPLE__) || defined(__MACH__)
|
||||||
(uint32_t)((monotime << 16) / ratio_16dot16_to_monotine);
|
(uint32_t)((monotime << 16) / ratio_16dot16_to_monotine);
|
||||||
#else
|
#else
|
||||||
(uint32_t)(monotime * 128 / 1953125);
|
(uint32_t)((monotime << 7) / 1953125);
|
||||||
#endif
|
#endif
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -2704,30 +2688,16 @@ MDBX_INTERNAL_FUNC uint32_t osal_monotime_to_16dot16(uint64_t monotime) {
|
|||||||
MDBX_INTERNAL_FUNC uint64_t osal_monotime(void) {
|
MDBX_INTERNAL_FUNC uint64_t osal_monotime(void) {
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
LARGE_INTEGER counter;
|
LARGE_INTEGER counter;
|
||||||
counter.QuadPart = 0;
|
if (QueryPerformanceCounter(&counter))
|
||||||
QueryPerformanceCounter(&counter);
|
|
||||||
return counter.QuadPart;
|
return counter.QuadPart;
|
||||||
#elif defined(__APPLE__) || defined(__MACH__)
|
#elif defined(__APPLE__) || defined(__MACH__)
|
||||||
return mach_absolute_time();
|
return mach_absolute_time();
|
||||||
#else
|
#else
|
||||||
|
|
||||||
#if defined(__linux__) || defined(__gnu_linux__)
|
|
||||||
static clockid_t posix_clockid = -1;
|
|
||||||
if (unlikely(posix_clockid < 0))
|
|
||||||
posix_clockid = choice_monoclock();
|
|
||||||
#elif defined(CLOCK_MONOTONIC)
|
|
||||||
#define posix_clockid CLOCK_MONOTONIC
|
|
||||||
#else
|
|
||||||
#define posix_clockid CLOCK_REALTIME
|
|
||||||
#endif
|
|
||||||
|
|
||||||
struct timespec ts;
|
struct timespec ts;
|
||||||
if (unlikely(clock_gettime(posix_clockid, &ts) != 0)) {
|
if (likely(clock_gettime(posix_clockid, &ts) == 0))
|
||||||
ts.tv_nsec = 0;
|
|
||||||
ts.tv_sec = 0;
|
|
||||||
}
|
|
||||||
return ts.tv_sec * UINT64_C(1000000000) + ts.tv_nsec;
|
return ts.tv_sec * UINT64_C(1000000000) + ts.tv_nsec;
|
||||||
#endif
|
#endif
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*----------------------------------------------------------------------------*/
|
/*----------------------------------------------------------------------------*/
|
||||||
@ -2766,13 +2736,13 @@ __cold static void bootid_collect(bin128_t *p, const void *s, size_t n) {
|
|||||||
|
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
|
|
||||||
static uint64_t windows_systemtime_ms() {
|
__cold static uint64_t windows_systemtime_ms() {
|
||||||
FILETIME ft;
|
FILETIME ft;
|
||||||
GetSystemTimeAsFileTime(&ft);
|
GetSystemTimeAsFileTime(&ft);
|
||||||
return ((uint64_t)ft.dwHighDateTime << 32 | ft.dwLowDateTime) / 10000ul;
|
return ((uint64_t)ft.dwHighDateTime << 32 | ft.dwLowDateTime) / 10000ul;
|
||||||
}
|
}
|
||||||
|
|
||||||
static uint64_t windows_bootime(void) {
|
__cold static uint64_t windows_bootime(void) {
|
||||||
unsigned confirmed = 0;
|
unsigned confirmed = 0;
|
||||||
uint64_t boottime = 0;
|
uint64_t boottime = 0;
|
||||||
uint64_t up0 = mdbx_GetTickCount64();
|
uint64_t up0 = mdbx_GetTickCount64();
|
||||||
@ -2799,8 +2769,9 @@ static uint64_t windows_bootime(void) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static LSTATUS mdbx_RegGetValue(HKEY hKey, LPCSTR lpSubKey, LPCSTR lpValue,
|
__cold static LSTATUS mdbx_RegGetValue(HKEY hKey, LPCSTR lpSubKey,
|
||||||
PVOID pvData, LPDWORD pcbData) {
|
LPCSTR lpValue, PVOID pvData,
|
||||||
|
LPDWORD pcbData) {
|
||||||
LSTATUS rc;
|
LSTATUS rc;
|
||||||
if (!mdbx_RegGetValueA) {
|
if (!mdbx_RegGetValueA) {
|
||||||
/* an old Windows 2000/XP */
|
/* an old Windows 2000/XP */
|
||||||
@ -3294,3 +3265,48 @@ __cold int mdbx_get_sysraminfo(intptr_t *page_size, intptr_t *total_pages,
|
|||||||
|
|
||||||
return MDBX_SUCCESS;
|
return MDBX_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef xMDBX_ALLOY
|
||||||
|
unsigned sys_pagesize;
|
||||||
|
MDBX_MAYBE_UNUSED unsigned sys_allocation_granularity;
|
||||||
|
#endif /* xMDBX_ALLOY */
|
||||||
|
|
||||||
|
void osal_ctor(void) {
|
||||||
|
#if MDBX_HAVE_PWRITEV && defined(_SC_IOV_MAX)
|
||||||
|
osal_iov_max = sysconf(_SC_IOV_MAX);
|
||||||
|
if (RUNNING_ON_VALGRIND && osal_iov_max > 64)
|
||||||
|
/* чтобы не описывать все 1024 исключения в valgrind_suppress.txt */
|
||||||
|
osal_iov_max = 64;
|
||||||
|
#endif /* MDBX_HAVE_PWRITEV && _SC_IOV_MAX */
|
||||||
|
|
||||||
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
|
SYSTEM_INFO si;
|
||||||
|
GetSystemInfo(&si);
|
||||||
|
sys_pagesize = si.dwPageSize;
|
||||||
|
sys_allocation_granularity = si.dwAllocationGranularity;
|
||||||
|
#else
|
||||||
|
sys_pagesize = sysconf(_SC_PAGE_SIZE);
|
||||||
|
sys_allocation_granularity = (MDBX_WORDBITS > 32) ? 65536 : 4096;
|
||||||
|
sys_allocation_granularity = (sys_allocation_granularity > sys_pagesize)
|
||||||
|
? sys_allocation_granularity
|
||||||
|
: sys_pagesize;
|
||||||
|
#endif
|
||||||
|
assert(sys_pagesize > 0 && (sys_pagesize & (sys_pagesize - 1)) == 0);
|
||||||
|
assert(sys_allocation_granularity >= sys_pagesize &&
|
||||||
|
sys_allocation_granularity % sys_pagesize == 0);
|
||||||
|
|
||||||
|
#if defined(__linux__) || defined(__gnu_linux__)
|
||||||
|
posix_clockid = choice_monoclock();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
|
QueryPerformanceFrequency(&performance_frequency);
|
||||||
|
#elif defined(__APPLE__) || defined(__MACH__)
|
||||||
|
mach_timebase_info_data_t ti;
|
||||||
|
mach_timebase_info(&ti);
|
||||||
|
ratio_16dot16_to_monotine = UINT64_C(1000000000) * ti.denom / ti.numer;
|
||||||
|
#endif
|
||||||
|
monotime_limit = osal_16dot16_to_monotime(UINT32_MAX - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
void osal_dtor(void) {}
|
||||||
|
12
src/osal.h
12
src/osal.h
@ -210,18 +210,16 @@ typedef pthread_mutex_t osal_fastmutex_t;
|
|||||||
/*----------------------------------------------------------------------------*/
|
/*----------------------------------------------------------------------------*/
|
||||||
/* OS abstraction layer stuff */
|
/* OS abstraction layer stuff */
|
||||||
|
|
||||||
|
MDBX_INTERNAL_VAR unsigned sys_pagesize;
|
||||||
|
MDBX_MAYBE_UNUSED MDBX_INTERNAL_VAR unsigned sys_allocation_granularity;
|
||||||
|
|
||||||
/* Get the size of a memory page for the system.
|
/* Get the size of a memory page for the system.
|
||||||
* This is the basic size that the platform's memory manager uses, and is
|
* This is the basic size that the platform's memory manager uses, and is
|
||||||
* fundamental to the use of memory-mapped files. */
|
* fundamental to the use of memory-mapped files. */
|
||||||
MDBX_MAYBE_UNUSED MDBX_NOTHROW_CONST_FUNCTION static __inline size_t
|
MDBX_MAYBE_UNUSED MDBX_NOTHROW_CONST_FUNCTION static __inline size_t
|
||||||
osal_syspagesize(void) {
|
osal_syspagesize(void) {
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
assert(sys_pagesize > 0 && (sys_pagesize & (sys_pagesize - 1)) == 0);
|
||||||
SYSTEM_INFO si;
|
return sys_pagesize;
|
||||||
GetSystemInfo(&si);
|
|
||||||
return si.dwPageSize;
|
|
||||||
#else
|
|
||||||
return sysconf(_SC_PAGE_SIZE);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user