Commit c65e9762 authored by John Esmet's avatar John Esmet Committed by Yoni Fogel

[t:4951] always release the MO lock before fsyncing the log in xa_prepare


git-svn-id: file:///svn/toku/tokudb@44126 c7de825b-a66e-492c-adef-691d508d4ae1
parent 2153c206
...@@ -218,6 +218,8 @@ toku_txn_abort_only(DB_TXN * txn, ...@@ -218,6 +218,8 @@ toku_txn_abort_only(DB_TXN * txn,
return r; return r;
} }
// requires: must hold the multi operation lock. it is
// released here before the fsync.
static int static int
toku_txn_xa_prepare (DB_TXN *txn, TOKU_XA_XID *xid) { toku_txn_xa_prepare (DB_TXN *txn, TOKU_XA_XID *xid) {
if (!txn) return EINVAL; if (!txn) return EINVAL;
...@@ -240,10 +242,14 @@ toku_txn_xa_prepare (DB_TXN *txn, TOKU_XA_XID *xid) { ...@@ -240,10 +242,14 @@ toku_txn_xa_prepare (DB_TXN *txn, TOKU_XA_XID *xid) {
LSN do_fsync_lsn; LSN do_fsync_lsn;
bool do_fsync; bool do_fsync;
toku_txn_get_fsync_info(ttxn, &do_fsync, &do_fsync_lsn); toku_txn_get_fsync_info(ttxn, &do_fsync, &do_fsync_lsn);
// release the multi operation lock before fsyncing the log
toku_multi_operation_client_unlock();
toku_txn_maybe_fsync_log(logger, do_fsync_lsn, do_fsync); toku_txn_maybe_fsync_log(logger, do_fsync_lsn, do_fsync);
return r; return r;
} }
// requires: must hold the multi operation lock. it is
// released in toku_txn_xa_prepare before the fsync.
static int static int
toku_txn_prepare (DB_TXN *txn, u_int8_t gid[DB_GID_SIZE]) { toku_txn_prepare (DB_TXN *txn, u_int8_t gid[DB_GID_SIZE]) {
TOKU_XA_XID xid; TOKU_XA_XID xid;
...@@ -331,17 +337,19 @@ locked_txn_abort(DB_TXN *txn) { ...@@ -331,17 +337,19 @@ locked_txn_abort(DB_TXN *txn) {
static int static int
locked_txn_prepare (DB_TXN *txn, u_int8_t gid[DB_GID_SIZE]) { locked_txn_prepare (DB_TXN *txn, u_int8_t gid[DB_GID_SIZE]) {
// toku_txn_prepare eventually releases the multi operation lock
// before fsyncing the log
toku_multi_operation_client_lock(); toku_multi_operation_client_lock();
int r = toku_txn_prepare(txn, gid); int r = toku_txn_prepare(txn, gid);
toku_multi_operation_client_unlock();
return r; return r;
} }
static int static int
locked_txn_xa_prepare (DB_TXN *txn, TOKU_XA_XID *xid) { locked_txn_xa_prepare (DB_TXN *txn, TOKU_XA_XID *xid) {
// toku_txn_xa_prepare eventually releases the multi operation lock
// before fsyncing the log
toku_multi_operation_client_lock(); toku_multi_operation_client_lock();
int r = toku_txn_xa_prepare(txn, xid); int r = toku_txn_xa_prepare(txn, xid);
toku_multi_operation_client_unlock();
return r; return r;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment