mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-08 04:44:14 +08:00
mdbx: Merge branch 'master' into nexenta.
This commit is contained in:
commit
43eff26278
38
mdb.c
38
mdb.c
@ -1505,6 +1505,7 @@ mdb_page_malloc(MDB_txn *txn, unsigned num)
|
|||||||
size_t size = env->me_psize;
|
size_t size = env->me_psize;
|
||||||
MDB_page *np = env->me_dpages;
|
MDB_page *np = env->me_dpages;
|
||||||
if (likely(num == 1 && np)) {
|
if (likely(num == 1 && np)) {
|
||||||
|
ASAN_UNPOISON_MEMORY_REGION(np, size);
|
||||||
VALGRIND_MEMPOOL_ALLOC(env, np, size);
|
VALGRIND_MEMPOOL_ALLOC(env, np, size);
|
||||||
VALGRIND_MAKE_MEM_DEFINED(&np->mp_next, sizeof(np->mp_next));
|
VALGRIND_MAKE_MEM_DEFINED(&np->mp_next, sizeof(np->mp_next));
|
||||||
env->me_dpages = np->mp_next;
|
env->me_dpages = np->mp_next;
|
||||||
@ -1583,6 +1584,7 @@ mdb_kill_page(MDB_env *env, pgno_t pgno)
|
|||||||
MDB_page *mp = (MDB_page *)(env->me_map + offs);
|
MDB_page *mp = (MDB_page *)(env->me_map + offs);
|
||||||
memset(&mp->mp_pb, 0x6F /* 'o', 111 */, env->me_psize - shift);
|
memset(&mp->mp_pb, 0x6F /* 'o', 111 */, env->me_psize - shift);
|
||||||
VALGRIND_MAKE_MEM_NOACCESS(&mp->mp_pb, env->me_psize - shift);
|
VALGRIND_MAKE_MEM_NOACCESS(&mp->mp_pb, env->me_psize - shift);
|
||||||
|
ASAN_POISON_MEMORY_REGION(&mp->mp_pb, env->me_psize - shift);
|
||||||
} else {
|
} else {
|
||||||
struct iovec iov[1];
|
struct iovec iov[1];
|
||||||
iov[0].iov_len = env->me_psize - shift;
|
iov[0].iov_len = env->me_psize - shift;
|
||||||
@ -1636,9 +1638,13 @@ 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 & MDBX_PAGEPERTURB))
|
MDB_page **link = &NEXT_LOOSE_PAGE(mp);
|
||||||
|
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;
|
VALGRIND_MAKE_MEM_UNDEFINED(link, sizeof(MDB_page*));
|
||||||
|
ASAN_UNPOISON_MEMORY_REGION(link, sizeof(MDB_page*));
|
||||||
|
}
|
||||||
|
*link = txn->mt_loose_pgs;
|
||||||
txn->mt_loose_pgs = mp;
|
txn->mt_loose_pgs = mp;
|
||||||
txn->mt_loose_count++;
|
txn->mt_loose_count++;
|
||||||
mp->mp_flags |= P_LOOSE;
|
mp->mp_flags |= P_LOOSE;
|
||||||
@ -2110,6 +2116,7 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
|
|||||||
txn->mt_loose_pgs = NEXT_LOOSE_PAGE(np);
|
txn->mt_loose_pgs = NEXT_LOOSE_PAGE(np);
|
||||||
txn->mt_loose_count--;
|
txn->mt_loose_count--;
|
||||||
mdb_debug("db %d use loose page %zu", DDBI(mc), np->mp_pgno);
|
mdb_debug("db %d use loose page %zu", DDBI(mc), np->mp_pgno);
|
||||||
|
ASAN_UNPOISON_MEMORY_REGION(np, env->me_psize);
|
||||||
*mp = np;
|
*mp = np;
|
||||||
return MDB_SUCCESS;
|
return MDB_SUCCESS;
|
||||||
}
|
}
|
||||||
@ -2361,6 +2368,7 @@ done:
|
|||||||
np = (MDB_page *)(env->me_map + env->me_psize * pgno);
|
np = (MDB_page *)(env->me_map + env->me_psize * pgno);
|
||||||
/* LY: reset no-access flag from mdb_kill_page() */
|
/* LY: reset no-access flag from mdb_kill_page() */
|
||||||
VALGRIND_MAKE_MEM_UNDEFINED(np, env->me_psize * num);
|
VALGRIND_MAKE_MEM_UNDEFINED(np, env->me_psize * num);
|
||||||
|
ASAN_UNPOISON_MEMORY_REGION(np, env->me_psize * num);
|
||||||
} else {
|
} else {
|
||||||
if (unlikely(!(np = mdb_page_malloc(txn, num)))) {
|
if (unlikely(!(np = mdb_page_malloc(txn, num)))) {
|
||||||
rc = ENOMEM;
|
rc = ENOMEM;
|
||||||
@ -5110,6 +5118,7 @@ mdbx_env_close_ex(MDB_env *env, int dont_sync)
|
|||||||
|
|
||||||
VALGRIND_DESTROY_MEMPOOL(env);
|
VALGRIND_DESTROY_MEMPOOL(env);
|
||||||
while ((dp = env->me_dpages) != NULL) {
|
while ((dp = env->me_dpages) != NULL) {
|
||||||
|
ASAN_UNPOISON_MEMORY_REGION(&dp->mp_next, sizeof(dp->mp_next));
|
||||||
VALGRIND_MAKE_MEM_DEFINED(&dp->mp_next, sizeof(dp->mp_next));
|
VALGRIND_MAKE_MEM_DEFINED(&dp->mp_next, sizeof(dp->mp_next));
|
||||||
env->me_dpages = dp->mp_next;
|
env->me_dpages = dp->mp_next;
|
||||||
free(dp);
|
free(dp);
|
||||||
@ -6885,7 +6894,6 @@ current:
|
|||||||
*/
|
*/
|
||||||
if (unlikely(level > 1)) {
|
if (unlikely(level > 1)) {
|
||||||
/* It is writable only in a parent txn */
|
/* It is writable only in a parent txn */
|
||||||
size_t sz = (size_t) env->me_psize * ovpages, off;
|
|
||||||
MDB_page *np = mdb_page_malloc(mc->mc_txn, ovpages);
|
MDB_page *np = mdb_page_malloc(mc->mc_txn, ovpages);
|
||||||
MDB_ID2 id2;
|
MDB_ID2 id2;
|
||||||
if (unlikely(!np))
|
if (unlikely(!np))
|
||||||
@ -6895,9 +6903,19 @@ current:
|
|||||||
/* Note - this page is already counted in parent's dirty_room */
|
/* Note - this page is already counted in parent's dirty_room */
|
||||||
rc2 = mdb_mid2l_insert(mc->mc_txn->mt_u.dirty_list, &id2);
|
rc2 = mdb_mid2l_insert(mc->mc_txn->mt_u.dirty_list, &id2);
|
||||||
mdb_cassert(mc, rc2 == 0);
|
mdb_cassert(mc, rc2 == 0);
|
||||||
if (1 || /* LY: Hm, why we should do this differently in dependence from MDB_RESERVE? */
|
/* Currently we make the page look as with put() in the
|
||||||
!(flags & MDB_RESERVE)) {
|
* parent txn, in case the user peeks at MDB_RESERVEd
|
||||||
/* Copy end of page, adjusting alignment so
|
* or unused parts. Some users treat ovpages specially.
|
||||||
|
*/
|
||||||
|
#if MDBX_MODE_ENABLED
|
||||||
|
/* LY: New page will contain only header from origin,
|
||||||
|
* but no any payload */
|
||||||
|
memcpy(np, omp, PAGEHDRSZ);
|
||||||
|
#else
|
||||||
|
size_t sz = (size_t) env->me_psize * ovpages, off;
|
||||||
|
if (!(flags & MDB_RESERVE)) {
|
||||||
|
/* Skip the part where LMDB will put *data.
|
||||||
|
* Copy end of page, adjusting alignment so
|
||||||
* compiler may copy words instead of bytes.
|
* compiler may copy words instead of bytes.
|
||||||
*/
|
*/
|
||||||
off = (PAGEHDRSZ + data->mv_size) & -sizeof(size_t);
|
off = (PAGEHDRSZ + data->mv_size) & -sizeof(size_t);
|
||||||
@ -6905,7 +6923,8 @@ current:
|
|||||||
(size_t *)((char *)omp + off), sz - off);
|
(size_t *)((char *)omp + off), sz - off);
|
||||||
sz = PAGEHDRSZ;
|
sz = PAGEHDRSZ;
|
||||||
}
|
}
|
||||||
memcpy(np, omp, sz); /* Copy beginning of page */
|
memcpy(np, omp, sz); /* Copy whole or header of page */
|
||||||
|
#endif /* MDBX_MODE_ENABLED */
|
||||||
omp = np;
|
omp = np;
|
||||||
}
|
}
|
||||||
SETDSZ(leaf, data->mv_size);
|
SETDSZ(leaf, data->mv_size);
|
||||||
@ -9177,7 +9196,7 @@ mdb_env_cthr_toggle(mdb_copy *my, int st)
|
|||||||
static int __cold
|
static int __cold
|
||||||
mdb_env_cwalk(mdb_copy *my, pgno_t *pg, int flags)
|
mdb_env_cwalk(mdb_copy *my, pgno_t *pg, int flags)
|
||||||
{
|
{
|
||||||
MDB_cursor mc;
|
MDB_cursor mc = {0};
|
||||||
MDB_txn *txn = my->mc_txn;
|
MDB_txn *txn = my->mc_txn;
|
||||||
MDB_node *ni;
|
MDB_node *ni;
|
||||||
MDB_page *mo, *mp, *leaf;
|
MDB_page *mo, *mp, *leaf;
|
||||||
@ -9190,10 +9209,9 @@ mdb_env_cwalk(mdb_copy *my, pgno_t *pg, int flags)
|
|||||||
return MDB_SUCCESS;
|
return MDB_SUCCESS;
|
||||||
|
|
||||||
mc.mc_snum = 1;
|
mc.mc_snum = 1;
|
||||||
mc.mc_top = 0;
|
|
||||||
mc.mc_txn = txn;
|
mc.mc_txn = txn;
|
||||||
|
|
||||||
rc = mdb_page_get(my->mc_txn, *pg, &mc.mc_pg[0], NULL);
|
rc = mdb_page_get(txn, *pg, &mc.mc_pg[0], NULL);
|
||||||
if (rc)
|
if (rc)
|
||||||
return rc;
|
return rc;
|
||||||
rc = mdb_page_search_root(&mc, NULL, MDB_PS_FIRST);
|
rc = mdb_page_search_root(&mc, NULL, MDB_PS_FIRST);
|
||||||
|
@ -11,12 +11,6 @@
|
|||||||
* top-level directory of the distribution or, alternatively, at
|
* top-level directory of the distribution or, alternatively, at
|
||||||
* <http://www.OpenLDAP.org/license.html>.
|
* <http://www.OpenLDAP.org/license.html>.
|
||||||
*/
|
*/
|
||||||
#ifdef _WIN32
|
|
||||||
#include <windows.h>
|
|
||||||
#define MDB_STDOUT GetStdHandle(STD_OUTPUT_HANDLE)
|
|
||||||
#else
|
|
||||||
#define MDB_STDOUT 1
|
|
||||||
#endif
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
@ -70,7 +64,7 @@ int main(int argc,char * argv[])
|
|||||||
if (rc == MDB_SUCCESS) {
|
if (rc == MDB_SUCCESS) {
|
||||||
act = "copying";
|
act = "copying";
|
||||||
if (argc == 2)
|
if (argc == 2)
|
||||||
rc = mdb_env_copyfd2(env, MDB_STDOUT, cpflags);
|
rc = mdb_env_copyfd2(env, STDOUT_FILENO, cpflags);
|
||||||
else
|
else
|
||||||
rc = mdb_env_copy2(env, argv[2], cpflags);
|
rc = mdb_env_copy2(env, argv[2], cpflags);
|
||||||
}
|
}
|
||||||
|
@ -20,12 +20,6 @@
|
|||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include "mdbx.h"
|
#include "mdbx.h"
|
||||||
|
|
||||||
#ifdef _WIN32
|
|
||||||
#define Z "I"
|
|
||||||
#else
|
|
||||||
#define Z "z"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define PRINT 1
|
#define PRINT 1
|
||||||
static int mode;
|
static int mode;
|
||||||
|
|
||||||
@ -116,7 +110,7 @@ static int dumpit(MDB_txn *txn, MDB_dbi dbi, char *name)
|
|||||||
if (name)
|
if (name)
|
||||||
printf("database=%s\n", name);
|
printf("database=%s\n", name);
|
||||||
printf("type=btree\n");
|
printf("type=btree\n");
|
||||||
printf("mapsize=%" Z "u\n", info.me_mapsize);
|
printf("mapsize=%zu\n", info.me_mapsize);
|
||||||
if (info.me_mapaddr)
|
if (info.me_mapaddr)
|
||||||
printf("mapaddr=%p\n", info.me_mapaddr);
|
printf("mapaddr=%p\n", info.me_mapaddr);
|
||||||
printf("maxreaders=%u\n", info.me_maxreaders);
|
printf("maxreaders=%u\n", info.me_maxreaders);
|
||||||
|
34
mdb_load.c
34
mdb_load.c
@ -38,12 +38,6 @@ static MDB_envinfo info;
|
|||||||
|
|
||||||
static MDB_val kbuf, dbuf;
|
static MDB_val kbuf, dbuf;
|
||||||
|
|
||||||
#ifdef _WIN32
|
|
||||||
#define Z "I"
|
|
||||||
#else
|
|
||||||
#define Z "z"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define STRLENOF(s) (sizeof(s)-1)
|
#define STRLENOF(s) (sizeof(s)-1)
|
||||||
|
|
||||||
typedef struct flagbit {
|
typedef struct flagbit {
|
||||||
@ -78,7 +72,7 @@ static void readhdr(void)
|
|||||||
} else if (!strncmp(dbuf.mv_data, "VERSION=", STRLENOF("VERSION="))) {
|
} else if (!strncmp(dbuf.mv_data, "VERSION=", STRLENOF("VERSION="))) {
|
||||||
version=atoi((char *)dbuf.mv_data+STRLENOF("VERSION="));
|
version=atoi((char *)dbuf.mv_data+STRLENOF("VERSION="));
|
||||||
if (version > 3) {
|
if (version > 3) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: unsupported VERSION %d\n",
|
fprintf(stderr, "%s: line %zd: unsupported VERSION %d\n",
|
||||||
prog, lineno, version);
|
prog, lineno, version);
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
@ -88,7 +82,7 @@ static void readhdr(void)
|
|||||||
if (!strncmp((char *)dbuf.mv_data+STRLENOF("FORMAT="), "print", STRLENOF("print")))
|
if (!strncmp((char *)dbuf.mv_data+STRLENOF("FORMAT="), "print", STRLENOF("print")))
|
||||||
mode |= PRINT;
|
mode |= PRINT;
|
||||||
else if (strncmp((char *)dbuf.mv_data+STRLENOF("FORMAT="), "bytevalue", STRLENOF("bytevalue"))) {
|
else if (strncmp((char *)dbuf.mv_data+STRLENOF("FORMAT="), "bytevalue", STRLENOF("bytevalue"))) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: unsupported FORMAT %s\n",
|
fprintf(stderr, "%s: line %zd: unsupported FORMAT %s\n",
|
||||||
prog, lineno, (char *)dbuf.mv_data+STRLENOF("FORMAT="));
|
prog, lineno, (char *)dbuf.mv_data+STRLENOF("FORMAT="));
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
@ -99,7 +93,7 @@ static void readhdr(void)
|
|||||||
subname = strdup((char *)dbuf.mv_data+STRLENOF("database="));
|
subname = strdup((char *)dbuf.mv_data+STRLENOF("database="));
|
||||||
} else if (!strncmp(dbuf.mv_data, "type=", STRLENOF("type="))) {
|
} else if (!strncmp(dbuf.mv_data, "type=", STRLENOF("type="))) {
|
||||||
if (strncmp((char *)dbuf.mv_data+STRLENOF("type="), "btree", STRLENOF("btree"))) {
|
if (strncmp((char *)dbuf.mv_data+STRLENOF("type="), "btree", STRLENOF("btree"))) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: unsupported type %s\n",
|
fprintf(stderr, "%s: line %zd: unsupported type %s\n",
|
||||||
prog, lineno, (char *)dbuf.mv_data+STRLENOF("type="));
|
prog, lineno, (char *)dbuf.mv_data+STRLENOF("type="));
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
@ -109,7 +103,7 @@ static void readhdr(void)
|
|||||||
if (ptr) *ptr = '\0';
|
if (ptr) *ptr = '\0';
|
||||||
i = sscanf((char *)dbuf.mv_data+STRLENOF("mapaddr="), "%p", &info.me_mapaddr);
|
i = sscanf((char *)dbuf.mv_data+STRLENOF("mapaddr="), "%p", &info.me_mapaddr);
|
||||||
if (i != 1) {
|
if (i != 1) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: invalid mapaddr %s\n",
|
fprintf(stderr, "%s: line %zd: invalid mapaddr %s\n",
|
||||||
prog, lineno, (char *)dbuf.mv_data+STRLENOF("mapaddr="));
|
prog, lineno, (char *)dbuf.mv_data+STRLENOF("mapaddr="));
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
@ -117,9 +111,9 @@ static void readhdr(void)
|
|||||||
int i;
|
int i;
|
||||||
ptr = memchr(dbuf.mv_data, '\n', dbuf.mv_size);
|
ptr = memchr(dbuf.mv_data, '\n', dbuf.mv_size);
|
||||||
if (ptr) *ptr = '\0';
|
if (ptr) *ptr = '\0';
|
||||||
i = sscanf((char *)dbuf.mv_data+STRLENOF("mapsize="), "%" Z "u", &info.me_mapsize);
|
i = sscanf((char *)dbuf.mv_data+STRLENOF("mapsize="), "%zu", &info.me_mapsize);
|
||||||
if (i != 1) {
|
if (i != 1) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: invalid mapsize %s\n",
|
fprintf(stderr, "%s: line %zd: invalid mapsize %s\n",
|
||||||
prog, lineno, (char *)dbuf.mv_data+STRLENOF("mapsize="));
|
prog, lineno, (char *)dbuf.mv_data+STRLENOF("mapsize="));
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
@ -129,7 +123,7 @@ static void readhdr(void)
|
|||||||
if (ptr) *ptr = '\0';
|
if (ptr) *ptr = '\0';
|
||||||
i = sscanf((char *)dbuf.mv_data+STRLENOF("maxreaders="), "%u", &info.me_maxreaders);
|
i = sscanf((char *)dbuf.mv_data+STRLENOF("maxreaders="), "%u", &info.me_maxreaders);
|
||||||
if (i != 1) {
|
if (i != 1) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: invalid maxreaders %s\n",
|
fprintf(stderr, "%s: line %zd: invalid maxreaders %s\n",
|
||||||
prog, lineno, (char *)dbuf.mv_data+STRLENOF("maxreaders="));
|
prog, lineno, (char *)dbuf.mv_data+STRLENOF("maxreaders="));
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
@ -146,12 +140,12 @@ static void readhdr(void)
|
|||||||
if (!dbflags[i].bit) {
|
if (!dbflags[i].bit) {
|
||||||
ptr = memchr(dbuf.mv_data, '=', dbuf.mv_size);
|
ptr = memchr(dbuf.mv_data, '=', dbuf.mv_size);
|
||||||
if (!ptr) {
|
if (!ptr) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: unexpected format\n",
|
fprintf(stderr, "%s: line %zd: unexpected format\n",
|
||||||
prog, lineno);
|
prog, lineno);
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
} else {
|
} else {
|
||||||
*ptr = '\0';
|
*ptr = '\0';
|
||||||
fprintf(stderr, "%s: line %" Z "d: unrecognized keyword ignored: %s\n",
|
fprintf(stderr, "%s: line %zd: unrecognized keyword ignored: %s\n",
|
||||||
prog, lineno, (char *)dbuf.mv_data);
|
prog, lineno, (char *)dbuf.mv_data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -161,7 +155,7 @@ static void readhdr(void)
|
|||||||
|
|
||||||
static void badend(void)
|
static void badend(void)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "%s: line %" Z "d: unexpected end of input\n",
|
fprintf(stderr, "%s: line %zd: unexpected end of input\n",
|
||||||
prog, lineno);
|
prog, lineno);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -219,7 +213,7 @@ badend:
|
|||||||
buf->mv_data = realloc(buf->mv_data, buf->mv_size*2);
|
buf->mv_data = realloc(buf->mv_data, buf->mv_size*2);
|
||||||
if (!buf->mv_data) {
|
if (!buf->mv_data) {
|
||||||
Eof = 1;
|
Eof = 1;
|
||||||
fprintf(stderr, "%s: line %" Z "d: out of memory, line too long\n",
|
fprintf(stderr, "%s: line %zd: out of memory, line too long\n",
|
||||||
prog, lineno);
|
prog, lineno);
|
||||||
return EOF;
|
return EOF;
|
||||||
}
|
}
|
||||||
@ -404,7 +398,7 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
rc = readline(&data, &dbuf);
|
rc = readline(&data, &dbuf);
|
||||||
if (rc) {
|
if (rc) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: failed to read key value\n", prog, lineno);
|
fprintf(stderr, "%s: line %zd: failed to read key value\n", prog, lineno);
|
||||||
goto txn_abort;
|
goto txn_abort;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -419,7 +413,7 @@ int main(int argc, char *argv[])
|
|||||||
if (batch == 100) {
|
if (batch == 100) {
|
||||||
rc = mdb_txn_commit(txn);
|
rc = mdb_txn_commit(txn);
|
||||||
if (rc) {
|
if (rc) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: txn_commit: %s\n",
|
fprintf(stderr, "%s: line %zd: txn_commit: %s\n",
|
||||||
prog, lineno, mdb_strerror(rc));
|
prog, lineno, mdb_strerror(rc));
|
||||||
goto env_close;
|
goto env_close;
|
||||||
}
|
}
|
||||||
@ -439,7 +433,7 @@ int main(int argc, char *argv[])
|
|||||||
rc = mdb_txn_commit(txn);
|
rc = mdb_txn_commit(txn);
|
||||||
txn = NULL;
|
txn = NULL;
|
||||||
if (rc) {
|
if (rc) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: txn_commit: %s\n",
|
fprintf(stderr, "%s: line %zd: txn_commit: %s\n",
|
||||||
prog, lineno, mdb_strerror(rc));
|
prog, lineno, mdb_strerror(rc));
|
||||||
goto env_close;
|
goto env_close;
|
||||||
}
|
}
|
||||||
|
4
mdbx.h
4
mdbx.h
@ -31,7 +31,7 @@
|
|||||||
When needed drop-in replacement for liblmdb you should:
|
When needed drop-in replacement for liblmdb you should:
|
||||||
- 'make lmdb' to build liblmdb.so and liblmdb.a;
|
- 'make lmdb' to build liblmdb.so and liblmdb.a;
|
||||||
- #include <lmdb.h> and use mdb_* functions;
|
- #include <lmdb.h> and use mdb_* functions;
|
||||||
- linking with liblmdb.so оr liblmdb.a;
|
- linking with liblmdb.so or liblmdb.a;
|
||||||
|
|
||||||
= This provides nearly full compatibility with
|
= This provides nearly full compatibility with
|
||||||
original LMDB from Symas Corp.
|
original LMDB from Symas Corp.
|
||||||
@ -41,7 +41,7 @@
|
|||||||
When exactly the libmdbx is needed, you should:
|
When exactly the libmdbx is needed, you should:
|
||||||
- 'make mdbx' to build libmdbx.so and libmdbx.a;
|
- 'make mdbx' to build libmdbx.so and libmdbx.a;
|
||||||
- #include <mdbx.h> and use mdbx_* functions;
|
- #include <mdbx.h> and use mdbx_* functions;
|
||||||
- linking with libmdbx.so оr libmdbx.a;
|
- linking with libmdbx.so or libmdbx.a;
|
||||||
|
|
||||||
= This allows using (linking) both MDBX and LMDB
|
= This allows using (linking) both MDBX and LMDB
|
||||||
simultaneously in the one application, for instance
|
simultaneously in the one application, for instance
|
||||||
|
Loading…
x
Reference in New Issue
Block a user