2009-02-17 09:18:35 +00:00
|
|
|
/*****************************************************************************
|
|
|
|
|
|
|
|
Copyright (c) 1995, 2009, Innobase Oy. All Rights Reserved.
|
|
|
|
|
|
|
|
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., 59 Temple
|
|
|
|
Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
|
|
|
|
*****************************************************************************/
|
|
|
|
|
2009-05-25 09:52:29 +00:00
|
|
|
/**************************************************//**
|
|
|
|
@file include/mtr0mtr.h
|
2005-10-27 07:29:40 +00:00
|
|
|
Mini-transaction buffer
|
|
|
|
|
|
|
|
Created 11/26/1995 Heikki Tuuri
|
|
|
|
*******************************************************/
|
|
|
|
|
|
|
|
#ifndef mtr0mtr_h
|
|
|
|
#define mtr0mtr_h
|
|
|
|
|
|
|
|
#include "univ.i"
|
|
|
|
#include "mem0mem.h"
|
|
|
|
#include "dyn0dyn.h"
|
|
|
|
#include "buf0types.h"
|
|
|
|
#include "sync0rw.h"
|
|
|
|
#include "ut0byte.h"
|
|
|
|
#include "mtr0types.h"
|
|
|
|
#include "page0types.h"
|
|
|
|
|
|
|
|
/* Logging modes for a mini-transaction */
|
|
|
|
#define MTR_LOG_ALL 21 /* default mode: log all operations
|
|
|
|
modifying disk-based data */
|
|
|
|
#define MTR_LOG_NONE 22 /* log no operations */
|
|
|
|
/*#define MTR_LOG_SPACE 23 */ /* log only operations modifying
|
|
|
|
file space page allocation data
|
|
|
|
(operations in fsp0fsp.* ) */
|
|
|
|
#define MTR_LOG_SHORT_INSERTS 24 /* inserts are logged in a shorter
|
|
|
|
form */
|
2006-02-23 19:25:29 +00:00
|
|
|
|
2005-10-27 07:29:40 +00:00
|
|
|
/* Types for the mlock objects to store in the mtr memo; NOTE that the
|
|
|
|
first 3 values must be RW_S_LATCH, RW_X_LATCH, RW_NO_LATCH */
|
|
|
|
#define MTR_MEMO_PAGE_S_FIX RW_S_LATCH
|
|
|
|
#define MTR_MEMO_PAGE_X_FIX RW_X_LATCH
|
|
|
|
#define MTR_MEMO_BUF_FIX RW_NO_LATCH
|
|
|
|
#define MTR_MEMO_MODIFY 54
|
|
|
|
#define MTR_MEMO_S_LOCK 55
|
|
|
|
#define MTR_MEMO_X_LOCK 56
|
|
|
|
|
2009-05-28 06:21:55 +00:00
|
|
|
/** @name Log item types
|
|
|
|
The log items are declared 'byte' so that the compiler can warn if val
|
|
|
|
and type parameters are switched in a call to mlog_write_ulint. NOTE!
|
|
|
|
For 1 - 8 bytes, the flag value must give the length also! @{ */
|
|
|
|
#define MLOG_SINGLE_REC_FLAG 128 /*!< if the mtr contains only
|
2005-10-27 07:29:40 +00:00
|
|
|
one log record for one page,
|
|
|
|
i.e., write_initial_log_record
|
|
|
|
has been called only once,
|
|
|
|
this flag is ORed to the type
|
|
|
|
of that first log record */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_1BYTE (1) /*!< one byte is written */
|
|
|
|
#define MLOG_2BYTES (2) /*!< 2 bytes ... */
|
|
|
|
#define MLOG_4BYTES (4) /*!< 4 bytes ... */
|
|
|
|
#define MLOG_8BYTES (8) /*!< 8 bytes ... */
|
|
|
|
#define MLOG_REC_INSERT ((byte)9) /*!< record insert */
|
|
|
|
#define MLOG_REC_CLUST_DELETE_MARK ((byte)10) /*!< mark clustered index record
|
2005-10-27 07:29:40 +00:00
|
|
|
deleted */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_REC_SEC_DELETE_MARK ((byte)11) /*!< mark secondary index record
|
2005-10-27 07:29:40 +00:00
|
|
|
deleted */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_REC_UPDATE_IN_PLACE ((byte)13) /*!< update of a record,
|
2005-10-27 07:29:40 +00:00
|
|
|
preserves record field sizes */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_REC_DELETE ((byte)14) /*!< delete a record from a
|
2005-10-27 07:29:40 +00:00
|
|
|
page */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_LIST_END_DELETE ((byte)15) /*!< delete record list end on
|
2005-10-27 07:29:40 +00:00
|
|
|
index page */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_LIST_START_DELETE ((byte)16) /*!< delete record list start on
|
2005-10-27 07:29:40 +00:00
|
|
|
index page */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_LIST_END_COPY_CREATED ((byte)17) /*!< copy record list end to a
|
2005-10-27 07:29:40 +00:00
|
|
|
new created index page */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_PAGE_REORGANIZE ((byte)18) /*!< reorganize an
|
|
|
|
index page in
|
|
|
|
ROW_FORMAT=REDUNDANT */
|
|
|
|
#define MLOG_PAGE_CREATE ((byte)19) /*!< create an index page */
|
|
|
|
#define MLOG_UNDO_INSERT ((byte)20) /*!< insert entry in an undo
|
2005-10-27 07:29:40 +00:00
|
|
|
log */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_UNDO_ERASE_END ((byte)21) /*!< erase an undo log
|
2006-08-29 09:30:31 +00:00
|
|
|
page end */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_UNDO_INIT ((byte)22) /*!< initialize a page in an
|
2005-10-27 07:29:40 +00:00
|
|
|
undo log */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_UNDO_HDR_DISCARD ((byte)23) /*!< discard an update undo log
|
2005-10-27 07:29:40 +00:00
|
|
|
header */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_UNDO_HDR_REUSE ((byte)24) /*!< reuse an insert undo log
|
2005-10-27 07:29:40 +00:00
|
|
|
header */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_UNDO_HDR_CREATE ((byte)25) /*!< create an undo
|
|
|
|
log header */
|
|
|
|
#define MLOG_REC_MIN_MARK ((byte)26) /*!< mark an index
|
|
|
|
record as the
|
|
|
|
predefined minimum
|
|
|
|
record */
|
|
|
|
#define MLOG_IBUF_BITMAP_INIT ((byte)27) /*!< initialize an
|
|
|
|
ibuf bitmap page */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*#define MLOG_FULL_PAGE ((byte)28) full contents of a page */
|
2009-09-16 07:07:21 +00:00
|
|
|
#ifdef UNIV_LOG_LSN_DEBUG
|
|
|
|
# define MLOG_LSN ((byte)28) /* current LSN */
|
|
|
|
#endif
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_INIT_FILE_PAGE ((byte)29) /*!< this means that a
|
|
|
|
file page is taken
|
|
|
|
into use and the prior
|
|
|
|
contents of the page
|
|
|
|
should be ignored: in
|
|
|
|
recovery we must not
|
|
|
|
trust the lsn values
|
|
|
|
stored to the file
|
|
|
|
page */
|
|
|
|
#define MLOG_WRITE_STRING ((byte)30) /*!< write a string to
|
|
|
|
a page */
|
|
|
|
#define MLOG_MULTI_REC_END ((byte)31) /*!< if a single mtr writes
|
2009-09-03 10:05:44 +00:00
|
|
|
several log records,
|
2005-10-27 07:29:40 +00:00
|
|
|
this log record ends the
|
|
|
|
sequence of these records */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_DUMMY_RECORD ((byte)32) /*!< dummy log record used to
|
2005-10-27 07:29:40 +00:00
|
|
|
pad a log block full */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_FILE_CREATE ((byte)33) /*!< log record about an .ibd
|
2005-10-27 07:29:40 +00:00
|
|
|
file creation */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_FILE_RENAME ((byte)34) /*!< log record about an .ibd
|
2005-10-27 07:29:40 +00:00
|
|
|
file rename */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_FILE_DELETE ((byte)35) /*!< log record about an .ibd
|
2005-10-27 07:29:40 +00:00
|
|
|
file deletion */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_COMP_REC_MIN_MARK ((byte)36) /*!< mark a compact
|
|
|
|
index record as the
|
|
|
|
predefined minimum
|
2005-10-27 07:29:40 +00:00
|
|
|
record */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_COMP_PAGE_CREATE ((byte)37) /*!< create a compact
|
2005-10-27 07:29:40 +00:00
|
|
|
index page */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_COMP_REC_INSERT ((byte)38) /*!< compact record insert */
|
2005-10-27 07:29:40 +00:00
|
|
|
#define MLOG_COMP_REC_CLUST_DELETE_MARK ((byte)39)
|
2009-05-28 06:21:55 +00:00
|
|
|
/*!< mark compact
|
|
|
|
clustered index record
|
|
|
|
deleted */
|
|
|
|
#define MLOG_COMP_REC_SEC_DELETE_MARK ((byte)40)/*!< mark compact
|
|
|
|
secondary index record
|
|
|
|
deleted; this log
|
|
|
|
record type is
|
|
|
|
redundant, as
|
|
|
|
MLOG_REC_SEC_DELETE_MARK
|
|
|
|
is independent of the
|
|
|
|
record format. */
|
|
|
|
#define MLOG_COMP_REC_UPDATE_IN_PLACE ((byte)41)/*!< update of a
|
|
|
|
compact record,
|
|
|
|
preserves record field
|
|
|
|
sizes */
|
|
|
|
#define MLOG_COMP_REC_DELETE ((byte)42) /*!< delete a compact record
|
2005-10-27 07:29:40 +00:00
|
|
|
from a page */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_COMP_LIST_END_DELETE ((byte)43) /*!< delete compact record list
|
2005-10-27 07:29:40 +00:00
|
|
|
end on index page */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_COMP_LIST_START_DELETE ((byte)44) /*!< delete compact record list
|
2005-10-27 07:29:40 +00:00
|
|
|
start on index page */
|
|
|
|
#define MLOG_COMP_LIST_END_COPY_CREATED ((byte)45)
|
2009-05-28 06:21:55 +00:00
|
|
|
/*!< copy compact
|
|
|
|
record list end to a
|
|
|
|
new created index
|
|
|
|
page */
|
|
|
|
#define MLOG_COMP_PAGE_REORGANIZE ((byte)46) /*!< reorganize an index page */
|
|
|
|
#define MLOG_FILE_CREATE2 ((byte)47) /*!< log record about creating
|
branches/zip: Implement the configuration parameter and settable global
variable innodb_file_format. Implement file format version stamping of
*.ibd files and SYS_TABLES.TYPE.
This change breaks introduces an incompatible change for for
compressed tables. We can do this, as we have not released yet.
innodb-zip.test: Add tests for stricter KEY_BLOCK_SIZE and ROW_FORMAT
checks.
DICT_TF_COMPRESSED_MASK, DICT_TF_COMPRESSED_SHIFT: Replace with
DICT_TF_ZSSIZE_MASK, DICT_TF_ZSSIZE_SHIFT.
DICT_TF_FORMAT_MASK, DICT_TF_FORMAT_SHIFT, DICT_TF_FORMAT_51,
DICT_TF_FORMAT_ZIP: File format version, stored in table->flags,
in the .ibd file header, and in SYS_TABLES.TYPE.
dict_create_sys_tables_tuple(): Write the table flags to SYS_TABLES.TYPE
if the format is at least DICT_TF_FORMAT_ZIP. For old formats
(DICT_TF_FORMAT_51), write DICT_TABLE_ORDINARY as the table type.
DB_TABLE_ZIP_NO_IBD: Remove the error code. The error handling is done
in ha_innodb.cc; as a failsafe measure, dict_build_table_def_step() will
silently clear the compression and format flags instead of returning this
error.
dict_mem_table_create(): Assert that no extra bits are set in the flags.
dict_sys_tables_get_zip_size(): Rename to dict_sys_tables_get_flags().
Check all flag bits, and return ULINT_UNDEFINED if the combination is
unsupported.
dict_boot(): Document the SYS_TABLES columns N_COLS and TYPE.
dict_table_get_format(), dict_table_set_format(),
dict_table_flags_to_zip_size(): New accessors to table->flags.
dtuple_convert_big_rec(): Introduce the auxiliary variables
local_len, local_prefix_len. Store a 768-byte prefix locally
if the file format is less than DICT_TF_FORMAT_ZIP.
dtuple_convert_back_big_rec(): Restore the columns.
srv_file_format: New variable: innodb_file_format.
fil_create_new_single_table_tablespace(): Replace the parameter zip_size
with table->flags.
fil_open_single_table_tablespace(): Replace the parameter zip_size_in_k
with table->flags. Check the flags.
fil_space_struct, fil_space_create(), fil_op_write_log():
Replace zip_size with flags.
fil_node_open_file(): Note a TODO item for InnoDB Hot Backup.
Check that the tablespace flags match.
fil_space_get_zip_size(): Rename to fil_space_get_flags(). Add a
wrapper for fil_space_get_zip_size().
fsp_header_get_flags(): New function.
fsp_header_init_fields(): Replace zip_size with flags.
FSP_SPACE_FLAGS: New name for the tablespace flags. This field used
to be called FSP_PAGE_ZIP_SIZE, or FSP_LOWEST_NO_WRITE. It has always
been written as 0 in MySQL/InnoDB versions 4.1 to 5.1.
MLOG_ZIP_FILE_CREATE: Rename to MLOG_FILE_CREATE2. Add a 32-bit
parameter for the tablespace flags.
ha_innobase::create(): Check the table attributes ROW_FORMAT and
KEY_BLOCK_SIZE. Issue errors if they are inappropriate, or warnings
if the inherited attributes (in ALTER TABLE) will be ignored.
PAGE_ZIP_MIN_SIZE_SHIFT: New constant: the 2-logarithm of PAGE_ZIP_MIN_SIZE.
2008-03-10 11:05:32 +00:00
|
|
|
an .ibd file, with format */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_ZIP_WRITE_NODE_PTR ((byte)48) /*!< write the node pointer of
|
2006-02-10 15:06:17 +00:00
|
|
|
a record on a compressed
|
|
|
|
non-leaf B-tree page */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_ZIP_WRITE_BLOB_PTR ((byte)49) /*!< write the BLOB pointer
|
2006-02-10 15:06:17 +00:00
|
|
|
of an externally stored column
|
|
|
|
on a compressed page */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_ZIP_WRITE_HEADER ((byte)50) /*!< write to compressed page
|
2006-02-22 13:02:40 +00:00
|
|
|
header */
|
2009-05-28 06:21:55 +00:00
|
|
|
#define MLOG_ZIP_PAGE_COMPRESS ((byte)51) /*!< compress an index page */
|
|
|
|
#define MLOG_BIGGEST_TYPE ((byte)51) /*!< biggest value (used in
|
|
|
|
assertions) */
|
|
|
|
/* @} */
|
2006-02-22 13:02:40 +00:00
|
|
|
|
2009-05-28 06:21:55 +00:00
|
|
|
/** @name Flags for MLOG_FILE operations
|
|
|
|
(stored in the page number parameter, called log_flags in the
|
|
|
|
functions). The page number parameter was originally written as 0. @{ */
|
|
|
|
#define MLOG_FILE_FLAG_TEMP 1 /*!< identifies TEMPORARY TABLE in
|
2009-04-29 19:23:27 +00:00
|
|
|
MLOG_FILE_CREATE, MLOG_FILE_CREATE2 */
|
2009-05-28 06:21:55 +00:00
|
|
|
/* @} */
|
2009-04-29 19:23:27 +00:00
|
|
|
|
2009-05-25 09:52:29 +00:00
|
|
|
/***************************************************************//**
|
2006-02-23 19:25:29 +00:00
|
|
|
Starts a mini-transaction and creates a mini-transaction handle
|
2009-05-25 05:30:14 +00:00
|
|
|
and buffer in the memory buffer given by the caller.
|
|
|
|
@return mtr buffer which also acts as the mtr handle */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
mtr_t*
|
|
|
|
mtr_start(
|
|
|
|
/*======*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mtr_t* mtr); /*!< in: memory buffer for the mtr buffer */
|
2009-05-25 09:52:29 +00:00
|
|
|
/***************************************************************//**
|
2005-10-27 07:29:40 +00:00
|
|
|
Commits a mini-transaction. */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
void
|
|
|
|
mtr_commit(
|
|
|
|
/*=======*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mtr_t* mtr); /*!< in: mini-transaction */
|
2009-05-25 09:52:29 +00:00
|
|
|
/**********************************************************//**
|
2009-05-25 05:30:14 +00:00
|
|
|
Sets and returns a savepoint in mtr.
|
|
|
|
@return savepoint */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
mtr_set_savepoint(
|
|
|
|
/*==============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mtr_t* mtr); /*!< in: mtr */
|
2009-05-25 09:52:29 +00:00
|
|
|
/**********************************************************//**
|
2005-10-27 07:29:40 +00:00
|
|
|
Releases the latches stored in an mtr memo down to a savepoint.
|
|
|
|
NOTE! The mtr must not have made changes to buffer pages after the
|
|
|
|
savepoint, as these can be handled only by mtr_commit. */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
void
|
|
|
|
mtr_rollback_to_savepoint(
|
|
|
|
/*======================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mtr_t* mtr, /*!< in: mtr */
|
|
|
|
ulint savepoint); /*!< in: savepoint */
|
2009-03-23 14:21:34 +00:00
|
|
|
#ifndef UNIV_HOTBACKUP
|
2009-05-25 09:52:29 +00:00
|
|
|
/**********************************************************//**
|
2005-10-27 07:29:40 +00:00
|
|
|
Releases the (index tree) s-latch stored in an mtr memo after a
|
|
|
|
savepoint. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
mtr_release_s_latch_at_savepoint(
|
|
|
|
/*=============================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mtr_t* mtr, /*!< in: mtr */
|
|
|
|
ulint savepoint, /*!< in: savepoint */
|
|
|
|
rw_lock_t* lock); /*!< in: latch to release */
|
2009-03-23 14:21:34 +00:00
|
|
|
#else /* !UNIV_HOTBACKUP */
|
|
|
|
# define mtr_release_s_latch_at_savepoint(mtr,savepoint,lock) ((void) 0)
|
|
|
|
#endif /* !UNIV_HOTBACKUP */
|
2009-05-25 09:52:29 +00:00
|
|
|
/***************************************************************//**
|
2009-05-25 05:30:14 +00:00
|
|
|
Gets the logging mode of a mini-transaction.
|
|
|
|
@return logging mode: MTR_LOG_NONE, ... */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
mtr_get_log_mode(
|
|
|
|
/*=============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mtr_t* mtr); /*!< in: mtr */
|
2009-05-25 09:52:29 +00:00
|
|
|
/***************************************************************//**
|
2009-05-25 05:30:14 +00:00
|
|
|
Changes the logging mode of a mini-transaction.
|
|
|
|
@return old mode */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
mtr_set_log_mode(
|
|
|
|
/*=============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mtr_t* mtr, /*!< in: mtr */
|
|
|
|
ulint mode); /*!< in: logging mode: MTR_LOG_NONE, ... */
|
2009-05-25 09:52:29 +00:00
|
|
|
/********************************************************//**
|
2009-05-25 05:30:14 +00:00
|
|
|
Reads 1 - 4 bytes from a file page buffered in the buffer pool.
|
|
|
|
@return value read */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
ulint
|
|
|
|
mtr_read_ulint(
|
|
|
|
/*===========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const byte* ptr, /*!< in: pointer from where to read */
|
|
|
|
ulint type, /*!< in: MLOG_1BYTE, MLOG_2BYTES, MLOG_4BYTES */
|
|
|
|
mtr_t* mtr); /*!< in: mini-transaction handle */
|
2009-05-25 09:52:29 +00:00
|
|
|
/********************************************************//**
|
2009-05-25 05:30:14 +00:00
|
|
|
Reads 8 bytes from a file page buffered in the buffer pool.
|
|
|
|
@return value read */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
dulint
|
|
|
|
mtr_read_dulint(
|
2006-02-23 19:25:29 +00:00
|
|
|
/*============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
const byte* ptr, /*!< in: pointer from where to read */
|
|
|
|
mtr_t* mtr); /*!< in: mini-transaction handle */
|
2009-03-23 14:21:34 +00:00
|
|
|
#ifndef UNIV_HOTBACKUP
|
2009-05-25 09:52:29 +00:00
|
|
|
/*********************************************************************//**
|
2005-10-27 07:29:40 +00:00
|
|
|
This macro locks an rw-lock in s-mode. */
|
|
|
|
#define mtr_s_lock(B, MTR) mtr_s_lock_func((B), __FILE__, __LINE__,\
|
|
|
|
(MTR))
|
2009-05-25 09:52:29 +00:00
|
|
|
/*********************************************************************//**
|
2005-10-27 07:29:40 +00:00
|
|
|
This macro locks an rw-lock in x-mode. */
|
|
|
|
#define mtr_x_lock(B, MTR) mtr_x_lock_func((B), __FILE__, __LINE__,\
|
|
|
|
(MTR))
|
2009-05-25 09:52:29 +00:00
|
|
|
/*********************************************************************//**
|
2005-10-27 07:29:40 +00:00
|
|
|
NOTE! Use the macro above!
|
|
|
|
Locks a lock in s-mode. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
mtr_s_lock_func(
|
|
|
|
/*============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
rw_lock_t* lock, /*!< in: rw-lock */
|
|
|
|
const char* file, /*!< in: file name */
|
|
|
|
ulint line, /*!< in: line number */
|
|
|
|
mtr_t* mtr); /*!< in: mtr */
|
2009-05-25 09:52:29 +00:00
|
|
|
/*********************************************************************//**
|
2005-10-27 07:29:40 +00:00
|
|
|
NOTE! Use the macro above!
|
|
|
|
Locks a lock in x-mode. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
mtr_x_lock_func(
|
|
|
|
/*============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
rw_lock_t* lock, /*!< in: rw-lock */
|
|
|
|
const char* file, /*!< in: file name */
|
|
|
|
ulint line, /*!< in: line number */
|
|
|
|
mtr_t* mtr); /*!< in: mtr */
|
2009-03-23 14:21:34 +00:00
|
|
|
#endif /* !UNIV_HOTBACKUP */
|
2005-10-27 07:29:40 +00:00
|
|
|
|
2009-05-25 09:52:29 +00:00
|
|
|
/***************************************************//**
|
2005-10-27 07:29:40 +00:00
|
|
|
Releases an object in the memo stack. */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
void
|
|
|
|
mtr_memo_release(
|
|
|
|
/*=============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mtr_t* mtr, /*!< in: mtr */
|
|
|
|
void* object, /*!< in: object */
|
|
|
|
ulint type); /*!< in: object type: MTR_MEMO_S_LOCK, ... */
|
2006-09-29 12:12:47 +00:00
|
|
|
#ifdef UNIV_DEBUG
|
2009-03-23 14:21:34 +00:00
|
|
|
# ifndef UNIV_HOTBACKUP
|
2009-05-25 09:52:29 +00:00
|
|
|
/**********************************************************//**
|
2009-05-25 05:30:14 +00:00
|
|
|
Checks if memo contains the given item.
|
|
|
|
@return TRUE if contains */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
ibool
|
|
|
|
mtr_memo_contains(
|
|
|
|
/*==============*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mtr_t* mtr, /*!< in: mtr */
|
|
|
|
const void* object, /*!< in: object to search */
|
|
|
|
ulint type); /*!< in: type of object */
|
2006-10-09 19:36:58 +00:00
|
|
|
|
2009-05-25 09:52:29 +00:00
|
|
|
/**********************************************************//**
|
2009-05-25 05:30:14 +00:00
|
|
|
Checks if memo contains the given page.
|
|
|
|
@return TRUE if contains */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2006-10-09 19:36:58 +00:00
|
|
|
ibool
|
|
|
|
mtr_memo_contains_page(
|
|
|
|
/*===================*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mtr_t* mtr, /*!< in: mtr */
|
|
|
|
const byte* ptr, /*!< in: pointer to buffer frame */
|
|
|
|
ulint type); /*!< in: type of object */
|
2009-05-25 09:52:29 +00:00
|
|
|
/*********************************************************//**
|
2005-10-27 07:29:40 +00:00
|
|
|
Prints info of an mtr handle. */
|
2008-02-18 18:38:33 +00:00
|
|
|
UNIV_INTERN
|
2005-10-27 07:29:40 +00:00
|
|
|
void
|
|
|
|
mtr_print(
|
|
|
|
/*======*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mtr_t* mtr); /*!< in: mtr */
|
2009-03-23 14:21:34 +00:00
|
|
|
# else /* !UNIV_HOTBACKUP */
|
|
|
|
# define mtr_memo_contains(mtr, object, type) TRUE
|
|
|
|
# define mtr_memo_contains_page(mtr, ptr, type) TRUE
|
|
|
|
# endif /* !UNIV_HOTBACKUP */
|
2006-09-29 12:12:47 +00:00
|
|
|
#endif /* UNIV_DEBUG */
|
2005-10-27 07:29:40 +00:00
|
|
|
/*######################################################################*/
|
|
|
|
|
|
|
|
#define MTR_BUF_MEMO_SIZE 200 /* number of slots in memo */
|
|
|
|
|
2009-05-25 09:52:29 +00:00
|
|
|
/***************************************************************//**
|
2009-05-25 05:30:14 +00:00
|
|
|
Returns the log object of a mini-transaction buffer.
|
|
|
|
@return log */
|
2005-10-27 07:29:40 +00:00
|
|
|
UNIV_INLINE
|
|
|
|
dyn_array_t*
|
|
|
|
mtr_get_log(
|
|
|
|
/*========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mtr_t* mtr); /*!< in: mini-transaction */
|
2009-05-25 09:52:29 +00:00
|
|
|
/***************************************************//**
|
2005-10-27 07:29:40 +00:00
|
|
|
Pushes an object to an mtr memo stack. */
|
|
|
|
UNIV_INLINE
|
|
|
|
void
|
|
|
|
mtr_memo_push(
|
|
|
|
/*==========*/
|
2009-05-25 05:30:14 +00:00
|
|
|
mtr_t* mtr, /*!< in: mtr */
|
|
|
|
void* object, /*!< in: object */
|
|
|
|
ulint type); /*!< in: object type: MTR_MEMO_S_LOCK, ... */
|
2005-10-27 07:29:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* Type definition of a mini-transaction memo stack slot. */
|
|
|
|
typedef struct mtr_memo_slot_struct mtr_memo_slot_t;
|
|
|
|
struct mtr_memo_slot_struct{
|
2009-05-26 12:28:49 +00:00
|
|
|
ulint type; /*!< type of the stored object (MTR_MEMO_S_LOCK, ...) */
|
|
|
|
void* object; /*!< pointer to the object */
|
2005-10-27 07:29:40 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Mini-transaction handle and buffer */
|
|
|
|
struct mtr_struct{
|
2006-08-16 09:35:36 +00:00
|
|
|
#ifdef UNIV_DEBUG
|
2009-05-26 12:28:49 +00:00
|
|
|
ulint state; /*!< MTR_ACTIVE, MTR_COMMITTING, MTR_COMMITTED */
|
2006-08-16 09:35:36 +00:00
|
|
|
#endif
|
2009-05-26 12:28:49 +00:00
|
|
|
dyn_array_t memo; /*!< memo stack for locks etc. */
|
|
|
|
dyn_array_t log; /*!< mini-transaction log */
|
2005-10-27 07:29:40 +00:00
|
|
|
ibool modifications;
|
|
|
|
/* TRUE if the mtr made modifications to
|
|
|
|
buffer pool pages */
|
|
|
|
ulint n_log_recs;
|
|
|
|
/* count of how many page initial log records
|
|
|
|
have been written to the mtr log */
|
|
|
|
ulint log_mode; /* specifies which operations should be
|
|
|
|
logged; default value MTR_LOG_ALL */
|
2006-11-29 14:52:16 +00:00
|
|
|
ib_uint64_t start_lsn;/* start lsn of the possible log entry for
|
2005-10-27 07:29:40 +00:00
|
|
|
this mtr */
|
2006-11-29 14:52:16 +00:00
|
|
|
ib_uint64_t end_lsn;/* end lsn of the possible log entry for
|
2005-10-27 07:29:40 +00:00
|
|
|
this mtr */
|
2009-01-12 12:40:08 +00:00
|
|
|
#ifdef UNIV_DEBUG
|
2005-10-27 07:29:40 +00:00
|
|
|
ulint magic_n;
|
2009-01-12 12:40:08 +00:00
|
|
|
#endif /* UNIV_DEBUG */
|
2005-10-27 07:29:40 +00:00
|
|
|
};
|
|
|
|
|
2009-01-12 12:40:08 +00:00
|
|
|
#ifdef UNIV_DEBUG
|
|
|
|
# define MTR_MAGIC_N 54551
|
|
|
|
#endif /* UNIV_DEBUG */
|
2005-10-27 07:29:40 +00:00
|
|
|
|
|
|
|
#define MTR_ACTIVE 12231
|
|
|
|
#define MTR_COMMITTING 56456
|
|
|
|
#define MTR_COMMITTED 34676
|
2006-02-23 19:25:29 +00:00
|
|
|
|
2005-10-27 07:29:40 +00:00
|
|
|
#ifndef UNIV_NONINL
|
|
|
|
#include "mtr0mtr.ic"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|