mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-23 01:28:20 +08:00
mdbx: drop me_dirtylist
field.
Change-Id: I93ee802c1b6ef5c6a2443e19754e1a20dbe0aea9
This commit is contained in:
parent
0b62453f6d
commit
c530c83337
10
src/core.c
10
src/core.c
@ -6374,7 +6374,6 @@ static int mdbx_txn_renew0(MDBX_txn *txn, const unsigned flags) {
|
|||||||
txn->tw.loose_pages = NULL;
|
txn->tw.loose_pages = NULL;
|
||||||
txn->tw.loose_count = 0;
|
txn->tw.loose_count = 0;
|
||||||
txn->tw.dirtyroom = MDBX_DPL_TXNFULL;
|
txn->tw.dirtyroom = MDBX_DPL_TXNFULL;
|
||||||
txn->tw.dirtylist = env->me_dirtylist;
|
|
||||||
mdbx_dpl_clear(txn->tw.dirtylist);
|
mdbx_dpl_clear(txn->tw.dirtylist);
|
||||||
MDBX_PNL_SIZE(txn->tw.retired_pages) = 0;
|
MDBX_PNL_SIZE(txn->tw.retired_pages) = 0;
|
||||||
txn->tw.spill_pages = NULL;
|
txn->tw.spill_pages = NULL;
|
||||||
@ -10733,9 +10732,6 @@ __cold int mdbx_env_open(MDBX_env *env, const char *pathname,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif /* MDBX_MMAP_INCOHERENT_FILE_WRITE */
|
#endif /* MDBX_MMAP_INCOHERENT_FILE_WRITE */
|
||||||
env->me_dirtylist = mdbx_calloc(MDBX_DPL_TXNFULL + 1, sizeof(MDBX_DP));
|
|
||||||
if (!env->me_dirtylist)
|
|
||||||
rc = MDBX_ENOMEM;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
env->me_flags = (flags & ~MDBX_FATAL_ERROR) | MDBX_ENV_ACTIVE;
|
env->me_flags = (flags & ~MDBX_FATAL_ERROR) | MDBX_ENV_ACTIVE;
|
||||||
@ -10899,7 +10895,9 @@ __cold int mdbx_env_open(MDBX_env *env, const char *pathname,
|
|||||||
env->me_txn0 = txn;
|
env->me_txn0 = txn;
|
||||||
txn->tw.retired_pages = mdbx_pnl_alloc(MDBX_PNL_INITIAL);
|
txn->tw.retired_pages = mdbx_pnl_alloc(MDBX_PNL_INITIAL);
|
||||||
txn->tw.reclaimed_pglist = 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)
|
txn->tw.dirtylist = mdbx_malloc(sizeof(MDBX_DP) * (MDBX_DPL_TXNFULL + 1));
|
||||||
|
if (!txn->tw.retired_pages || !txn->tw.reclaimed_pglist ||
|
||||||
|
!txn->tw.dirtylist)
|
||||||
rc = MDBX_ENOMEM;
|
rc = MDBX_ENOMEM;
|
||||||
} else
|
} else
|
||||||
rc = MDBX_ENOMEM;
|
rc = MDBX_ENOMEM;
|
||||||
@ -10998,8 +10996,8 @@ static __cold int mdbx_env_close0(MDBX_env *env) {
|
|||||||
mdbx_free(env->me_dbiseqs);
|
mdbx_free(env->me_dbiseqs);
|
||||||
mdbx_free(env->me_dbflags);
|
mdbx_free(env->me_dbflags);
|
||||||
mdbx_free(env->me_pathname);
|
mdbx_free(env->me_pathname);
|
||||||
mdbx_free(env->me_dirtylist);
|
|
||||||
if (env->me_txn0) {
|
if (env->me_txn0) {
|
||||||
|
mdbx_free(env->me_txn0->tw.dirtylist);
|
||||||
mdbx_txl_free(env->me_txn0->tw.lifo_reclaimed);
|
mdbx_txl_free(env->me_txn0->tw.lifo_reclaimed);
|
||||||
mdbx_pnl_free(env->me_txn0->tw.retired_pages);
|
mdbx_pnl_free(env->me_txn0->tw.retired_pages);
|
||||||
mdbx_pnl_free(env->me_txn0->tw.spill_pages);
|
mdbx_pnl_free(env->me_txn0->tw.spill_pages);
|
||||||
|
@ -976,8 +976,6 @@ struct MDBX_env {
|
|||||||
MDBX_page *me_dp_reserve; /* list of malloc'd blocks for re-use */
|
MDBX_page *me_dp_reserve; /* list of malloc'd blocks for re-use */
|
||||||
/* PNL of pages that became unused in a write txn */
|
/* PNL of pages that became unused in a write txn */
|
||||||
MDBX_PNL me_retired_pages;
|
MDBX_PNL me_retired_pages;
|
||||||
/* MDBX_DP of pages written during a write txn. */
|
|
||||||
MDBX_DPL me_dirtylist;
|
|
||||||
/* Number of freelist items that can fit in a single overflow page */
|
/* Number of freelist items that can fit in a single overflow page */
|
||||||
unsigned me_maxgc_ov1page;
|
unsigned me_maxgc_ov1page;
|
||||||
unsigned me_branch_nodemax; /* max size of a branch-node */
|
unsigned me_branch_nodemax; /* max size of a branch-node */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user