mdbx: fix snap-state bug.

Change-Id: I8700209ab012bfef21c88fe06c39b80a640291c6
This commit is contained in:
Leo Yuriev 2017-04-27 01:26:33 +03:00
parent d5b5434fa6
commit 9e07b71c27

View File

@ -2185,23 +2185,22 @@ static int mdbx_txn_renew0(MDB_txn *txn, unsigned flags) {
mdbx_thread_rthc_set(env->me_txkey, r); mdbx_thread_rthc_set(env->me_txkey, r);
} }
while ((env->me_flags & MDB_FATAL_ERROR) == 0) { while (1) {
MDB_meta *const meta = mdbx_meta_head(txn->mt_env); MDB_meta *const meta = mdbx_meta_head(txn->mt_env);
txnid_t lead = meta->mm_txnid; const txnid_t snap = meta->mm_txnid;
r->mr_txnid = lead; r->mr_txnid = snap;
mdbx_coherent_barrier(); mdbx_coherent_barrier();
txnid_t snap = mdbx_meta_head(txn->mt_env)->mm_txnid; /* Snap the state from current meta-head */
/* LY: Retry on a race, ITS#7970. */ txn->mt_txnid = snap;
if (likely(lead == snap)) {
txn->mt_txnid = lead;
txn->mt_next_pgno = meta->mm_last_pg + 1; txn->mt_next_pgno = meta->mm_last_pg + 1;
/* Copy the DB info and flags */
memcpy(txn->mt_dbs, meta->mm_dbs, CORE_DBS * sizeof(MDB_db)); memcpy(txn->mt_dbs, meta->mm_dbs, CORE_DBS * sizeof(MDB_db));
txn->mt_canary = meta->mm_canary; txn->mt_canary = meta->mm_canary;
/* LY: Retry on a race, ITS#7970. */
if (likely(meta == mdbx_meta_head(txn->mt_env) && snap == meta->mm_txnid))
break; break;
} }
}
txn->mt_u.reader = r; txn->mt_u.reader = r;
txn->mt_dbxs = env->me_dbxs; /* mostly static anyway */ txn->mt_dbxs = env->me_dbxs; /* mostly static anyway */