mariadb/storage/innobase/include/row0quiesce.h
2018-11-29 12:53:44 +02:00

67 lines
2.3 KiB
C

/*****************************************************************************
Copyright (c) 2012, 2016, Oracle and/or its affiliates. All Rights Reserved.
Copyright (c) 2017, 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, Suite 500, Boston, MA 02110-1335 USA
*****************************************************************************/
/**************************************************//**
@file include/row0quiesce.h
Header file for tablespace quiesce functions.
Created 2012-02-08 by Sunny Bains
*******************************************************/
#ifndef row0quiesce_h
#define row0quiesce_h
#include "dict0types.h"
struct trx_t;
/** The version number of the export meta-data text file. */
#define IB_EXPORT_CFG_VERSION_V1 0x1UL
/*********************************************************************//**
Quiesce the tablespace that the table resides in. */
void
row_quiesce_table_start(
/*====================*/
dict_table_t* table, /*!< in: quiesce this table */
trx_t* trx) /*!< in/out: transaction/session */
MY_ATTRIBUTE((nonnull));
/*********************************************************************//**
Set a table's quiesce state.
@return DB_SUCCESS or errro code. */
dberr_t
row_quiesce_set_state(
/*==================*/
dict_table_t* table, /*!< in: quiesce this table */
ib_quiesce_t state, /*!< in: quiesce state to set */
trx_t* trx) /*!< in/out: transaction */
MY_ATTRIBUTE((nonnull, warn_unused_result));
/*********************************************************************//**
Cleanup after table quiesce. */
void
row_quiesce_table_complete(
/*=======================*/
dict_table_t* table, /*!< in: quiesce this table */
trx_t* trx) /*!< in/out: transaction/session */
MY_ATTRIBUTE((nonnull));
#endif /* row0quiesce_h */