mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-08 06:44:12 +08:00
mdbx: fix env_sync_ex() for out-of-txn case.
Change-Id: Ie19bbe1d467ce4fc83f8dfc1e367070f532ee335
This commit is contained in:
parent
9168f8c69d
commit
65fd8be9b5
22
src/mdbx.c
22
src/mdbx.c
@ -2171,7 +2171,7 @@ static txnid_t mdbx_find_oldest(MDBX_txn *txn) {
|
|||||||
mdbx_tassert(txn, (txn->mt_flags & MDBX_RDONLY) == 0);
|
mdbx_tassert(txn, (txn->mt_flags & MDBX_RDONLY) == 0);
|
||||||
MDBX_env *env = txn->mt_env;
|
MDBX_env *env = txn->mt_env;
|
||||||
const txnid_t edge = mdbx_reclaiming_detent(env);
|
const txnid_t edge = mdbx_reclaiming_detent(env);
|
||||||
mdbx_tassert(txn, edge <= txn->mt_txnid - 1);
|
mdbx_tassert(txn, edge <= txn->mt_txnid);
|
||||||
|
|
||||||
MDBX_lockinfo *const lck = env->me_lck;
|
MDBX_lockinfo *const lck = env->me_lck;
|
||||||
if (unlikely(lck == NULL /* exclusive mode */))
|
if (unlikely(lck == NULL /* exclusive mode */))
|
||||||
@ -2213,7 +2213,7 @@ static txnid_t mdbx_find_oldest(MDBX_txn *txn) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Find largest mvcc-snapshot still referenced. */
|
/* Find largest mvcc-snapshot still referenced. */
|
||||||
static pgno_t mdbx_find_largest(MDBX_env *env, pgno_t largest) {
|
static __cold pgno_t mdbx_find_largest(MDBX_env *env, pgno_t largest) {
|
||||||
MDBX_lockinfo *const lck = env->me_lck;
|
MDBX_lockinfo *const lck = env->me_lck;
|
||||||
if (likely(lck != NULL /* exclusive mode */)) {
|
if (likely(lck != NULL /* exclusive mode */)) {
|
||||||
const unsigned snap_nreaders = lck->mti_numreaders;
|
const unsigned snap_nreaders = lck->mti_numreaders;
|
||||||
@ -3021,17 +3021,17 @@ __cold static int mdbx_env_sync_ex(MDBX_env *env, int force, int nonblock) {
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
MDBX_meta *head = mdbx_meta_head(env);
|
const MDBX_meta *head = mdbx_meta_head(env);
|
||||||
if (!META_IS_STEADY(head) || env->me_sync_pending) {
|
if (!META_IS_STEADY(head) || env->me_sync_pending) {
|
||||||
|
|
||||||
if (force || (env->me_sync_threshold &&
|
if (force || (env->me_sync_threshold &&
|
||||||
env->me_sync_pending >= env->me_sync_threshold))
|
env->me_sync_pending >= env->me_sync_threshold))
|
||||||
flags &= MDBX_WRITEMAP /* clear flags for full steady sync */;
|
flags &= MDBX_WRITEMAP /* clear flags for full steady sync */;
|
||||||
|
|
||||||
if (outside_txn &&
|
if (outside_txn) {
|
||||||
env->me_sync_pending >
|
if (env->me_sync_pending >
|
||||||
pgno2bytes(env, 16 /* FIXME: define threshold */) &&
|
pgno2bytes(env, 16 /* FIXME: define threshold */) &&
|
||||||
(flags & MDBX_NOSYNC) == 0) {
|
(flags & (MDBX_NOSYNC | MDBX_MAPASYNC)) == 0) {
|
||||||
mdbx_assert(env, ((flags ^ env->me_flags) & MDBX_WRITEMAP) == 0);
|
mdbx_assert(env, ((flags ^ env->me_flags) & MDBX_WRITEMAP) == 0);
|
||||||
const size_t usedbytes = pgno_align2os_bytes(env, head->mm_geo.next);
|
const size_t usedbytes = pgno_align2os_bytes(env, head->mm_geo.next);
|
||||||
|
|
||||||
@ -3039,8 +3039,7 @@ __cold static int mdbx_env_sync_ex(MDBX_env *env, int force, int nonblock) {
|
|||||||
|
|
||||||
/* LY: pre-sync without holding lock to reduce latency for writer(s) */
|
/* LY: pre-sync without holding lock to reduce latency for writer(s) */
|
||||||
int rc = (flags & MDBX_WRITEMAP)
|
int rc = (flags & MDBX_WRITEMAP)
|
||||||
? mdbx_msync(&env->me_dxb_mmap, 0, usedbytes,
|
? mdbx_msync(&env->me_dxb_mmap, 0, usedbytes, false)
|
||||||
flags & MDBX_MAPASYNC)
|
|
||||||
: mdbx_filesync(env->me_fd, MDBX_SYNC_DATA);
|
: mdbx_filesync(env->me_fd, MDBX_SYNC_DATA);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
return rc;
|
return rc;
|
||||||
@ -3052,8 +3051,13 @@ __cold static int mdbx_env_sync_ex(MDBX_env *env, int force, int nonblock) {
|
|||||||
/* LY: head may be changed. */
|
/* LY: head may be changed. */
|
||||||
head = mdbx_meta_head(env);
|
head = mdbx_meta_head(env);
|
||||||
}
|
}
|
||||||
|
env->me_txn0->mt_txnid = meta_txnid(env, head, false);
|
||||||
|
mdbx_find_oldest(env->me_txn0);
|
||||||
|
}
|
||||||
|
|
||||||
if (!META_IS_STEADY(head) || env->me_sync_pending) {
|
if (!META_IS_STEADY(head) ||
|
||||||
|
((flags & (MDBX_NOSYNC | MDBX_MAPASYNC)) == 0 &&
|
||||||
|
env->me_sync_pending)) {
|
||||||
mdbx_debug("meta-head %" PRIaPGNO ", %s, sync_pending %" PRIuPTR,
|
mdbx_debug("meta-head %" PRIaPGNO ", %s, sync_pending %" PRIuPTR,
|
||||||
container_of(head, MDBX_page, mp_data)->mp_pgno,
|
container_of(head, MDBX_page, mp_data)->mp_pgno,
|
||||||
mdbx_durable_str(head), env->me_sync_pending);
|
mdbx_durable_str(head), env->me_sync_pending);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user