mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-15 22:34:30 +08:00
mdbx: подстройка dirty-pages-limit при старте транзакций.
This commit is contained in:
parent
c8c541649c
commit
26f6fd351a
147
src/api-opts.c
147
src/api-opts.c
@ -3,7 +3,37 @@
|
|||||||
|
|
||||||
#include "internals.h"
|
#include "internals.h"
|
||||||
|
|
||||||
__cold static unsigned default_rp_augment_limit(const MDBX_env *env) {
|
static pgno_t env_max_pgno(const MDBX_env *env) {
|
||||||
|
return env->ps ? bytes2pgno(env, env->geo_in_bytes.upper ? env->geo_in_bytes.upper : MAX_MAPSIZE) : PAGELIST_LIMIT;
|
||||||
|
}
|
||||||
|
|
||||||
|
__cold pgno_t default_dp_limit(const MDBX_env *env) {
|
||||||
|
/* auto-setup dp_limit by "The42" ;-) */
|
||||||
|
intptr_t total_ram_pages, avail_ram_pages;
|
||||||
|
int err = mdbx_get_sysraminfo(nullptr, &total_ram_pages, &avail_ram_pages);
|
||||||
|
pgno_t dp_limit = 1024;
|
||||||
|
if (unlikely(err != MDBX_SUCCESS))
|
||||||
|
ERROR("mdbx_get_sysraminfo(), rc %d", err);
|
||||||
|
else {
|
||||||
|
size_t estimate = (size_t)(total_ram_pages + avail_ram_pages) / 42;
|
||||||
|
if (env->ps) {
|
||||||
|
if (env->ps > globals.sys_pagesize)
|
||||||
|
estimate /= env->ps / globals.sys_pagesize;
|
||||||
|
else if (env->ps < globals.sys_pagesize)
|
||||||
|
estimate *= globals.sys_pagesize / env->ps;
|
||||||
|
}
|
||||||
|
dp_limit = (pgno_t)estimate;
|
||||||
|
}
|
||||||
|
|
||||||
|
dp_limit = (dp_limit < PAGELIST_LIMIT) ? dp_limit : PAGELIST_LIMIT;
|
||||||
|
const pgno_t max_pgno = env_max_pgno(env);
|
||||||
|
if (dp_limit > max_pgno - NUM_METAS)
|
||||||
|
dp_limit = max_pgno - NUM_METAS;
|
||||||
|
dp_limit = (dp_limit > CURSOR_STACK_SIZE * 4) ? dp_limit : CURSOR_STACK_SIZE * 4;
|
||||||
|
return dp_limit;
|
||||||
|
}
|
||||||
|
|
||||||
|
__cold static pgno_t default_rp_augment_limit(const MDBX_env *env) {
|
||||||
const size_t timeframe = /* 16 секунд */ 16 << 16;
|
const size_t timeframe = /* 16 секунд */ 16 << 16;
|
||||||
const size_t remain_1sec =
|
const size_t remain_1sec =
|
||||||
(env->options.gc_time_limit < timeframe) ? timeframe - (size_t)env->options.gc_time_limit : 0;
|
(env->options.gc_time_limit < timeframe) ? timeframe - (size_t)env->options.gc_time_limit : 0;
|
||||||
@ -45,15 +75,51 @@ static uint16_t default_subpage_reserve_limit(const MDBX_env *env) {
|
|||||||
return 2753 /* 4.2% */;
|
return 2753 /* 4.2% */;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static uint16_t default_merge_threshold_16dot16_percent(const MDBX_env *env) {
|
||||||
|
(void)env;
|
||||||
|
return 65536 / 4 /* 25% */;
|
||||||
|
}
|
||||||
|
|
||||||
|
static pgno_t default_dp_reserve_limit(const MDBX_env *env) {
|
||||||
|
(void)env;
|
||||||
|
return MDBX_PNL_INITIAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static pgno_t default_dp_initial(const MDBX_env *env) {
|
||||||
|
(void)env;
|
||||||
|
return MDBX_PNL_INITIAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t default_spill_max_denominator(const MDBX_env *env) {
|
||||||
|
(void)env;
|
||||||
|
return 8;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t default_spill_min_denominator(const MDBX_env *env) {
|
||||||
|
(void)env;
|
||||||
|
return 8;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t default_spill_parent4child_denominator(const MDBX_env *env) {
|
||||||
|
(void)env;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t default_dp_loose_limit(const MDBX_env *env) {
|
||||||
|
(void)env;
|
||||||
|
return 64;
|
||||||
|
}
|
||||||
|
|
||||||
void env_options_init(MDBX_env *env) {
|
void env_options_init(MDBX_env *env) {
|
||||||
env->options.rp_augment_limit = MDBX_PNL_INITIAL;
|
env->options.rp_augment_limit = default_rp_augment_limit(env);
|
||||||
env->options.dp_reserve_limit = MDBX_PNL_INITIAL;
|
env->options.dp_reserve_limit = default_dp_reserve_limit(env);
|
||||||
env->options.dp_initial = MDBX_PNL_INITIAL;
|
env->options.dp_initial = default_dp_initial(env);
|
||||||
env->options.spill_max_denominator = 8;
|
env->options.dp_limit = default_dp_limit(env);
|
||||||
env->options.spill_min_denominator = 8;
|
env->options.spill_max_denominator = default_spill_max_denominator(env);
|
||||||
env->options.spill_parent4child_denominator = 0;
|
env->options.spill_min_denominator = default_spill_min_denominator(env);
|
||||||
env->options.dp_loose_limit = 64;
|
env->options.spill_parent4child_denominator = default_spill_parent4child_denominator(env);
|
||||||
env->options.merge_threshold_16dot16_percent = 65536 / 4 /* 25% */;
|
env->options.dp_loose_limit = default_dp_loose_limit(env);
|
||||||
|
env->options.merge_threshold_16dot16_percent = default_merge_threshold_16dot16_percent(env);
|
||||||
if (default_prefer_waf_insteadof_balance(env))
|
if (default_prefer_waf_insteadof_balance(env))
|
||||||
env->options.prefer_waf_insteadof_balance = true;
|
env->options.prefer_waf_insteadof_balance = true;
|
||||||
|
|
||||||
@ -71,12 +137,31 @@ void env_options_init(MDBX_env *env) {
|
|||||||
env->options.subpage.reserve_limit = default_subpage_reserve_limit(env);
|
env->options.subpage.reserve_limit = default_subpage_reserve_limit(env);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void env_options_adjust_dp_limit(MDBX_env *env) {
|
||||||
|
if (!env->options.flags.non_auto.dp_limit)
|
||||||
|
env->options.dp_limit = default_dp_limit(env);
|
||||||
|
else {
|
||||||
|
const pgno_t max_pgno = env_max_pgno(env);
|
||||||
|
if (env->options.dp_limit > max_pgno - NUM_METAS)
|
||||||
|
env->options.dp_limit = max_pgno - NUM_METAS;
|
||||||
|
if (env->options.dp_limit < CURSOR_STACK_SIZE * 4)
|
||||||
|
env->options.dp_limit = CURSOR_STACK_SIZE * 4;
|
||||||
|
}
|
||||||
|
if (env->options.dp_initial > env->options.dp_limit && env->options.dp_initial > default_dp_initial(env))
|
||||||
|
env->options.dp_initial = env->options.dp_limit;
|
||||||
|
env->options.need_dp_limit_adjust = false;
|
||||||
|
}
|
||||||
|
|
||||||
void env_options_adjust_defaults(MDBX_env *env) {
|
void env_options_adjust_defaults(MDBX_env *env) {
|
||||||
if (!env->options.flags.non_auto.rp_augment_limit)
|
if (!env->options.flags.non_auto.rp_augment_limit)
|
||||||
env->options.rp_augment_limit = default_rp_augment_limit(env);
|
env->options.rp_augment_limit = default_rp_augment_limit(env);
|
||||||
if (!env->options.flags.non_auto.prefault_write)
|
if (!env->options.flags.non_auto.prefault_write)
|
||||||
env->options.prefault_write = default_prefault_write(env);
|
env->options.prefault_write = default_prefault_write(env);
|
||||||
|
|
||||||
|
env->options.need_dp_limit_adjust = true;
|
||||||
|
if (!env->txn)
|
||||||
|
env_options_adjust_dp_limit(env);
|
||||||
|
|
||||||
const size_t basis = env->geo_in_bytes.now;
|
const size_t basis = env->geo_in_bytes.now;
|
||||||
/* TODO: use options? */
|
/* TODO: use options? */
|
||||||
const unsigned factor = 9;
|
const unsigned factor = 9;
|
||||||
@ -85,7 +170,6 @@ void env_options_adjust_defaults(MDBX_env *env) {
|
|||||||
: basis >> factor;
|
: basis >> factor;
|
||||||
threshold =
|
threshold =
|
||||||
(threshold < env->geo_in_bytes.shrink || !env->geo_in_bytes.shrink) ? threshold : env->geo_in_bytes.shrink;
|
(threshold < env->geo_in_bytes.shrink || !env->geo_in_bytes.shrink) ? threshold : env->geo_in_bytes.shrink;
|
||||||
|
|
||||||
env->madv_threshold = bytes2pgno(env, bytes_align2os_bytes(env, threshold));
|
env->madv_threshold = bytes2pgno(env, bytes_align2os_bytes(env, threshold));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -163,7 +247,7 @@ __cold int mdbx_env_set_option(MDBX_env *env, const MDBX_option_t option, uint64
|
|||||||
|
|
||||||
case MDBX_opt_dp_reserve_limit:
|
case MDBX_opt_dp_reserve_limit:
|
||||||
if (value == /* default */ UINT64_MAX)
|
if (value == /* default */ UINT64_MAX)
|
||||||
value = INT_MAX;
|
value = default_dp_reserve_limit(env);
|
||||||
if (unlikely(value > INT_MAX))
|
if (unlikely(value > INT_MAX))
|
||||||
return LOG_IFERR(MDBX_EINVAL);
|
return LOG_IFERR(MDBX_EINVAL);
|
||||||
if (env->options.dp_reserve_limit != (unsigned)value) {
|
if (env->options.dp_reserve_limit != (unsigned)value) {
|
||||||
@ -218,9 +302,7 @@ __cold int mdbx_env_set_option(MDBX_env *env, const MDBX_option_t option, uint64
|
|||||||
|
|
||||||
case MDBX_opt_txn_dp_limit:
|
case MDBX_opt_txn_dp_limit:
|
||||||
case MDBX_opt_txn_dp_initial:
|
case MDBX_opt_txn_dp_initial:
|
||||||
if (value == /* default */ UINT64_MAX)
|
if (value != /* default */ UINT64_MAX && unlikely(value > PAGELIST_LIMIT || value < CURSOR_STACK_SIZE * 4))
|
||||||
value = PAGELIST_LIMIT;
|
|
||||||
if (unlikely(value > PAGELIST_LIMIT || value < CURSOR_STACK_SIZE * 4))
|
|
||||||
return LOG_IFERR(MDBX_EINVAL);
|
return LOG_IFERR(MDBX_EINVAL);
|
||||||
if (unlikely(env->flags & MDBX_RDONLY))
|
if (unlikely(env->flags & MDBX_RDONLY))
|
||||||
return LOG_IFERR(MDBX_EACCESS);
|
return LOG_IFERR(MDBX_EACCESS);
|
||||||
@ -233,40 +315,45 @@ __cold int mdbx_env_set_option(MDBX_env *env, const MDBX_option_t option, uint64
|
|||||||
if (env->txn)
|
if (env->txn)
|
||||||
err = MDBX_EPERM /* unable change during transaction */;
|
err = MDBX_EPERM /* unable change during transaction */;
|
||||||
else {
|
else {
|
||||||
const pgno_t value32 = (pgno_t)value;
|
const pgno_t max_pgno = env_max_pgno(env);
|
||||||
if (option == MDBX_opt_txn_dp_initial && env->options.dp_initial != value32) {
|
if (option == MDBX_opt_txn_dp_initial) {
|
||||||
env->options.dp_initial = value32;
|
if (value == /* default */ UINT64_MAX)
|
||||||
if (env->options.dp_limit < value32) {
|
env->options.dp_initial = default_dp_initial(env);
|
||||||
env->options.dp_limit = value32;
|
else {
|
||||||
env->options.flags.non_auto.dp_limit = 1;
|
env->options.dp_initial = (pgno_t)value;
|
||||||
|
if (env->options.dp_initial > max_pgno)
|
||||||
|
env->options.dp_initial = (max_pgno > CURSOR_STACK_SIZE * 4) ? max_pgno : CURSOR_STACK_SIZE * 4;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (option == MDBX_opt_txn_dp_limit && env->options.dp_limit != value32) {
|
if (option == MDBX_opt_txn_dp_limit) {
|
||||||
env->options.dp_limit = value32;
|
if (value == /* default */ UINT64_MAX) {
|
||||||
env->options.flags.non_auto.dp_limit = 1;
|
env->options.flags.non_auto.dp_limit = 0;
|
||||||
if (env->options.dp_initial > value32)
|
} else {
|
||||||
env->options.dp_initial = value32;
|
env->options.flags.non_auto.dp_limit = 1;
|
||||||
|
env->options.dp_limit = (pgno_t)value;
|
||||||
|
}
|
||||||
|
env_options_adjust_dp_limit(env);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MDBX_opt_spill_max_denominator:
|
case MDBX_opt_spill_max_denominator:
|
||||||
if (value == /* default */ UINT64_MAX)
|
if (value == /* default */ UINT64_MAX)
|
||||||
value = 8;
|
value = default_spill_max_denominator(env);
|
||||||
if (unlikely(value > 255))
|
if (unlikely(value > 255))
|
||||||
return LOG_IFERR(MDBX_EINVAL);
|
return LOG_IFERR(MDBX_EINVAL);
|
||||||
env->options.spill_max_denominator = (uint8_t)value;
|
env->options.spill_max_denominator = (uint8_t)value;
|
||||||
break;
|
break;
|
||||||
case MDBX_opt_spill_min_denominator:
|
case MDBX_opt_spill_min_denominator:
|
||||||
if (value == /* default */ UINT64_MAX)
|
if (value == /* default */ UINT64_MAX)
|
||||||
value = 8;
|
value = default_spill_min_denominator(env);
|
||||||
if (unlikely(value > 255))
|
if (unlikely(value > 255))
|
||||||
return LOG_IFERR(MDBX_EINVAL);
|
return LOG_IFERR(MDBX_EINVAL);
|
||||||
env->options.spill_min_denominator = (uint8_t)value;
|
env->options.spill_min_denominator = (uint8_t)value;
|
||||||
break;
|
break;
|
||||||
case MDBX_opt_spill_parent4child_denominator:
|
case MDBX_opt_spill_parent4child_denominator:
|
||||||
if (value == /* default */ UINT64_MAX)
|
if (value == /* default */ UINT64_MAX)
|
||||||
value = 0;
|
value = default_spill_parent4child_denominator(env);
|
||||||
if (unlikely(value > 255))
|
if (unlikely(value > 255))
|
||||||
return LOG_IFERR(MDBX_EINVAL);
|
return LOG_IFERR(MDBX_EINVAL);
|
||||||
env->options.spill_parent4child_denominator = (uint8_t)value;
|
env->options.spill_parent4child_denominator = (uint8_t)value;
|
||||||
@ -274,7 +361,7 @@ __cold int mdbx_env_set_option(MDBX_env *env, const MDBX_option_t option, uint64
|
|||||||
|
|
||||||
case MDBX_opt_loose_limit:
|
case MDBX_opt_loose_limit:
|
||||||
if (value == /* default */ UINT64_MAX)
|
if (value == /* default */ UINT64_MAX)
|
||||||
value = 64;
|
value = default_dp_loose_limit(env);
|
||||||
if (unlikely(value > 255))
|
if (unlikely(value > 255))
|
||||||
return LOG_IFERR(MDBX_EINVAL);
|
return LOG_IFERR(MDBX_EINVAL);
|
||||||
env->options.dp_loose_limit = (uint8_t)value;
|
env->options.dp_loose_limit = (uint8_t)value;
|
||||||
@ -282,7 +369,7 @@ __cold int mdbx_env_set_option(MDBX_env *env, const MDBX_option_t option, uint64
|
|||||||
|
|
||||||
case MDBX_opt_merge_threshold_16dot16_percent:
|
case MDBX_opt_merge_threshold_16dot16_percent:
|
||||||
if (value == /* default */ UINT64_MAX)
|
if (value == /* default */ UINT64_MAX)
|
||||||
value = 65536 / 4 /* 25% */;
|
value = default_merge_threshold_16dot16_percent(env);
|
||||||
if (unlikely(value < 8192 || value > 32768))
|
if (unlikely(value < 8192 || value > 32768))
|
||||||
return LOG_IFERR(MDBX_EINVAL);
|
return LOG_IFERR(MDBX_EINVAL);
|
||||||
env->options.merge_threshold_16dot16_percent = (unsigned)value;
|
env->options.merge_threshold_16dot16_percent = (unsigned)value;
|
||||||
|
25
src/env.c
25
src/env.c
@ -52,30 +52,7 @@ __cold unsigned env_setup_pagesize(MDBX_env *env, const size_t pagesize) {
|
|||||||
eASSERT(env, bytes2pgno(env, pagesize + pagesize) == 2);
|
eASSERT(env, bytes2pgno(env, pagesize + pagesize) == 2);
|
||||||
recalculate_merge_thresholds(env);
|
recalculate_merge_thresholds(env);
|
||||||
recalculate_subpage_thresholds(env);
|
recalculate_subpage_thresholds(env);
|
||||||
|
env_options_adjust_dp_limit(env);
|
||||||
const pgno_t max_pgno = bytes2pgno(env, MAX_MAPSIZE);
|
|
||||||
if (!env->options.flags.non_auto.dp_limit) {
|
|
||||||
/* auto-setup dp_limit by "The42" ;-) */
|
|
||||||
intptr_t total_ram_pages, avail_ram_pages;
|
|
||||||
int err = mdbx_get_sysraminfo(nullptr, &total_ram_pages, &avail_ram_pages);
|
|
||||||
if (unlikely(err != MDBX_SUCCESS))
|
|
||||||
ERROR("mdbx_get_sysraminfo(), rc %d", err);
|
|
||||||
else {
|
|
||||||
size_t reasonable_dpl_limit = (size_t)(total_ram_pages + avail_ram_pages) / 42;
|
|
||||||
if (pagesize > globals.sys_pagesize)
|
|
||||||
reasonable_dpl_limit /= pagesize / globals.sys_pagesize;
|
|
||||||
else if (pagesize < globals.sys_pagesize)
|
|
||||||
reasonable_dpl_limit *= globals.sys_pagesize / pagesize;
|
|
||||||
reasonable_dpl_limit = (reasonable_dpl_limit < PAGELIST_LIMIT) ? reasonable_dpl_limit : PAGELIST_LIMIT;
|
|
||||||
reasonable_dpl_limit =
|
|
||||||
(reasonable_dpl_limit > CURSOR_STACK_SIZE * 4) ? reasonable_dpl_limit : CURSOR_STACK_SIZE * 4;
|
|
||||||
env->options.dp_limit = (unsigned)reasonable_dpl_limit;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (env->options.dp_limit > max_pgno - NUM_METAS)
|
|
||||||
env->options.dp_limit = max_pgno - NUM_METAS;
|
|
||||||
if (env->options.dp_initial > env->options.dp_limit)
|
|
||||||
env->options.dp_initial = env->options.dp_limit;
|
|
||||||
return env->ps;
|
return env->ps;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -401,6 +401,7 @@ struct MDBX_env {
|
|||||||
bool prefault_write;
|
bool prefault_write;
|
||||||
bool prefer_waf_insteadof_balance; /* Strive to minimize WAF instead of
|
bool prefer_waf_insteadof_balance; /* Strive to minimize WAF instead of
|
||||||
balancing pages fullment */
|
balancing pages fullment */
|
||||||
|
bool need_dp_limit_adjust;
|
||||||
struct {
|
struct {
|
||||||
uint16_t limit;
|
uint16_t limit;
|
||||||
uint16_t room_threshold;
|
uint16_t room_threshold;
|
||||||
|
@ -77,11 +77,15 @@ MDBX_INTERNAL int env_info(const MDBX_env *env, const MDBX_txn *txn, MDBX_envinf
|
|||||||
MDBX_INTERNAL int env_sync(MDBX_env *env, bool force, bool nonblock);
|
MDBX_INTERNAL int env_sync(MDBX_env *env, bool force, bool nonblock);
|
||||||
MDBX_INTERNAL int env_close(MDBX_env *env, bool resurrect_after_fork);
|
MDBX_INTERNAL int env_close(MDBX_env *env, bool resurrect_after_fork);
|
||||||
MDBX_INTERNAL bool env_txn0_owned(const MDBX_env *env);
|
MDBX_INTERNAL bool env_txn0_owned(const MDBX_env *env);
|
||||||
MDBX_INTERNAL void env_options_init(MDBX_env *env);
|
|
||||||
MDBX_INTERNAL void env_options_adjust_defaults(MDBX_env *env);
|
|
||||||
MDBX_INTERNAL int __must_check_result env_page_auxbuffer(MDBX_env *env);
|
MDBX_INTERNAL int __must_check_result env_page_auxbuffer(MDBX_env *env);
|
||||||
MDBX_INTERNAL unsigned env_setup_pagesize(MDBX_env *env, const size_t pagesize);
|
MDBX_INTERNAL unsigned env_setup_pagesize(MDBX_env *env, const size_t pagesize);
|
||||||
|
|
||||||
|
/* api-opt.c */
|
||||||
|
MDBX_INTERNAL void env_options_init(MDBX_env *env);
|
||||||
|
MDBX_INTERNAL void env_options_adjust_defaults(MDBX_env *env);
|
||||||
|
MDBX_INTERNAL void env_options_adjust_dp_limit(MDBX_env *env);
|
||||||
|
MDBX_INTERNAL pgno_t default_dp_limit(const MDBX_env *env);
|
||||||
|
|
||||||
/* tree.c */
|
/* tree.c */
|
||||||
MDBX_INTERNAL int tree_drop(MDBX_cursor *mc, const bool may_have_tables);
|
MDBX_INTERNAL int tree_drop(MDBX_cursor *mc, const bool may_have_tables);
|
||||||
MDBX_INTERNAL int __must_check_result tree_rebalance(MDBX_cursor *mc);
|
MDBX_INTERNAL int __must_check_result tree_rebalance(MDBX_cursor *mc);
|
||||||
|
33
src/txn.c
33
src/txn.c
@ -654,21 +654,6 @@ int txn_renew(MDBX_txn *txn, unsigned flags) {
|
|||||||
if (txn->tw.gc.retxl)
|
if (txn->tw.gc.retxl)
|
||||||
MDBX_PNL_SETSIZE(txn->tw.gc.retxl, 0);
|
MDBX_PNL_SETSIZE(txn->tw.gc.retxl, 0);
|
||||||
env->txn = txn;
|
env->txn = txn;
|
||||||
|
|
||||||
if ((txn->flags & MDBX_WRITEMAP) == 0 || MDBX_AVOID_MSYNC) {
|
|
||||||
rc = dpl_alloc(txn);
|
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
|
||||||
goto bailout;
|
|
||||||
txn->tw.dirtyroom = txn->env->options.dp_limit;
|
|
||||||
txn->tw.dirtylru = MDBX_DEBUG ? UINT32_MAX / 3 - 42 : 0;
|
|
||||||
} else {
|
|
||||||
tASSERT(txn, txn->tw.dirtylist == nullptr);
|
|
||||||
txn->tw.dirtylist = nullptr;
|
|
||||||
txn->tw.dirtyroom = MAX_PAGENO;
|
|
||||||
txn->tw.dirtylru = 0;
|
|
||||||
}
|
|
||||||
eASSERT(env, txn->tw.writemap_dirty_npages == 0);
|
|
||||||
eASSERT(env, txn->tw.writemap_spilled_npages == 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
txn->front_txnid = txn->txnid + ((flags & (MDBX_WRITEMAP | MDBX_RDONLY)) == 0);
|
txn->front_txnid = txn->txnid + ((flags & (MDBX_WRITEMAP | MDBX_RDONLY)) == 0);
|
||||||
@ -834,6 +819,24 @@ int txn_renew(MDBX_txn *txn, unsigned flags) {
|
|||||||
#endif /* Windows */
|
#endif /* Windows */
|
||||||
} else {
|
} else {
|
||||||
tASSERT(txn, txn == env->basal_txn);
|
tASSERT(txn, txn == env->basal_txn);
|
||||||
|
|
||||||
|
if (env->options.need_dp_limit_adjust)
|
||||||
|
env_options_adjust_dp_limit(env);
|
||||||
|
if ((txn->flags & MDBX_WRITEMAP) == 0 || MDBX_AVOID_MSYNC) {
|
||||||
|
rc = dpl_alloc(txn);
|
||||||
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
|
goto bailout;
|
||||||
|
txn->tw.dirtyroom = txn->env->options.dp_limit;
|
||||||
|
txn->tw.dirtylru = MDBX_DEBUG ? UINT32_MAX / 3 - 42 : 0;
|
||||||
|
} else {
|
||||||
|
tASSERT(txn, txn->tw.dirtylist == nullptr);
|
||||||
|
txn->tw.dirtylist = nullptr;
|
||||||
|
txn->tw.dirtyroom = MAX_PAGENO;
|
||||||
|
txn->tw.dirtylru = 0;
|
||||||
|
}
|
||||||
|
eASSERT(env, txn->tw.writemap_dirty_npages == 0);
|
||||||
|
eASSERT(env, txn->tw.writemap_spilled_npages == 0);
|
||||||
|
|
||||||
MDBX_cursor *const gc = ptr_disp(txn, sizeof(MDBX_txn));
|
MDBX_cursor *const gc = ptr_disp(txn, sizeof(MDBX_txn));
|
||||||
rc = cursor_init(gc, txn, FREE_DBI);
|
rc = cursor_init(gc, txn, FREE_DBI);
|
||||||
if (rc != MDBX_SUCCESS)
|
if (rc != MDBX_SUCCESS)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user