mirror of
https://github.com/isar/libmdbx.git
synced 2025-02-03 04:40:51 +08:00
mdbx: simplify find-oldest inside mdbx_page_alloc().
Change-Id: I88dfc8ee268eba2452bffd3c4e6cfd066bcd8b04
This commit is contained in:
parent
760f7d1331
commit
ae71c2aa36
23
src/mdbx.c
23
src/mdbx.c
@ -1558,7 +1558,6 @@ static int mdbx_page_alloc(MDBX_cursor *mc, unsigned num, MDBX_page **mp,
|
||||
txnid_t oldest = 0, last = 0;
|
||||
MDBX_cursor_op op;
|
||||
MDBX_cursor m2;
|
||||
int found_oldest = 0;
|
||||
|
||||
if (likely(flags & MDBX_ALLOC_GC)) {
|
||||
flags |= env->me_flags & (MDBX_COALESCE | MDBX_LIFORECLAIM);
|
||||
@ -1614,13 +1613,10 @@ static int mdbx_page_alloc(MDBX_cursor *mc, unsigned num, MDBX_page **mp,
|
||||
if (unlikely(!(flags & MDBX_ALLOC_GC)))
|
||||
break;
|
||||
|
||||
oldest = env->me_pgoldest;
|
||||
oldest = (flags & MDBX_LIFORECLAIM) ? mdbx_find_oldest(txn, NULL)
|
||||
: env->me_pgoldest;
|
||||
mdbx_cursor_init(&m2, txn, FREE_DBI, NULL);
|
||||
if (flags & MDBX_LIFORECLAIM) {
|
||||
if (!found_oldest) {
|
||||
oldest = mdbx_find_oldest(txn, NULL);
|
||||
found_oldest = 1;
|
||||
}
|
||||
/* Begin from oldest reader if any */
|
||||
if (oldest > 2) {
|
||||
last = oldest - 1;
|
||||
@ -1639,10 +1635,6 @@ static int mdbx_page_alloc(MDBX_cursor *mc, unsigned num, MDBX_page **mp,
|
||||
if (!(flags & MDBX_LIFORECLAIM)) {
|
||||
/* Do not fetch more if the record will be too recent */
|
||||
if (op != MDBX_FIRST && ++last >= oldest) {
|
||||
if (!found_oldest) {
|
||||
oldest = mdbx_find_oldest(txn, NULL);
|
||||
found_oldest = 1;
|
||||
}
|
||||
if (oldest <= last)
|
||||
break;
|
||||
}
|
||||
@ -1652,7 +1644,6 @@ static int mdbx_page_alloc(MDBX_cursor *mc, unsigned num, MDBX_page **mp,
|
||||
if (rc == MDBX_NOTFOUND && (flags & MDBX_LIFORECLAIM)) {
|
||||
if (op == MDBX_SET_RANGE)
|
||||
continue;
|
||||
found_oldest = 1;
|
||||
if (oldest < mdbx_find_oldest(txn, NULL)) {
|
||||
oldest = env->me_pgoldest;
|
||||
last = oldest - 1;
|
||||
@ -1670,10 +1661,7 @@ static int mdbx_page_alloc(MDBX_cursor *mc, unsigned num, MDBX_page **mp,
|
||||
|
||||
last = *(txnid_t *)key.iov_base;
|
||||
if (oldest <= last) {
|
||||
if (!found_oldest) {
|
||||
oldest = mdbx_find_oldest(txn, NULL);
|
||||
found_oldest = 1;
|
||||
}
|
||||
if (oldest <= last) {
|
||||
if (flags & MDBX_LIFORECLAIM)
|
||||
continue;
|
||||
@ -1804,20 +1792,17 @@ static int mdbx_page_alloc(MDBX_cursor *mc, unsigned num, MDBX_page **mp,
|
||||
MDBX_meta meta = *head;
|
||||
if (mdbx_sync_locked(env, me_flags, &meta) == MDBX_SUCCESS) {
|
||||
txnid_t snap = mdbx_find_oldest(txn, NULL);
|
||||
if (snap > oldest) {
|
||||
if (snap > oldest)
|
||||
continue;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (rc == MDBX_MAP_FULL) {
|
||||
txnid_t snap = mdbx_oomkick(env, oldest);
|
||||
if (snap > oldest) {
|
||||
oldest = snap;
|
||||
if (snap > oldest)
|
||||
continue;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fail:
|
||||
if (mp) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user