mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-16 00:54:30 +08:00
mdbx: чистка исходников pnl/dpl/txl.
This commit is contained in:
parent
225fb79eb2
commit
bc56a613ab
@ -129,7 +129,7 @@ __hot __noinline dpl_t *dpl_sort_slowpath(const MDBX_txn *txn) {
|
|||||||
#define DP_SEARCH_CMP(dp, id) ((dp).pgno < (id))
|
#define DP_SEARCH_CMP(dp, id) ((dp).pgno < (id))
|
||||||
SEARCH_IMPL(dp_bsearch, dp_t, pgno_t, DP_SEARCH_CMP)
|
SEARCH_IMPL(dp_bsearch, dp_t, pgno_t, DP_SEARCH_CMP)
|
||||||
|
|
||||||
__hot __noinline MDBX_INTERNAL size_t dpl_search(const MDBX_txn *txn, pgno_t pgno) {
|
__hot __noinline size_t dpl_search(const MDBX_txn *txn, pgno_t pgno) {
|
||||||
tASSERT(txn, (txn->flags & MDBX_TXN_RDONLY) == 0);
|
tASSERT(txn, (txn->flags & MDBX_TXN_RDONLY) == 0);
|
||||||
tASSERT(txn, (txn->flags & MDBX_WRITEMAP) == 0 || MDBX_AVOID_MSYNC);
|
tASSERT(txn, (txn->flags & MDBX_WRITEMAP) == 0 || MDBX_AVOID_MSYNC);
|
||||||
|
|
||||||
|
22
src/pnl.c
22
src/pnl.c
@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
#include "internals.h"
|
#include "internals.h"
|
||||||
|
|
||||||
MDBX_INTERNAL pnl_t pnl_alloc(size_t size) {
|
pnl_t pnl_alloc(size_t size) {
|
||||||
size_t bytes = pnl_size2bytes(size);
|
size_t bytes = pnl_size2bytes(size);
|
||||||
pnl_t pnl = osal_malloc(bytes);
|
pnl_t pnl = osal_malloc(bytes);
|
||||||
if (likely(pnl)) {
|
if (likely(pnl)) {
|
||||||
@ -18,12 +18,12 @@ MDBX_INTERNAL pnl_t pnl_alloc(size_t size) {
|
|||||||
return pnl;
|
return pnl;
|
||||||
}
|
}
|
||||||
|
|
||||||
MDBX_INTERNAL void pnl_free(pnl_t pnl) {
|
void pnl_free(pnl_t pnl) {
|
||||||
if (likely(pnl))
|
if (likely(pnl))
|
||||||
osal_free(pnl - 1);
|
osal_free(pnl - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
MDBX_INTERNAL void pnl_shrink(pnl_t __restrict *__restrict ppnl) {
|
void pnl_shrink(pnl_t __restrict *__restrict ppnl) {
|
||||||
assert(pnl_bytes2size(pnl_size2bytes(MDBX_PNL_INITIAL)) >= MDBX_PNL_INITIAL &&
|
assert(pnl_bytes2size(pnl_size2bytes(MDBX_PNL_INITIAL)) >= MDBX_PNL_INITIAL &&
|
||||||
pnl_bytes2size(pnl_size2bytes(MDBX_PNL_INITIAL)) < MDBX_PNL_INITIAL * 3 / 2);
|
pnl_bytes2size(pnl_size2bytes(MDBX_PNL_INITIAL)) < MDBX_PNL_INITIAL * 3 / 2);
|
||||||
assert(MDBX_PNL_GETSIZE(*ppnl) <= PAGELIST_LIMIT && MDBX_PNL_ALLOCLEN(*ppnl) >= MDBX_PNL_GETSIZE(*ppnl));
|
assert(MDBX_PNL_GETSIZE(*ppnl) <= PAGELIST_LIMIT && MDBX_PNL_ALLOCLEN(*ppnl) >= MDBX_PNL_GETSIZE(*ppnl));
|
||||||
@ -42,7 +42,7 @@ MDBX_INTERNAL void pnl_shrink(pnl_t __restrict *__restrict ppnl) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
MDBX_INTERNAL int pnl_reserve(pnl_t __restrict *__restrict ppnl, const size_t wanna) {
|
int pnl_reserve(pnl_t __restrict *__restrict ppnl, const size_t wanna) {
|
||||||
const size_t allocated = MDBX_PNL_ALLOCLEN(*ppnl);
|
const size_t allocated = MDBX_PNL_ALLOCLEN(*ppnl);
|
||||||
assert(MDBX_PNL_GETSIZE(*ppnl) <= PAGELIST_LIMIT && MDBX_PNL_ALLOCLEN(*ppnl) >= MDBX_PNL_GETSIZE(*ppnl));
|
assert(MDBX_PNL_GETSIZE(*ppnl) <= PAGELIST_LIMIT && MDBX_PNL_ALLOCLEN(*ppnl) >= MDBX_PNL_GETSIZE(*ppnl));
|
||||||
if (likely(allocated >= wanna))
|
if (likely(allocated >= wanna))
|
||||||
@ -99,15 +99,15 @@ static __always_inline int __must_check_result pnl_append_stepped(unsigned step,
|
|||||||
return MDBX_SUCCESS;
|
return MDBX_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
__hot MDBX_INTERNAL int __must_check_result spill_append_span(__restrict pnl_t *ppnl, pgno_t pgno, size_t n) {
|
__hot int __must_check_result spill_append_span(__restrict pnl_t *ppnl, pgno_t pgno, size_t n) {
|
||||||
return pnl_append_stepped(2, ppnl, pgno << 1, n);
|
return pnl_append_stepped(2, ppnl, pgno << 1, n);
|
||||||
}
|
}
|
||||||
|
|
||||||
__hot MDBX_INTERNAL int __must_check_result pnl_append_span(__restrict pnl_t *ppnl, pgno_t pgno, size_t n) {
|
__hot int __must_check_result pnl_append_span(__restrict pnl_t *ppnl, pgno_t pgno, size_t n) {
|
||||||
return pnl_append_stepped(1, ppnl, pgno, n);
|
return pnl_append_stepped(1, ppnl, pgno, n);
|
||||||
}
|
}
|
||||||
|
|
||||||
__hot MDBX_INTERNAL int __must_check_result pnl_insert_span(__restrict pnl_t *ppnl, pgno_t pgno, size_t n) {
|
__hot int __must_check_result pnl_insert_span(__restrict pnl_t *ppnl, pgno_t pgno, size_t n) {
|
||||||
assert(n > 0);
|
assert(n > 0);
|
||||||
int rc = pnl_need(ppnl, n);
|
int rc = pnl_need(ppnl, n);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
@ -125,7 +125,7 @@ __hot MDBX_INTERNAL int __must_check_result pnl_insert_span(__restrict pnl_t *pp
|
|||||||
return MDBX_SUCCESS;
|
return MDBX_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
__hot __noinline MDBX_INTERNAL bool pnl_check(const const_pnl_t pnl, const size_t limit) {
|
__hot __noinline bool pnl_check(const const_pnl_t pnl, const size_t limit) {
|
||||||
assert(limit >= MIN_PAGENO - MDBX_ENABLE_REFUND);
|
assert(limit >= MIN_PAGENO - MDBX_ENABLE_REFUND);
|
||||||
if (likely(MDBX_PNL_GETSIZE(pnl))) {
|
if (likely(MDBX_PNL_GETSIZE(pnl))) {
|
||||||
if (unlikely(MDBX_PNL_GETSIZE(pnl) > PAGELIST_LIMIT))
|
if (unlikely(MDBX_PNL_GETSIZE(pnl) > PAGELIST_LIMIT))
|
||||||
@ -179,7 +179,7 @@ static __always_inline void pnl_merge_inner(pgno_t *__restrict dst, const pgno_t
|
|||||||
} while (likely(src_b > src_b_detent));
|
} while (likely(src_b > src_b_detent));
|
||||||
}
|
}
|
||||||
|
|
||||||
__hot MDBX_INTERNAL size_t pnl_merge(pnl_t dst, const pnl_t src) {
|
__hot size_t pnl_merge(pnl_t dst, const pnl_t src) {
|
||||||
assert(pnl_check_allocated(dst, MAX_PAGENO + 1));
|
assert(pnl_check_allocated(dst, MAX_PAGENO + 1));
|
||||||
assert(pnl_check(src, MAX_PAGENO + 1));
|
assert(pnl_check(src, MAX_PAGENO + 1));
|
||||||
const size_t src_len = MDBX_PNL_GETSIZE(src);
|
const size_t src_len = MDBX_PNL_GETSIZE(src);
|
||||||
@ -215,7 +215,7 @@ RADIXSORT_IMPL(pgno, pgno_t, MDBX_PNL_EXTRACT_KEY, MDBX_PNL_PREALLOC_FOR_RADIXSO
|
|||||||
|
|
||||||
SORT_IMPL(pgno_sort, false, pgno_t, MDBX_PNL_ORDERED)
|
SORT_IMPL(pgno_sort, false, pgno_t, MDBX_PNL_ORDERED)
|
||||||
|
|
||||||
__hot __noinline MDBX_INTERNAL void pnl_sort_nochk(pnl_t pnl) {
|
__hot __noinline void pnl_sort_nochk(pnl_t pnl) {
|
||||||
if (likely(MDBX_PNL_GETSIZE(pnl) < MDBX_RADIXSORT_THRESHOLD) ||
|
if (likely(MDBX_PNL_GETSIZE(pnl) < MDBX_RADIXSORT_THRESHOLD) ||
|
||||||
unlikely(!pgno_radixsort(&MDBX_PNL_FIRST(pnl), MDBX_PNL_GETSIZE(pnl))))
|
unlikely(!pgno_radixsort(&MDBX_PNL_FIRST(pnl), MDBX_PNL_GETSIZE(pnl))))
|
||||||
pgno_sort(MDBX_PNL_BEGIN(pnl), MDBX_PNL_END(pnl));
|
pgno_sort(MDBX_PNL_BEGIN(pnl), MDBX_PNL_END(pnl));
|
||||||
@ -223,7 +223,7 @@ __hot __noinline MDBX_INTERNAL void pnl_sort_nochk(pnl_t pnl) {
|
|||||||
|
|
||||||
SEARCH_IMPL(pgno_bsearch, pgno_t, pgno_t, MDBX_PNL_ORDERED)
|
SEARCH_IMPL(pgno_bsearch, pgno_t, pgno_t, MDBX_PNL_ORDERED)
|
||||||
|
|
||||||
__hot __noinline MDBX_INTERNAL size_t pnl_search_nochk(const pnl_t pnl, pgno_t pgno) {
|
__hot __noinline size_t pnl_search_nochk(const pnl_t pnl, pgno_t pgno) {
|
||||||
const pgno_t *begin = MDBX_PNL_BEGIN(pnl);
|
const pgno_t *begin = MDBX_PNL_BEGIN(pnl);
|
||||||
const pgno_t *it = pgno_bsearch(begin, MDBX_PNL_GETSIZE(pnl), pgno);
|
const pgno_t *it = pgno_bsearch(begin, MDBX_PNL_GETSIZE(pnl), pgno);
|
||||||
const pgno_t *end = begin + MDBX_PNL_GETSIZE(pnl);
|
const pgno_t *end = begin + MDBX_PNL_GETSIZE(pnl);
|
||||||
|
10
src/txl.c
10
src/txl.c
@ -17,7 +17,7 @@ static inline size_t txl_bytes2size(const size_t bytes) {
|
|||||||
return size - 2;
|
return size - 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
MDBX_INTERNAL txl_t txl_alloc(void) {
|
txl_t txl_alloc(void) {
|
||||||
size_t bytes = txl_size2bytes(txl_initial);
|
size_t bytes = txl_size2bytes(txl_initial);
|
||||||
txl_t txl = osal_malloc(bytes);
|
txl_t txl = osal_malloc(bytes);
|
||||||
if (likely(txl)) {
|
if (likely(txl)) {
|
||||||
@ -32,12 +32,12 @@ MDBX_INTERNAL txl_t txl_alloc(void) {
|
|||||||
return txl;
|
return txl;
|
||||||
}
|
}
|
||||||
|
|
||||||
MDBX_INTERNAL void txl_free(txl_t txl) {
|
void txl_free(txl_t txl) {
|
||||||
if (likely(txl))
|
if (likely(txl))
|
||||||
osal_free(txl - 1);
|
osal_free(txl - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
MDBX_INTERNAL int txl_reserve(txl_t __restrict *__restrict ptxl, const size_t wanna) {
|
int txl_reserve(txl_t __restrict *__restrict ptxl, const size_t wanna) {
|
||||||
const size_t allocated = (size_t)MDBX_PNL_ALLOCLEN(*ptxl);
|
const size_t allocated = (size_t)MDBX_PNL_ALLOCLEN(*ptxl);
|
||||||
assert(MDBX_PNL_GETSIZE(*ptxl) <= txl_max && MDBX_PNL_ALLOCLEN(*ptxl) >= MDBX_PNL_GETSIZE(*ptxl));
|
assert(MDBX_PNL_GETSIZE(*ptxl) <= txl_max && MDBX_PNL_ALLOCLEN(*ptxl) >= MDBX_PNL_GETSIZE(*ptxl));
|
||||||
if (likely(allocated >= wanna))
|
if (likely(allocated >= wanna))
|
||||||
@ -78,9 +78,9 @@ static __always_inline void txl_xappend(txl_t __restrict txl, txnid_t id) {
|
|||||||
|
|
||||||
#define TXNID_SORT_CMP(first, last) ((first) > (last))
|
#define TXNID_SORT_CMP(first, last) ((first) > (last))
|
||||||
SORT_IMPL(txnid_sort, false, txnid_t, TXNID_SORT_CMP)
|
SORT_IMPL(txnid_sort, false, txnid_t, TXNID_SORT_CMP)
|
||||||
MDBX_INTERNAL void txl_sort(txl_t txl) { txnid_sort(MDBX_PNL_BEGIN(txl), MDBX_PNL_END(txl)); }
|
void txl_sort(txl_t txl) { txnid_sort(MDBX_PNL_BEGIN(txl), MDBX_PNL_END(txl)); }
|
||||||
|
|
||||||
MDBX_INTERNAL int __must_check_result txl_append(txl_t __restrict *ptxl, txnid_t id) {
|
int __must_check_result txl_append(txl_t __restrict *ptxl, txnid_t id) {
|
||||||
if (unlikely(MDBX_PNL_GETSIZE(*ptxl) == MDBX_PNL_ALLOCLEN(*ptxl))) {
|
if (unlikely(MDBX_PNL_GETSIZE(*ptxl) == MDBX_PNL_ALLOCLEN(*ptxl))) {
|
||||||
int rc = txl_need(ptxl, txl_granulate);
|
int rc = txl_need(ptxl, txl_granulate);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user