mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-23 01:48:21 +08:00
mdbx: backport - Pass cursor to mdb_page_get(), mdb_node_read().
No change in behavior. Change-Id: I19054cfd96fa883970a0dc66a0088596a142ea07
This commit is contained in:
parent
ca97abb7f3
commit
fe4e9993d6
100
mdb.c
100
mdb.c
@ -1092,10 +1092,10 @@ typedef struct MDB_ntxn {
|
|||||||
#define METAPAGE_2(env) \
|
#define METAPAGE_2(env) \
|
||||||
(&((MDB_metabuf*) ((env)->me_map + env->me_psize))->mb_metabuf.mm_meta)
|
(&((MDB_metabuf*) ((env)->me_map + env->me_psize))->mb_metabuf.mm_meta)
|
||||||
|
|
||||||
static int mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags);
|
static int mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags);
|
||||||
static int mdb_page_new(MDB_cursor *mc, uint32_t flags, int num, MDB_page **mp);
|
static int mdb_page_new(MDB_cursor *mc, uint32_t flags, int num, MDB_page **mp);
|
||||||
static int mdb_page_touch(MDB_cursor *mc);
|
static int mdb_page_touch(MDB_cursor *mc);
|
||||||
static int mdb_cursor_touch(MDB_cursor *mc);
|
static int mdb_cursor_touch(MDB_cursor *mc);
|
||||||
|
|
||||||
#define MDB_END_NAMES {"committed", "empty-commit", "abort", "reset", \
|
#define MDB_END_NAMES {"committed", "empty-commit", "abort", "reset", \
|
||||||
"reset-tmp", "fail-begin", "fail-beginchild"}
|
"reset-tmp", "fail-begin", "fail-beginchild"}
|
||||||
@ -1108,16 +1108,16 @@ enum {
|
|||||||
#define MDB_END_UPDATE 0x10 /**< update env state (DBIs) */
|
#define MDB_END_UPDATE 0x10 /**< update env state (DBIs) */
|
||||||
#define MDB_END_FREE 0x20 /**< free txn unless it is #MDB_env.%me_txn0 */
|
#define MDB_END_FREE 0x20 /**< free txn unless it is #MDB_env.%me_txn0 */
|
||||||
#define MDB_END_SLOT MDB_NOTLS /**< release any reader slot if #MDB_NOTLS */
|
#define MDB_END_SLOT MDB_NOTLS /**< release any reader slot if #MDB_NOTLS */
|
||||||
static int mdb_txn_end(MDB_txn *txn, unsigned mode);
|
static int mdb_txn_end(MDB_txn *txn, unsigned mode);
|
||||||
|
|
||||||
static int mdb_page_get(MDB_txn *txn, pgno_t pgno, MDB_page **mp, int *lvl);
|
static int mdb_page_get(MDB_cursor *mc, pgno_t pgno, MDB_page **mp, int *lvl);
|
||||||
static int mdb_page_search_root(MDB_cursor *mc,
|
static int mdb_page_search_root(MDB_cursor *mc,
|
||||||
MDB_val *key, int modify);
|
MDB_val *key, int modify);
|
||||||
#define MDB_PS_MODIFY 1
|
#define MDB_PS_MODIFY 1
|
||||||
#define MDB_PS_ROOTONLY 2
|
#define MDB_PS_ROOTONLY 2
|
||||||
#define MDB_PS_FIRST 4
|
#define MDB_PS_FIRST 4
|
||||||
#define MDB_PS_LAST 8
|
#define MDB_PS_LAST 8
|
||||||
static int mdb_page_search(MDB_cursor *mc,
|
static int mdb_page_search(MDB_cursor *mc,
|
||||||
MDB_val *key, int flags);
|
MDB_val *key, int flags);
|
||||||
static int mdb_page_merge(MDB_cursor *csrc, MDB_cursor *cdst);
|
static int mdb_page_merge(MDB_cursor *csrc, MDB_cursor *cdst);
|
||||||
|
|
||||||
@ -1125,17 +1125,17 @@ static int mdb_page_merge(MDB_cursor *csrc, MDB_cursor *cdst);
|
|||||||
static int mdb_page_split(MDB_cursor *mc, MDB_val *newkey, MDB_val *newdata,
|
static int mdb_page_split(MDB_cursor *mc, MDB_val *newkey, MDB_val *newdata,
|
||||||
pgno_t newpgno, unsigned nflags);
|
pgno_t newpgno, unsigned nflags);
|
||||||
|
|
||||||
static int mdb_env_read_header(MDB_env *env, MDB_meta *meta);
|
static int mdb_env_read_header(MDB_env *env, MDB_meta *meta);
|
||||||
static int mdb_env_sync0(MDB_env *env, unsigned flags, MDB_meta *pending);
|
static int mdb_env_sync0(MDB_env *env, unsigned flags, MDB_meta *pending);
|
||||||
static void mdb_env_close0(MDB_env *env);
|
static void mdb_env_close0(MDB_env *env);
|
||||||
|
|
||||||
static MDB_node *mdb_node_search(MDB_cursor *mc, MDB_val *key, int *exactp);
|
static MDB_node *mdb_node_search(MDB_cursor *mc, MDB_val *key, int *exactp);
|
||||||
static int mdb_node_add(MDB_cursor *mc, indx_t indx,
|
static int mdb_node_add(MDB_cursor *mc, indx_t indx,
|
||||||
MDB_val *key, MDB_val *data, pgno_t pgno, unsigned flags);
|
MDB_val *key, MDB_val *data, pgno_t pgno, unsigned flags);
|
||||||
static void mdb_node_del(MDB_cursor *mc, int ksize);
|
static void mdb_node_del(MDB_cursor *mc, int ksize);
|
||||||
static void mdb_node_shrink(MDB_page *mp, indx_t indx);
|
static void mdb_node_shrink(MDB_page *mp, indx_t indx);
|
||||||
static int mdb_node_move(MDB_cursor *csrc, MDB_cursor *cdst, int fromleft);
|
static int mdb_node_move(MDB_cursor *csrc, MDB_cursor *cdst, int fromleft);
|
||||||
static int mdb_node_read(MDB_txn *txn, MDB_node *leaf, MDB_val *data);
|
static int mdb_node_read(MDB_cursor *mc, MDB_node *leaf, MDB_val *data);
|
||||||
static size_t mdb_leaf_size(MDB_env *env, MDB_val *key, MDB_val *data);
|
static size_t mdb_leaf_size(MDB_env *env, MDB_val *key, MDB_val *data);
|
||||||
static size_t mdb_branch_size(MDB_env *env, MDB_val *key);
|
static size_t mdb_branch_size(MDB_env *env, MDB_val *key);
|
||||||
|
|
||||||
@ -1161,8 +1161,8 @@ static void mdb_xcursor_init1(MDB_cursor *mc, MDB_node *node);
|
|||||||
static void mdb_xcursor_init2(MDB_cursor *mc, MDB_xcursor *src_mx, int force);
|
static void mdb_xcursor_init2(MDB_cursor *mc, MDB_xcursor *src_mx, int force);
|
||||||
|
|
||||||
static int mdb_drop0(MDB_cursor *mc, int subs);
|
static int mdb_drop0(MDB_cursor *mc, int subs);
|
||||||
static void mdb_default_cmp(MDB_txn *txn, MDB_dbi dbi);
|
static void mdb_default_cmp(MDB_txn *txn, MDB_dbi dbi);
|
||||||
static int mdb_reader_check0(MDB_env *env, int rlocked, int *dead);
|
static int mdb_reader_check0(MDB_env *env, int rlocked, int *dead);
|
||||||
|
|
||||||
/** @cond */
|
/** @cond */
|
||||||
static MDB_cmp_func mdb_cmp_memn, mdb_cmp_memnr, mdb_cmp_int_ai, mdb_cmp_int_a2, mdb_cmp_int_ua;
|
static MDB_cmp_func mdb_cmp_memn, mdb_cmp_memnr, mdb_cmp_int_ai, mdb_cmp_int_a2, mdb_cmp_int_ua;
|
||||||
@ -1716,7 +1716,7 @@ mdb_pages_xkeep(MDB_cursor *mc, unsigned pflags, int all)
|
|||||||
{
|
{
|
||||||
enum { Mask = P_SUBP|P_DIRTY|P_LOOSE|P_KEEP };
|
enum { Mask = P_SUBP|P_DIRTY|P_LOOSE|P_KEEP };
|
||||||
MDB_txn *txn = mc->mc_txn;
|
MDB_txn *txn = mc->mc_txn;
|
||||||
MDB_cursor *m3;
|
MDB_cursor *m3, *m0 = mc;
|
||||||
MDB_xcursor *mx;
|
MDB_xcursor *mx;
|
||||||
MDB_page *dp, *mp;
|
MDB_page *dp, *mp;
|
||||||
MDB_node *leaf;
|
MDB_node *leaf;
|
||||||
@ -1759,7 +1759,7 @@ mdb_pages_xkeep(MDB_cursor *mc, unsigned pflags, int all)
|
|||||||
pgno_t pgno = txn->mt_dbs[i].md_root;
|
pgno_t pgno = txn->mt_dbs[i].md_root;
|
||||||
if (pgno == P_INVALID)
|
if (pgno == P_INVALID)
|
||||||
continue;
|
continue;
|
||||||
if ((rc = mdb_page_get(txn, pgno, &dp, &level)) != MDB_SUCCESS)
|
if (unlikely((rc = mdb_page_get(m0, pgno, &dp, &level)) != MDB_SUCCESS))
|
||||||
break;
|
break;
|
||||||
if ((dp->mp_flags & Mask) == pflags && level <= 1)
|
if ((dp->mp_flags & Mask) == pflags && level <= 1)
|
||||||
dp->mp_flags ^= P_KEEP;
|
dp->mp_flags ^= P_KEEP;
|
||||||
@ -2215,7 +2215,7 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp, int flags)
|
|||||||
|
|
||||||
np = m2.mc_pg[m2.mc_top];
|
np = m2.mc_pg[m2.mc_top];
|
||||||
leaf = NODEPTR(np, m2.mc_ki[m2.mc_top]);
|
leaf = NODEPTR(np, m2.mc_ki[m2.mc_top]);
|
||||||
if (unlikely((rc = mdb_node_read(txn, leaf, &data)) != MDB_SUCCESS))
|
if (unlikely((rc = mdb_node_read(&m2, leaf, &data)) != MDB_SUCCESS))
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
if ((flags & MDBX_LIFORECLAIM) && !txn->mt_lifo_reclaimed) {
|
if ((flags & MDBX_LIFORECLAIM) && !txn->mt_lifo_reclaimed) {
|
||||||
@ -5381,15 +5381,16 @@ mdb_cursor_push(MDB_cursor *mc, MDB_page *mp)
|
|||||||
|
|
||||||
/** Find the address of the page corresponding to a given page number.
|
/** Find the address of the page corresponding to a given page number.
|
||||||
* Set #MDB_TXN_ERROR on failure.
|
* Set #MDB_TXN_ERROR on failure.
|
||||||
* @param[in] txn the transaction for this access.
|
* @param[in] mc the cursor accessing the page.
|
||||||
* @param[in] pgno the page number for the page to retrieve.
|
* @param[in] pgno the page number for the page to retrieve.
|
||||||
* @param[out] ret address of a pointer where the page's address will be stored.
|
* @param[out] ret address of a pointer where the page's address will be stored.
|
||||||
* @param[out] lvl dirty_list inheritance level of found page. 1=current txn, 0=mapped page.
|
* @param[out] lvl dirty_list inheritance level of found page. 1=current txn, 0=mapped page.
|
||||||
* @return 0 on success, non-zero on failure.
|
* @return 0 on success, non-zero on failure.
|
||||||
*/
|
*/
|
||||||
static int
|
static int
|
||||||
mdb_page_get(MDB_txn *txn, pgno_t pgno, MDB_page **ret, int *lvl)
|
mdb_page_get(MDB_cursor *mc, pgno_t pgno, MDB_page **ret, int *lvl)
|
||||||
{
|
{
|
||||||
|
MDB_txn *txn = mc->mc_txn;
|
||||||
MDB_env *env = txn->mt_env;
|
MDB_env *env = txn->mt_env;
|
||||||
MDB_page *p = NULL;
|
MDB_page *p = NULL;
|
||||||
int level;
|
int level;
|
||||||
@ -5483,7 +5484,7 @@ mdb_page_search_root(MDB_cursor *mc, MDB_val *key, int flags)
|
|||||||
mdb_cassert(mc, i < NUMKEYS(mp));
|
mdb_cassert(mc, i < NUMKEYS(mp));
|
||||||
node = NODEPTR(mp, i);
|
node = NODEPTR(mp, i);
|
||||||
|
|
||||||
if (unlikely((rc = mdb_page_get(mc->mc_txn, NODEPGNO(node), &mp, NULL)) != 0))
|
if (unlikely((rc = mdb_page_get(mc, NODEPGNO(node), &mp, NULL)) != 0))
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
mc->mc_ki[mc->mc_top] = i;
|
mc->mc_ki[mc->mc_top] = i;
|
||||||
@ -5525,7 +5526,7 @@ mdb_page_search_lowest(MDB_cursor *mc)
|
|||||||
MDB_node *node = NODEPTR(mp, 0);
|
MDB_node *node = NODEPTR(mp, 0);
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
if (unlikely((rc = mdb_page_get(mc->mc_txn, NODEPGNO(node), &mp, NULL)) != 0))
|
if (unlikely((rc = mdb_page_get(mc, NODEPGNO(node), &mp, NULL)) != 0))
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
mc->mc_ki[mc->mc_top] = 0;
|
mc->mc_ki[mc->mc_top] = 0;
|
||||||
@ -5577,7 +5578,7 @@ mdb_page_search(MDB_cursor *mc, MDB_val *key, int flags)
|
|||||||
return MDB_NOTFOUND;
|
return MDB_NOTFOUND;
|
||||||
if (unlikely((leaf->mn_flags & (F_DUPDATA|F_SUBDATA)) != F_SUBDATA))
|
if (unlikely((leaf->mn_flags & (F_DUPDATA|F_SUBDATA)) != F_SUBDATA))
|
||||||
return MDB_INCOMPATIBLE; /* not a named DB */
|
return MDB_INCOMPATIBLE; /* not a named DB */
|
||||||
rc = mdb_node_read(mc->mc_txn, leaf, &data);
|
rc = mdb_node_read(&mc2, leaf, &data);
|
||||||
if (rc)
|
if (rc)
|
||||||
return rc;
|
return rc;
|
||||||
memcpy(&flags, ((char *) data.mv_data + offsetof(MDB_db, md_flags)),
|
memcpy(&flags, ((char *) data.mv_data + offsetof(MDB_db, md_flags)),
|
||||||
@ -5601,7 +5602,7 @@ mdb_page_search(MDB_cursor *mc, MDB_val *key, int flags)
|
|||||||
|
|
||||||
mdb_cassert(mc, root > 1);
|
mdb_cassert(mc, root > 1);
|
||||||
if (!mc->mc_pg[0] || mc->mc_pg[0]->mp_pgno != root)
|
if (!mc->mc_pg[0] || mc->mc_pg[0]->mp_pgno != root)
|
||||||
if (unlikely((rc = mdb_page_get(mc->mc_txn, root, &mc->mc_pg[0], NULL)) != 0))
|
if (unlikely((rc = mdb_page_get(mc, root, &mc->mc_pg[0], NULL)) != 0))
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
mc->mc_snum = 1;
|
mc->mc_snum = 1;
|
||||||
@ -5698,13 +5699,13 @@ release:
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** Return the data associated with a given node.
|
/** Return the data associated with a given node.
|
||||||
* @param[in] txn The transaction for this operation.
|
* @param[in] mc The cursor for this operation.
|
||||||
* @param[in] leaf The node being read.
|
* @param[in] leaf The node being read.
|
||||||
* @param[out] data Updated to point to the node's data.
|
* @param[out] data Updated to point to the node's data.
|
||||||
* @return 0 on success, non-zero on failure.
|
* @return 0 on success, non-zero on failure.
|
||||||
*/
|
*/
|
||||||
static MDBX_INLINE int
|
static MDBX_INLINE int
|
||||||
mdb_node_read(MDB_txn *txn, MDB_node *leaf, MDB_val *data)
|
mdb_node_read(MDB_cursor *mc, MDB_node *leaf, MDB_val *data)
|
||||||
{
|
{
|
||||||
MDB_page *omp; /* overflow page */
|
MDB_page *omp; /* overflow page */
|
||||||
pgno_t pgno;
|
pgno_t pgno;
|
||||||
@ -5720,7 +5721,7 @@ mdb_node_read(MDB_txn *txn, MDB_node *leaf, MDB_val *data)
|
|||||||
*/
|
*/
|
||||||
data->mv_size = NODEDSZ(leaf);
|
data->mv_size = NODEDSZ(leaf);
|
||||||
memcpy(&pgno, NODEDATA(leaf), sizeof(pgno));
|
memcpy(&pgno, NODEDATA(leaf), sizeof(pgno));
|
||||||
if (unlikely((rc = mdb_page_get(txn, pgno, &omp, NULL)) != 0)) {
|
if (unlikely((rc = mdb_page_get(mc, pgno, &omp, NULL)) != 0)) {
|
||||||
mdb_debug("read overflow page %zu failed", pgno);
|
mdb_debug("read overflow page %zu failed", pgno);
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
@ -5801,7 +5802,7 @@ mdb_cursor_sibling(MDB_cursor *mc, int move_right)
|
|||||||
mdb_cassert(mc, IS_BRANCH(mc->mc_pg[mc->mc_top]));
|
mdb_cassert(mc, IS_BRANCH(mc->mc_pg[mc->mc_top]));
|
||||||
|
|
||||||
indx = NODEPTR(mc->mc_pg[mc->mc_top], mc->mc_ki[mc->mc_top]);
|
indx = NODEPTR(mc->mc_pg[mc->mc_top], mc->mc_ki[mc->mc_top]);
|
||||||
if (unlikely((rc = mdb_page_get(mc->mc_txn, NODEPGNO(indx), &mp, NULL)) != 0)) {
|
if (unlikely((rc = mdb_page_get(mc, NODEPGNO(indx), &mp, NULL)) != 0)) {
|
||||||
/* mc will be inconsistent if caller does mc_snum++ as above */
|
/* mc will be inconsistent if caller does mc_snum++ as above */
|
||||||
mc->mc_flags &= ~(C_INITIALIZED|C_EOF);
|
mc->mc_flags &= ~(C_INITIALIZED|C_EOF);
|
||||||
return rc;
|
return rc;
|
||||||
@ -5884,7 +5885,7 @@ skip:
|
|||||||
mdb_xcursor_init1(mc, leaf);
|
mdb_xcursor_init1(mc, leaf);
|
||||||
}
|
}
|
||||||
if (data) {
|
if (data) {
|
||||||
if (unlikely((rc = mdb_node_read(mc->mc_txn, leaf, data)) != MDB_SUCCESS))
|
if (unlikely((rc = mdb_node_read(mc, leaf, data)) != MDB_SUCCESS))
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
if (F_ISSET(leaf->mn_flags, F_DUPDATA)) {
|
if (F_ISSET(leaf->mn_flags, F_DUPDATA)) {
|
||||||
@ -5967,7 +5968,7 @@ mdb_cursor_prev(MDB_cursor *mc, MDB_val *key, MDB_val *data, MDB_cursor_op op)
|
|||||||
mdb_xcursor_init1(mc, leaf);
|
mdb_xcursor_init1(mc, leaf);
|
||||||
}
|
}
|
||||||
if (data) {
|
if (data) {
|
||||||
if (unlikely((rc = mdb_node_read(mc->mc_txn, leaf, data)) != MDB_SUCCESS))
|
if (unlikely((rc = mdb_node_read(mc, leaf, data)) != MDB_SUCCESS))
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
if (F_ISSET(leaf->mn_flags, F_DUPDATA)) {
|
if (F_ISSET(leaf->mn_flags, F_DUPDATA)) {
|
||||||
@ -6156,7 +6157,7 @@ set1:
|
|||||||
}
|
}
|
||||||
} else if (op == MDB_GET_BOTH || op == MDB_GET_BOTH_RANGE) {
|
} else if (op == MDB_GET_BOTH || op == MDB_GET_BOTH_RANGE) {
|
||||||
MDB_val olddata;
|
MDB_val olddata;
|
||||||
if (unlikely((rc = mdb_node_read(mc->mc_txn, leaf, &olddata)) != MDB_SUCCESS))
|
if (unlikely((rc = mdb_node_read(mc, leaf, &olddata)) != MDB_SUCCESS))
|
||||||
return rc;
|
return rc;
|
||||||
rc = mc->mc_dbx->md_dcmp(data, &olddata);
|
rc = mc->mc_dbx->md_dcmp(data, &olddata);
|
||||||
if (rc) {
|
if (rc) {
|
||||||
@ -6169,7 +6170,7 @@ set1:
|
|||||||
} else {
|
} else {
|
||||||
if (mc->mc_xcursor)
|
if (mc->mc_xcursor)
|
||||||
mc->mc_xcursor->mx_cursor.mc_flags &= ~(C_INITIALIZED|C_EOF);
|
mc->mc_xcursor->mx_cursor.mc_flags &= ~(C_INITIALIZED|C_EOF);
|
||||||
if (unlikely((rc = mdb_node_read(mc->mc_txn, leaf, data)) != MDB_SUCCESS))
|
if (unlikely((rc = mdb_node_read(mc, leaf, data)) != MDB_SUCCESS))
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -6218,7 +6219,7 @@ mdb_cursor_first(MDB_cursor *mc, MDB_val *key, MDB_val *data)
|
|||||||
if (unlikely(rc))
|
if (unlikely(rc))
|
||||||
return rc;
|
return rc;
|
||||||
} else {
|
} else {
|
||||||
if (unlikely((rc = mdb_node_read(mc->mc_txn, leaf, data)) != MDB_SUCCESS))
|
if (unlikely((rc = mdb_node_read(mc, leaf, data)) != MDB_SUCCESS))
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -6263,7 +6264,7 @@ mdb_cursor_last(MDB_cursor *mc, MDB_val *key, MDB_val *data)
|
|||||||
if (unlikely(rc))
|
if (unlikely(rc))
|
||||||
return rc;
|
return rc;
|
||||||
} else {
|
} else {
|
||||||
if (unlikely((rc = mdb_node_read(mc->mc_txn, leaf, data)) != MDB_SUCCESS))
|
if (unlikely((rc = mdb_node_read(mc, leaf, data)) != MDB_SUCCESS))
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -6312,7 +6313,7 @@ mdb_cursor_get(MDB_cursor *mc, MDB_val *key, MDB_val *data,
|
|||||||
if (F_ISSET(leaf->mn_flags, F_DUPDATA)) {
|
if (F_ISSET(leaf->mn_flags, F_DUPDATA)) {
|
||||||
rc = mdb_cursor_get(&mc->mc_xcursor->mx_cursor, data, NULL, MDB_GET_CURRENT);
|
rc = mdb_cursor_get(&mc->mc_xcursor->mx_cursor, data, NULL, MDB_GET_CURRENT);
|
||||||
} else {
|
} else {
|
||||||
rc = mdb_node_read(mc->mc_txn, leaf, data);
|
rc = mdb_node_read(mc, leaf, data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -6429,7 +6430,7 @@ fetchm:
|
|||||||
MDB_node *leaf = NODEPTR(mc->mc_pg[mc->mc_top], mc->mc_ki[mc->mc_top]);
|
MDB_node *leaf = NODEPTR(mc->mc_pg[mc->mc_top], mc->mc_ki[mc->mc_top]);
|
||||||
if (!F_ISSET(leaf->mn_flags, F_DUPDATA)) {
|
if (!F_ISSET(leaf->mn_flags, F_DUPDATA)) {
|
||||||
MDB_GET_KEY(leaf, key);
|
MDB_GET_KEY(leaf, key);
|
||||||
rc = mdb_node_read(mc->mc_txn, leaf, data);
|
rc = mdb_node_read(mc, leaf, data);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -6830,7 +6831,7 @@ current:
|
|||||||
int level, ovpages, dpages = OVPAGES(data->mv_size, env->me_psize);
|
int level, ovpages, dpages = OVPAGES(data->mv_size, env->me_psize);
|
||||||
|
|
||||||
memcpy(&pg, olddata.mv_data, sizeof(pg));
|
memcpy(&pg, olddata.mv_data, sizeof(pg));
|
||||||
if (unlikely((rc2 = mdb_page_get(mc->mc_txn, pg, &omp, &level)) != 0))
|
if (unlikely((rc2 = mdb_page_get(mc, pg, &omp, &level)) != 0))
|
||||||
return rc2;
|
return rc2;
|
||||||
ovpages = omp->mp_pages;
|
ovpages = omp->mp_pages;
|
||||||
|
|
||||||
@ -7141,7 +7142,7 @@ mdb_cursor_del(MDB_cursor *mc, unsigned flags)
|
|||||||
pgno_t pg;
|
pgno_t pg;
|
||||||
|
|
||||||
memcpy(&pg, NODEDATA(leaf), sizeof(pg));
|
memcpy(&pg, NODEDATA(leaf), sizeof(pg));
|
||||||
if (unlikely((rc = mdb_page_get(mc->mc_txn, pg, &omp, NULL)) ||
|
if (unlikely((rc = mdb_page_get(mc, pg, &omp, NULL)) ||
|
||||||
(rc = mdb_ovpage_free(mc, omp))))
|
(rc = mdb_ovpage_free(mc, omp))))
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
@ -8313,7 +8314,7 @@ mdb_rebalance(MDB_cursor *mc)
|
|||||||
if (unlikely(rc))
|
if (unlikely(rc))
|
||||||
return rc;
|
return rc;
|
||||||
mc->mc_db->md_root = NODEPGNO(NODEPTR(mp, 0));
|
mc->mc_db->md_root = NODEPGNO(NODEPTR(mp, 0));
|
||||||
rc = mdb_page_get(mc->mc_txn,mc->mc_db->md_root,&mc->mc_pg[0],NULL);
|
rc = mdb_page_get(mc, mc->mc_db->md_root, &mc->mc_pg[0], NULL);
|
||||||
if (unlikely(rc))
|
if (unlikely(rc))
|
||||||
return rc;
|
return rc;
|
||||||
mc->mc_db->md_depth--;
|
mc->mc_db->md_depth--;
|
||||||
@ -8374,7 +8375,7 @@ mdb_rebalance(MDB_cursor *mc)
|
|||||||
mdb_debug("reading right neighbor");
|
mdb_debug("reading right neighbor");
|
||||||
mn.mc_ki[ptop]++;
|
mn.mc_ki[ptop]++;
|
||||||
node = NODEPTR(mc->mc_pg[ptop], mn.mc_ki[ptop]);
|
node = NODEPTR(mc->mc_pg[ptop], mn.mc_ki[ptop]);
|
||||||
rc = mdb_page_get(mc->mc_txn,NODEPGNO(node),&mn.mc_pg[mn.mc_top],NULL);
|
rc = mdb_page_get(mc, NODEPGNO(node), &mn.mc_pg[mn.mc_top], NULL);
|
||||||
if (unlikely(rc))
|
if (unlikely(rc))
|
||||||
return rc;
|
return rc;
|
||||||
mn.mc_ki[mn.mc_top] = 0;
|
mn.mc_ki[mn.mc_top] = 0;
|
||||||
@ -8386,7 +8387,7 @@ mdb_rebalance(MDB_cursor *mc)
|
|||||||
mdb_debug("reading left neighbor");
|
mdb_debug("reading left neighbor");
|
||||||
mn.mc_ki[ptop]--;
|
mn.mc_ki[ptop]--;
|
||||||
node = NODEPTR(mc->mc_pg[ptop], mn.mc_ki[ptop]);
|
node = NODEPTR(mc->mc_pg[ptop], mn.mc_ki[ptop]);
|
||||||
rc = mdb_page_get(mc->mc_txn,NODEPGNO(node),&mn.mc_pg[mn.mc_top],NULL);
|
rc = mdb_page_get(mc, NODEPGNO(node), &mn.mc_pg[mn.mc_top], NULL);
|
||||||
if (unlikely(rc))
|
if (unlikely(rc))
|
||||||
return rc;
|
return rc;
|
||||||
mn.mc_ki[mn.mc_top] = NUMKEYS(mn.mc_pg[mn.mc_top]) - 1;
|
mn.mc_ki[mn.mc_top] = NUMKEYS(mn.mc_pg[mn.mc_top]) - 1;
|
||||||
@ -9149,7 +9150,6 @@ static int __cold
|
|||||||
mdb_env_cwalk(mdb_copy *my, pgno_t *pg, int flags)
|
mdb_env_cwalk(mdb_copy *my, pgno_t *pg, int flags)
|
||||||
{
|
{
|
||||||
MDB_cursor mc;
|
MDB_cursor mc;
|
||||||
MDB_txn *txn = my->mc_txn;
|
|
||||||
MDB_node *ni;
|
MDB_node *ni;
|
||||||
MDB_page *mo, *mp, *leaf;
|
MDB_page *mo, *mp, *leaf;
|
||||||
char *buf, *ptr;
|
char *buf, *ptr;
|
||||||
@ -9162,9 +9162,9 @@ mdb_env_cwalk(mdb_copy *my, pgno_t *pg, int flags)
|
|||||||
|
|
||||||
memset(&mc, 0, sizeof(mc));
|
memset(&mc, 0, sizeof(mc));
|
||||||
mc.mc_snum = 1;
|
mc.mc_snum = 1;
|
||||||
mc.mc_txn = txn;
|
mc.mc_txn = my->mc_txn;
|
||||||
|
|
||||||
rc = mdb_page_get(txn, *pg, &mc.mc_pg[0], NULL);
|
rc = mdb_page_get(&mc, *pg, &mc.mc_pg[0], NULL);
|
||||||
if (rc)
|
if (rc)
|
||||||
return rc;
|
return rc;
|
||||||
rc = mdb_page_search_root(&mc, NULL, MDB_PS_FIRST);
|
rc = mdb_page_search_root(&mc, NULL, MDB_PS_FIRST);
|
||||||
@ -9209,7 +9209,7 @@ mdb_env_cwalk(mdb_copy *my, pgno_t *pg, int flags)
|
|||||||
|
|
||||||
memcpy(&pg, NODEDATA(ni), sizeof(pg));
|
memcpy(&pg, NODEDATA(ni), sizeof(pg));
|
||||||
memcpy(NODEDATA(ni), &my->mc_next_pgno, sizeof(pgno_t));
|
memcpy(NODEDATA(ni), &my->mc_next_pgno, sizeof(pgno_t));
|
||||||
rc = mdb_page_get(txn, pg, &omp, NULL);
|
rc = mdb_page_get(&mc, pg, &omp, NULL);
|
||||||
if (rc)
|
if (rc)
|
||||||
goto done;
|
goto done;
|
||||||
if (my->mc_wlen[toggle] >= MDB_WBUF) {
|
if (my->mc_wlen[toggle] >= MDB_WBUF) {
|
||||||
@ -9259,7 +9259,7 @@ mdb_env_cwalk(mdb_copy *my, pgno_t *pg, int flags)
|
|||||||
again:
|
again:
|
||||||
ni = NODEPTR(mp, mc.mc_ki[mc.mc_top]);
|
ni = NODEPTR(mp, mc.mc_ki[mc.mc_top]);
|
||||||
pg = NODEPGNO(ni);
|
pg = NODEPGNO(ni);
|
||||||
rc = mdb_page_get(txn, pg, &mp, NULL);
|
rc = mdb_page_get(&mc, pg, &mp, NULL);
|
||||||
if (rc)
|
if (rc)
|
||||||
goto done;
|
goto done;
|
||||||
mc.mc_top++;
|
mc.mc_top++;
|
||||||
@ -10006,7 +10006,7 @@ mdb_drop0(MDB_cursor *mc, int subs)
|
|||||||
MDB_page *omp;
|
MDB_page *omp;
|
||||||
pgno_t pg;
|
pgno_t pg;
|
||||||
memcpy(&pg, NODEDATA(ni), sizeof(pg));
|
memcpy(&pg, NODEDATA(ni), sizeof(pg));
|
||||||
rc = mdb_page_get(txn, pg, &omp, NULL);
|
rc = mdb_page_get(mc, pg, &omp, NULL);
|
||||||
if (unlikely(rc))
|
if (unlikely(rc))
|
||||||
goto done;
|
goto done;
|
||||||
mdb_cassert(mc, IS_OVERFLOW(omp));
|
mdb_cassert(mc, IS_OVERFLOW(omp));
|
||||||
|
11
mdbx.c
11
mdbx.c
@ -182,7 +182,12 @@ mdb_env_walk(mdb_walk_ctx_t *ctx, const char* dbi, pgno_t pg, int flags, int dee
|
|||||||
if (pg == P_INVALID)
|
if (pg == P_INVALID)
|
||||||
return MDB_SUCCESS; /* empty db */
|
return MDB_SUCCESS; /* empty db */
|
||||||
|
|
||||||
rc = mdb_page_get(ctx->mw_txn, pg, &mp, NULL);
|
MDB_cursor mc;
|
||||||
|
memset(&mc, 0, sizeof(mc));
|
||||||
|
mc.mc_snum = 1;
|
||||||
|
mc.mc_txn = ctx->mw_txn;
|
||||||
|
|
||||||
|
rc = mdb_page_get(&mc, pg, &mp, NULL);
|
||||||
if (rc)
|
if (rc)
|
||||||
return rc;
|
return rc;
|
||||||
if (pg != mp->mp_p.p_pgno)
|
if (pg != mp->mp_p.p_pgno)
|
||||||
@ -220,7 +225,7 @@ mdb_env_walk(mdb_walk_ctx_t *ctx, const char* dbi, pgno_t pg, int flags, int dee
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (align_bytes = i = 0; i < nkeys;
|
for (align_bytes = i = 0; i < nkeys;
|
||||||
align_bytes += ((payload_size + align_bytes) & 1), i++) {
|
align_bytes += ((payload_size + align_bytes) & 1), i++) {
|
||||||
MDB_node *node;
|
MDB_node *node;
|
||||||
|
|
||||||
if (IS_LEAF2(mp)) {
|
if (IS_LEAF2(mp)) {
|
||||||
@ -249,7 +254,7 @@ mdb_env_walk(mdb_walk_ctx_t *ctx, const char* dbi, pgno_t pg, int flags, int dee
|
|||||||
|
|
||||||
payload_size += sizeof(pgno_t);
|
payload_size += sizeof(pgno_t);
|
||||||
opg = NODEDATA(node);
|
opg = NODEDATA(node);
|
||||||
rc = mdb_page_get(ctx->mw_txn, *opg, &omp, NULL);
|
rc = mdb_page_get(&mc, *opg, &omp, NULL);
|
||||||
if (rc)
|
if (rc)
|
||||||
return rc;
|
return rc;
|
||||||
if (*opg != omp->mp_p.p_pgno)
|
if (*opg != omp->mp_p.p_pgno)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user