mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-21 18:08:21 +08:00
mdbx: MDB_END_EOTDONE and refine txn_commit().
This commit is contained in:
parent
3d08b9e76f
commit
abc7dca247
27
mdbx.c
27
mdbx.c
@ -1261,6 +1261,7 @@ enum {
|
|||||||
#define MDB_END_OPMASK 0x0F /**< mask for #mdbx_txn_end() operation number */
|
#define MDB_END_OPMASK 0x0F /**< mask for #mdbx_txn_end() operation number */
|
||||||
#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_EOTDONE 0x40 /**< txn's cursors already closed */
|
||||||
#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 mdbx_txn_end(MDB_txn *txn, unsigned mode);
|
static int mdbx_txn_end(MDB_txn *txn, unsigned mode);
|
||||||
|
|
||||||
@ -3266,7 +3267,7 @@ static int mdbx_txn_end(MDB_txn *txn, unsigned mode) {
|
|||||||
} else if (!F_ISSET(txn->mt_flags, MDB_TXN_FINISHED)) {
|
} else if (!F_ISSET(txn->mt_flags, MDB_TXN_FINISHED)) {
|
||||||
pgno_t *pghead = env->me_pghead;
|
pgno_t *pghead = env->me_pghead;
|
||||||
|
|
||||||
if (!(mode & MDB_END_UPDATE)) /* !(already closed cursors) */
|
if (!(mode & MDB_END_EOTDONE)) /* !(already closed cursors) */
|
||||||
mdbx_cursors_eot(txn, 0);
|
mdbx_cursors_eot(txn, 0);
|
||||||
if (!(env->me_flags & MDB_WRITEMAP)) {
|
if (!(env->me_flags & MDB_WRITEMAP)) {
|
||||||
mdbx_dlist_free(txn);
|
mdbx_dlist_free(txn);
|
||||||
@ -3806,8 +3807,7 @@ done:
|
|||||||
|
|
||||||
int mdbx_txn_commit(MDB_txn *txn) {
|
int mdbx_txn_commit(MDB_txn *txn) {
|
||||||
int rc;
|
int rc;
|
||||||
unsigned i, end_mode;
|
unsigned i;
|
||||||
MDB_env *env;
|
|
||||||
|
|
||||||
if (unlikely(txn == NULL))
|
if (unlikely(txn == NULL))
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
@ -3815,15 +3815,12 @@ int mdbx_txn_commit(MDB_txn *txn) {
|
|||||||
if (unlikely(txn->mt_signature != MDBX_MT_SIGNATURE))
|
if (unlikely(txn->mt_signature != MDBX_MT_SIGNATURE))
|
||||||
return MDB_VERSION_MISMATCH;
|
return MDB_VERSION_MISMATCH;
|
||||||
|
|
||||||
if (unlikely(txn->mt_env->me_pid != getpid())) {
|
MDB_env *env = txn->mt_env;
|
||||||
txn->mt_env->me_flags |= MDB_FATAL_ERROR;
|
if (unlikely(env->me_pid != getpid())) {
|
||||||
|
env->me_flags |= MDB_FATAL_ERROR;
|
||||||
return MDB_PANIC;
|
return MDB_PANIC;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* mdbx_txn_end() mode for a commit which writes nothing */
|
|
||||||
end_mode =
|
|
||||||
MDB_END_EMPTY_COMMIT | MDB_END_UPDATE | MDB_END_SLOT | MDB_END_FREE;
|
|
||||||
|
|
||||||
if (txn->mt_child) {
|
if (txn->mt_child) {
|
||||||
rc = mdbx_txn_commit(txn->mt_child);
|
rc = mdbx_txn_commit(txn->mt_child);
|
||||||
txn->mt_child = NULL;
|
txn->mt_child = NULL;
|
||||||
@ -3831,11 +3828,11 @@ int mdbx_txn_commit(MDB_txn *txn) {
|
|||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
env = txn->mt_env;
|
/* mdbx_txn_end() mode for a commit which writes nothing */
|
||||||
|
unsigned end_mode =
|
||||||
if (unlikely(F_ISSET(txn->mt_flags, MDB_TXN_RDONLY))) {
|
MDB_END_EMPTY_COMMIT | MDB_END_UPDATE | MDB_END_SLOT | MDB_END_FREE;
|
||||||
|
if (unlikely(F_ISSET(txn->mt_flags, MDB_TXN_RDONLY)))
|
||||||
goto done;
|
goto done;
|
||||||
}
|
|
||||||
|
|
||||||
if (unlikely(txn->mt_flags & (MDB_TXN_FINISHED | MDB_TXN_ERROR))) {
|
if (unlikely(txn->mt_flags & (MDB_TXN_FINISHED | MDB_TXN_ERROR))) {
|
||||||
mdbx_debug("error flag is set, can't commit");
|
mdbx_debug("error flag is set, can't commit");
|
||||||
@ -3989,7 +3986,6 @@ int mdbx_txn_commit(MDB_txn *txn) {
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
env = txn->mt_env;
|
|
||||||
if (unlikely(txn != env->me_txn)) {
|
if (unlikely(txn != env->me_txn)) {
|
||||||
mdbx_debug("attempt to commit unknown transaction");
|
mdbx_debug("attempt to commit unknown transaction");
|
||||||
rc = EINVAL;
|
rc = EINVAL;
|
||||||
@ -3997,6 +3993,7 @@ int mdbx_txn_commit(MDB_txn *txn) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
mdbx_cursors_eot(txn, 0);
|
mdbx_cursors_eot(txn, 0);
|
||||||
|
end_mode |= MDB_END_EOTDONE;
|
||||||
|
|
||||||
if (!txn->mt_u.dirty_list[0].mid &&
|
if (!txn->mt_u.dirty_list[0].mid &&
|
||||||
!(txn->mt_flags & (MDB_TXN_DIRTY | MDB_TXN_SPILLS)))
|
!(txn->mt_flags & (MDB_TXN_DIRTY | MDB_TXN_SPILLS)))
|
||||||
@ -4054,7 +4051,7 @@ int mdbx_txn_commit(MDB_txn *txn) {
|
|||||||
}
|
}
|
||||||
if (unlikely(rc != MDB_SUCCESS))
|
if (unlikely(rc != MDB_SUCCESS))
|
||||||
goto fail;
|
goto fail;
|
||||||
end_mode = MDB_END_COMMITTED | MDB_END_UPDATE;
|
end_mode = MDB_END_COMMITTED | MDB_END_UPDATE | MDB_END_EOTDONE;
|
||||||
|
|
||||||
done:
|
done:
|
||||||
return mdbx_txn_end(txn, end_mode);
|
return mdbx_txn_end(txn, end_mode);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user