mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-20 05:28:21 +08:00
mdbx: доработка подготовки резерва перед обновлением GC при включенном BigFoot.
This commit is contained in:
parent
3757eb72f7
commit
07674ada47
188
src/core.c
188
src/core.c
@ -6761,6 +6761,7 @@ static pgr_t page_alloc_slowpath(const MDBX_cursor *mc, const size_t num,
|
|||||||
|
|
||||||
MDBX_cursor *const gc =
|
MDBX_cursor *const gc =
|
||||||
(MDBX_cursor *)((char *)env->me_txn0 + sizeof(MDBX_txn));
|
(MDBX_cursor *)((char *)env->me_txn0 + sizeof(MDBX_txn));
|
||||||
|
eASSERT(env, mc != gc && gc->mc_next == nullptr);
|
||||||
gc->mc_txn = txn;
|
gc->mc_txn = txn;
|
||||||
gc->mc_flags = 0;
|
gc->mc_flags = 0;
|
||||||
|
|
||||||
@ -7188,8 +7189,16 @@ done:
|
|||||||
}
|
}
|
||||||
if (LOG_ENABLED(level))
|
if (LOG_ENABLED(level))
|
||||||
debug_log(level, __func__, __LINE__,
|
debug_log(level, __func__, __LINE__,
|
||||||
"unable alloc %zu %s, flags 0x%x, errcode %d\n", num, what,
|
"unable alloc %zu %s, alloc-flags 0x%x, err %d, txn-flags "
|
||||||
flags, ret.err);
|
"0x%x, re-list-len %zu, loose-count %zu, gc: height %u, "
|
||||||
|
"branch %zu, leaf %zu, large %zu, entries %zu\n",
|
||||||
|
num, what, flags, ret.err, txn->mt_flags,
|
||||||
|
MDBX_PNL_GETSIZE(txn->tw.relist), txn->tw.loose_count,
|
||||||
|
txn->mt_dbs[FREE_DBI].md_depth,
|
||||||
|
(size_t)txn->mt_dbs[FREE_DBI].md_branch_pages,
|
||||||
|
(size_t)txn->mt_dbs[FREE_DBI].md_leaf_pages,
|
||||||
|
(size_t)txn->mt_dbs[FREE_DBI].md_overflow_pages,
|
||||||
|
(size_t)txn->mt_dbs[FREE_DBI].md_entries);
|
||||||
ret.page = NULL;
|
ret.page = NULL;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -9508,7 +9517,13 @@ static __always_inline size_t gcu_backlog_size(MDBX_txn *txn) {
|
|||||||
|
|
||||||
static int gcu_clean_stored_retired(MDBX_txn *txn, gcu_context_t *ctx) {
|
static int gcu_clean_stored_retired(MDBX_txn *txn, gcu_context_t *ctx) {
|
||||||
int err = MDBX_SUCCESS;
|
int err = MDBX_SUCCESS;
|
||||||
if (ctx->retired_stored)
|
if (ctx->retired_stored) {
|
||||||
|
MDBX_cursor *const gc = (MDBX_cursor *)((char *)txn + sizeof(MDBX_txn));
|
||||||
|
tASSERT(txn, txn == txn->mt_env->me_txn0 && gc->mc_next == nullptr);
|
||||||
|
gc->mc_txn = txn;
|
||||||
|
gc->mc_flags = 0;
|
||||||
|
gc->mc_next = txn->mt_cursors[FREE_DBI];
|
||||||
|
txn->mt_cursors[FREE_DBI] = gc;
|
||||||
do {
|
do {
|
||||||
MDBX_val key, val;
|
MDBX_val key, val;
|
||||||
#if MDBX_ENABLE_BIGFOOT
|
#if MDBX_ENABLE_BIGFOOT
|
||||||
@ -9517,11 +9532,10 @@ static int gcu_clean_stored_retired(MDBX_txn *txn, gcu_context_t *ctx) {
|
|||||||
key.iov_base = &txn->mt_txnid;
|
key.iov_base = &txn->mt_txnid;
|
||||||
#endif /* MDBX_ENABLE_BIGFOOT */
|
#endif /* MDBX_ENABLE_BIGFOOT */
|
||||||
key.iov_len = sizeof(txnid_t);
|
key.iov_len = sizeof(txnid_t);
|
||||||
const struct cursor_set_result csr =
|
const struct cursor_set_result csr = cursor_set(gc, &key, &val, MDBX_SET);
|
||||||
cursor_set(&ctx->cursor, &key, &val, MDBX_SET);
|
|
||||||
if (csr.err == MDBX_SUCCESS && csr.exact) {
|
if (csr.err == MDBX_SUCCESS && csr.exact) {
|
||||||
ctx->retired_stored = 0;
|
ctx->retired_stored = 0;
|
||||||
err = mdbx_cursor_del(&ctx->cursor, 0);
|
err = mdbx_cursor_del(gc, 0);
|
||||||
TRACE("== clear-4linear, backlog %zu, err %d", gcu_backlog_size(txn),
|
TRACE("== clear-4linear, backlog %zu, err %d", gcu_backlog_size(txn),
|
||||||
err);
|
err);
|
||||||
}
|
}
|
||||||
@ -9531,6 +9545,9 @@ static int gcu_clean_stored_retired(MDBX_txn *txn, gcu_context_t *ctx) {
|
|||||||
#else
|
#else
|
||||||
while (0);
|
while (0);
|
||||||
#endif /* MDBX_ENABLE_BIGFOOT */
|
#endif /* MDBX_ENABLE_BIGFOOT */
|
||||||
|
txn->mt_cursors[FREE_DBI] = gc->mc_next;
|
||||||
|
gc->mc_next = nullptr;
|
||||||
|
}
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -9544,28 +9561,45 @@ static int gcu_touch(gcu_context_t *ctx) {
|
|||||||
/* Prepare a backlog of pages to modify GC itself, while reclaiming is
|
/* Prepare a backlog of pages to modify GC itself, while reclaiming is
|
||||||
* prohibited. It should be enough to prevent search in page_alloc_slowpath()
|
* prohibited. It should be enough to prevent search in page_alloc_slowpath()
|
||||||
* during a deleting, when GC tree is unbalanced. */
|
* during a deleting, when GC tree is unbalanced. */
|
||||||
static int gcu_prepare_backlog(MDBX_txn *txn, gcu_context_t *ctx,
|
static int gcu_prepare_backlog(MDBX_txn *txn, gcu_context_t *ctx) {
|
||||||
const bool reserve4retired) {
|
const size_t for_cow = txn->mt_dbs[FREE_DBI].md_depth;
|
||||||
const size_t pages4retiredlist =
|
const size_t for_rebalance = for_cow + 1;
|
||||||
reserve4retired ? number_of_ovpages(
|
size_t for_split = ctx->retired_stored == 0;
|
||||||
txn->mt_env, MDBX_PNL_SIZEOF(txn->tw.retired_pages))
|
|
||||||
: 0;
|
|
||||||
const size_t backlog4cow = txn->mt_dbs[FREE_DBI].md_depth;
|
|
||||||
const size_t backlog4rebalance = backlog4cow + 1;
|
|
||||||
|
|
||||||
if (likely(pages4retiredlist < 2 &&
|
const intptr_t retired_left =
|
||||||
gcu_backlog_size(txn) > (reserve4retired
|
MDBX_PNL_SIZEOF(txn->tw.retired_pages) - ctx->retired_stored;
|
||||||
? backlog4rebalance
|
size_t for_retiredlist = 0;
|
||||||
: (backlog4cow + backlog4rebalance))))
|
if (MDBX_ENABLE_BIGFOOT && retired_left > 0) {
|
||||||
|
for_retiredlist = (retired_left + txn->mt_env->me_maxgc_ov1page - 1) /
|
||||||
|
txn->mt_env->me_maxgc_ov1page;
|
||||||
|
const size_t per_branch_page =
|
||||||
|
(txn->mt_env->me_psize - PAGEHDRSZ) /
|
||||||
|
(sizeof(indx_t) + sizeof(MDBX_node) + sizeof(txnid_t));
|
||||||
|
for (size_t entries = for_retiredlist; entries > 1; for_split += entries)
|
||||||
|
entries = (entries + per_branch_page - 1) / per_branch_page;
|
||||||
|
} else if (!MDBX_ENABLE_BIGFOOT && retired_left != 0) {
|
||||||
|
for_retiredlist =
|
||||||
|
number_of_ovpages(txn->mt_env, MDBX_PNL_SIZEOF(txn->tw.retired_pages));
|
||||||
|
}
|
||||||
|
|
||||||
|
const size_t for_tree_before_touch = for_cow + for_rebalance + for_split;
|
||||||
|
const size_t for_tree_after_touch = for_rebalance + for_split;
|
||||||
|
const size_t for_data = for_retiredlist;
|
||||||
|
const size_t for_all_before_touch = for_data + for_tree_before_touch;
|
||||||
|
const size_t for_all_after_touch = for_data + for_tree_after_touch;
|
||||||
|
|
||||||
|
if (likely(for_data < 2 && gcu_backlog_size(txn) > for_all_before_touch))
|
||||||
return MDBX_SUCCESS;
|
return MDBX_SUCCESS;
|
||||||
|
|
||||||
TRACE(
|
TRACE(">> retired-stored %zu, left %zi, backlog %zu, need %zu (4list %zu, "
|
||||||
">> reserve4retired %c, backlog %zu, 4list %zu, 4cow %zu, 4rebalance %zu",
|
"4split %zu, "
|
||||||
reserve4retired ? 'Y' : 'N', gcu_backlog_size(txn), pages4retiredlist,
|
"4cow %zu, 4tree %zu)",
|
||||||
backlog4cow, backlog4rebalance);
|
ctx->retired_stored, retired_left, gcu_backlog_size(txn),
|
||||||
|
for_all_before_touch, for_data, for_split, for_cow,
|
||||||
|
for_tree_before_touch);
|
||||||
|
|
||||||
int err;
|
int err;
|
||||||
if (unlikely(pages4retiredlist > 2)) {
|
if (unlikely(for_data > 2)) {
|
||||||
MDBX_val key, val;
|
MDBX_val key, val;
|
||||||
key.iov_base = val.iov_base = nullptr;
|
key.iov_base = val.iov_base = nullptr;
|
||||||
key.iov_len = sizeof(txnid_t);
|
key.iov_len = sizeof(txnid_t);
|
||||||
@ -9578,28 +9612,34 @@ static int gcu_prepare_backlog(MDBX_txn *txn, gcu_context_t *ctx,
|
|||||||
err = gcu_touch(ctx);
|
err = gcu_touch(ctx);
|
||||||
TRACE("== after-touch, backlog %zu, err %d", gcu_backlog_size(txn), err);
|
TRACE("== after-touch, backlog %zu, err %d", gcu_backlog_size(txn), err);
|
||||||
|
|
||||||
if (unlikely(pages4retiredlist > 1) &&
|
if (!MDBX_ENABLE_BIGFOOT && unlikely(for_data > 1) &&
|
||||||
MDBX_PNL_GETSIZE(txn->tw.retired_pages) != ctx->retired_stored &&
|
MDBX_PNL_GETSIZE(txn->tw.retired_pages) != ctx->retired_stored &&
|
||||||
err == MDBX_SUCCESS) {
|
err == MDBX_SUCCESS) {
|
||||||
tASSERT(txn, reserve4retired);
|
if (unlikely(ctx->retired_stored)) {
|
||||||
err = gcu_clean_stored_retired(txn, ctx);
|
err = gcu_clean_stored_retired(txn, ctx);
|
||||||
if (unlikely(err != MDBX_SUCCESS))
|
if (unlikely(err != MDBX_SUCCESS))
|
||||||
return err;
|
return err;
|
||||||
err =
|
if (!ctx->retired_stored)
|
||||||
page_alloc_slowpath(&ctx->cursor, pages4retiredlist, MDBX_ALLOC_RESERVE)
|
return /* restart by tail-recursion */ gcu_prepare_backlog(txn, ctx);
|
||||||
.err;
|
}
|
||||||
|
err = page_alloc_slowpath(&ctx->cursor, for_data, MDBX_ALLOC_RESERVE).err;
|
||||||
TRACE("== after-4linear, backlog %zu, err %d", gcu_backlog_size(txn), err);
|
TRACE("== after-4linear, backlog %zu, err %d", gcu_backlog_size(txn), err);
|
||||||
cASSERT(&ctx->cursor,
|
cASSERT(&ctx->cursor,
|
||||||
gcu_backlog_size(txn) >= pages4retiredlist || err != MDBX_SUCCESS);
|
gcu_backlog_size(txn) >= for_data || err != MDBX_SUCCESS);
|
||||||
}
|
}
|
||||||
|
|
||||||
while (gcu_backlog_size(txn) < backlog4cow + pages4retiredlist &&
|
while (gcu_backlog_size(txn) < for_all_after_touch && err == MDBX_SUCCESS)
|
||||||
err == MDBX_SUCCESS)
|
|
||||||
err = page_alloc_slowpath(&ctx->cursor, 0,
|
err = page_alloc_slowpath(&ctx->cursor, 0,
|
||||||
MDBX_ALLOC_RESERVE | MDBX_ALLOC_UNIMPORTANT)
|
MDBX_ALLOC_RESERVE | MDBX_ALLOC_UNIMPORTANT)
|
||||||
.err;
|
.err;
|
||||||
|
|
||||||
TRACE("<< backlog %zu, err %d", gcu_backlog_size(txn), err);
|
TRACE("<< backlog %zu, err %d, gc: height %u, branch %zu, leaf %zu, large "
|
||||||
|
"%zu, entries %zu",
|
||||||
|
gcu_backlog_size(txn), err, txn->mt_dbs[FREE_DBI].md_depth,
|
||||||
|
(size_t)txn->mt_dbs[FREE_DBI].md_branch_pages,
|
||||||
|
(size_t)txn->mt_dbs[FREE_DBI].md_leaf_pages,
|
||||||
|
(size_t)txn->mt_dbs[FREE_DBI].md_overflow_pages,
|
||||||
|
(size_t)txn->mt_dbs[FREE_DBI].md_entries);
|
||||||
return (err != MDBX_NOTFOUND) ? err : MDBX_SUCCESS;
|
return (err != MDBX_NOTFOUND) ? err : MDBX_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -9665,9 +9705,10 @@ retry:
|
|||||||
TRACE("%s", " >> continue");
|
TRACE("%s", " >> continue");
|
||||||
|
|
||||||
if (ctx->retired_stored != MDBX_PNL_GETSIZE(txn->tw.retired_pages) &&
|
if (ctx->retired_stored != MDBX_PNL_GETSIZE(txn->tw.retired_pages) &&
|
||||||
(MDBX_PNL_GETSIZE(txn->tw.retired_pages) > env->me_maxgc_ov1page ||
|
(ctx->loop == 1 ||
|
||||||
|
MDBX_PNL_GETSIZE(txn->tw.retired_pages) > env->me_maxgc_ov1page ||
|
||||||
ctx->retired_stored > env->me_maxgc_ov1page)) {
|
ctx->retired_stored > env->me_maxgc_ov1page)) {
|
||||||
rc = gcu_prepare_backlog(txn, ctx, true);
|
rc = gcu_prepare_backlog(txn, ctx);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
goto bailout;
|
goto bailout;
|
||||||
}
|
}
|
||||||
@ -9696,7 +9737,7 @@ retry:
|
|||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
goto bailout;
|
goto bailout;
|
||||||
if (likely(!ctx->dense)) {
|
if (likely(!ctx->dense)) {
|
||||||
rc = gcu_prepare_backlog(txn, ctx, false);
|
rc = gcu_prepare_backlog(txn, ctx);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
goto bailout;
|
goto bailout;
|
||||||
}
|
}
|
||||||
@ -9730,7 +9771,7 @@ retry:
|
|||||||
if (ctx->cleaned_id > txn->tw.last_reclaimed)
|
if (ctx->cleaned_id > txn->tw.last_reclaimed)
|
||||||
break;
|
break;
|
||||||
if (likely(!ctx->dense)) {
|
if (likely(!ctx->dense)) {
|
||||||
rc = gcu_prepare_backlog(txn, ctx, false);
|
rc = gcu_prepare_backlog(txn, ctx);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
goto bailout;
|
goto bailout;
|
||||||
}
|
}
|
||||||
@ -9767,30 +9808,29 @@ retry:
|
|||||||
|
|
||||||
/* handle loose pages - put ones into the reclaimed- or retired-list */
|
/* handle loose pages - put ones into the reclaimed- or retired-list */
|
||||||
if (txn->tw.loose_pages) {
|
if (txn->tw.loose_pages) {
|
||||||
|
tASSERT(txn, txn->tw.loose_count > 0);
|
||||||
/* Return loose page numbers to tw.relist,
|
/* Return loose page numbers to tw.relist,
|
||||||
* though usually none are left at this point.
|
* though usually none are left at this point.
|
||||||
* The pages themselves remain in dirtylist. */
|
* The pages themselves remain in dirtylist. */
|
||||||
if (unlikely(!txn->tw.lifo_reclaimed && txn->tw.last_reclaimed < 1)) {
|
if (unlikely(!txn->tw.lifo_reclaimed && txn->tw.last_reclaimed < 1)) {
|
||||||
if (txn->tw.loose_count > 0) {
|
TRACE("%s: try allocate gc-slot for %zu loose-pages", dbg_prefix_mode,
|
||||||
TRACE("%s: try allocate gc-slot for %zu loose-pages", dbg_prefix_mode,
|
txn->tw.loose_count);
|
||||||
txn->tw.loose_count);
|
rc = page_alloc_slowpath(&ctx->cursor, 0, MDBX_ALLOC_RESERVE).err;
|
||||||
rc = page_alloc_slowpath(&ctx->cursor, 0, MDBX_ALLOC_RESERVE).err;
|
if (rc == MDBX_SUCCESS) {
|
||||||
if (rc == MDBX_SUCCESS) {
|
TRACE("%s: retry since gc-slot for %zu loose-pages available",
|
||||||
TRACE("%s: retry since gc-slot for %zu loose-pages available",
|
dbg_prefix_mode, txn->tw.loose_count);
|
||||||
dbg_prefix_mode, txn->tw.loose_count);
|
continue;
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Put loose page numbers in tw.retired_pages,
|
|
||||||
* since unable to return them to tw.relist. */
|
|
||||||
if (unlikely((rc = pnl_need(&txn->tw.retired_pages,
|
|
||||||
txn->tw.loose_count)) != 0))
|
|
||||||
goto bailout;
|
|
||||||
for (MDBX_page *mp = txn->tw.loose_pages; mp; mp = mp->mp_next)
|
|
||||||
pnl_xappend(txn->tw.retired_pages, mp->mp_pgno);
|
|
||||||
TRACE("%s: append %zu loose-pages to retired-pages", dbg_prefix_mode,
|
|
||||||
txn->tw.loose_count);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Put loose page numbers in tw.retired_pages,
|
||||||
|
* since unable to return them to tw.relist. */
|
||||||
|
if (unlikely((rc = pnl_need(&txn->tw.retired_pages,
|
||||||
|
txn->tw.loose_count)) != 0))
|
||||||
|
goto bailout;
|
||||||
|
for (MDBX_page *mp = txn->tw.loose_pages; mp; mp = mp->mp_next)
|
||||||
|
pnl_xappend(txn->tw.retired_pages, mp->mp_pgno);
|
||||||
|
TRACE("%s: append %zu loose-pages to retired-pages", dbg_prefix_mode,
|
||||||
|
txn->tw.loose_count);
|
||||||
} else {
|
} else {
|
||||||
/* Room for loose pages + temp PNL with same */
|
/* Room for loose pages + temp PNL with same */
|
||||||
rc = pnl_need(&txn->tw.relist, 2 * txn->tw.loose_count + 2);
|
rc = pnl_need(&txn->tw.relist, 2 * txn->tw.loose_count + 2);
|
||||||
@ -9874,14 +9914,31 @@ retry:
|
|||||||
}
|
}
|
||||||
|
|
||||||
retired_pages_before = MDBX_PNL_GETSIZE(txn->tw.retired_pages);
|
retired_pages_before = MDBX_PNL_GETSIZE(txn->tw.retired_pages);
|
||||||
rc = gcu_prepare_backlog(txn, ctx, true);
|
rc = gcu_prepare_backlog(txn, ctx);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
goto bailout;
|
goto bailout;
|
||||||
|
if (retired_pages_before != MDBX_PNL_GETSIZE(txn->tw.retired_pages)) {
|
||||||
|
TRACE("%s: retired-list changed (%zu -> %zu), retry", dbg_prefix_mode,
|
||||||
|
retired_pages_before, MDBX_PNL_GETSIZE(txn->tw.retired_pages));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
pnl_sort(txn->tw.retired_pages, txn->mt_next_pgno);
|
pnl_sort(txn->tw.retired_pages, txn->mt_next_pgno);
|
||||||
ctx->retired_stored = 0;
|
ctx->retired_stored = 0;
|
||||||
ctx->bigfoot = txn->mt_txnid;
|
ctx->bigfoot = txn->mt_txnid;
|
||||||
do {
|
do {
|
||||||
|
if (ctx->retired_stored) {
|
||||||
|
rc = gcu_prepare_backlog(txn, ctx);
|
||||||
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
|
goto bailout;
|
||||||
|
if (ctx->retired_stored >=
|
||||||
|
MDBX_PNL_GETSIZE(txn->tw.retired_pages)) {
|
||||||
|
TRACE("%s: retired-list changed (%zu -> %zu), retry",
|
||||||
|
dbg_prefix_mode, retired_pages_before,
|
||||||
|
MDBX_PNL_GETSIZE(txn->tw.retired_pages));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
key.iov_len = sizeof(txnid_t);
|
key.iov_len = sizeof(txnid_t);
|
||||||
key.iov_base = &ctx->bigfoot;
|
key.iov_base = &ctx->bigfoot;
|
||||||
const size_t left =
|
const size_t left =
|
||||||
@ -9927,7 +9984,7 @@ retry:
|
|||||||
key.iov_len = sizeof(txnid_t);
|
key.iov_len = sizeof(txnid_t);
|
||||||
key.iov_base = &txn->mt_txnid;
|
key.iov_base = &txn->mt_txnid;
|
||||||
do {
|
do {
|
||||||
gcu_prepare_backlog(txn, ctx, true);
|
gcu_prepare_backlog(txn, ctx);
|
||||||
data.iov_len = MDBX_PNL_SIZEOF(txn->tw.retired_pages);
|
data.iov_len = MDBX_PNL_SIZEOF(txn->tw.retired_pages);
|
||||||
rc = mdbx_cursor_put(&ctx->cursor, &key, &data, MDBX_RESERVE);
|
rc = mdbx_cursor_put(&ctx->cursor, &key, &data, MDBX_RESERVE);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
@ -9940,7 +9997,7 @@ retry:
|
|||||||
eASSERT(env, data.iov_len == MDBX_PNL_SIZEOF(txn->tw.retired_pages));
|
eASSERT(env, data.iov_len == MDBX_PNL_SIZEOF(txn->tw.retired_pages));
|
||||||
memcpy(data.iov_base, txn->tw.retired_pages, data.iov_len);
|
memcpy(data.iov_base, txn->tw.retired_pages, data.iov_len);
|
||||||
|
|
||||||
TRACE("%s: put-retired #%u @ %" PRIaTXN, dbg_prefix_mode,
|
TRACE("%s: put-retired #%zu @ %" PRIaTXN, dbg_prefix_mode,
|
||||||
ctx->retired_stored, txn->mt_txnid);
|
ctx->retired_stored, txn->mt_txnid);
|
||||||
#endif /* MDBX_ENABLE_BIGFOOT */
|
#endif /* MDBX_ENABLE_BIGFOOT */
|
||||||
if (LOG_ENABLED(MDBX_LOG_EXTRA)) {
|
if (LOG_ENABLED(MDBX_LOG_EXTRA)) {
|
||||||
@ -9982,7 +10039,7 @@ retry:
|
|||||||
if (0 >= (intptr_t)left)
|
if (0 >= (intptr_t)left)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
const size_t prefer_max_scatter = 257;
|
const size_t prefer_max_scatter = MDBX_ENABLE_BIGFOOT ? MDBX_TXL_MAX : 257;
|
||||||
txnid_t reservation_gc_id;
|
txnid_t reservation_gc_id;
|
||||||
if (ctx->lifo) {
|
if (ctx->lifo) {
|
||||||
if (txn->tw.lifo_reclaimed == nullptr) {
|
if (txn->tw.lifo_reclaimed == nullptr) {
|
||||||
@ -10154,6 +10211,10 @@ retry:
|
|||||||
: (ctx->rid < INT16_MAX) ? (size_t)ctx->rid
|
: (ctx->rid < INT16_MAX) ? (size_t)ctx->rid
|
||||||
: INT16_MAX;
|
: INT16_MAX;
|
||||||
if (avail_gc_slots > 1) {
|
if (avail_gc_slots > 1) {
|
||||||
|
#if MDBX_ENABLE_BIGFOOT
|
||||||
|
chunk = (chunk < env->me_maxgc_ov1page * 2) ? chunk / 2
|
||||||
|
: env->me_maxgc_ov1page;
|
||||||
|
#else
|
||||||
if (chunk < env->me_maxgc_ov1page * 2)
|
if (chunk < env->me_maxgc_ov1page * 2)
|
||||||
chunk /= 2;
|
chunk /= 2;
|
||||||
else {
|
else {
|
||||||
@ -10190,6 +10251,7 @@ retry:
|
|||||||
: tail;
|
: tail;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif /* MDBX_ENABLE_BIGFOOT */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
tASSERT(txn, chunk > 0);
|
tASSERT(txn, chunk > 0);
|
||||||
@ -10217,7 +10279,7 @@ retry:
|
|||||||
data.iov_len = (chunk + 1) * sizeof(pgno_t);
|
data.iov_len = (chunk + 1) * sizeof(pgno_t);
|
||||||
TRACE("%s: reserve %zu [%zu...%zu) @%" PRIaTXN, dbg_prefix_mode, chunk,
|
TRACE("%s: reserve %zu [%zu...%zu) @%" PRIaTXN, dbg_prefix_mode, chunk,
|
||||||
ctx->settled + 1, ctx->settled + chunk + 1, reservation_gc_id);
|
ctx->settled + 1, ctx->settled + chunk + 1, reservation_gc_id);
|
||||||
gcu_prepare_backlog(txn, ctx, true);
|
gcu_prepare_backlog(txn, ctx);
|
||||||
rc = mdbx_cursor_put(&ctx->cursor, &key, &data,
|
rc = mdbx_cursor_put(&ctx->cursor, &key, &data,
|
||||||
MDBX_RESERVE | MDBX_NOOVERWRITE);
|
MDBX_RESERVE | MDBX_NOOVERWRITE);
|
||||||
tASSERT(txn, pnl_check_allocated(txn->tw.relist,
|
tASSERT(txn, pnl_check_allocated(txn->tw.relist,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user