mdbx: aligned page-buffer.

Change-Id: Id469c353c47a5a486747bf2c21ee8c003cd2d103
This commit is contained in:
Leonid Yuriev 2019-12-19 15:12:21 +03:00
parent e70a7f620e
commit d11bfef36b

View File

@ -9151,27 +9151,32 @@ int __cold mdbx_env_open(MDBX_env *env, const char *pathname, unsigned flags,
} }
if ((flags & MDBX_RDONLY) == 0) { if ((flags & MDBX_RDONLY) == 0) {
rc = MDBX_ENOMEM; const size_t tsize = sizeof(MDBX_txn),
MDBX_txn *txn; size = tsize + env->me_maxdbs *
int tsize = sizeof(MDBX_txn), (sizeof(MDBX_db) + sizeof(MDBX_cursor *) +
size = sizeof(unsigned) + 1);
tsize + env->me_maxdbs * (sizeof(MDBX_db) + sizeof(MDBX_cursor *) + rc = mdbx_memalign_alloc(
sizeof(unsigned) + 1); env->me_os_psize,
if ((env->me_pbuf = mdbx_calloc( env->me_psize * (1 /* page buffer */ + 1 /* page killer bufer */),
1 /* page buffer */ + 1 /* page killer bufer */, env->me_psize)) && &env->me_pbuf);
(txn = mdbx_calloc(1, size))) { if (rc == MDBX_SUCCESS) {
txn->mt_dbs = (MDBX_db *)((char *)txn + tsize); memset(env->me_pbuf, -1, env->me_psize * 2);
txn->mt_cursors = (MDBX_cursor **)(txn->mt_dbs + env->me_maxdbs); MDBX_txn *txn = mdbx_calloc(1, size);
txn->mt_dbiseqs = (unsigned *)(txn->mt_cursors + env->me_maxdbs); if (txn) {
txn->mt_dbflags = (uint8_t *)(txn->mt_dbiseqs + env->me_maxdbs); txn->mt_dbs = (MDBX_db *)((char *)txn + tsize);
txn->mt_env = env; txn->mt_cursors = (MDBX_cursor **)(txn->mt_dbs + env->me_maxdbs);
txn->mt_dbxs = env->me_dbxs; txn->mt_dbiseqs = (unsigned *)(txn->mt_cursors + env->me_maxdbs);
txn->mt_flags = MDBX_TXN_FINISHED; txn->mt_dbflags = (uint8_t *)(txn->mt_dbiseqs + env->me_maxdbs);
env->me_txn0 = txn; txn->mt_env = env;
txn->tw.retired_pages = mdbx_pnl_alloc(MDBX_PNL_INITIAL); txn->mt_dbxs = env->me_dbxs;
txn->tw.reclaimed_pglist = mdbx_pnl_alloc(MDBX_PNL_INITIAL); txn->mt_flags = MDBX_TXN_FINISHED;
if (txn->tw.retired_pages && txn->tw.reclaimed_pglist) env->me_txn0 = txn;
rc = MDBX_SUCCESS; txn->tw.retired_pages = mdbx_pnl_alloc(MDBX_PNL_INITIAL);
txn->tw.reclaimed_pglist = mdbx_pnl_alloc(MDBX_PNL_INITIAL);
if (!txn->tw.retired_pages || !txn->tw.reclaimed_pglist)
rc = MDBX_ENOMEM;
} else
rc = MDBX_ENOMEM;
} }
} }
@ -9256,7 +9261,7 @@ static int __cold mdbx_env_close0(MDBX_env *env) {
mdbx_free(env->me_dbxs[i].md_name.iov_base); mdbx_free(env->me_dbxs[i].md_name.iov_base);
mdbx_free(env->me_dbxs); mdbx_free(env->me_dbxs);
} }
mdbx_free(env->me_pbuf); mdbx_memalign_free(env->me_pbuf);
mdbx_free(env->me_dbiseqs); mdbx_free(env->me_dbiseqs);
mdbx_free(env->me_dbflags); mdbx_free(env->me_dbflags);
mdbx_free(env->me_path); mdbx_free(env->me_path);