mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-08 04:34:12 +08:00
mdbx: refine freelist_save() to simplify loose-pages handling (preparation for pages refunding).
Change-Id: I1f15487383fbfb6770e1f7128a2d8349a1cfdf25
This commit is contained in:
parent
7ed97d50b1
commit
592c064873
46
src/mdbx.c
46
src/mdbx.c
@ -2953,16 +2953,36 @@ again_on_freelist_change:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (unlikely(!env->me_reclaimed_pglist) && txn->mt_loose_pages &&
|
if (txn->mt_loose_pages) {
|
||||||
|
/* Return loose page numbers to me_reclaimed_pglist,
|
||||||
|
* though usually none are left at this point.
|
||||||
|
* The pages themselves remain in dirtylist. */
|
||||||
|
if (unlikely(!env->me_reclaimed_pglist) &&
|
||||||
!(lifo && env->me_last_reclaimed > 1)) {
|
!(lifo && env->me_last_reclaimed > 1)) {
|
||||||
/* Put loose page numbers in mt_free_pages, since
|
/* Put loose page numbers in mt_free_pages,
|
||||||
* we may be unable to return them to me_reclaimed_pglist. */
|
* since unable to return them to me_reclaimed_pglist. */
|
||||||
MDBX_page *mp = txn->mt_loose_pages;
|
MDBX_page *mp = txn->mt_loose_pages;
|
||||||
if (unlikely((rc = mdbx_midl_need(&txn->mt_befree_pages,
|
if (unlikely((rc = mdbx_midl_need(&txn->mt_befree_pages,
|
||||||
txn->mt_loose_count)) != 0))
|
txn->mt_loose_count)) != 0))
|
||||||
return rc;
|
return rc;
|
||||||
for (; mp; mp = NEXT_LOOSE_PAGE(mp))
|
for (; mp; mp = NEXT_LOOSE_PAGE(mp))
|
||||||
mdbx_midl_xappend(txn->mt_befree_pages, mp->mp_pgno);
|
mdbx_midl_xappend(txn->mt_befree_pages, mp->mp_pgno);
|
||||||
|
} else {
|
||||||
|
/* Room for loose pages + temp IDL with same */
|
||||||
|
if ((rc = mdbx_midl_need(&env->me_reclaimed_pglist,
|
||||||
|
2 * txn->mt_loose_count + 1)) != 0)
|
||||||
|
goto bailout;
|
||||||
|
MDBX_IDL loose = env->me_reclaimed_pglist +
|
||||||
|
MDBX_IDL_ALLOCLEN(env->me_reclaimed_pglist) -
|
||||||
|
txn->mt_loose_count;
|
||||||
|
unsigned count = 0;
|
||||||
|
for (MDBX_page *mp = txn->mt_loose_pages; mp; mp = NEXT_LOOSE_PAGE(mp))
|
||||||
|
loose[++count] = mp->mp_pgno;
|
||||||
|
loose[0] = count;
|
||||||
|
mdbx_midl_sort(loose);
|
||||||
|
mdbx_midl_xmerge(env->me_reclaimed_pglist, loose);
|
||||||
|
}
|
||||||
|
|
||||||
txn->mt_loose_pages = NULL;
|
txn->mt_loose_pages = NULL;
|
||||||
txn->mt_loose_count = 0;
|
txn->mt_loose_count = 0;
|
||||||
}
|
}
|
||||||
@ -3098,26 +3118,6 @@ again_on_freelist_change:
|
|||||||
cleanup_reclaimed_pos ==
|
cleanup_reclaimed_pos ==
|
||||||
(txn->mt_lifo_reclaimed ? txn->mt_lifo_reclaimed[0] : 0));
|
(txn->mt_lifo_reclaimed ? txn->mt_lifo_reclaimed[0] : 0));
|
||||||
|
|
||||||
/* Return loose page numbers to me_reclaimed_pglist, though usually none are
|
|
||||||
* left at this point. The pages themselves remain in dirtylist. */
|
|
||||||
if (txn->mt_loose_pages) {
|
|
||||||
/* Room for loose pages + temp IDL with same */
|
|
||||||
if ((rc = mdbx_midl_need(&env->me_reclaimed_pglist,
|
|
||||||
2 * txn->mt_loose_count + 1)) != 0)
|
|
||||||
goto bailout;
|
|
||||||
MDBX_IDL loose = env->me_reclaimed_pglist +
|
|
||||||
MDBX_IDL_ALLOCLEN(env->me_reclaimed_pglist) -
|
|
||||||
txn->mt_loose_count;
|
|
||||||
unsigned count = 0;
|
|
||||||
for (MDBX_page *mp = txn->mt_loose_pages; mp; mp = NEXT_LOOSE_PAGE(mp))
|
|
||||||
loose[++count] = mp->mp_pgno;
|
|
||||||
loose[0] = count;
|
|
||||||
mdbx_midl_sort(loose);
|
|
||||||
mdbx_midl_xmerge(env->me_reclaimed_pglist, loose);
|
|
||||||
txn->mt_loose_pages = NULL;
|
|
||||||
txn->mt_loose_count = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Fill in the reserved me_reclaimed_pglist records */
|
/* Fill in the reserved me_reclaimed_pglist records */
|
||||||
rc = MDBX_SUCCESS;
|
rc = MDBX_SUCCESS;
|
||||||
if (env->me_reclaimed_pglist && env->me_reclaimed_pglist[0]) {
|
if (env->me_reclaimed_pglist && env->me_reclaimed_pglist[0]) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user