/***************************************************************************** Copyright (c) 1996, 2015, Oracle and/or its affiliates. All Rights Reserved. Copyright (c) 2016, 2021, MariaDB Corporation. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; version 2 of the License. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335 USA *****************************************************************************/ /**************************************************//** @file include/trx0trx.ic The transaction Created 3/26/1996 Heikki Tuuri *******************************************************/ /**********************************************************************//** Determines if a transaction is in the given state. The caller must hold trx->mutex, or it must be the thread that is serving a running transaction. A running RW transaction must be in trx_sys.rw_trx_hash. @return TRUE if trx->state == state */ UNIV_INLINE bool trx_state_eq( /*=========*/ const trx_t* trx, /*!< in: transaction */ trx_state_t state, /*!< in: state; if state != TRX_STATE_NOT_STARTED asserts that trx->state != TRX_STATE_NOT_STARTED */ bool relaxed) /*!< in: whether to allow trx->state == TRX_STATE_NOT_STARTED after an error has been reported */ { #ifdef UNIV_DEBUG switch (trx->state) { case TRX_STATE_PREPARED: case TRX_STATE_PREPARED_RECOVERED: case TRX_STATE_COMMITTED_IN_MEMORY: ut_ad(!trx_is_autocommit_non_locking(trx)); return(trx->state == state); case TRX_STATE_ACTIVE: assert_trx_nonlocking_or_in_list(trx); return(state == trx->state); case TRX_STATE_NOT_STARTED: /* These states are not allowed for running transactions. */ ut_a(state == TRX_STATE_NOT_STARTED || (relaxed && thd_get_error_number(trx->mysql_thd))); return(true); } ut_error; #endif /* UNIV_DEBUG */ return(trx->state == state); } /****************************************************************//** Retrieves the error_info field from a trx. @return the error info */ UNIV_INLINE const dict_index_t* trx_get_error_info( /*===============*/ const trx_t* trx) /*!< in: trx object */ { return(trx->error_info); } /**********************************************************************//** Determine if a transaction is a dictionary operation. @return dictionary operation mode */ UNIV_INLINE enum trx_dict_op_t trx_get_dict_operation( /*===================*/ const trx_t* trx) /*!< in: transaction */ { trx_dict_op_t op = static_cast(trx->dict_operation); #ifdef UNIV_DEBUG switch (op) { case TRX_DICT_OP_NONE: case TRX_DICT_OP_TABLE: case TRX_DICT_OP_INDEX: return(op); } ut_error; #endif /* UNIV_DEBUG */ return(op); } /**********************************************************************//** Flag a transaction a dictionary operation. */ UNIV_INLINE void trx_set_dict_operation( /*===================*/ trx_t* trx, /*!< in/out: transaction */ enum trx_dict_op_t op) /*!< in: operation, not TRX_DICT_OP_NONE */ { #ifdef UNIV_DEBUG enum trx_dict_op_t old_op = trx_get_dict_operation(trx); switch (op) { case TRX_DICT_OP_NONE: ut_error; break; case TRX_DICT_OP_TABLE: switch (old_op) { case TRX_DICT_OP_NONE: case TRX_DICT_OP_INDEX: case TRX_DICT_OP_TABLE: goto ok; } ut_error; break; case TRX_DICT_OP_INDEX: ut_ad(old_op == TRX_DICT_OP_NONE); break; } ok: #endif /* UNIV_DEBUG */ trx->ddl = true; trx->dict_operation = op; }