mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-01 23:24:13 +08:00
mdbx: refine mdbx.h and API description, etc (3 of 5).
Change-Id: I05890bdf2e29c6c5a4b1f861f5bfda920e970126
This commit is contained in:
parent
4022110955
commit
b19e180fab
@ -10,9 +10,10 @@ Database](https://en.wikipedia.org/wiki/Lightning_Memory-Mapped_Database)
|
|||||||
2.8](LICENSE). Русскоязычная версия этого README [здесь](README-RU.md).
|
2.8](LICENSE). Русскоязычная версия этого README [здесь](README-RU.md).
|
||||||
|
|
||||||
_libmdbx_ is superior to LMDB in terms of features and reliability, not
|
_libmdbx_ is superior to LMDB in terms of features and reliability, not
|
||||||
inferior in performance. _libmdbx_ works on Linux, FreeBSD, MacOS X and
|
inferior in performance. In comparison to LMDB, _libmdbx_ makes many
|
||||||
other systems compliant with POSIX.1-2008, but also support Windows as a
|
things just work perfectly, not silently and catastrophically break
|
||||||
complementary platform.
|
down. _libmdbx_ supports Linux, Windows, MacOS, FreeBSD and other
|
||||||
|
systems compliant with POSIX.1-2008.
|
||||||
|
|
||||||
The next version is under active non-public development and will be
|
The next version is under active non-public development and will be
|
||||||
released as **_MithrilDB_** and `libmithrildb` for libraries & packages.
|
released as **_MithrilDB_** and `libmithrildb` for libraries & packages.
|
||||||
|
@ -1411,7 +1411,7 @@ static const char *__mdbx_strerr(int errnum) {
|
|||||||
"MDBX_NOTFOUND: No matching key/data pair found",
|
"MDBX_NOTFOUND: No matching key/data pair found",
|
||||||
"MDBX_PAGE_NOTFOUND: Requested page not found",
|
"MDBX_PAGE_NOTFOUND: Requested page not found",
|
||||||
"MDBX_CORRUPTED: Database is corrupted",
|
"MDBX_CORRUPTED: Database is corrupted",
|
||||||
"MDBX_PANIC: Update of meta page failed or environment had fatal error",
|
"MDBX_PANIC: Environment had fatal error",
|
||||||
"MDBX_VERSION_MISMATCH: DB version mismatch libmdbx",
|
"MDBX_VERSION_MISMATCH: DB version mismatch libmdbx",
|
||||||
"MDBX_INVALID: File is not an MDBX file",
|
"MDBX_INVALID: File is not an MDBX file",
|
||||||
"MDBX_MAP_FULL: Environment mapsize limit reached",
|
"MDBX_MAP_FULL: Environment mapsize limit reached",
|
||||||
@ -2937,7 +2937,7 @@ done:
|
|||||||
mdbx_assert(env, txn->mt_next_pgno <= txn->mt_end_pgno);
|
mdbx_assert(env, txn->mt_next_pgno <= txn->mt_end_pgno);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (env->me_flags & MDBX_PAGEPERTURB)
|
if (unlikely(env->me_flags & MDBX_PAGEPERTURB))
|
||||||
memset(np, 0x71 /* 'q', 113 */, pgno2bytes(env, num));
|
memset(np, 0x71 /* 'q', 113 */, pgno2bytes(env, num));
|
||||||
VALGRIND_MAKE_MEM_UNDEFINED(np, pgno2bytes(env, num));
|
VALGRIND_MAKE_MEM_UNDEFINED(np, pgno2bytes(env, num));
|
||||||
|
|
||||||
@ -5872,7 +5872,7 @@ static void __cold mdbx_setup_pagesize(MDBX_env *env, const size_t pagesize) {
|
|||||||
|
|
||||||
int __cold mdbx_env_create(MDBX_env **penv) {
|
int __cold mdbx_env_create(MDBX_env **penv) {
|
||||||
MDBX_env *env = mdbx_calloc(1, sizeof(MDBX_env));
|
MDBX_env *env = mdbx_calloc(1, sizeof(MDBX_env));
|
||||||
if (!env)
|
if (unlikely(!env))
|
||||||
return MDBX_ENOMEM;
|
return MDBX_ENOMEM;
|
||||||
|
|
||||||
env->me_maxreaders = DEFAULT_READERS;
|
env->me_maxreaders = DEFAULT_READERS;
|
||||||
@ -5883,7 +5883,7 @@ int __cold mdbx_env_create(MDBX_env **penv) {
|
|||||||
|
|
||||||
int rc;
|
int rc;
|
||||||
const size_t os_psize = mdbx_syspagesize();
|
const size_t os_psize = mdbx_syspagesize();
|
||||||
if (!mdbx_is_power2(os_psize) || os_psize < MIN_PAGESIZE) {
|
if (unlikely(!mdbx_is_power2(os_psize) || os_psize < MIN_PAGESIZE)) {
|
||||||
mdbx_error("unsuitable system pagesize %" PRIuPTR, os_psize);
|
mdbx_error("unsuitable system pagesize %" PRIuPTR, os_psize);
|
||||||
rc = MDBX_INCOMPATIBLE;
|
rc = MDBX_INCOMPATIBLE;
|
||||||
goto bailout;
|
goto bailout;
|
||||||
@ -5942,7 +5942,7 @@ static int __cold mdbx_env_map(MDBX_env *env, const int is_exclusive,
|
|||||||
#if defined(MADV_DODUMP) && defined(MADV_DONTDUMP)
|
#if defined(MADV_DODUMP) && defined(MADV_DONTDUMP)
|
||||||
const size_t meta_length = pgno2bytes(env, NUM_METAS);
|
const size_t meta_length = pgno2bytes(env, NUM_METAS);
|
||||||
(void)madvise(env->me_map, meta_length, MADV_DODUMP);
|
(void)madvise(env->me_map, meta_length, MADV_DODUMP);
|
||||||
if (!(env->me_flags & MDBX_PAGEPERTURB))
|
if ((env->me_flags & MDBX_PAGEPERTURB) == 0)
|
||||||
(void)madvise(env->me_map + meta_length, env->me_mapsize - meta_length,
|
(void)madvise(env->me_map + meta_length, env->me_mapsize - meta_length,
|
||||||
MADV_DONTDUMP);
|
MADV_DONTDUMP);
|
||||||
#endif
|
#endif
|
||||||
@ -13921,7 +13921,7 @@ __hot static ptrdiff_t estimate(const MDBX_db *db,
|
|||||||
* level-1: branch-page(s) => scale = leaf-factor * branch-factor^2
|
* level-1: branch-page(s) => scale = leaf-factor * branch-factor^2
|
||||||
* level-2: branch-page(s) => scale = leaf-factor * branch-factor
|
* level-2: branch-page(s) => scale = leaf-factor * branch-factor
|
||||||
* level-N: branch-page(s) => scale = leaf-factor
|
* level-N: branch-page(s) => scale = leaf-factor
|
||||||
* last-level: leaf-page(s) => scale = 1
|
* leaf-level: leaf-page(s) => scale = 1
|
||||||
*/
|
*/
|
||||||
ptrdiff_t btree_power = db->md_depth - 2 - dr->level;
|
ptrdiff_t btree_power = db->md_depth - 2 - dr->level;
|
||||||
if (btree_power < 0)
|
if (btree_power < 0)
|
||||||
@ -14611,8 +14611,8 @@ __cold intptr_t mdbx_limits_txnsize_max(intptr_t pagesize) {
|
|||||||
return pagesize * (MDBX_DPL_TXNFULL - 1);
|
return pagesize * (MDBX_DPL_TXNFULL - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*----------------------------------------------------------------------------*/
|
/*** Attribute support functions for Nexenta **********************************/
|
||||||
/* attribute support functions for Nexenta */
|
#ifdef MDBX_NEXENTA_ATTRS
|
||||||
|
|
||||||
static __inline int mdbx_attr_peek(MDBX_val *data, mdbx_attr_t *attrptr) {
|
static __inline int mdbx_attr_peek(MDBX_val *data, mdbx_attr_t *attrptr) {
|
||||||
if (unlikely(data->iov_len < sizeof(mdbx_attr_t)))
|
if (unlikely(data->iov_len < sizeof(mdbx_attr_t)))
|
||||||
@ -14735,8 +14735,9 @@ int mdbx_set_attr(MDBX_txn *txn, MDBX_dbi dbi, MDBX_val *key, MDBX_val *data,
|
|||||||
txn->mt_cursors[dbi] = cx.outer.mc_next;
|
txn->mt_cursors[dbi] = cx.outer.mc_next;
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
#endif /* MDBX_NEXENTA_ATTRS */
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
/******************************************************************************/
|
||||||
/* *INDENT-OFF* */
|
/* *INDENT-OFF* */
|
||||||
/* clang-format off */
|
/* clang-format off */
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user