mirror of
https://gitflic.ru/project/erthink/libmdbx.git
synced 2025-01-27 10:29:26 +00:00
mdbx: use MAX_TXN internally (cosmetics).
Change-Id: Ic8171dbfa8bb32272e46e939223316f6182d3a7a
This commit is contained in:
parent
463a8af35b
commit
8f31aad0fb
18
src/core.c
18
src/core.c
@ -5075,7 +5075,7 @@ skip_cache:
|
||||
goto fail;
|
||||
}
|
||||
last = unaligned_peek_u64(4, key.iov_base);
|
||||
if (unlikely(last < 1 || last >= SAFE64_INVALID_THRESHOLD)) {
|
||||
if (unlikely(last < MIN_TXNID || last > MAX_TXNID)) {
|
||||
rc = MDBX_CORRUPTED;
|
||||
goto fail;
|
||||
}
|
||||
@ -5792,7 +5792,7 @@ static pgno_t mdbx_find_largest_this(MDBX_env *env, pgno_t largest) {
|
||||
goto retry;
|
||||
if (largest < snap_pages &&
|
||||
lck->mti_oldest_reader <= /* ignore pending updates */ snap_txnid &&
|
||||
snap_txnid < SAFE64_INVALID_THRESHOLD)
|
||||
snap_txnid <= MAX_TXNID)
|
||||
largest = snap_pages;
|
||||
}
|
||||
}
|
||||
@ -5999,8 +5999,7 @@ static int mdbx_txn_renew0(MDBX_txn *txn, unsigned flags) {
|
||||
}
|
||||
}
|
||||
|
||||
if (unlikely(txn->mt_txnid == 0 ||
|
||||
txn->mt_txnid >= SAFE64_INVALID_THRESHOLD)) {
|
||||
if (unlikely(txn->mt_txnid < MIN_TXNID || txn->mt_txnid > MAX_TXNID)) {
|
||||
mdbx_error("%s", "environment corrupted by died writer, must shutdown!");
|
||||
rc = MDBX_CORRUPTED;
|
||||
goto bailout;
|
||||
@ -6022,7 +6021,7 @@ static int mdbx_txn_renew0(MDBX_txn *txn, unsigned flags) {
|
||||
if (lck->mti_readers[i].mr_pid == env->me_pid &&
|
||||
unlikely(lck->mti_readers[i].mr_tid == tid)) {
|
||||
const txnid_t txnid = safe64_read(&lck->mti_readers[i].mr_txnid);
|
||||
if (txnid >= MIN_TXNID && txnid < SAFE64_INVALID_THRESHOLD)
|
||||
if (txnid >= MIN_TXNID && txnid <= MAX_TXNID)
|
||||
return MDBX_TXN_OVERLAPPING;
|
||||
}
|
||||
}
|
||||
@ -6050,7 +6049,7 @@ static int mdbx_txn_renew0(MDBX_txn *txn, unsigned flags) {
|
||||
txn->mt_canary = meta->mm_canary;
|
||||
const txnid_t snap = mdbx_meta_txnid_stable(env, meta);
|
||||
txn->mt_txnid = safe64_txnid_next(snap);
|
||||
if (unlikely(txn->mt_txnid >= SAFE64_INVALID_THRESHOLD)) {
|
||||
if (unlikely(txn->mt_txnid > MAX_TXNID)) {
|
||||
mdbx_debug("%s", "txnid overflow!");
|
||||
rc = MDBX_TXN_FULL;
|
||||
goto bailout;
|
||||
@ -6992,8 +6991,7 @@ retry:
|
||||
goto bailout;
|
||||
}
|
||||
cleaned_gc_id = unaligned_peek_u64(4, key.iov_base);
|
||||
if (unlikely(cleaned_gc_id < 1 ||
|
||||
cleaned_gc_id >= SAFE64_INVALID_THRESHOLD)) {
|
||||
if (unlikely(cleaned_gc_id < MIN_TXNID || cleaned_gc_id > MAX_TXNID)) {
|
||||
rc = MDBX_CORRUPTED;
|
||||
goto bailout;
|
||||
}
|
||||
@ -7242,7 +7240,7 @@ retry:
|
||||
break;
|
||||
}
|
||||
|
||||
mdbx_tassert(txn, gc_rid > 1 && gc_rid < SAFE64_INVALID_THRESHOLD);
|
||||
mdbx_tassert(txn, gc_rid >= MIN_TXNID && gc_rid <= MAX_TXNID);
|
||||
rc = mdbx_txl_append(&txn->tw.lifo_reclaimed, --gc_rid);
|
||||
if (unlikely(rc != MDBX_SUCCESS))
|
||||
goto bailout;
|
||||
@ -7285,7 +7283,7 @@ retry:
|
||||
goto bailout;
|
||||
}
|
||||
txnid_t gc_first = unaligned_peek_u64(4, key.iov_base);
|
||||
if (unlikely(gc_first < 1 || gc_first >= SAFE64_INVALID_THRESHOLD)) {
|
||||
if (unlikely(gc_first < MIN_TXNID || gc_first > MAX_TXNID)) {
|
||||
rc = MDBX_CORRUPTED;
|
||||
goto bailout;
|
||||
}
|
||||
|
@ -207,10 +207,13 @@ typedef uint32_t pgno_t;
|
||||
#define MAX_PAGENO UINT32_C(0x7FFFffff)
|
||||
#define MIN_PAGENO NUM_METAS
|
||||
|
||||
#define SAFE64_INVALID_THRESHOLD UINT64_C(0xffffFFFF00000000)
|
||||
|
||||
/* A transaction ID. */
|
||||
typedef uint64_t txnid_t;
|
||||
#define PRIaTXN PRIi64
|
||||
#define MIN_TXNID UINT64_C(1)
|
||||
#define MAX_TXNID (SAFE64_INVALID_THRESHOLD - 1)
|
||||
#define INVALID_TXNID UINT64_MAX
|
||||
/* LY: for testing non-atomic 64-bit txnid on 32-bit arches.
|
||||
* #define MDBX_TXNID_STEP (UINT32_MAX / 3) */
|
||||
@ -251,8 +254,6 @@ typedef union mdbx_safe64 {
|
||||
};
|
||||
} mdbx_safe64_t;
|
||||
|
||||
#define SAFE64_INVALID_THRESHOLD UINT64_C(0xffffFFFF00000000)
|
||||
|
||||
/* Information about a single database in the environment. */
|
||||
typedef struct MDBX_db {
|
||||
uint16_t md_flags; /* see mdbx_dbi_open */
|
||||
|
Loading…
Reference in New Issue
Block a user