mdbx: Merge branch 'master' into nexenta.

This commit is contained in:
Leo Yuriev 2016-05-04 23:09:01 +03:00
commit cd14429b5d
5 changed files with 216 additions and 213 deletions

View File

@ -1,10 +1,15 @@
LMDB 0.9 Change Log LMDB 0.9 Change Log
MDBX MDBX
Fix ITS#8393 case MDB_GET_BOTH on non-dup record Add MDB_PREV_MULTIPLE
LMDB 0.9.19 Release Engineering
Fix MDB_GET_BOTH on non-dup record (ITS#8393)
Optimize mdb_drop
Fix xcursors after mdb_cursor_del (ITS#8406)
Fix MDB_NEXT_DUP after mdb_cursor_del (ITS#8412)
LMDB 0.9.18 Release (2016/02/05) LMDB 0.9.18 Release (2016/02/05)
Add MDB_PREV_MULTIPLE
already done for mdbx - Fix robust mutex detection on glibc 2.10-11 (ITS#8330) already done for mdbx - Fix robust mutex detection on glibc 2.10-11 (ITS#8330)
Fix page_search_root assert on FreeDB (ITS#8336) Fix page_search_root assert on FreeDB (ITS#8336)
Fix MDB_APPENDDUP vs. rewrite(single item) (ITS#8334) Fix MDB_APPENDDUP vs. rewrite(single item) (ITS#8334)

View File

@ -11,7 +11,7 @@
#endif #endif
#if defined(__GNUC__) || defined(__clang__) #if defined(__GNUC__) || defined(__clang__)
# define MDB_INLINE __inline # define MDBX_INLINE __inline
#elif defined(__INTEL_COMPILER) /* LY: Intel Compiler may mimic GCC and MSC */ #elif defined(__INTEL_COMPILER) /* LY: Intel Compiler may mimic GCC and MSC */
# include <intrin.h> # include <intrin.h>
# if defined(__ia64__) || defined(__ia64) || defined(_M_IA64) # if defined(__ia64__) || defined(__ia64) || defined(_M_IA64)
@ -19,34 +19,34 @@
# elif defined(__i386__) || defined(__x86_64__) # elif defined(__i386__) || defined(__x86_64__)
# pragma intrinsic(_mm_mfence) # pragma intrinsic(_mm_mfence)
# endif # endif
# define MDB_INLINE __inline # define MDBX_INLINE __inline
#elif defined(__SUNPRO_C) || defined(__sun) || defined(sun) #elif defined(__SUNPRO_C) || defined(__sun) || defined(sun)
# include <mbarrier.h> # include <mbarrier.h>
# define MDB_INLINE inline # define MDBX_INLINE inline
#elif (defined(_HPUX_SOURCE) || defined(__hpux) || defined(__HP_aCC)) \ #elif (defined(_HPUX_SOURCE) || defined(__hpux) || defined(__HP_aCC)) \
&& (defined(HP_IA64) || defined(__ia64)) && (defined(HP_IA64) || defined(__ia64))
# include <machine/sys/inline.h> # include <machine/sys/inline.h>
# define MDB_INLINE # define MDBX_INLINE
#elif defined(__IBMC__) && defined(__powerpc) #elif defined(__IBMC__) && defined(__powerpc)
# include <atomic.h> # include <atomic.h>
# define MDB_INLINE # define MDBX_INLINE
#elif defined(_AIX) #elif defined(_AIX)
# include <builtins.h> # include <builtins.h>
# include <sys/atomic_op.h> # include <sys/atomic_op.h>
# define MDB_INLINE # define MDBX_INLINE
#elif (defined(__osf__) && defined(__DECC)) || defined(__alpha) #elif (defined(__osf__) && defined(__DECC)) || defined(__alpha)
# include <machine/builtins.h> # include <machine/builtins.h>
# include <c_asm.h> # include <c_asm.h>
# define MDB_INLINE # define MDBX_INLINE
#elif defined(__MWERKS__) #elif defined(__MWERKS__)
/* CodeWarrior - troubles ? */ /* CodeWarrior - troubles ? */
# pragma gcc_extensions # pragma gcc_extensions
# define MDB_INLINE # define MDBX_INLINE
#elif defined(__SNC__) #elif defined(__SNC__)
/* Sony PS3 - troubles ? */ /* Sony PS3 - troubles ? */
# define MDB_INLINE # define MDBX_INLINE
#else #else
# define MDB_INLINE # define MDBX_INLINE
#endif #endif
#if defined(__i386__) || defined(__x86_64__) \ #if defined(__i386__) || defined(__x86_64__) \
@ -63,13 +63,13 @@
# define MDB_CACHE_IS_COHERENT 0 # define MDB_CACHE_IS_COHERENT 0
#endif #endif
#define MDB_BARRIER_COMPILER 0 #define MDBX_BARRIER_COMPILER 0
#define MDB_BARRIER_MEMORY 1 #define MDBX_BARRIER_MEMORY 1
static MDB_INLINE void mdb_barrier(int type) { static MDBX_INLINE void mdbx_barrier(int type) {
#if defined(__clang__) #if defined(__clang__)
__asm__ __volatile__ ("" ::: "memory"); __asm__ __volatile__ ("" ::: "memory");
if (type > MDB_BARRIER_COMPILER) if (type > MDBX_BARRIER_COMPILER)
# if __has_extension(c_atomic) || __has_extension(cxx_atomic) # if __has_extension(c_atomic) || __has_extension(cxx_atomic)
__c11_atomic_thread_fence(__ATOMIC_SEQ_CST); __c11_atomic_thread_fence(__ATOMIC_SEQ_CST);
# else # else
@ -77,7 +77,7 @@ static MDB_INLINE void mdb_barrier(int type) {
# endif # endif
#elif defined(__GNUC__) #elif defined(__GNUC__)
__asm__ __volatile__ ("" ::: "memory"); __asm__ __volatile__ ("" ::: "memory");
if (type > MDB_BARRIER_COMPILER) if (type > MDBX_BARRIER_COMPILER)
# if defined(__ATOMIC_SEQ_CST) # if defined(__ATOMIC_SEQ_CST)
__atomic_thread_fence(__ATOMIC_SEQ_CST); __atomic_thread_fence(__ATOMIC_SEQ_CST);
# else # else
@ -85,7 +85,7 @@ static MDB_INLINE void mdb_barrier(int type) {
# endif # endif
#elif defined(__INTEL_COMPILER) /* LY: Intel Compiler may mimic GCC and MSC */ #elif defined(__INTEL_COMPILER) /* LY: Intel Compiler may mimic GCC and MSC */
__memory_barrier(); __memory_barrier();
if (type > MDB_BARRIER_COMPILER) if (type > MDBX_BARRIER_COMPILER)
# if defined(__ia64__) || defined(__ia64) || defined(_M_IA64) # if defined(__ia64__) || defined(__ia64) || defined(_M_IA64)
__mf(); __mf();
# elif defined(__i386__) || defined(__x86_64__) # elif defined(__i386__) || defined(__x86_64__)
@ -95,17 +95,17 @@ static MDB_INLINE void mdb_barrier(int type) {
# endif # endif
#elif defined(__SUNPRO_C) || defined(__sun) || defined(sun) #elif defined(__SUNPRO_C) || defined(__sun) || defined(sun)
__compiler_barrier(); __compiler_barrier();
if (type > MDB_BARRIER_COMPILER) if (type > MDBX_BARRIER_COMPILER)
__machine_rw_barrier(); __machine_rw_barrier();
#elif (defined(_HPUX_SOURCE) || defined(__hpux) || defined(__HP_aCC)) \ #elif (defined(_HPUX_SOURCE) || defined(__hpux) || defined(__HP_aCC)) \
&& (defined(HP_IA64) || defined(__ia64)) && (defined(HP_IA64) || defined(__ia64))
_Asm_sched_fence(/* LY: no-arg meaning 'all expect ALU', e.g. 0x3D3D */); _Asm_sched_fence(/* LY: no-arg meaning 'all expect ALU', e.g. 0x3D3D */);
if (type > MDB_BARRIER_COMPILER) if (type > MDBX_BARRIER_COMPILER)
_Asm_mf(); _Asm_mf();
#elif defined(_AIX) || defined(__ppc__) || defined(__powerpc__) \ #elif defined(_AIX) || defined(__ppc__) || defined(__powerpc__) \
|| defined(__ppc64__) || defined(__powerpc64__) || defined(__ppc64__) || defined(__powerpc64__)
__fence(); __fence();
if (type > MDB_BARRIER_COMPILER) if (type > MDBX_BARRIER_COMPILER)
__lwsync(); __lwsync();
#elif (defined(__osf__) && defined(__DECC)) || defined(__alpha) #elif (defined(__osf__) && defined(__DECC)) || defined(__alpha)
__PAL_DRAINA(); /* LY: excessive ? */ __PAL_DRAINA(); /* LY: excessive ? */
@ -115,15 +115,15 @@ static MDB_INLINE void mdb_barrier(int type) {
#endif #endif
} }
#define mdb_compiler_barrier() \ #define mdbx_compiler_barrier() \
mdb_barrier(MDB_BARRIER_COMPILER) mdbx_barrier(MDBX_BARRIER_COMPILER)
#define mdb_memory_barrier() \ #define mdbx_memory_barrier() \
mdb_barrier(MDB_BARRIER_MEMORY) mdbx_barrier(MDBX_BARRIER_MEMORY)
#define mdb_coherent_barrier() \ #define mdbx_coherent_barrier() \
mdb_barrier(MDB_CACHE_IS_COHERENT ? MDB_BARRIER_COMPILER : MDB_BARRIER_MEMORY) mdbx_barrier(MDB_CACHE_IS_COHERENT ? MDBX_BARRIER_COMPILER : MDBX_BARRIER_MEMORY)
static MDB_INLINE void mdb_invalidate_cache(void *addr, int nbytes) { static MDBX_INLINE void mdb_invalidate_cache(void *addr, int nbytes) {
mdb_coherent_barrier(); mdbx_coherent_barrier();
#if defined(__mips) && defined(__linux) #if defined(__mips) && defined(__linux)
/* MIPS has cache coherency issues. /* MIPS has cache coherency issues.
* Note: for any nbytes >= on-chip cache size, entire is flushed. */ * Note: for any nbytes >= on-chip cache size, entire is flushed. */

44
lmdb.h
View File

@ -309,15 +309,15 @@ typedef void (MDB_rel_func)(MDB_val *item, void *oldptr, void *newptr, void *rel
#if MDBX_MODE_ENABLED #if MDBX_MODE_ENABLED
/** aim to coalesce FreeDB records */ /** aim to coalesce FreeDB records */
#define MDB_COALESCE 0x2000000 #define MDBX_COALESCE 0x2000000
/** LIFO policy for reclaiming FreeDB records */ /** LIFO policy for reclaiming FreeDB records */
#define MDB_LIFORECLAIM 0x4000000 #define MDBX_LIFORECLAIM 0x4000000
#endif /* MDBX_MODE_ENABLED */ #endif /* MDBX_MODE_ENABLED */
/** make a steady-sync only on close and explicit env-sync */ /** make a steady-sync only on close and explicit env-sync */
#define MDB_UTTERLY_NOSYNC (MDB_NOSYNC|MDB_MAPASYNC) #define MDBX_UTTERLY_NOSYNC (MDB_NOSYNC|MDB_MAPASYNC)
/** debuging option, fill/perturb released pages */ /** debuging option, fill/perturb released pages */
#define MDB_PAGEPERTURB 0x8000000 #define MDBX_PAGEPERTURB 0x8000000
/** @} */ /** @} */
/** @defgroup mdb_dbi_open Database Flags /** @defgroup mdb_dbi_open Database Flags
@ -642,10 +642,10 @@ int mdb_env_create(MDB_env **env);
* caller is expected to overwrite all of the memory that was * caller is expected to overwrite all of the memory that was
* reserved in that case. * reserved in that case.
* This flag may be changed at any time using #mdb_env_set_flags(). * This flag may be changed at any time using #mdb_env_set_flags().
* <li>#MDB_COALESCE * <li>#MDBX_COALESCE
* Aim to coalesce records while reclaiming FreeDB. * Aim to coalesce records while reclaiming FreeDB.
* This flag may be changed at any time using #mdb_env_set_flags(). * This flag may be changed at any time using #mdb_env_set_flags().
* <li>#MDB_LIFORECLAIM * <li>#MDBX_LIFORECLAIM
* LIFO policy for reclaiming FreeDB records. This significantly reduce * LIFO policy for reclaiming FreeDB records. This significantly reduce
* write IPOS in case MDB_NOSYNC with periodically checkpoints. * write IPOS in case MDB_NOSYNC with periodically checkpoints.
* </ul> * </ul>
@ -1682,7 +1682,7 @@ int mdbx_txn_straggler(MDB_txn *txn, int *percent);
* 1 on success (reader was killed), * 1 on success (reader was killed),
* >1 on success (reader was SURE killed). * >1 on success (reader was SURE killed).
*/ */
typedef int (MDB_oom_func)(MDB_env *env, int pid, void* thread_id, size_t txn, unsigned gap, int retry); typedef int (MDBX_oom_func)(MDB_env *env, int pid, void* thread_id, size_t txn, unsigned gap, int retry);
/** @brief Set the OOM callback. /** @brief Set the OOM callback.
* *
@ -1690,9 +1690,9 @@ typedef int (MDB_oom_func)(MDB_env *env, int pid, void* thread_id, size_t txn, u
* a laggard readers to allowing reclaiming of freeDB. * a laggard readers to allowing reclaiming of freeDB.
* *
* @param[in] env An environment handle returned by #mdb_env_create(). * @param[in] env An environment handle returned by #mdb_env_create().
* @param[in] oomfunc A #MDB_oom_func function or NULL to disable. * @param[in] oomfunc A #MDBX_oom_func function or NULL to disable.
*/ */
void mdbx_env_set_oomfunc(MDB_env *env, MDB_oom_func *oom_func); void mdbx_env_set_oomfunc(MDB_env *env, MDBX_oom_func *oom_func);
/** @brief Get the current oom_func callback. /** @brief Get the current oom_func callback.
* *
@ -1700,32 +1700,32 @@ void mdbx_env_set_oomfunc(MDB_env *env, MDB_oom_func *oom_func);
* a laggard readers to allowing reclaiming of freeDB. * a laggard readers to allowing reclaiming of freeDB.
* *
* @param[in] env An environment handle returned by #mdb_env_create(). * @param[in] env An environment handle returned by #mdb_env_create().
* @return A #MDB_oom_func function or NULL if disabled. * @return A #MDBX_oom_func function or NULL if disabled.
*/ */
MDB_oom_func* mdbx_env_get_oomfunc(MDB_env *env); MDBX_oom_func* mdbx_env_get_oomfunc(MDB_env *env);
#endif /* MDBX_MODE_ENABLED */ #endif /* MDBX_MODE_ENABLED */
/** @} */ /** @} */
#if MDBX_MODE_ENABLED #if MDBX_MODE_ENABLED
#define MDB_DBG_ASSERT 1 #define MDBX_DBG_ASSERT 1
#define MDB_DBG_PRINT 2 #define MDBX_DBG_PRINT 2
#define MDB_DBG_TRACE 4 #define MDBX_DBG_TRACE 4
#define MDB_DBG_EXTRA 8 #define MDBX_DBG_EXTRA 8
#define MDB_DBG_AUDIT 16 #define MDBX_DBG_AUDIT 16
#define MDB_DBG_EDGE 32 #define MDBX_DBG_EDGE 32
/* LY: a "don't touch" value */ /* LY: a "don't touch" value */
#define MDB_DBG_DNT (-1L) #define MDBX_DBG_DNT (-1L)
typedef void MDB_debug_func(int type, const char *function, int line, typedef void MDBX_debug_func(int type, const char *function, int line,
const char *msg, va_list args); const char *msg, va_list args);
int mdbx_setup_debug(int flags, MDB_debug_func* logger, long edge_txn); int mdbx_setup_debug(int flags, MDBX_debug_func* logger, long edge_txn);
typedef int MDB_pgvisitor_func(size_t pgno, unsigned pgnumber, void* ctx, typedef int MDBX_pgvisitor_func(size_t pgno, unsigned pgnumber, void* ctx,
const char* dbi, const char *type, int nentries, const char* dbi, const char *type, int nentries,
int payload_bytes, int header_bytes, int unused_bytes); int payload_bytes, int header_bytes, int unused_bytes);
int mdbx_env_pgwalk(MDB_txn *txn, MDB_pgvisitor_func* visitor, void* ctx); int mdbx_env_pgwalk(MDB_txn *txn, MDBX_pgvisitor_func* visitor, void* ctx);
#endif /* MDBX_MODE_ENABLED */ #endif /* MDBX_MODE_ENABLED */
char* mdb_dkey(MDB_val *key, char *buf); char* mdb_dkey(MDB_val *key, char *buf);

260
mdb.c
View File

@ -100,14 +100,14 @@
#include "./midl.h" #include "./midl.h"
#if ! MDBX_MODE_ENABLED #if ! MDBX_MODE_ENABLED
# define MDB_COALESCE 0 # define MDBX_COALESCE 0
# define MDB_LIFORECLAIM 0 # define MDBX_LIFORECLAIM 0
# define MDB_DBG_ASSERT 0 # define MDBX_DBG_ASSERT 0
# define MDB_DBG_PRINT 0 # define MDBX_DBG_PRINT 0
# define MDB_DBG_TRACE 0 # define MDBX_DBG_TRACE 0
# define MDB_DBG_EXTRA 0 # define MDBX_DBG_EXTRA 0
# define MDB_DBG_AUDIT 0 # define MDBX_DBG_AUDIT 0
# define MDB_DBG_EDGE 0 # define MDBX_DBG_EDGE 0
#endif /* ! MDBX_MODE_ENABLED */ #endif /* ! MDBX_MODE_ENABLED */
#if (BYTE_ORDER == LITTLE_ENDIAN) == (BYTE_ORDER == BIG_ENDIAN) #if (BYTE_ORDER == LITTLE_ENDIAN) == (BYTE_ORDER == BIG_ENDIAN)
@ -979,7 +979,7 @@ struct MDB_env {
uint64_t me_sync_pending; /**< Total dirty/commited bytes since the last mdb_env_sync() */ uint64_t me_sync_pending; /**< Total dirty/commited bytes since the last mdb_env_sync() */
uint64_t me_sync_threshold; /**< Treshold of above to force synchronous flush */ uint64_t me_sync_threshold; /**< Treshold of above to force synchronous flush */
#if MDBX_MODE_ENABLED #if MDBX_MODE_ENABLED
MDB_oom_func *me_oom_func; /**< Callback for kicking laggard readers */ MDBX_oom_func *me_oom_func; /**< Callback for kicking laggard readers */
#endif #endif
#ifdef USE_VALGRIND #ifdef USE_VALGRIND
int me_valgrind_handle; int me_valgrind_handle;
@ -1147,22 +1147,22 @@ mdb_strerror(int err)
#if MDBX_MODE_ENABLED #if MDBX_MODE_ENABLED
int mdb_runtime_flags = MDB_DBG_PRINT int mdb_runtime_flags = MDBX_DBG_PRINT
#if MDB_DEBUG #if MDB_DEBUG
| MDB_DBG_ASSERT | MDBX_DBG_ASSERT
#endif #endif
#if MDB_DEBUG > 1 #if MDB_DEBUG > 1
| MDB_DBG_TRACE | MDBX_DBG_TRACE
#endif #endif
#if MDB_DEBUG > 2 #if MDB_DEBUG > 2
| MDB_DBG_AUDIT | MDBX_DBG_AUDIT
#endif #endif
#if MDB_DEBUG > 3 #if MDB_DEBUG > 3
| MDB_DBG_EXTRA | MDBX_DBG_EXTRA
#endif #endif
; ;
static MDB_debug_func *mdb_debug_logger; static MDBX_debug_func *mdb_debug_logger;
#else /* MDBX_MODE_ENABLED */ #else /* MDBX_MODE_ENABLED */
# define mdb_runtime_flags 0 # define mdb_runtime_flags 0
@ -1182,20 +1182,20 @@ static MDB_debug_func *mdb_debug_logger;
env->me_assert_func(env, msg, func, line); env->me_assert_func(env, msg, func, line);
else { else {
if (mdb_debug_logger) if (mdb_debug_logger)
mdb_debug_log(MDB_DBG_ASSERT, func, line, "assert: %s\n", msg); mdb_debug_log(MDBX_DBG_ASSERT, func, line, "assert: %s\n", msg);
__assert_fail(msg, __FILE__, line, func); __assert_fail(msg, __FILE__, line, func);
} }
} }
# define mdb_assert_enabled() \ # define mdb_assert_enabled() \
unlikely(mdb_runtime_flags & MDB_DBG_ASSERT) unlikely(mdb_runtime_flags & MDBX_DBG_ASSERT)
# define mdb_audit_enabled() \ # define mdb_audit_enabled() \
unlikely(mdb_runtime_flags & MDB_DBG_AUDIT) unlikely(mdb_runtime_flags & MDBX_DBG_AUDIT)
# define mdb_debug_enabled(type) \ # define mdb_debug_enabled(type) \
unlikely(mdb_runtime_flags & \ unlikely(mdb_runtime_flags & \
(type & (MDB_DBG_TRACE | MDB_DBG_EXTRA))) (type & (MDBX_DBG_TRACE | MDBX_DBG_EXTRA)))
#else #else
# define mdb_debug_enabled(type) (0) # define mdb_debug_enabled(type) (0)
@ -1207,14 +1207,14 @@ static MDB_debug_func *mdb_debug_logger;
#if MDBX_MODE_ENABLED #if MDBX_MODE_ENABLED
int __cold int __cold
mdbx_setup_debug(int flags, MDB_debug_func* logger, long edge_txn) { mdbx_setup_debug(int flags, MDBX_debug_func* logger, long edge_txn) {
unsigned ret = mdb_runtime_flags; unsigned ret = mdb_runtime_flags;
if (flags != (int) MDB_DBG_DNT) if (flags != (int) MDBX_DBG_DNT)
mdb_runtime_flags = flags; mdb_runtime_flags = flags;
if (logger != (MDB_debug_func*) MDB_DBG_DNT) if (logger != (MDBX_debug_func*) MDBX_DBG_DNT)
mdb_debug_logger = logger; mdb_debug_logger = logger;
#if MDB_DEBUG #if MDB_DEBUG
if (edge_txn != (long) MDB_DBG_DNT) if (edge_txn != (long) MDBX_DBG_DNT)
mdb_debug_edge = edge_txn; mdb_debug_edge = edge_txn;
#else #else
(void) edge_txn; (void) edge_txn;
@ -1241,26 +1241,26 @@ mdb_debug_log(int type, const char *function, int line,
} }
#define mdb_print(fmt, ...) \ #define mdb_print(fmt, ...) \
mdb_debug_log(MDB_DBG_PRINT, NULL, 0, fmt, ##__VA_ARGS__) mdb_debug_log(MDBX_DBG_PRINT, NULL, 0, fmt, ##__VA_ARGS__)
#define mdb_debug(fmt, ...) do { \ #define mdb_debug(fmt, ...) do { \
if (mdb_debug_enabled(MDB_DBG_TRACE)) \ if (mdb_debug_enabled(MDBX_DBG_TRACE)) \
mdb_debug_log(MDB_DBG_TRACE, __FUNCTION__, __LINE__, fmt "\n", ##__VA_ARGS__); \ mdb_debug_log(MDBX_DBG_TRACE, __FUNCTION__, __LINE__, fmt "\n", ##__VA_ARGS__); \
} while(0) } while(0)
#define mdb_debug_print(fmt, ...) do { \ #define mdb_debug_print(fmt, ...) do { \
if (mdb_debug_enabled(MDB_DBG_TRACE)) \ if (mdb_debug_enabled(MDBX_DBG_TRACE)) \
mdb_debug_log(MDB_DBG_TRACE, NULL, 0, fmt, ##__VA_ARGS__); \ mdb_debug_log(MDBX_DBG_TRACE, NULL, 0, fmt, ##__VA_ARGS__); \
} while(0) } while(0)
#define mdb_debug_extra(fmt, ...) do { \ #define mdb_debug_extra(fmt, ...) do { \
if (mdb_debug_enabled(MDB_DBG_EXTRA)) \ if (mdb_debug_enabled(MDBX_DBG_EXTRA)) \
mdb_debug_log(MDB_DBG_EXTRA, __FUNCTION__, __LINE__, fmt, ##__VA_ARGS__); \ mdb_debug_log(MDBX_DBG_EXTRA, __FUNCTION__, __LINE__, fmt, ##__VA_ARGS__); \
} while(0) } while(0)
#define mdb_debug_extra_print(fmt, ...) do { \ #define mdb_debug_extra_print(fmt, ...) do { \
if (mdb_debug_enabled(MDB_DBG_EXTRA)) \ if (mdb_debug_enabled(MDBX_DBG_EXTRA)) \
mdb_debug_log(MDB_DBG_EXTRA, NULL, 0, fmt, ##__VA_ARGS__); \ mdb_debug_log(MDBX_DBG_EXTRA, NULL, 0, fmt, ##__VA_ARGS__); \
} while(0) } while(0)
#define mdb_ensure_msg(env, expr, msg) \ #define mdb_ensure_msg(env, expr, msg) \
@ -1288,7 +1288,7 @@ mdb_debug_log(int type, const char *function, int line,
mdb_assert((txn)->mt_env, expr) mdb_assert((txn)->mt_env, expr)
/** Return the page number of \b mp which may be sub-page, for debug output */ /** Return the page number of \b mp which may be sub-page, for debug output */
static MDB_INLINE pgno_t static MDBX_INLINE pgno_t
mdb_dbg_pgno(MDB_page *mp) mdb_dbg_pgno(MDB_page *mp)
{ {
pgno_t ret; pgno_t ret;
@ -1538,7 +1538,7 @@ mdb_page_malloc(MDB_txn *txn, unsigned num)
* Saves single pages to a list, for future reuse. * Saves single pages to a list, for future reuse.
* (This is not used for multi-page overflow pages.) * (This is not used for multi-page overflow pages.)
*/ */
static MDB_INLINE void static MDBX_INLINE void
mdb_page_free(MDB_env *env, MDB_page *mp) mdb_page_free(MDB_env *env, MDB_page *mp)
{ {
mp->mp_next = env->me_dpages; mp->mp_next = env->me_dpages;
@ -1636,7 +1636,7 @@ mdb_page_loose(MDB_cursor *mc, MDB_page *mp)
} }
if (loose) { if (loose) {
mdb_debug("loosen db %d page %zu", DDBI(mc), mp->mp_pgno); mdb_debug("loosen db %d page %zu", DDBI(mc), mp->mp_pgno);
if (unlikely(txn->mt_env->me_flags & MDB_PAGEPERTURB)) if (unlikely(txn->mt_env->me_flags & MDBX_PAGEPERTURB))
mdb_kill_page(txn->mt_env, pgno); mdb_kill_page(txn->mt_env, pgno);
NEXT_LOOSE_PAGE(mp) = txn->mt_loose_pgs; NEXT_LOOSE_PAGE(mp) = txn->mt_loose_pgs;
txn->mt_loose_pgs = mp; txn->mt_loose_pgs = mp;
@ -1852,7 +1852,7 @@ bailout:
return rc; return rc;
} }
static MDB_INLINE uint64_t static MDBX_INLINE uint64_t
mdb_meta_sign(MDB_meta *meta) { mdb_meta_sign(MDB_meta *meta) {
uint64_t sign = MDB_DATASIGN_NONE; uint64_t sign = MDB_DATASIGN_NONE;
#if 0 /* TODO */ #if 0 /* TODO */
@ -1868,7 +1868,7 @@ mdb_meta_sign(MDB_meta *meta) {
return (sign > MDB_DATASIGN_WEAK) ? sign : ~sign; return (sign > MDB_DATASIGN_WEAK) ? sign : ~sign;
} }
static MDB_INLINE MDB_meta* static MDBX_INLINE MDB_meta*
mdb_meta_head_w(MDB_env *env) { mdb_meta_head_w(MDB_env *env) {
MDB_meta* a = METAPAGE_1(env); MDB_meta* a = METAPAGE_1(env);
MDB_meta* b = METAPAGE_2(env); MDB_meta* b = METAPAGE_2(env);
@ -1903,7 +1903,7 @@ mdb_meta_head_r(MDB_env *env) {
h = b; h = b;
} else { } else {
/* LY: seems got a collision with mdb_env_sync0() */ /* LY: seems got a collision with mdb_env_sync0() */
mdb_coherent_barrier(); mdbx_coherent_barrier();
head_txnid = env->me_txns->mti_txnid; head_txnid = env->me_txns->mti_txnid;
mdb_assert(env, a->mm_txnid != b->mm_txnid || head_txnid == 0); mdb_assert(env, a->mm_txnid != b->mm_txnid || head_txnid == 0);
@ -1927,12 +1927,12 @@ mdb_meta_head_r(MDB_env *env) {
return h; return h;
} }
static MDB_INLINE MDB_meta* static MDBX_INLINE MDB_meta*
mdb_env_meta_flipflop(const MDB_env *env, MDB_meta* meta) { mdb_env_meta_flipflop(const MDB_env *env, MDB_meta* meta) {
return (meta == METAPAGE_1(env)) ? METAPAGE_2(env) : METAPAGE_1(env); return (meta == METAPAGE_1(env)) ? METAPAGE_2(env) : METAPAGE_1(env);
} }
static MDB_INLINE int static MDBX_INLINE int
mdb_meta_lt(MDB_meta* a, MDB_meta* b) { mdb_meta_lt(MDB_meta* a, MDB_meta* b) {
return (META_IS_STEADY(a) == META_IS_STEADY(b)) return (META_IS_STEADY(a) == META_IS_STEADY(b))
? a->mm_txnid < b->mm_txnid : META_IS_STEADY(b); ? a->mm_txnid < b->mm_txnid : META_IS_STEADY(b);
@ -1971,11 +1971,11 @@ txnid_t mdb_find_oldest(MDB_env *env, int *laggard)
if (laggard) if (laggard)
*laggard = reader; *laggard = reader;
return oldest; return env->me_pgoldest = oldest;
} }
static int __cold static txnid_t __cold
mdb_oomkick(MDB_env *env, txnid_t oldest) mdbx_oomkick(MDB_env *env, txnid_t oldest)
{ {
int retry; int retry;
txnid_t snap; txnid_t snap;
@ -1988,7 +1988,7 @@ mdb_oomkick(MDB_env *env, txnid_t oldest)
snap = mdb_find_oldest(env, &reader); snap = mdb_find_oldest(env, &reader);
if (oldest < snap) if (oldest < snap)
return 1; return snap;
if (reader < 0) if (reader < 0)
return 0; return 0;
@ -2019,7 +2019,7 @@ mdb_oomkick(MDB_env *env, txnid_t oldest)
if (rc > 1) { if (rc > 1) {
r->mr_tid = 0; r->mr_tid = 0;
r->mr_pid = 0; r->mr_pid = 0;
mdb_coherent_barrier(); mdbx_coherent_barrier();
} }
} }
} }
@ -2028,8 +2028,7 @@ mdb_oomkick(MDB_env *env, txnid_t oldest)
#endif /* MDBX_MODE_ENABLED */ #endif /* MDBX_MODE_ENABLED */
} }
snap = mdb_find_oldest(env, NULL); return mdb_find_oldest(env, NULL);
return oldest < snap;
} }
/** Add a page to the txn's dirty list */ /** Add a page to the txn's dirty list */
@ -2067,10 +2066,10 @@ mdb_page_dirty(MDB_txn *txn, MDB_page *mp)
* @return 0 on success, non-zero on failure. * @return 0 on success, non-zero on failure.
*/ */
#define MDB_ALLOC_CACHE 1 #define MDBX_ALLOC_CACHE 1
#define MDB_ALLOC_GC 2 #define MDBX_ALLOC_GC 2
#define MDB_ALLOC_NEW 4 #define MDBX_ALLOC_NEW 4
#define MDB_ALLOC_ALL (MDB_ALLOC_CACHE|MDB_ALLOC_GC|MDB_ALLOC_NEW) #define MDBX_ALLOC_ALL (MDBX_ALLOC_CACHE|MDBX_ALLOC_GC|MDBX_ALLOC_NEW)
static int static int
mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags) mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
@ -2084,18 +2083,18 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
txnid_t oldest = 0, last = 0; txnid_t oldest = 0, last = 0;
MDB_cursor_op op; MDB_cursor_op op;
MDB_cursor m2; MDB_cursor m2;
int found_old; int found_oldest = 0;
if (likely(flags & MDB_ALLOC_GC)) { if (likely(flags & MDBX_ALLOC_GC)) {
flags |= env->me_flags & (MDB_COALESCE | MDB_LIFORECLAIM); flags |= env->me_flags & (MDBX_COALESCE | MDBX_LIFORECLAIM);
if (unlikely(mc->mc_flags & C_RECLAIMING)) { if (unlikely(mc->mc_flags & C_RECLAIMING)) {
/* If mc is updating the freeDB, then the freelist cannot play /* If mc is updating the freeDB, then the freelist cannot play
* catch-up with itself by growing while trying to save it. */ * catch-up with itself by growing while trying to save it. */
flags &= ~(MDB_ALLOC_GC | MDB_COALESCE | MDB_LIFORECLAIM); flags &= ~(MDBX_ALLOC_GC | MDBX_COALESCE | MDBX_LIFORECLAIM);
} }
} }
if (likely(flags & MDB_ALLOC_CACHE)) { if (likely(flags & MDBX_ALLOC_CACHE)) {
/* If there are any loose pages, just use them */ /* If there are any loose pages, just use them */
assert(mp && num); assert(mp && num);
if (likely(num == 1 && txn->mt_loose_pgs)) { if (likely(num == 1 && txn->mt_loose_pgs)) {
@ -2115,8 +2114,7 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
} }
for (;;) { /* oom-kick retry loop */ for (;;) { /* oom-kick retry loop */
found_old = 0; for (op = MDB_FIRST;; op = (flags & MDBX_LIFORECLAIM) ? MDB_PREV : MDB_NEXT) {
for (op = MDB_FIRST;; op = (flags & MDB_LIFORECLAIM) ? MDB_PREV : MDB_NEXT) {
MDB_val key, data; MDB_val key, data;
MDB_node *leaf; MDB_node *leaf;
pgno_t *idl; pgno_t *idl;
@ -2124,9 +2122,9 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
/* Seek a big enough contiguous page range. Prefer /* Seek a big enough contiguous page range. Prefer
* pages at the tail, just truncating the list. * pages at the tail, just truncating the list.
*/ */
if (likely(flags & MDB_ALLOC_CACHE) if (likely(flags & MDBX_ALLOC_CACHE)
&& mop_len > n2 && mop_len > n2
&& ( !(flags & MDB_COALESCE) || op == MDB_FIRST)) { && ( !(flags & MDBX_COALESCE) || op == MDB_FIRST)) {
i = mop_len; i = mop_len;
do { do {
pgno = mop[i]; pgno = mop[i];
@ -2137,20 +2135,19 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
if (op == MDB_FIRST) { /* 1st iteration */ if (op == MDB_FIRST) { /* 1st iteration */
/* Prepare to fetch more and coalesce */ /* Prepare to fetch more and coalesce */
if (unlikely( !(flags & MDB_ALLOC_GC) )) if (unlikely( !(flags & MDBX_ALLOC_GC) ))
break; break;
oldest = env->me_pgoldest; oldest = env->me_pgoldest;
mdb_cursor_init(&m2, txn, FREE_DBI, NULL); mdb_cursor_init(&m2, txn, FREE_DBI, NULL);
if (flags & MDB_LIFORECLAIM) { if (flags & MDBX_LIFORECLAIM) {
if (env->me_pglast > 1) { if (env->me_pglast > 1) {
/* Continue lookup from env->me_pglast to lower/first */ /* Continue lookup from env->me_pglast to lower/first */
last = env->me_pglast - 1; last = env->me_pglast - 1;
op = MDB_SET_RANGE; op = MDB_SET_RANGE;
} else { } else {
oldest = mdb_find_oldest(env, NULL); oldest = mdb_find_oldest(env, NULL);
env->me_pgoldest = oldest; found_oldest = 1;
found_old = 1;
/* Begin from oldest reader if any */ /* Begin from oldest reader if any */
if (oldest > 2) { if (oldest > 2) {
last = oldest - 1; last = oldest - 1;
@ -2167,13 +2164,12 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
key.mv_size = sizeof(last); key.mv_size = sizeof(last);
} }
if (! (flags & MDB_LIFORECLAIM) ) { if (! (flags & MDBX_LIFORECLAIM) ) {
/* Do not fetch more if the record will be too recent */ /* Do not fetch more if the record will be too recent */
if (op != MDB_FIRST && ++last >= oldest) { if (op != MDB_FIRST && ++last >= oldest) {
if (!found_old) { if (!found_oldest) {
oldest = mdb_find_oldest(env, NULL); oldest = mdb_find_oldest(env, NULL);
env->me_pgoldest = oldest; found_oldest = 1;
found_old = 1;
} }
if (oldest <= last) if (oldest <= last)
break; break;
@ -2181,12 +2177,11 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
} }
rc = mdb_cursor_get(&m2, &key, NULL, op); rc = mdb_cursor_get(&m2, &key, NULL, op);
if (rc == MDB_NOTFOUND && (flags & MDB_LIFORECLAIM)) { if (rc == MDB_NOTFOUND && (flags & MDBX_LIFORECLAIM)) {
if (op == MDB_SET_RANGE) if (op == MDB_SET_RANGE)
continue; continue;
env->me_pgoldest = mdb_find_oldest(env, NULL); found_oldest = 1;
found_old = 1; if (oldest < mdb_find_oldest(env, NULL)) {
if (oldest < env->me_pgoldest) {
oldest = env->me_pgoldest; oldest = env->me_pgoldest;
last = oldest - 1; last = oldest - 1;
key.mv_data = &last; key.mv_data = &last;
@ -2203,19 +2198,18 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
last = *(txnid_t*)key.mv_data; last = *(txnid_t*)key.mv_data;
if (oldest <= last) { if (oldest <= last) {
if (!found_old) { if (!found_oldest) {
oldest = mdb_find_oldest(env, NULL); oldest = mdb_find_oldest(env, NULL);
env->me_pgoldest = oldest; found_oldest = 1;
found_old = 1;
} }
if (oldest <= last) { if (oldest <= last) {
if (flags & MDB_LIFORECLAIM) if (flags & MDBX_LIFORECLAIM)
continue; continue;
break; break;
} }
} }
if (flags & MDB_LIFORECLAIM) { if (flags & MDBX_LIFORECLAIM) {
if (txn->mt_lifo_reclaimed) { if (txn->mt_lifo_reclaimed) {
for(j = txn->mt_lifo_reclaimed[0]; j > 0; --j) for(j = txn->mt_lifo_reclaimed[0]; j > 0; --j)
if (txn->mt_lifo_reclaimed[j] == last) if (txn->mt_lifo_reclaimed[j] == last)
@ -2230,7 +2224,7 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
if (unlikely((rc = mdb_node_read(txn, leaf, &data)) != MDB_SUCCESS)) if (unlikely((rc = mdb_node_read(txn, leaf, &data)) != MDB_SUCCESS))
goto fail; goto fail;
if ((flags & MDB_LIFORECLAIM) && !txn->mt_lifo_reclaimed) { if ((flags & MDBX_LIFORECLAIM) && !txn->mt_lifo_reclaimed) {
txn->mt_lifo_reclaimed = mdb_midl_alloc(env->me_maxfree_1pg); txn->mt_lifo_reclaimed = mdb_midl_alloc(env->me_maxfree_1pg);
if (unlikely(!txn->mt_lifo_reclaimed)) { if (unlikely(!txn->mt_lifo_reclaimed)) {
rc = ENOMEM; rc = ENOMEM;
@ -2251,13 +2245,13 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
goto fail; goto fail;
mop = env->me_pghead; mop = env->me_pghead;
} }
if (flags & MDB_LIFORECLAIM) { if (flags & MDBX_LIFORECLAIM) {
if ((rc = mdb_midl_append(&txn->mt_lifo_reclaimed, last)) != 0) if ((rc = mdb_midl_append(&txn->mt_lifo_reclaimed, last)) != 0)
goto fail; goto fail;
} }
env->me_pglast = last; env->me_pglast = last;
if (mdb_debug_enabled(MDB_DBG_EXTRA)) { if (mdb_debug_enabled(MDBX_DBG_EXTRA)) {
mdb_debug_extra("IDL read txn %zu root %zu num %u, IDL", mdb_debug_extra("IDL read txn %zu root %zu num %u, IDL",
last, txn->mt_dbs[FREE_DBI].md_root, i); last, txn->mt_dbs[FREE_DBI].md_root, i);
for (j = i; j; j--) for (j = i; j; j--)
@ -2269,7 +2263,7 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
mdb_midl_xmerge(mop, idl); mdb_midl_xmerge(mop, idl);
mop_len = mop[0]; mop_len = mop[0];
if (unlikely((flags & MDB_ALLOC_CACHE) == 0)) { if (unlikely((flags & MDBX_ALLOC_CACHE) == 0)) {
/* force gc reclaim mode */ /* force gc reclaim mode */
return MDB_SUCCESS; return MDB_SUCCESS;
} }
@ -2277,14 +2271,14 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
/* Don't try to coalesce too much. */ /* Don't try to coalesce too much. */
if (mop_len > MDB_IDL_UM_SIZE / 2) if (mop_len > MDB_IDL_UM_SIZE / 2)
break; break;
if (flags & MDB_COALESCE) { if (flags & MDBX_COALESCE) {
if (mop_len /* current size */ >= env->me_maxfree_1pg / 2 if (mop_len /* current size */ >= env->me_maxfree_1pg / 2
|| i /* prev size */ >= env->me_maxfree_1pg / 4) || i /* prev size */ >= env->me_maxfree_1pg / 4)
flags &= ~MDB_COALESCE; flags &= ~MDBX_COALESCE;
} }
} }
if ((flags & (MDB_COALESCE|MDB_ALLOC_CACHE)) == (MDB_COALESCE|MDB_ALLOC_CACHE) if ((flags & (MDBX_COALESCE|MDBX_ALLOC_CACHE)) == (MDBX_COALESCE|MDBX_ALLOC_CACHE)
&& mop_len > n2) { && mop_len > n2) {
i = mop_len; i = mop_len;
do { do {
@ -2296,7 +2290,7 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
i = 0; i = 0;
rc = MDB_NOTFOUND; rc = MDB_NOTFOUND;
if (likely(flags & MDB_ALLOC_NEW)) { if (likely(flags & MDBX_ALLOC_NEW)) {
/* Use new pages from the map when nothing suitable in the freeDB */ /* Use new pages from the map when nothing suitable in the freeDB */
pgno = txn->mt_next_pgno; pgno = txn->mt_next_pgno;
if (likely(pgno + num <= env->me_maxpg)) if (likely(pgno + num <= env->me_maxpg))
@ -2305,7 +2299,7 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
rc = MDB_MAP_FULL; rc = MDB_MAP_FULL;
} }
if (flags & MDB_ALLOC_GC) { if (flags & MDBX_ALLOC_GC) {
MDB_meta* head = mdb_meta_head_w(env); MDB_meta* head = mdb_meta_head_w(env);
MDB_meta* tail = mdb_env_meta_flipflop(env, head); MDB_meta* tail = mdb_env_meta_flipflop(env, head);
@ -2328,20 +2322,25 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
oldest, env->me_txns->mt1.mtb.mtb_txnid ); oldest, env->me_txns->mt1.mtb.mtb_txnid );
int flags = env->me_flags & MDB_WRITEMAP; int flags = env->me_flags & MDB_WRITEMAP;
if ((env->me_flags & MDB_UTTERLY_NOSYNC) == MDB_UTTERLY_NOSYNC) if ((env->me_flags & MDBX_UTTERLY_NOSYNC) == MDBX_UTTERLY_NOSYNC)
flags |= MDB_UTTERLY_NOSYNC; flags |= MDBX_UTTERLY_NOSYNC;
mdb_assert(env, env->me_sync_pending > 0); mdb_assert(env, env->me_sync_pending > 0);
if (mdb_env_sync0(env, flags, &meta) == MDB_SUCCESS) { if (mdb_env_sync0(env, flags, &meta) == MDB_SUCCESS) {
txnid_t snap = mdb_find_oldest(env, NULL); txnid_t snap = mdb_find_oldest(env, NULL);
if (snap > oldest) if (snap > oldest) {
continue; continue;
} }
} }
}
if (rc == MDB_MAP_FULL && mdb_oomkick(env, oldest)) if (rc == MDB_MAP_FULL) {
txnid_t snap = mdbx_oomkick(env, oldest);
if (snap > oldest) {
continue; continue;
} }
}
}
fail: fail:
if (mp) { if (mp) {
@ -2373,7 +2372,7 @@ done:
txn->mt_next_pgno = pgno + num; txn->mt_next_pgno = pgno + num;
} }
if (env->me_flags & MDB_PAGEPERTURB) if (env->me_flags & MDBX_PAGEPERTURB)
memset(np, 0x71 /* 'q', 113 */, env->me_psize * num); memset(np, 0x71 /* 'q', 113 */, env->me_psize * num);
VALGRIND_MAKE_MEM_UNDEFINED(np, env->me_psize * num); VALGRIND_MAKE_MEM_UNDEFINED(np, env->me_psize * num);
@ -2496,7 +2495,7 @@ mdb_page_touch(MDB_cursor *mc)
goto done; goto done;
} }
if (unlikely((rc = mdb_midl_need(&txn->mt_free_pgs, 1)) || if (unlikely((rc = mdb_midl_need(&txn->mt_free_pgs, 1)) ||
(rc = mdb_page_alloc(mc, 1, &np, MDB_ALLOC_ALL)))) (rc = mdb_page_alloc(mc, 1, &np, MDBX_ALLOC_ALL))))
goto fail; goto fail;
pgno = np->mp_pgno; pgno = np->mp_pgno;
mdb_debug("touched db %d page %zu -> %zu", DDBI(mc), mp->mp_pgno, pgno); mdb_debug("touched db %d page %zu -> %zu", DDBI(mc), mp->mp_pgno, pgno);
@ -2830,7 +2829,7 @@ mdb_txn_renew0(MDB_txn *txn, unsigned flags)
r->mr_pid = 0; r->mr_pid = 0;
r->mr_txnid = ~(txnid_t)0; r->mr_txnid = ~(txnid_t)0;
r->mr_tid = tid; r->mr_tid = tid;
mdb_coherent_barrier(); mdbx_coherent_barrier();
#ifdef __SANITIZE_THREAD__ #ifdef __SANITIZE_THREAD__
pthread_mutex_lock(&tsan_mutex); pthread_mutex_lock(&tsan_mutex);
#endif #endif
@ -2856,7 +2855,7 @@ mdb_txn_renew0(MDB_txn *txn, unsigned flags)
MDB_meta *meta = mdb_meta_head_r(txn->mt_env); MDB_meta *meta = mdb_meta_head_r(txn->mt_env);
txnid_t lead = meta->mm_txnid; txnid_t lead = meta->mm_txnid;
r->mr_txnid = lead; r->mr_txnid = lead;
mdb_coherent_barrier(); mdbx_coherent_barrier();
txnid_t snap = txn->mt_env->me_txns->mti_txnid; txnid_t snap = txn->mt_env->me_txns->mti_txnid;
/* LY: Retry on a race, ITS#7970. */ /* LY: Retry on a race, ITS#7970. */
@ -2890,9 +2889,9 @@ mdb_txn_renew0(MDB_txn *txn, unsigned flags)
#if MDB_DEBUG #if MDB_DEBUG
if (unlikely(txn->mt_txnid == mdb_debug_edge)) { if (unlikely(txn->mt_txnid == mdb_debug_edge)) {
if (! mdb_debug_logger) if (! mdb_debug_logger)
mdb_runtime_flags |= MDB_DBG_TRACE | MDB_DBG_EXTRA mdb_runtime_flags |= MDBX_DBG_TRACE | MDBX_DBG_EXTRA
| MDB_DBG_AUDIT | MDB_DBG_ASSERT; | MDBX_DBG_AUDIT | MDBX_DBG_ASSERT;
mdb_debug_log(MDB_DBG_EDGE, __FUNCTION__, __LINE__, mdb_debug_log(MDBX_DBG_EDGE, __FUNCTION__, __LINE__,
"on/off edge (txn %zu)", txn->mt_txnid); "on/off edge (txn %zu)", txn->mt_txnid);
} }
#endif #endif
@ -3189,7 +3188,7 @@ mdb_txn_end(MDB_txn *txn, unsigned mode)
pthread_mutex_unlock(&tsan_mutex); pthread_mutex_unlock(&tsan_mutex);
#endif #endif
} }
mdb_coherent_barrier(); mdbx_coherent_barrier();
txn->mt_numdbs = 0; /* prevent further DBI activity */ txn->mt_numdbs = 0; /* prevent further DBI activity */
txn->mt_flags |= MDB_TXN_FINISHED; txn->mt_flags |= MDB_TXN_FINISHED;
@ -3275,7 +3274,7 @@ mdb_txn_abort(MDB_txn *txn)
return mdb_txn_end(txn, MDB_END_ABORT|MDB_END_SLOT|MDB_END_FREE); return mdb_txn_end(txn, MDB_END_ABORT|MDB_END_SLOT|MDB_END_FREE);
} }
static MDB_INLINE int static MDBX_INLINE int
mdb_backlog_size(MDB_txn *txn) mdb_backlog_size(MDB_txn *txn)
{ {
int reclaimed = txn->mt_env->me_pghead ? txn->mt_env->me_pghead[0] : 0; int reclaimed = txn->mt_env->me_pghead ? txn->mt_env->me_pghead[0] : 0;
@ -3289,7 +3288,7 @@ static int
mdb_prep_backlog(MDB_txn *txn, MDB_cursor *mc) mdb_prep_backlog(MDB_txn *txn, MDB_cursor *mc)
{ {
/* LY: extra page(s) for b-tree rebalancing */ /* LY: extra page(s) for b-tree rebalancing */
const int extra = (txn->mt_env->me_flags & MDB_LIFORECLAIM) ? 2 : 1; const int extra = (txn->mt_env->me_flags & MDBX_LIFORECLAIM) ? 2 : 1;
if (mdb_backlog_size(txn) < mc->mc_db->md_depth + extra) { if (mdb_backlog_size(txn) < mc->mc_db->md_depth + extra) {
int rc = mdb_cursor_touch(mc); int rc = mdb_cursor_touch(mc);
@ -3297,7 +3296,7 @@ mdb_prep_backlog(MDB_txn *txn, MDB_cursor *mc)
return rc; return rc;
while (unlikely(mdb_backlog_size(txn) < extra)) { while (unlikely(mdb_backlog_size(txn) < extra)) {
rc = mdb_page_alloc(mc, 1, NULL, MDB_ALLOC_GC); rc = mdb_page_alloc(mc, 1, NULL, MDBX_ALLOC_GC);
if (unlikely(rc)) { if (unlikely(rc)) {
if (unlikely(rc != MDB_NOTFOUND)) if (unlikely(rc != MDB_NOTFOUND))
return rc; return rc;
@ -3326,7 +3325,7 @@ mdb_freelist_save(MDB_txn *txn)
pgno_t freecnt = 0, *free_pgs, *mop; pgno_t freecnt = 0, *free_pgs, *mop;
ssize_t head_room = 0, total_room = 0, mop_len, clean_limit; ssize_t head_room = 0, total_room = 0, mop_len, clean_limit;
unsigned cleanup_idx = 0, refill_idx = 0; unsigned cleanup_idx = 0, refill_idx = 0;
const int lifo = (env->me_flags & MDB_LIFORECLAIM) != 0; const int lifo = (env->me_flags & MDBX_LIFORECLAIM) != 0;
mdb_cursor_init(&mc, txn, FREE_DBI, NULL); mdb_cursor_init(&mc, txn, FREE_DBI, NULL);
@ -3422,7 +3421,7 @@ again:
mdb_midl_sort(free_pgs); mdb_midl_sort(free_pgs);
memcpy(data.mv_data, free_pgs, data.mv_size); memcpy(data.mv_data, free_pgs, data.mv_size);
if (mdb_debug_enabled(MDB_DBG_EXTRA)) { if (mdb_debug_enabled(MDBX_DBG_EXTRA)) {
unsigned i = free_pgs[0]; unsigned i = free_pgs[0];
mdb_debug_extra("IDL write txn %zu root %zu num %u, IDL", mdb_debug_extra("IDL write txn %zu root %zu num %u, IDL",
txn->mt_txnid, txn->mt_dbs[FREE_DBI].md_root, i); txn->mt_txnid, txn->mt_dbs[FREE_DBI].md_root, i);
@ -3456,7 +3455,7 @@ again:
if (lifo) { if (lifo) {
if (refill_idx > (txn->mt_lifo_reclaimed ? txn->mt_lifo_reclaimed[0] : 0)) { if (refill_idx > (txn->mt_lifo_reclaimed ? txn->mt_lifo_reclaimed[0] : 0)) {
/* LY: need more just a txn-id for save page list. */ /* LY: need more just a txn-id for save page list. */
rc = mdb_page_alloc(&mc, 0, NULL, MDB_ALLOC_GC); rc = mdb_page_alloc(&mc, 0, NULL, MDBX_ALLOC_GC);
if (likely(rc == 0)) if (likely(rc == 0))
/* LY: ok, reclaimed from freedb. */ /* LY: ok, reclaimed from freedb. */
continue; continue;
@ -4196,7 +4195,7 @@ mdb_env_sync0(MDB_env *env, unsigned flags, MDB_meta *pending)
pending->mm_datasync_sign = mdb_meta_sign(pending); pending->mm_datasync_sign = mdb_meta_sign(pending);
} else { } else {
pending->mm_datasync_sign = pending->mm_datasync_sign =
(flags & MDB_UTTERLY_NOSYNC) == MDB_UTTERLY_NOSYNC (flags & MDBX_UTTERLY_NOSYNC) == MDBX_UTTERLY_NOSYNC
? MDB_DATASIGN_NONE : MDB_DATASIGN_WEAK; ? MDB_DATASIGN_NONE : MDB_DATASIGN_WEAK;
} }
mdb_debug("writing meta %d, root %zu, txn_id %zu, %s", mdb_debug("writing meta %d, root %zu, txn_id %zu, %s",
@ -4354,14 +4353,13 @@ mdb_env_map(MDB_env *env, void *addr, size_t usedsize)
#endif #endif
#ifdef MADV_DONTDUMP #ifdef MADV_DONTDUMP
if (! (flags & MDB_PAGEPERTURB)) { if (! (flags & MDBX_PAGEPERTURB)) {
(void) madvise(env->me_map, env->me_mapsize, MADV_DONTDUMP); (void) madvise(env->me_map, env->me_mapsize, MADV_DONTDUMP);
} }
#endif #endif
#ifdef MADV_REMOVE #ifdef MADV_REMOVE
if (flags & MDB_WRITEMAP) { if (flags & MDB_WRITEMAP) {
assert(used_edge < env->me_mapsize);
(void) madvise(env->me_map + usedsize, env->me_mapsize - usedsize, MADV_REMOVE); (void) madvise(env->me_map + usedsize, env->me_mapsize - usedsize, MADV_REMOVE);
} }
#endif #endif
@ -4583,9 +4581,9 @@ void mdb_env_reader_destr(void *ptr)
mdb_ensure(NULL, reader->mr_rthc == rthc); mdb_ensure(NULL, reader->mr_rthc == rthc);
rthc->rc_reader = NULL; rthc->rc_reader = NULL;
reader->mr_rthc = NULL; reader->mr_rthc = NULL;
mdb_compiler_barrier(); mdbx_compiler_barrier();
reader->mr_pid = 0; reader->mr_pid = 0;
mdb_coherent_barrier(); mdbx_coherent_barrier();
} }
mdb_ensure(NULL, pthread_mutex_unlock(&mdb_rthc_lock) == 0); mdb_ensure(NULL, pthread_mutex_unlock(&mdb_rthc_lock) == 0);
free(rthc); free(rthc);
@ -4847,9 +4845,9 @@ mdb_env_setup_locks(MDB_env *env, char *lpath, int mode, int *excl)
* environment and re-opening it with the new flags. * environment and re-opening it with the new flags.
*/ */
#define CHANGEABLE (MDB_NOSYNC|MDB_NOMETASYNC|MDB_MAPASYNC| \ #define CHANGEABLE (MDB_NOSYNC|MDB_NOMETASYNC|MDB_MAPASYNC| \
MDB_NOMEMINIT|MDB_COALESCE|MDB_PAGEPERTURB) MDB_NOMEMINIT|MDBX_COALESCE|MDBX_PAGEPERTURB)
#define CHANGELESS (MDB_FIXEDMAP|MDB_NOSUBDIR|MDB_RDONLY| \ #define CHANGELESS (MDB_FIXEDMAP|MDB_NOSUBDIR|MDB_RDONLY| \
MDB_WRITEMAP|MDB_NOTLS|MDB_NORDAHEAD|MDB_LIFORECLAIM) MDB_WRITEMAP|MDB_NOTLS|MDB_NORDAHEAD|MDBX_LIFORECLAIM)
#if VALID_FLAGS & PERSISTENT_FLAGS & (CHANGEABLE|CHANGELESS) #if VALID_FLAGS & PERSISTENT_FLAGS & (CHANGEABLE|CHANGELESS)
# error "Persistent DB flags & env flags overlap, but both go in mm_flags" # error "Persistent DB flags & env flags overlap, but both go in mm_flags"
@ -4870,12 +4868,12 @@ mdbx_env_open_ex(MDB_env *env, const char *path, unsigned flags, mode_t mode, in
if (unlikely(env->me_signature != MDBX_ME_SIGNATURE)) if (unlikely(env->me_signature != MDBX_ME_SIGNATURE))
return MDB_VERSION_MISMATCH; return MDB_VERSION_MISMATCH;
#if MDB_LIFORECLAIM #if MDBX_LIFORECLAIM
/* LY: don't allow LIFO with just NOMETASYNC */ /* LY: don't allow LIFO with just NOMETASYNC */
if ((flags & (MDB_NOMETASYNC | MDB_LIFORECLAIM | MDB_NOSYNC)) if ((flags & (MDB_NOMETASYNC | MDBX_LIFORECLAIM | MDB_NOSYNC))
== (MDB_NOMETASYNC | MDB_LIFORECLAIM)) == (MDB_NOMETASYNC | MDBX_LIFORECLAIM))
return EINVAL; return EINVAL;
#endif /* MDB_LIFORECLAIM */ #endif /* MDBX_LIFORECLAIM */
if (env->me_fd != INVALID_HANDLE_VALUE || (flags & ~(CHANGEABLE|CHANGELESS))) if (env->me_fd != INVALID_HANDLE_VALUE || (flags & ~(CHANGEABLE|CHANGELESS)))
return EINVAL; return EINVAL;
@ -4904,7 +4902,7 @@ mdbx_env_open_ex(MDB_env *env, const char *path, unsigned flags, mode_t mode, in
if (flags & MDB_RDONLY) { if (flags & MDB_RDONLY) {
/* LY: silently ignore irrelevant flags when we're only getting read access */ /* LY: silently ignore irrelevant flags when we're only getting read access */
flags &= ~(MDB_WRITEMAP | MDB_MAPASYNC | MDB_NOSYNC | MDB_NOMETASYNC flags &= ~(MDB_WRITEMAP | MDB_MAPASYNC | MDB_NOSYNC | MDB_NOMETASYNC
| MDB_COALESCE | MDB_LIFORECLAIM | MDB_NOMEMINIT); | MDBX_COALESCE | MDBX_LIFORECLAIM | MDB_NOMEMINIT);
} else { } else {
if (!((env->me_free_pgs = mdb_midl_alloc(MDB_IDL_UM_MAX)) if (!((env->me_free_pgs = mdb_midl_alloc(MDB_IDL_UM_MAX))
&& (env->me_dirty_list = calloc(MDB_IDL_UM_SIZE, sizeof(MDB_ID2))))) && (env->me_dirty_list = calloc(MDB_IDL_UM_SIZE, sizeof(MDB_ID2)))))
@ -5078,7 +5076,7 @@ mdb_env_close0(MDB_env *env)
reader->mr_pid = 0; reader->mr_pid = 0;
} }
} }
mdb_coherent_barrier(); mdbx_coherent_barrier();
mdb_ensure(env, pthread_mutex_unlock(&mdb_rthc_lock) == 0); mdb_ensure(env, pthread_mutex_unlock(&mdb_rthc_lock) == 0);
} }
@ -5740,7 +5738,7 @@ release:
* @param[out] data Updated to point to the node's data. * @param[out] data Updated to point to the node's data.
* @return 0 on success, non-zero on failure. * @return 0 on success, non-zero on failure.
*/ */
static MDB_INLINE int static MDBX_INLINE int
mdb_node_read(MDB_txn *txn, MDB_node *leaf, MDB_val *data) mdb_node_read(MDB_txn *txn, MDB_node *leaf, MDB_val *data)
{ {
MDB_page *omp; /* overflow page */ MDB_page *omp; /* overflow page */
@ -6825,7 +6823,7 @@ prep_subDB:
dummy.md_entries = NUMKEYS(fp); dummy.md_entries = NUMKEYS(fp);
xdata.mv_size = sizeof(MDB_db); xdata.mv_size = sizeof(MDB_db);
xdata.mv_data = &dummy; xdata.mv_data = &dummy;
if ((rc = mdb_page_alloc(mc, 1, &mp, MDB_ALLOC_ALL))) if ((rc = mdb_page_alloc(mc, 1, &mp, MDBX_ALLOC_ALL)))
return rc; return rc;
offset = env->me_psize - olddata.mv_size; offset = env->me_psize - olddata.mv_size;
flags |= F_DUPDATA|F_SUBDATA; flags |= F_DUPDATA|F_SUBDATA;
@ -7199,7 +7197,7 @@ mdb_page_new(MDB_cursor *mc, uint32_t flags, int num, MDB_page **mp)
MDB_page *np; MDB_page *np;
int rc; int rc;
if (unlikely((rc = mdb_page_alloc(mc, num, &np, MDB_ALLOC_ALL)))) if (unlikely((rc = mdb_page_alloc(mc, num, &np, MDBX_ALLOC_ALL))))
return rc; return rc;
mdb_debug("allocated new mpage %zu, page size %u", mdb_debug("allocated new mpage %zu, page size %u",
np->mp_pgno, mc->mc_txn->mt_env->me_psize); np->mp_pgno, mc->mc_txn->mt_env->me_psize);
@ -7231,7 +7229,7 @@ mdb_page_new(MDB_cursor *mc, uint32_t flags, int num, MDB_page **mp)
* @param[in] data The data for the node. * @param[in] data The data for the node.
* @return The number of bytes needed to store the node. * @return The number of bytes needed to store the node.
*/ */
static MDB_INLINE size_t static MDBX_INLINE size_t
mdb_leaf_size(MDB_env *env, MDB_val *key, MDB_val *data) mdb_leaf_size(MDB_env *env, MDB_val *key, MDB_val *data)
{ {
size_t sz; size_t sz;
@ -7255,7 +7253,7 @@ mdb_leaf_size(MDB_env *env, MDB_val *key, MDB_val *data)
* @param[in] key The key for the node. * @param[in] key The key for the node.
* @return The number of bytes needed to store the node. * @return The number of bytes needed to store the node.
*/ */
static MDB_INLINE size_t static MDBX_INLINE size_t
mdb_branch_size(MDB_env *env, MDB_val *key) mdb_branch_size(MDB_env *env, MDB_val *key)
{ {
size_t sz; size_t sz;
@ -9614,12 +9612,12 @@ mdb_env_set_flags(MDB_env *env, unsigned flags, int onoff)
else else
flags = env->me_flags & ~flags; flags = env->me_flags & ~flags;
#if MDB_LIFORECLAIM #if MDBX_LIFORECLAIM
/* LY: don't allow LIFO with just NOMETASYNC */ /* LY: don't allow LIFO with just NOMETASYNC */
if ((flags & (MDB_NOMETASYNC | MDB_LIFORECLAIM | MDB_NOSYNC)) if ((flags & (MDB_NOMETASYNC | MDBX_LIFORECLAIM | MDB_NOSYNC))
== (MDB_NOMETASYNC | MDB_LIFORECLAIM)) == (MDB_NOMETASYNC | MDBX_LIFORECLAIM))
return EINVAL; return EINVAL;
#endif /* MDB_LIFORECLAIM */ #endif /* MDBX_LIFORECLAIM */
env->me_flags = flags; env->me_flags = flags;
mdb_mutex_unlock(env, mutex); mdb_mutex_unlock(env, mutex);
@ -10370,7 +10368,7 @@ mdb_reader_check0(MDB_env *env, int rlocked, int *dead)
mdb_debug("clear stale reader pid %u txn %zd", mdb_debug("clear stale reader pid %u txn %zd",
(unsigned) pid, mr[j].mr_txnid); (unsigned) pid, mr[j].mr_txnid);
mr[j].mr_rthc = NULL; mr[j].mr_rthc = NULL;
mdb_compiler_barrier(); mdbx_compiler_barrier();
mr[j].mr_pid = 0; mr[j].mr_pid = 0;
count++; count++;
} }
@ -10453,13 +10451,13 @@ static void mdb_mutex_unlock(MDB_env *env, pthread_mutex_t *mutex) {
#if MDBX_MODE_ENABLED #if MDBX_MODE_ENABLED
void __cold void __cold
mdbx_env_set_oomfunc(MDB_env *env, MDB_oom_func *oomfunc) mdbx_env_set_oomfunc(MDB_env *env, MDBX_oom_func *oomfunc)
{ {
if (likely(env && env->me_signature == MDBX_ME_SIGNATURE)) if (likely(env && env->me_signature == MDBX_ME_SIGNATURE))
env->me_oom_func = oomfunc; env->me_oom_func = oomfunc;
} }
MDB_oom_func* __cold MDBX_oom_func* __cold
mdbx_env_get_oomfunc(MDB_env *env) mdbx_env_get_oomfunc(MDB_env *env)
{ {
return likely(env && env->me_signature == MDBX_ME_SIGNATURE) return likely(env && env->me_signature == MDBX_ME_SIGNATURE)
@ -10469,7 +10467,7 @@ mdbx_env_get_oomfunc(MDB_env *env)
struct mdb_walk_ctx { struct mdb_walk_ctx {
MDB_txn *mw_txn; MDB_txn *mw_txn;
void *mw_user; void *mw_user;
MDB_pgvisitor_func *mw_visitor; MDBX_pgvisitor_func *mw_visitor;
}; };
typedef struct mdb_walk_ctx mdb_walk_ctx_t; typedef struct mdb_walk_ctx mdb_walk_ctx_t;
@ -10601,7 +10599,7 @@ mdb_env_walk(mdb_walk_ctx_t *ctx, const char* dbi, pgno_t pg, int flags, int dee
} }
int __cold int __cold
mdbx_env_pgwalk(MDB_txn *txn, MDB_pgvisitor_func* visitor, void* user) mdbx_env_pgwalk(MDB_txn *txn, MDBX_pgvisitor_func* visitor, void* user)
{ {
mdb_walk_ctx_t ctx; mdb_walk_ctx_t ctx;
int rc; int rc;

View File

@ -117,10 +117,10 @@ static void wbench(int flags, int mb, int count, int salt)
printf(" WRITEMAP"); printf(" WRITEMAP");
if (flags & MDB_MAPASYNC) if (flags & MDB_MAPASYNC)
printf(" MAPASYNC"); printf(" MAPASYNC");
#if defined(MDB_COALESCE) && defined(MDB_LIFORECLAIM) #if defined(MDBX_COALESCE) && defined(MDBX_LIFORECLAIM)
if (flags & MDB_COALESCE) if (flags & MDBX_COALESCE)
printf(" COALESCE"); printf(" COALESCE");
if (flags & MDB_LIFORECLAIM) if (flags & MDBX_LIFORECLAIM)
printf(" LIFO"); printf(" LIFO");
#endif #endif
printf(" 0x%X\n", flags); printf(" 0x%X\n", flags);
@ -193,10 +193,10 @@ static void wbench(int flags, int mb, int count, int salt)
fprintf(stderr, " WRITEMAP"); fprintf(stderr, " WRITEMAP");
if (flags & MDB_MAPASYNC) if (flags & MDB_MAPASYNC)
fprintf(stderr, " MAPASYNC"); fprintf(stderr, " MAPASYNC");
#if defined(MDB_COALESCE) && defined(MDB_LIFORECLAIM) #if defined(MDBX_COALESCE) && defined(MDBX_LIFORECLAIM)
if (flags & MDB_COALESCE) if (flags & MDBX_COALESCE)
fprintf(stderr, " COALESCE"); fprintf(stderr, " COALESCE");
if (flags & MDB_LIFORECLAIM) if (flags & MDBX_LIFORECLAIM)
fprintf(stderr, " LIFO"); fprintf(stderr, " LIFO");
#endif #endif
fprintf(stderr, "\t%.3f\t%.3f\t%.3f\t%.3f\n", rt.iops_w / 1000.0, rt.cpu_user_s, rt.cpu_sys_s, rt.wall_s); fprintf(stderr, "\t%.3f\t%.3f\t%.3f\t%.3f\n", rt.iops_w / 1000.0, rt.cpu_user_s, rt.cpu_sys_s, rt.wall_s);
@ -214,50 +214,50 @@ int main(int argc,char * argv[])
printf("\nDefault 'sync' mode..."); printf("\nDefault 'sync' mode...");
wbench(0, SIZE, COUNT, SALT); wbench(0, SIZE, COUNT, SALT);
#if defined(MDB_COALESCE) && defined(MDB_LIFORECLAIM) #if defined(MDBX_COALESCE) && defined(MDBX_LIFORECLAIM)
// wbench(MDB_COALESCE, SIZE, COUNT, SALT); // wbench(MDBX_COALESCE, SIZE, COUNT, SALT);
wbench(MDB_COALESCE | MDB_LIFORECLAIM, SIZE, COUNT, SALT); wbench(MDBX_COALESCE | MDBX_LIFORECLAIM, SIZE, COUNT, SALT);
// wbench(MDB_LIFORECLAIM, SIZE, COUNT, SALT); // wbench(MDBX_LIFORECLAIM, SIZE, COUNT, SALT);
#endif #endif
printf("\nno-meta-sync hack..."); printf("\nno-meta-sync hack...");
wbench(MDB_NOMETASYNC, SIZE, COUNT, SALT); wbench(MDB_NOMETASYNC, SIZE, COUNT, SALT);
#if defined(MDB_COALESCE) && defined(MDB_LIFORECLAIM) #if defined(MDBX_COALESCE) && defined(MDBX_LIFORECLAIM)
// wbench(MDB_NOMETASYNC | MDB_COALESCE, SIZE, COUNT, SALT); // wbench(MDB_NOMETASYNC | MDBX_COALESCE, SIZE, COUNT, SALT);
wbench(MDB_NOMETASYNC | MDB_COALESCE | MDB_LIFORECLAIM, SIZE, COUNT, SALT); wbench(MDB_NOMETASYNC | MDBX_COALESCE | MDBX_LIFORECLAIM, SIZE, COUNT, SALT);
// wbench(MDB_NOMETASYNC | MDB_LIFORECLAIM, SIZE, COUNT, SALT); // wbench(MDB_NOMETASYNC | MDBX_LIFORECLAIM, SIZE, COUNT, SALT);
#endif #endif
printf("\nno-sync..."); printf("\nno-sync...");
wbench(MDB_NOSYNC, SIZE, COUNT, SALT); wbench(MDB_NOSYNC, SIZE, COUNT, SALT);
#if defined(MDB_COALESCE) && defined(MDB_LIFORECLAIM) #if defined(MDBX_COALESCE) && defined(MDBX_LIFORECLAIM)
// wbench(MDB_NOSYNC | MDB_COALESCE, SIZE, COUNT, SALT); // wbench(MDB_NOSYNC | MDBX_COALESCE, SIZE, COUNT, SALT);
// wbench(MDB_NOSYNC | MDB_COALESCE | MDB_LIFORECLAIM, SIZE, COUNT, SALT); // wbench(MDB_NOSYNC | MDBX_COALESCE | MDBX_LIFORECLAIM, SIZE, COUNT, SALT);
// wbench(MDB_NOSYNC | MDB_LIFORECLAIM, SIZE, COUNT, SALT); // wbench(MDB_NOSYNC | MDBX_LIFORECLAIM, SIZE, COUNT, SALT);
#endif #endif
printf("\nr/w-map..."); printf("\nr/w-map...");
wbench(MDB_WRITEMAP, SIZE, COUNT, SALT); wbench(MDB_WRITEMAP, SIZE, COUNT, SALT);
#if defined(MDB_COALESCE) && defined(MDB_LIFORECLAIM) #if defined(MDBX_COALESCE) && defined(MDBX_LIFORECLAIM)
// wbench(MDB_WRITEMAP | MDB_COALESCE, SIZE, COUNT, SALT); // wbench(MDB_WRITEMAP | MDBX_COALESCE, SIZE, COUNT, SALT);
wbench(MDB_WRITEMAP | MDB_COALESCE | MDB_LIFORECLAIM, SIZE, COUNT, SALT); wbench(MDB_WRITEMAP | MDBX_COALESCE | MDBX_LIFORECLAIM, SIZE, COUNT, SALT);
// wbench(MDB_WRITEMAP | MDB_LIFORECLAIM, SIZE, COUNT, SALT); // wbench(MDB_WRITEMAP | MDBX_LIFORECLAIM, SIZE, COUNT, SALT);
#endif #endif
printf("\nasync..."); printf("\nasync...");
wbench(MDB_WRITEMAP | MDB_MAPASYNC, SIZE, COUNT, SALT); wbench(MDB_WRITEMAP | MDB_MAPASYNC, SIZE, COUNT, SALT);
#if defined(MDB_COALESCE) && defined(MDB_LIFORECLAIM) #if defined(MDBX_COALESCE) && defined(MDBX_LIFORECLAIM)
// wbench(MDB_WRITEMAP | MDB_MAPASYNC | MDB_COALESCE, SIZE, COUNT, SALT); // wbench(MDB_WRITEMAP | MDB_MAPASYNC | MDBX_COALESCE, SIZE, COUNT, SALT);
wbench(MDB_WRITEMAP | MDB_MAPASYNC | MDB_COALESCE | MDB_LIFORECLAIM, SIZE, COUNT, SALT); wbench(MDB_WRITEMAP | MDB_MAPASYNC | MDBX_COALESCE | MDBX_LIFORECLAIM, SIZE, COUNT, SALT);
// wbench(MDB_WRITEMAP | MDB_MAPASYNC | MDB_LIFORECLAIM, SIZE, COUNT, SALT); // wbench(MDB_WRITEMAP | MDB_MAPASYNC | MDBX_LIFORECLAIM, SIZE, COUNT, SALT);
#endif #endif
printf("\nr/w-map + no-sync..."); printf("\nr/w-map + no-sync...");
wbench(MDB_NOSYNC | MDB_WRITEMAP, SIZE, COUNT, SALT); wbench(MDB_NOSYNC | MDB_WRITEMAP, SIZE, COUNT, SALT);
#if defined(MDB_COALESCE) && defined(MDB_LIFORECLAIM) #if defined(MDBX_COALESCE) && defined(MDBX_LIFORECLAIM)
// wbench(MDB_NOSYNC | MDB_WRITEMAP | MDB_COALESCE, SIZE, COUNT, SALT); // wbench(MDB_NOSYNC | MDB_WRITEMAP | MDBX_COALESCE, SIZE, COUNT, SALT);
wbench(MDB_NOSYNC | MDB_WRITEMAP | MDB_COALESCE | MDB_LIFORECLAIM, SIZE, COUNT, SALT); wbench(MDB_NOSYNC | MDB_WRITEMAP | MDBX_COALESCE | MDBX_LIFORECLAIM, SIZE, COUNT, SALT);
// wbench(MDB_NOSYNC | MDB_WRITEMAP | MDB_LIFORECLAIM, SIZE, COUNT, SALT); // wbench(MDB_NOSYNC | MDB_WRITEMAP | MDBX_LIFORECLAIM, SIZE, COUNT, SALT);
#endif #endif
return 0; return 0;