mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-02 00:44:12 +08:00
mdbx: initial OSX support.
This commit is contained in:
parent
f5a25b8d5e
commit
91088af935
5
Makefile
5
Makefile
@ -23,6 +23,7 @@ suffix ?=
|
|||||||
|
|
||||||
CC ?= gcc
|
CC ?= gcc
|
||||||
CXX ?= g++
|
CXX ?= g++
|
||||||
|
LD ?= ld
|
||||||
CFLAGS ?= -O2 -g3 -Wall -Werror -Wextra -ffunction-sections -fPIC -fvisibility=hidden
|
CFLAGS ?= -O2 -g3 -Wall -Werror -Wextra -ffunction-sections -fPIC -fvisibility=hidden
|
||||||
|
|
||||||
XCFLAGS ?= -DNDEBUG=1 -DMDBX_DEBUG=0 -DLIBMDBX_EXPORTS=1
|
XCFLAGS ?= -DNDEBUG=1 -DMDBX_DEBUG=0 -DLIBMDBX_EXPORTS=1
|
||||||
@ -32,8 +33,8 @@ TESTDB ?= $(shell [ -d /dev/shm ] && echo /dev/shm || echo /tmp)/mdbx-test.db
|
|||||||
TESTLOG ?= $(shell [ -d /dev/shm ] && echo /dev/shm || echo /tmp)/mdbx-test.log
|
TESTLOG ?= $(shell [ -d /dev/shm ] && echo /dev/shm || echo /tmp)/mdbx-test.log
|
||||||
|
|
||||||
# LY: '--no-as-needed,-lrt' for ability to built with modern glibc, but then run with the old
|
# LY: '--no-as-needed,-lrt' for ability to built with modern glibc, but then run with the old
|
||||||
LDFLAGS ?= -Wl,--gc-sections,-z,relro,-O1,--no-as-needed,-lrt
|
LDFLAGS ?= $(shell $(LD) --help 2>/dev/null | grep -q -- --gc-sections && echo '-Wl,--gc-sections,-z,relro,-O1')$(shell $(LD) --help 2>/dev/null | grep -q -- -dead_strip && echo '-Wl,-dead_strip')
|
||||||
EXE_LDFLAGS ?= -pthread -lrt
|
EXE_LDFLAGS ?= -pthread
|
||||||
|
|
||||||
# LY: just for benchmarking
|
# LY: just for benchmarking
|
||||||
IOARENA ?= $(shell \
|
IOARENA ?= $(shell \
|
||||||
|
@ -30,6 +30,10 @@
|
|||||||
# define _FILE_OFFSET_BITS 64
|
# define _FILE_OFFSET_BITS 64
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef __APPLE__
|
||||||
|
#define _DARWIN_C_SOURCE
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
# if _MSC_VER < 1400
|
# if _MSC_VER < 1400
|
||||||
# error "Microsoft Visual C++ 8.0 (Visual Studio 2005) or later version is required"
|
# error "Microsoft Visual C++ 8.0 (Visual Studio 2005) or later version is required"
|
||||||
|
@ -18,7 +18,7 @@
|
|||||||
* even though they don't support Robust Mutexes.
|
* even though they don't support Robust Mutexes.
|
||||||
* Compile with -DMDBX_USE_ROBUST=0. */
|
* Compile with -DMDBX_USE_ROBUST=0. */
|
||||||
#ifndef MDBX_USE_ROBUST
|
#ifndef MDBX_USE_ROBUST
|
||||||
#if defined(EOWNERDEAD) || _POSIX_C_SOURCE >= 200809L
|
#if (defined(EOWNERDEAD) || _POSIX_C_SOURCE >= 200809L) && !defined(__APPLE__)
|
||||||
#define MDBX_USE_ROBUST 1
|
#define MDBX_USE_ROBUST 1
|
||||||
#else
|
#else
|
||||||
#define MDBX_USE_ROBUST 0
|
#define MDBX_USE_ROBUST 0
|
||||||
|
33
src/mdbx.c
33
src/mdbx.c
@ -292,6 +292,16 @@ static CRITICAL_SECTION rthc_critical_section;
|
|||||||
#else
|
#else
|
||||||
int __cxa_thread_atexit_impl(void (*dtor)(void *), void *obj, void *dso_symbol)
|
int __cxa_thread_atexit_impl(void (*dtor)(void *), void *obj, void *dso_symbol)
|
||||||
__attribute__((weak));
|
__attribute__((weak));
|
||||||
|
#ifdef __APPLE__ /* FIXME: Thread-Local Storage destructors & DSO-unloading */
|
||||||
|
int __cxa_thread_atexit_impl(void (*dtor)(void *), void *obj,
|
||||||
|
void *dso_symbol) {
|
||||||
|
(void)dtor;
|
||||||
|
(void)obj;
|
||||||
|
(void)dso_symbol;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
#endif /* __APPLE__ */
|
||||||
|
|
||||||
static pthread_mutex_t mdbx_rthc_mutex = PTHREAD_MUTEX_INITIALIZER;
|
static pthread_mutex_t mdbx_rthc_mutex = PTHREAD_MUTEX_INITIALIZER;
|
||||||
static pthread_cond_t mdbx_rthc_cond = PTHREAD_COND_INITIALIZER;
|
static pthread_cond_t mdbx_rthc_cond = PTHREAD_COND_INITIALIZER;
|
||||||
static mdbx_thread_key_t mdbx_rthc_key;
|
static mdbx_thread_key_t mdbx_rthc_key;
|
||||||
@ -515,9 +525,9 @@ __cold void mdbx_rthc_global_dtor(void) {
|
|||||||
mdbx_thread_key_delete(key);
|
mdbx_thread_key_delete(key);
|
||||||
for (MDBX_reader *rthc = rthc_table[i].begin; rthc < rthc_table[i].end;
|
for (MDBX_reader *rthc = rthc_table[i].begin; rthc < rthc_table[i].end;
|
||||||
++rthc) {
|
++rthc) {
|
||||||
mdbx_trace("== [%i] = key %u, %p ... %p, rthc %p (%+i), "
|
mdbx_trace("== [%i] = key %zu, %p ... %p, rthc %p (%+i), "
|
||||||
"rthc-pid %i, current-pid %i",
|
"rthc-pid %i, current-pid %i",
|
||||||
i, key, rthc_table[i].begin, rthc_table[i].end, rthc,
|
i, (size_t)key, rthc_table[i].begin, rthc_table[i].end, rthc,
|
||||||
(int)(rthc - rthc_table[i].begin), rthc->mr_pid, self_pid);
|
(int)(rthc - rthc_table[i].begin), rthc->mr_pid, self_pid);
|
||||||
if (rthc->mr_pid == self_pid) {
|
if (rthc->mr_pid == self_pid) {
|
||||||
rthc->mr_pid = 0;
|
rthc->mr_pid = 0;
|
||||||
@ -553,8 +563,8 @@ __cold int mdbx_rthc_alloc(mdbx_thread_key_t *key, MDBX_reader *begin,
|
|||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
mdbx_rthc_lock();
|
mdbx_rthc_lock();
|
||||||
mdbx_trace(">> key 0x%x, rthc_count %u, rthc_limit %u", *key, rthc_count,
|
mdbx_trace(">> key %zu, rthc_count %u, rthc_limit %u", (size_t)*key,
|
||||||
rthc_limit);
|
rthc_count, rthc_limit);
|
||||||
if (rthc_count == rthc_limit) {
|
if (rthc_count == rthc_limit) {
|
||||||
rthc_entry_t *new_table =
|
rthc_entry_t *new_table =
|
||||||
mdbx_realloc((rthc_table == rthc_table_static) ? nullptr : rthc_table,
|
mdbx_realloc((rthc_table == rthc_table_static) ? nullptr : rthc_table,
|
||||||
@ -568,13 +578,14 @@ __cold int mdbx_rthc_alloc(mdbx_thread_key_t *key, MDBX_reader *begin,
|
|||||||
rthc_table = new_table;
|
rthc_table = new_table;
|
||||||
rthc_limit *= 2;
|
rthc_limit *= 2;
|
||||||
}
|
}
|
||||||
mdbx_trace("== [%i] = key %u, %p ... %p", rthc_count, *key, begin, end);
|
mdbx_trace("== [%i] = key %zu, %p ... %p", rthc_count, (size_t)*key, begin,
|
||||||
|
end);
|
||||||
rthc_table[rthc_count].key = *key;
|
rthc_table[rthc_count].key = *key;
|
||||||
rthc_table[rthc_count].begin = begin;
|
rthc_table[rthc_count].begin = begin;
|
||||||
rthc_table[rthc_count].end = end;
|
rthc_table[rthc_count].end = end;
|
||||||
++rthc_count;
|
++rthc_count;
|
||||||
mdbx_trace("<< key 0x%x, rthc_count %u, rthc_limit %u", *key, rthc_count,
|
mdbx_trace("<< key %zu, rthc_count %u, rthc_limit %u", (size_t)*key,
|
||||||
rthc_limit);
|
rthc_count, rthc_limit);
|
||||||
mdbx_rthc_unlock();
|
mdbx_rthc_unlock();
|
||||||
return MDBX_SUCCESS;
|
return MDBX_SUCCESS;
|
||||||
|
|
||||||
@ -587,8 +598,8 @@ bailout:
|
|||||||
__cold void mdbx_rthc_remove(const mdbx_thread_key_t key) {
|
__cold void mdbx_rthc_remove(const mdbx_thread_key_t key) {
|
||||||
mdbx_thread_key_delete(key);
|
mdbx_thread_key_delete(key);
|
||||||
mdbx_rthc_lock();
|
mdbx_rthc_lock();
|
||||||
mdbx_trace(">> key 0x%x, rthc_count %u, rthc_limit %u", key, rthc_count,
|
mdbx_trace(">> key %zu, rthc_count %u, rthc_limit %u", (size_t)key,
|
||||||
rthc_limit);
|
rthc_count, rthc_limit);
|
||||||
|
|
||||||
for (unsigned i = 0; i < rthc_count; ++i) {
|
for (unsigned i = 0; i < rthc_count; ++i) {
|
||||||
if (key == rthc_table[i].key) {
|
if (key == rthc_table[i].key) {
|
||||||
@ -614,8 +625,8 @@ __cold void mdbx_rthc_remove(const mdbx_thread_key_t key) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
mdbx_trace("<< key 0x%x, rthc_count %u, rthc_limit %u", key, rthc_count,
|
mdbx_trace("<< key %zu, rthc_count %u, rthc_limit %u", (size_t)key,
|
||||||
rthc_limit);
|
rthc_count, rthc_limit);
|
||||||
mdbx_rthc_unlock();
|
mdbx_rthc_unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
19
src/osal.c
19
src/osal.c
@ -159,9 +159,14 @@ typedef struct _FILE_PROVIDER_EXTERNAL_INFO_V1 {
|
|||||||
/* Prototype should match libc runtime. ISO POSIX (2003) & LSB 1.x-3.x */
|
/* Prototype should match libc runtime. ISO POSIX (2003) & LSB 1.x-3.x */
|
||||||
__nothrow __noreturn void __assert_fail(const char *assertion, const char *file,
|
__nothrow __noreturn void __assert_fail(const char *assertion, const char *file,
|
||||||
unsigned line, const char *function);
|
unsigned line, const char *function);
|
||||||
#elif (defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) || \
|
#elif defined(__APPLE__) || defined(__MACH__)
|
||||||
|
__nothrow __noreturn void __assert_rtn(const char *function, const char *file,
|
||||||
|
int line, const char *assertion);
|
||||||
|
#define __assert_fail(assertion, file, line, function) \
|
||||||
|
__assert_rtn(function, file, line, assertion)
|
||||||
|
#elif defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) || \
|
||||||
defined(__BSD__) || defined(__NETBSD__) || defined(__bsdi__) || \
|
defined(__BSD__) || defined(__NETBSD__) || defined(__bsdi__) || \
|
||||||
defined(__DragonFly__))
|
defined(__DragonFly__)
|
||||||
__nothrow __noreturn void __assert(const char *function, const char *file,
|
__nothrow __noreturn void __assert(const char *function, const char *file,
|
||||||
int line, const char *assertion);
|
int line, const char *assertion);
|
||||||
#define __assert_fail(assertion, file, line, function) \
|
#define __assert_fail(assertion, file, line, function) \
|
||||||
@ -548,6 +553,9 @@ int mdbx_openfile(const char *pathname, int flags, mode_t mode,
|
|||||||
if (fd_flags != -1)
|
if (fd_flags != -1)
|
||||||
(void)fcntl(*fd, F_SETFL, fd_flags | O_DIRECT);
|
(void)fcntl(*fd, F_SETFL, fd_flags | O_DIRECT);
|
||||||
#endif /* O_DIRECT */
|
#endif /* O_DIRECT */
|
||||||
|
#if defined(F_NOCACHE)
|
||||||
|
(void)fcntl(*fd, F_NOCACHE, 1);
|
||||||
|
#endif /* F_NOCACHE */
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -626,7 +634,7 @@ int mdbx_pwrite(mdbx_filehandle_t fd, const void *buf, size_t bytes,
|
|||||||
|
|
||||||
int mdbx_pwritev(mdbx_filehandle_t fd, struct iovec *iov, int iovcnt,
|
int mdbx_pwritev(mdbx_filehandle_t fd, struct iovec *iov, int iovcnt,
|
||||||
uint64_t offset, size_t expected_written) {
|
uint64_t offset, size_t expected_written) {
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
#if defined(_WIN32) || defined(_WIN64) || defined(__APPLE__)
|
||||||
size_t written = 0;
|
size_t written = 0;
|
||||||
for (int i = 0; i < iovcnt; ++i) {
|
for (int i = 0; i < iovcnt; ++i) {
|
||||||
int rc = mdbx_pwrite(fd, iov[i].iov_base, iov[i].iov_len, offset);
|
int rc = mdbx_pwrite(fd, iov[i].iov_base, iov[i].iov_len, offset);
|
||||||
@ -1158,7 +1166,10 @@ retry_mapview:;
|
|||||||
return rc;
|
return rc;
|
||||||
#else
|
#else
|
||||||
if (limit != map->length) {
|
if (limit != map->length) {
|
||||||
#if defined(_GNU_SOURCE) && !defined(__FreeBSD__)
|
#if defined(_GNU_SOURCE) && \
|
||||||
|
!(defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) || \
|
||||||
|
defined(__BSD__) || defined(__NETBSD__) || defined(__bsdi__) || \
|
||||||
|
defined(__DragonFly__) || defined(__APPLE__) || defined(__MACH__))
|
||||||
void *ptr = mremap(map->address, map->length, limit,
|
void *ptr = mremap(map->address, map->length, limit,
|
||||||
/* LY: in case changing the mapping size calling code
|
/* LY: in case changing the mapping size calling code
|
||||||
must guarantees the absence of competing threads, and
|
must guarantees the absence of competing threads, and
|
||||||
|
@ -55,7 +55,7 @@
|
|||||||
#include <time.h>
|
#include <time.h>
|
||||||
#if !(defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) || \
|
#if !(defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) || \
|
||||||
defined(__BSD__) || defined(__NETBSD__) || defined(__bsdi__) || \
|
defined(__BSD__) || defined(__NETBSD__) || defined(__bsdi__) || \
|
||||||
defined(__DragonFly__))
|
defined(__DragonFly__) || defined(__APPLE__) || defined(__MACH__))
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
#endif /* xBSD */
|
#endif /* xBSD */
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user