mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-04 17:34:14 +08:00
mdbx: cleanup after last pull-request.
Cleanup after 4e40af60e74143aedaa8d295f0f33a3c892a1c9b (Merge pull request #20 from rouzier/feature/txn_try).
This commit is contained in:
parent
875d22ff38
commit
17b8e48bf4
2
mdbx.h
2
mdbx.h
@ -327,7 +327,7 @@ typedef int(MDBX_cmp_func)(const MDBX_val *a, const MDBX_val *b);
|
|||||||
/* Store multiple data items in one call. Only for MDBX_DUPFIXED. */
|
/* Store multiple data items in one call. Only for MDBX_DUPFIXED. */
|
||||||
#define MDBX_MULTIPLE 0x80000u
|
#define MDBX_MULTIPLE 0x80000u
|
||||||
|
|
||||||
/* Transaction Flags*/
|
/* Transaction Flags */
|
||||||
/* Do not block when starting a write transaction */
|
/* Do not block when starting a write transaction */
|
||||||
#define MDBX_TRYTXN 0x10000000u
|
#define MDBX_TRYTXN 0x10000000u
|
||||||
|
|
||||||
|
@ -553,8 +553,8 @@ struct MDBX_txn {
|
|||||||
|
|
||||||
/* Transaction Flags */
|
/* Transaction Flags */
|
||||||
/* mdbx_txn_begin() flags */
|
/* mdbx_txn_begin() flags */
|
||||||
#define MDBX_TXN_BEGIN_FLAGS_PERSISTENT (MDBX_NOMETASYNC | MDBX_NOSYNC | MDBX_RDONLY)
|
#define MDBX_TXN_BEGIN_FLAGS \
|
||||||
#define MDBX_TXN_BEGIN_FLAGS (MDBX_TXN_BEGIN_FLAGS_PERSISTENT | MDBX_TRYTXN)
|
(MDBX_NOMETASYNC | MDBX_NOSYNC | MDBX_RDONLY | MDBX_TRYTXN)
|
||||||
#define MDBX_TXN_NOMETASYNC \
|
#define MDBX_TXN_NOMETASYNC \
|
||||||
MDBX_NOMETASYNC /* don't sync meta for this txn on commit */
|
MDBX_NOMETASYNC /* don't sync meta for this txn on commit */
|
||||||
#define MDBX_TXN_NOSYNC MDBX_NOSYNC /* don't sync this txn on commit */
|
#define MDBX_TXN_NOSYNC MDBX_NOSYNC /* don't sync this txn on commit */
|
||||||
|
@ -2563,7 +2563,8 @@ static int mdbx_txn_renew0(MDBX_txn *txn, unsigned flags) {
|
|||||||
} else {
|
} else {
|
||||||
/* Not yet touching txn == env->me_txn0, it may be active */
|
/* Not yet touching txn == env->me_txn0, it may be active */
|
||||||
mdbx_jitter4testing(false);
|
mdbx_jitter4testing(false);
|
||||||
rc = F_ISSET(flags, MDBX_TRYTXN) ? mdbx_txn_trylock(env) : mdbx_txn_lock(env);
|
rc = F_ISSET(flags, MDBX_TRYTXN) ? mdbx_txn_trylock(env)
|
||||||
|
: mdbx_txn_lock(env);
|
||||||
if (unlikely(rc))
|
if (unlikely(rc))
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
@ -2665,7 +2666,6 @@ int mdbx_txn_begin(MDBX_env *env, MDBX_txn *parent, unsigned flags,
|
|||||||
MDBX_txn **ret) {
|
MDBX_txn **ret) {
|
||||||
MDBX_txn *txn;
|
MDBX_txn *txn;
|
||||||
MDBX_ntxn *ntxn;
|
MDBX_ntxn *ntxn;
|
||||||
//unsigned pflags;
|
|
||||||
int rc, size, tsize;
|
int rc, size, tsize;
|
||||||
|
|
||||||
if (unlikely(!env || !ret))
|
if (unlikely(!env || !ret))
|
||||||
@ -2720,7 +2720,7 @@ int mdbx_txn_begin(MDBX_env *env, MDBX_txn *parent, unsigned flags,
|
|||||||
txn->mt_dbxs = env->me_dbxs; /* static */
|
txn->mt_dbxs = env->me_dbxs; /* static */
|
||||||
txn->mt_dbs = (MDBX_db *)((char *)txn + tsize);
|
txn->mt_dbs = (MDBX_db *)((char *)txn + tsize);
|
||||||
txn->mt_dbflags = (uint8_t *)txn + size - env->me_maxdbs;
|
txn->mt_dbflags = (uint8_t *)txn + size - env->me_maxdbs;
|
||||||
txn->mt_flags = flags & MDBX_TXN_BEGIN_FLAGS_PERSISTENT;
|
txn->mt_flags = flags;
|
||||||
txn->mt_env = env;
|
txn->mt_env = env;
|
||||||
|
|
||||||
if (parent) {
|
if (parent) {
|
||||||
|
@ -20,7 +20,14 @@
|
|||||||
|
|
||||||
#define ACTOR_ID_MAX INT16_MAX
|
#define ACTOR_ID_MAX INT16_MAX
|
||||||
|
|
||||||
enum actor_testcase { ac_none, ac_hill, ac_deadread, ac_deadwrite, ac_jitter, ac_try };
|
enum actor_testcase {
|
||||||
|
ac_none,
|
||||||
|
ac_hill,
|
||||||
|
ac_deadread,
|
||||||
|
ac_deadwrite,
|
||||||
|
ac_jitter,
|
||||||
|
ac_try
|
||||||
|
};
|
||||||
|
|
||||||
enum actor_status {
|
enum actor_status {
|
||||||
as_unknown,
|
as_unknown,
|
||||||
|
@ -178,17 +178,18 @@ void testcase::db_close() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void testcase::txn_begin(unsigned flags) {
|
void testcase::txn_begin(unsigned flags) {
|
||||||
log_trace(">> txn_begin(%s)", flags & MDBX_RDONLY ? "read-only" : "read-write");
|
log_trace(">> txn_begin(%s)",
|
||||||
|
flags & MDBX_RDONLY ? "read-only" : "read-write");
|
||||||
assert(!txn_guard);
|
assert(!txn_guard);
|
||||||
|
|
||||||
MDBX_txn *txn = nullptr;
|
MDBX_txn *txn = nullptr;
|
||||||
int rc =
|
int rc = mdbx_txn_begin(db_guard.get(), nullptr, flags, &txn);
|
||||||
mdbx_txn_begin(db_guard.get(), nullptr, flags, &txn);
|
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
failure_perror("mdbx_txn_begin()", rc);
|
failure_perror("mdbx_txn_begin()", rc);
|
||||||
txn_guard.reset(txn);
|
txn_guard.reset(txn);
|
||||||
|
|
||||||
log_trace("<< txn_begin(%s)", flags & MDBX_RDONLY ? "read-only" : "read-write");
|
log_trace("<< txn_begin(%s)",
|
||||||
|
flags & MDBX_RDONLY ? "read-only" : "read-write");
|
||||||
}
|
}
|
||||||
|
|
||||||
void testcase::txn_end(bool abort) {
|
void testcase::txn_end(bool abort) {
|
||||||
|
@ -15,8 +15,7 @@ bool testcase_try::run() {
|
|||||||
|
|
||||||
MDBX_txn *txn = nullptr;
|
MDBX_txn *txn = nullptr;
|
||||||
MDBX_txn *txn2 = nullptr;
|
MDBX_txn *txn2 = nullptr;
|
||||||
int rc =
|
int rc = mdbx_txn_begin(db_guard.get(), nullptr, 0, &txn);
|
||||||
mdbx_txn_begin(db_guard.get(), nullptr, 0, &txn);
|
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
failure_perror("mdbx_txn_begin(MDBX_TRYTXN)", rc);
|
failure_perror("mdbx_txn_begin(MDBX_TRYTXN)", rc);
|
||||||
else {
|
else {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user