mdbx: refine PN-lists.

Change-Id: Ib5ffafe634993b6f3b0fb7e35cc49f7d9b8c95a5
This commit is contained in:
Leonid Yuriev 2018-08-17 16:17:51 +03:00
parent cb081424ff
commit 0f63ab0385

View File

@ -682,8 +682,8 @@ static void mdbx_pnl_shrink(MDBX_PNL *ppl) {
/* shrink to MDBX_PNL_UM_MAX */ /* shrink to MDBX_PNL_UM_MAX */
pl = realloc(pl, (MDBX_PNL_UM_MAX + 2) * sizeof(pgno_t)); pl = realloc(pl, (MDBX_PNL_UM_MAX + 2) * sizeof(pgno_t));
if (likely(pl)) { if (likely(pl)) {
*pl++ = MDBX_PNL_UM_MAX; *pl = MDBX_PNL_UM_MAX;
*ppl = pl; *ppl = pl + 1;
} }
} }
} }
@ -707,36 +707,25 @@ static int __must_check_result mdbx_pnl_grow(MDBX_PNL *ppl, size_t num) {
return MDBX_SUCCESS; return MDBX_SUCCESS;
} }
static int __must_check_result mdbx_txl_grow(MDBX_TXL *ptr, size_t num) {
MDBX_TXL list = *ptr - 1;
/* grow it */
list = realloc(list, ((size_t)*list + num + 2) * sizeof(txnid_t));
if (unlikely(!list))
return MDBX_ENOMEM;
*list++ += num;
*ptr = list;
return MDBX_SUCCESS;
}
/* Make room for num additional elements in an PNL. /* Make room for num additional elements in an PNL.
* [in,out] ppl Address of the PNL. * [in,out] ppl Address of the PNL.
* [in] num Number of elements to make room for. * [in] num Number of elements to make room for.
* Returns 0 on success, MDBX_ENOMEM on failure. */ * Returns 0 on success, MDBX_ENOMEM on failure. */
static int __must_check_result mdbx_pnl_need(MDBX_PNL *ppl, size_t num) { static int __must_check_result mdbx_pnl_need(MDBX_PNL *ppl, size_t num) {
MDBX_PNL pl = *ppl; MDBX_PNL pl = *ppl - 1;
assert(pl[0] <= MDBX_PNL_MAX && pl[0] <= pl[-1]); assert(pl[1] <= MDBX_PNL_MAX && pl[1] <= pl[0]);
assert(num <= MDBX_PNL_MAX); assert(num <= MDBX_PNL_MAX);
num += pl[0]; num += pl[1];
if (unlikely(num > pl[-1])) { if (unlikely(num > pl[0])) {
if (unlikely(num > MDBX_PNL_MAX)) if (unlikely(num > MDBX_PNL_MAX))
return MDBX_TXN_FULL; return MDBX_TXN_FULL;
num = (num + num / 4 + (256 + 2)) & ~255u; num = (num + num / 4 + (256 + 2)) & ~255u;
num = (num < MDBX_PNL_MAX + 2) ? num : MDBX_PNL_MAX + 2; num = (num < MDBX_PNL_MAX + 2) ? num : MDBX_PNL_MAX + 2;
pl = realloc(pl - 1, num * sizeof(pgno_t)); pl = realloc(pl, num * sizeof(pgno_t));
if (unlikely(!pl)) if (unlikely(!pl))
return MDBX_ENOMEM; return MDBX_ENOMEM;
*pl++ = (pgno_t)num - 2; *pl = (pgno_t)num - 2;
*ppl = pl; *ppl = pl + 1;
} }
return MDBX_SUCCESS; return MDBX_SUCCESS;
} }
@ -759,20 +748,6 @@ static int __must_check_result mdbx_pnl_append(MDBX_PNL *ppl, pgno_t id) {
return MDBX_SUCCESS; return MDBX_SUCCESS;
} }
static int __must_check_result mdbx_txl_append(MDBX_TXL *ptr, txnid_t id) {
MDBX_TXL list = *ptr;
/* Too big? */
if (unlikely(list[0] >= list[-1])) {
int rc = mdbx_txl_grow(ptr, (size_t)list[0]);
if (unlikely(rc != MDBX_SUCCESS))
return rc;
list = *ptr;
}
list[0]++;
list[list[0]] = id;
return MDBX_SUCCESS;
}
/* Append an PNL onto an PNL. /* Append an PNL onto an PNL.
* [in,out] ppl Address of the PNL to append to. * [in,out] ppl Address of the PNL to append to.
* [in] app The PNL to append. * [in] app The PNL to append.
@ -792,21 +767,6 @@ static int __must_check_result mdbx_pnl_append_list(MDBX_PNL *ppl,
return MDBX_SUCCESS; return MDBX_SUCCESS;
} }
static int __must_check_result mdbx_txl_append_list(MDBX_TXL *ptr,
MDBX_TXL append) {
MDBX_TXL list = *ptr;
/* Too big? */
if (unlikely(list[0] + append[0] >= list[-1])) {
int rc = mdbx_txl_grow(ptr, (size_t)append[0]);
if (unlikely(rc != MDBX_SUCCESS))
return rc;
list = *ptr;
}
memcpy(&list[list[0] + 1], &append[1], (size_t)append[0] * sizeof(txnid_t));
list[0] += append[0];
return MDBX_SUCCESS;
}
/* Append an ID range onto an PNL. /* Append an ID range onto an PNL.
* [in,out] ppl Address of the PNL to append to. * [in,out] ppl Address of the PNL to append to.
* [in] id The lowest ID to append. * [in] id The lowest ID to append.
@ -849,6 +809,46 @@ static void __hot mdbx_pnl_xmerge(MDBX_PNL pnl, MDBX_PNL merge) {
assert(mdbx_pnl_check(pnl, true)); assert(mdbx_pnl_check(pnl, true));
} }
static int __must_check_result mdbx_txl_grow(MDBX_TXL *ptr, size_t num) {
MDBX_TXL list = *ptr - 1;
/* grow it */
list = realloc(list, ((size_t)*list + num + 2) * sizeof(txnid_t));
if (unlikely(!list))
return MDBX_ENOMEM;
*list += num;
*ptr = list + 1;
return MDBX_SUCCESS;
}
static int __must_check_result mdbx_txl_append(MDBX_TXL *ptr, txnid_t id) {
MDBX_TXL list = *ptr;
/* Too big? */
if (unlikely(list[0] >= list[-1])) {
int rc = mdbx_txl_grow(ptr, (size_t)list[0]);
if (unlikely(rc != MDBX_SUCCESS))
return rc;
list = *ptr;
}
list[0]++;
list[list[0]] = id;
return MDBX_SUCCESS;
}
static int __must_check_result mdbx_txl_append_list(MDBX_TXL *ptr,
MDBX_TXL append) {
MDBX_TXL list = *ptr;
/* Too big? */
if (unlikely(list[0] + append[0] >= list[-1])) {
int rc = mdbx_txl_grow(ptr, (size_t)append[0]);
if (unlikely(rc != MDBX_SUCCESS))
return rc;
list = *ptr;
}
memcpy(&list[list[0] + 1], &append[1], (size_t)append[0] * sizeof(txnid_t));
list[0] += append[0];
return MDBX_SUCCESS;
}
/* Search for an ID in an ID2L. /* Search for an ID in an ID2L.
* [in] pnl The ID2L to search. * [in] pnl The ID2L to search.
* [in] id The ID to search for. * [in] id The ID to search for.
@ -900,7 +900,7 @@ static int __must_check_result mdbx_mid2l_insert(MDBX_ID2L pnl, MDBX_ID2 *id) {
if (unlikely(x < 1)) if (unlikely(x < 1))
return /* internal error */ MDBX_PROBLEM; return /* internal error */ MDBX_PROBLEM;
if (x <= pnl[0].mid && pnl[x].mid == id->mid) if (unlikely(pnl[x].mid == id->mid && x <= pnl[0].mid))
return /* duplicate */ MDBX_PROBLEM; return /* duplicate */ MDBX_PROBLEM;
if (unlikely(pnl[0].mid >= MDBX_PNL_UM_MAX)) if (unlikely(pnl[0].mid >= MDBX_PNL_UM_MAX))