From 850fe8408edaae2d21295cb34a0b78206d129a00 Mon Sep 17 00:00:00 2001 From: Leonid Yuriev Date: Mon, 19 Nov 2018 13:30:10 +0300 Subject: [PATCH] mdbx: backport - relax DBI-sequences for concurrent open DBI-handles for present tables. Change-Id: I7f07d2e716074bd9c2847aeb062e366f46cca214 --- src/mdbx.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/mdbx.c b/src/mdbx.c index 95120ca9..e6907a8c 100644 --- a/src/mdbx.c +++ b/src/mdbx.c @@ -11213,19 +11213,19 @@ int mdbx_dbi_open_ex(MDBX_txn *txn, const char *table_name, unsigned user_flags, bailout: free(namedup); } else { - txn->mt_dbiseqs[slot] = (env->me_dbiseqs[slot] += 1); txn->mt_dbflags[slot] = (uint8_t)dbflag; txn->mt_dbxs[slot].md_name.iov_base = namedup; - mdbx_compiler_barrier(); txn->mt_dbxs[slot].md_name.iov_len = len; - if (slot == txn->mt_numdbs) - txn->mt_numdbs++; + txn->mt_numdbs += (slot == txn->mt_numdbs); if ((dbflag & DB_CREAT) == 0) { env->me_dbflags[slot] = txn->mt_dbs[slot].md_flags | MDBX_VALID; mdbx_compiler_barrier(); if (env->me_numdbs <= slot) env->me_numdbs = slot + 1; + } else { + env->me_dbiseqs[slot] += 1; } + txn->mt_dbiseqs[slot] = env->me_dbiseqs[slot]; *dbi = slot; }