2014-02-26 19:11:54 +01:00
|
|
|
/*****************************************************************************
|
|
|
|
|
2014-05-06 21:13:16 +02:00
|
|
|
Copyright (c) 1995, 2014, Oracle and/or its affiliates. All Rights Reserved.
|
2014-03-03 14:27:56 +02:00
|
|
|
Copyright (c) 2013, 2014, SkySQL Ab. All Rights Reserved.
|
2014-02-26 19:11:54 +01:00
|
|
|
|
|
|
|
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/fil0fil.h
|
|
|
|
The low-level file system
|
|
|
|
|
|
|
|
Created 10/25/1995 Heikki Tuuri
|
|
|
|
*******************************************************/
|
|
|
|
|
|
|
|
#ifndef fil0fil_h
|
|
|
|
#define fil0fil_h
|
2014-12-22 16:53:17 +02:00
|
|
|
#define MSG_CANNOT_DECRYPT "can not decrypt"
|
2014-02-26 19:11:54 +01:00
|
|
|
#include "univ.i"
|
|
|
|
|
|
|
|
#ifndef UNIV_INNOCHECKSUM
|
|
|
|
|
|
|
|
#include "dict0types.h"
|
|
|
|
#include "ut0byte.h"
|
|
|
|
#include "os0file.h"
|
2014-10-25 08:21:52 +03:00
|
|
|
#include "hash0hash.h"
|
2014-02-26 19:11:54 +01:00
|
|
|
#ifndef UNIV_HOTBACKUP
|
|
|
|
#include "sync0rw.h"
|
|
|
|
#include "ibuf0types.h"
|
|
|
|
#include "log0log.h"
|
|
|
|
#endif /* !UNIV_HOTBACKUP */
|
|
|
|
|
|
|
|
#include <list>
|
|
|
|
|
|
|
|
// Forward declaration
|
|
|
|
struct trx_t;
|
|
|
|
struct fil_space_t;
|
|
|
|
|
|
|
|
typedef std::list<const char*> space_name_list_t;
|
|
|
|
|
|
|
|
/** When mysqld is run, the default directory "." is the mysqld datadir,
|
2014-09-11 10:13:35 +02:00
|
|
|
but in the MySQL Embedded Server Library and mysqlbackup it is not the default
|
2014-02-26 19:11:54 +01:00
|
|
|
directory, and we must set the base file path explicitly */
|
|
|
|
extern const char* fil_path_to_mysql_datadir;
|
|
|
|
|
|
|
|
/** Initial size of a single-table tablespace in pages */
|
|
|
|
#define FIL_IBD_FILE_INITIAL_SIZE 4
|
|
|
|
|
|
|
|
/** 'null' (undefined) page offset in the context of file spaces */
|
|
|
|
#define FIL_NULL ULINT32_UNDEFINED
|
|
|
|
|
|
|
|
/* Space address data type; this is intended to be used when
|
|
|
|
addresses accurate to a byte are stored in file pages. If the page part
|
|
|
|
of the address is FIL_NULL, the address is considered undefined. */
|
|
|
|
|
|
|
|
typedef byte fil_faddr_t; /*!< 'type' definition in C: an address
|
|
|
|
stored in a file page is a string of bytes */
|
2015-01-19 12:39:17 +02:00
|
|
|
|
|
|
|
#endif /* !UNIV_INNOCHECKSUM */
|
|
|
|
|
2014-02-26 19:11:54 +01:00
|
|
|
#define FIL_ADDR_PAGE 0 /* first in address is the page offset */
|
|
|
|
#define FIL_ADDR_BYTE 4 /* then comes 2-byte byte offset within page*/
|
|
|
|
|
|
|
|
#define FIL_ADDR_SIZE 6 /* address size is 6 bytes */
|
|
|
|
|
2015-01-19 12:39:17 +02:00
|
|
|
#ifndef UNIV_INNOCHECKSUM
|
|
|
|
|
2014-02-26 19:11:54 +01:00
|
|
|
/** File space address */
|
|
|
|
struct fil_addr_t{
|
|
|
|
ulint page; /*!< page number within a space */
|
|
|
|
ulint boffset; /*!< byte offset within the page */
|
|
|
|
};
|
|
|
|
|
|
|
|
/** The null file address */
|
|
|
|
extern fil_addr_t fil_addr_null;
|
|
|
|
|
|
|
|
#endif /* !UNIV_INNOCHECKSUM */
|
|
|
|
|
|
|
|
/** The byte offsets on a file page for various variables @{ */
|
|
|
|
#define FIL_PAGE_SPACE_OR_CHKSUM 0 /*!< in < MySQL-4.0.14 space id the
|
|
|
|
page belongs to (== 0) but in later
|
|
|
|
versions the 'new' checksum of the
|
|
|
|
page */
|
|
|
|
#define FIL_PAGE_OFFSET 4 /*!< page offset inside space */
|
|
|
|
#define FIL_PAGE_PREV 8 /*!< if there is a 'natural'
|
|
|
|
predecessor of the page, its
|
|
|
|
offset. Otherwise FIL_NULL.
|
|
|
|
This field is not set on BLOB
|
|
|
|
pages, which are stored as a
|
|
|
|
singly-linked list. See also
|
|
|
|
FIL_PAGE_NEXT. */
|
|
|
|
#define FIL_PAGE_NEXT 12 /*!< if there is a 'natural' successor
|
|
|
|
of the page, its offset.
|
|
|
|
Otherwise FIL_NULL.
|
|
|
|
B-tree index pages
|
|
|
|
(FIL_PAGE_TYPE contains FIL_PAGE_INDEX)
|
|
|
|
on the same PAGE_LEVEL are maintained
|
|
|
|
as a doubly linked list via
|
|
|
|
FIL_PAGE_PREV and FIL_PAGE_NEXT
|
|
|
|
in the collation order of the
|
|
|
|
smallest user record on each page. */
|
|
|
|
#define FIL_PAGE_LSN 16 /*!< lsn of the end of the newest
|
|
|
|
modification log record to the page */
|
|
|
|
#define FIL_PAGE_TYPE 24 /*!< file page type: FIL_PAGE_INDEX,...,
|
|
|
|
2 bytes.
|
|
|
|
|
|
|
|
The contents of this field can only
|
|
|
|
be trusted in the following case:
|
|
|
|
if the page is an uncompressed
|
|
|
|
B-tree index page, then it is
|
|
|
|
guaranteed that the value is
|
|
|
|
FIL_PAGE_INDEX.
|
|
|
|
The opposite does not hold.
|
|
|
|
|
|
|
|
In tablespaces created by
|
|
|
|
MySQL/InnoDB 5.1.7 or later, the
|
|
|
|
contents of this field is valid
|
|
|
|
for all uncompressed pages. */
|
2014-12-22 16:53:17 +02:00
|
|
|
#define FIL_PAGE_FILE_FLUSH_LSN_OR_KEY_VERSION 26 /*!< for the first page
|
|
|
|
in a system tablespace data file
|
|
|
|
(ibdata*, not *.ibd): the file has
|
|
|
|
been flushed to disk at least up
|
|
|
|
to this lsn
|
|
|
|
for other pages: a 32-bit key version
|
|
|
|
used to encrypt the page + 32-bit checksum
|
|
|
|
or 64 bits of zero if no encryption
|
|
|
|
*/
|
2014-07-21 22:21:30 +03:00
|
|
|
/** If page type is FIL_PAGE_COMPRESSED then the 8 bytes starting at
|
|
|
|
FIL_PAGE_FILE_FLUSH_LSN are broken down as follows: */
|
|
|
|
|
|
|
|
/** Control information version format (u8) */
|
2014-12-22 16:53:17 +02:00
|
|
|
static const ulint FIL_PAGE_VERSION = FIL_PAGE_FILE_FLUSH_LSN_OR_KEY_VERSION;
|
2014-07-21 22:21:30 +03:00
|
|
|
|
|
|
|
/** Compression algorithm (u8) */
|
|
|
|
static const ulint FIL_PAGE_ALGORITHM_V1 = FIL_PAGE_VERSION + 1;
|
|
|
|
|
|
|
|
/** Original page type (u16) */
|
|
|
|
static const ulint FIL_PAGE_ORIGINAL_TYPE_V1 = FIL_PAGE_ALGORITHM_V1 + 1;
|
|
|
|
|
|
|
|
/** Original data size in bytes (u16)*/
|
|
|
|
static const ulint FIL_PAGE_ORIGINAL_SIZE_V1 = FIL_PAGE_ORIGINAL_TYPE_V1 + 2;
|
|
|
|
|
|
|
|
/** Size after compression (u16)*/
|
|
|
|
static const ulint FIL_PAGE_COMPRESS_SIZE_V1 = FIL_PAGE_ORIGINAL_SIZE_V1 + 2;
|
|
|
|
|
2014-02-26 19:11:54 +01:00
|
|
|
#define FIL_PAGE_ARCH_LOG_NO_OR_SPACE_ID 34 /*!< starting from 4.1.x this
|
|
|
|
contains the space id of the page */
|
2014-05-05 18:20:28 +02:00
|
|
|
#define FIL_PAGE_SPACE_ID FIL_PAGE_ARCH_LOG_NO_OR_SPACE_ID
|
|
|
|
|
2014-02-26 19:11:54 +01:00
|
|
|
#define FIL_PAGE_DATA 38 /*!< start of the data on the page */
|
2013-12-19 14:36:38 +02:00
|
|
|
/* Following are used when page compression is used */
|
|
|
|
#define FIL_PAGE_COMPRESSED_SIZE 2 /*!< Number of bytes used to store
|
|
|
|
actual payload data size on
|
|
|
|
compressed pages. */
|
2014-02-26 19:11:54 +01:00
|
|
|
/* @} */
|
|
|
|
/** File page trailer @{ */
|
|
|
|
#define FIL_PAGE_END_LSN_OLD_CHKSUM 8 /*!< the low 4 bytes of this are used
|
|
|
|
to store the page checksum, the
|
|
|
|
last 4 bytes should be identical
|
|
|
|
to the last 4 bytes of FIL_PAGE_LSN */
|
|
|
|
#define FIL_PAGE_DATA_END 8 /*!< size of the page trailer */
|
|
|
|
/* @} */
|
|
|
|
|
|
|
|
/** File page types (values of FIL_PAGE_TYPE) @{ */
|
2014-12-22 16:53:17 +02:00
|
|
|
#define FIL_PAGE_PAGE_COMPRESSED_ENCRYPTED 35631 /* page compressed +
|
|
|
|
encrypted page */
|
2013-12-19 14:36:38 +02:00
|
|
|
#define FIL_PAGE_PAGE_COMPRESSED 34354 /*!< page compressed page */
|
2014-12-22 16:53:17 +02:00
|
|
|
#define FIL_PAGE_PAGE_ENCRYPTED 34355 /*!< Page encrypted page */
|
2014-02-26 19:11:54 +01:00
|
|
|
#define FIL_PAGE_INDEX 17855 /*!< B-tree node */
|
|
|
|
#define FIL_PAGE_UNDO_LOG 2 /*!< Undo log page */
|
|
|
|
#define FIL_PAGE_INODE 3 /*!< Index node */
|
|
|
|
#define FIL_PAGE_IBUF_FREE_LIST 4 /*!< Insert buffer free list */
|
|
|
|
/* File page types introduced in MySQL/InnoDB 5.1.7 */
|
|
|
|
#define FIL_PAGE_TYPE_ALLOCATED 0 /*!< Freshly allocated page */
|
|
|
|
#define FIL_PAGE_IBUF_BITMAP 5 /*!< Insert buffer bitmap */
|
|
|
|
#define FIL_PAGE_TYPE_SYS 6 /*!< System page */
|
|
|
|
#define FIL_PAGE_TYPE_TRX_SYS 7 /*!< Transaction system data */
|
|
|
|
#define FIL_PAGE_TYPE_FSP_HDR 8 /*!< File space header */
|
|
|
|
#define FIL_PAGE_TYPE_XDES 9 /*!< Extent descriptor page */
|
|
|
|
#define FIL_PAGE_TYPE_BLOB 10 /*!< Uncompressed BLOB page */
|
|
|
|
#define FIL_PAGE_TYPE_ZBLOB 11 /*!< First compressed BLOB page */
|
|
|
|
#define FIL_PAGE_TYPE_ZBLOB2 12 /*!< Subsequent compressed BLOB page */
|
2014-07-25 14:37:10 +03:00
|
|
|
#define FIL_PAGE_TYPE_COMPRESSED 13 /*!< Compressed page */
|
|
|
|
#define FIL_PAGE_TYPE_LAST FIL_PAGE_TYPE_COMPRESSED
|
2014-02-26 19:11:54 +01:00
|
|
|
/*!< Last page type */
|
|
|
|
/* @} */
|
|
|
|
|
|
|
|
/** Space types @{ */
|
|
|
|
#define FIL_TABLESPACE 501 /*!< tablespace */
|
|
|
|
#define FIL_LOG 502 /*!< redo log */
|
|
|
|
/* @} */
|
|
|
|
|
2015-01-19 12:39:17 +02:00
|
|
|
#ifndef UNIV_INNOCHECKSUM
|
|
|
|
|
2014-02-26 19:11:54 +01:00
|
|
|
/** The number of fsyncs done to the log */
|
|
|
|
extern ulint fil_n_log_flushes;
|
|
|
|
|
|
|
|
/** Number of pending redo log flushes */
|
|
|
|
extern ulint fil_n_pending_log_flushes;
|
|
|
|
/** Number of pending tablespace flushes */
|
|
|
|
extern ulint fil_n_pending_tablespace_flushes;
|
|
|
|
|
|
|
|
/** Number of files currently open */
|
|
|
|
extern ulint fil_n_file_opened;
|
|
|
|
|
2014-12-22 16:53:17 +02:00
|
|
|
/* structure containing encryption specification */
|
|
|
|
typedef struct fil_space_crypt_struct fil_space_crypt_t;
|
|
|
|
|
2014-05-06 21:13:16 +02:00
|
|
|
struct fsp_open_info {
|
|
|
|
ibool success; /*!< Has the tablespace been opened? */
|
|
|
|
const char* check_msg; /*!< fil_check_first_page() message */
|
|
|
|
ibool valid; /*!< Is the tablespace valid? */
|
|
|
|
os_file_t file; /*!< File handle */
|
|
|
|
char* filepath; /*!< File path to open */
|
|
|
|
lsn_t lsn; /*!< Flushed LSN from header page */
|
|
|
|
ulint id; /*!< Space ID */
|
|
|
|
ulint flags; /*!< Tablespace flags */
|
2014-12-22 16:53:17 +02:00
|
|
|
ulint encryption_error; /*!< if an encryption error occurs */
|
2014-05-06 21:13:16 +02:00
|
|
|
#ifdef UNIV_LOG_ARCHIVE
|
|
|
|
ulint arch_log_no; /*!< latest archived log file number */
|
|
|
|
#endif /* UNIV_LOG_ARCHIVE */
|
2014-12-22 16:53:17 +02:00
|
|
|
fil_space_crypt_t* crypt_data; /*!< crypt data */
|
2014-05-06 21:13:16 +02:00
|
|
|
};
|
|
|
|
|
2014-10-25 08:21:52 +03:00
|
|
|
struct fil_space_t;
|
|
|
|
|
|
|
|
/** File node of a tablespace or the log data space */
|
|
|
|
struct fil_node_t {
|
|
|
|
fil_space_t* space; /*!< backpointer to the space where this node
|
|
|
|
belongs */
|
|
|
|
char* name; /*!< path to the file */
|
|
|
|
ibool open; /*!< TRUE if file open */
|
|
|
|
os_file_t handle; /*!< OS handle to the file, if file open */
|
|
|
|
os_event_t sync_event;/*!< Condition event to group and
|
|
|
|
serialize calls to fsync */
|
|
|
|
ibool is_raw_disk;/*!< TRUE if the 'file' is actually a raw
|
|
|
|
device or a raw disk partition */
|
|
|
|
ulint size; /*!< size of the file in database pages, 0 if
|
|
|
|
not known yet; the possible last incomplete
|
|
|
|
megabyte may be ignored if space == 0 */
|
|
|
|
ulint n_pending;
|
|
|
|
/*!< count of pending i/o's on this file;
|
|
|
|
closing of the file is not allowed if
|
|
|
|
this is > 0 */
|
|
|
|
ulint n_pending_flushes;
|
|
|
|
/*!< count of pending flushes on this file;
|
|
|
|
closing of the file is not allowed if
|
|
|
|
this is > 0 */
|
|
|
|
ibool being_extended;
|
|
|
|
/*!< TRUE if the node is currently
|
|
|
|
being extended. */
|
|
|
|
ib_int64_t modification_counter;/*!< when we write to the file we
|
|
|
|
increment this by one */
|
|
|
|
ib_int64_t flush_counter;/*!< up to what
|
|
|
|
modification_counter value we have
|
|
|
|
flushed the modifications to disk */
|
2014-12-02 22:25:16 +01:00
|
|
|
ulint file_block_size;/*!< file system block size */
|
2014-10-25 08:21:52 +03:00
|
|
|
UT_LIST_NODE_T(fil_node_t) chain;
|
|
|
|
/*!< link field for the file chain */
|
|
|
|
UT_LIST_NODE_T(fil_node_t) LRU;
|
|
|
|
/*!< link field for the LRU list */
|
|
|
|
ulint magic_n;/*!< FIL_NODE_MAGIC_N */
|
|
|
|
};
|
|
|
|
|
|
|
|
/** Value of fil_node_t::magic_n */
|
|
|
|
#define FIL_NODE_MAGIC_N 89389
|
|
|
|
|
|
|
|
/** Tablespace or log data space: let us call them by a common name space */
|
|
|
|
struct fil_space_t {
|
|
|
|
char* name; /*!< space name = the path to the first file in
|
|
|
|
it */
|
|
|
|
ulint id; /*!< space id */
|
|
|
|
ib_int64_t tablespace_version;
|
|
|
|
/*!< in DISCARD/IMPORT this timestamp
|
|
|
|
is used to check if we should ignore
|
|
|
|
an insert buffer merge request for a
|
|
|
|
page because it actually was for the
|
|
|
|
previous incarnation of the space */
|
|
|
|
ibool mark; /*!< this is set to TRUE at database startup if
|
|
|
|
the space corresponds to a table in the InnoDB
|
|
|
|
data dictionary; so we can print a warning of
|
|
|
|
orphaned tablespaces */
|
|
|
|
ibool stop_ios;/*!< TRUE if we want to rename the
|
|
|
|
.ibd file of tablespace and want to
|
|
|
|
stop temporarily posting of new i/o
|
|
|
|
requests on the file */
|
|
|
|
ibool stop_new_ops;
|
|
|
|
/*!< we set this TRUE when we start
|
|
|
|
deleting a single-table tablespace.
|
|
|
|
When this is set following new ops
|
|
|
|
are not allowed:
|
|
|
|
* read IO request
|
|
|
|
* ibuf merge
|
|
|
|
* file flush
|
|
|
|
Note that we can still possibly have
|
|
|
|
new write operations because we don't
|
|
|
|
check this flag when doing flush
|
|
|
|
batches. */
|
|
|
|
ulint purpose;/*!< FIL_TABLESPACE, FIL_LOG, or
|
|
|
|
FIL_ARCH_LOG */
|
|
|
|
UT_LIST_BASE_NODE_T(fil_node_t) chain;
|
|
|
|
/*!< base node for the file chain */
|
|
|
|
ulint size; /*!< space size in pages; 0 if a single-table
|
|
|
|
tablespace whose size we do not know yet;
|
|
|
|
last incomplete megabytes in data files may be
|
|
|
|
ignored if space == 0 */
|
|
|
|
ulint flags; /*!< tablespace flags; see
|
|
|
|
fsp_flags_is_valid(),
|
|
|
|
fsp_flags_get_zip_size() */
|
|
|
|
ulint n_reserved_extents;
|
|
|
|
/*!< number of reserved free extents for
|
|
|
|
ongoing operations like B-tree page split */
|
|
|
|
ulint n_pending_flushes; /*!< this is positive when flushing
|
|
|
|
the tablespace to disk; dropping of the
|
|
|
|
tablespace is forbidden if this is positive */
|
|
|
|
ulint n_pending_ops;/*!< this is positive when we
|
|
|
|
have pending operations against this
|
|
|
|
tablespace. The pending operations can
|
|
|
|
be ibuf merges or lock validation code
|
|
|
|
trying to read a block.
|
|
|
|
Dropping of the tablespace is forbidden
|
|
|
|
if this is positive */
|
|
|
|
hash_node_t hash; /*!< hash chain node */
|
|
|
|
hash_node_t name_hash;/*!< hash chain the name_hash table */
|
|
|
|
#ifndef UNIV_HOTBACKUP
|
|
|
|
rw_lock_t latch; /*!< latch protecting the file space storage
|
|
|
|
allocation */
|
|
|
|
#endif /* !UNIV_HOTBACKUP */
|
|
|
|
UT_LIST_NODE_T(fil_space_t) unflushed_spaces;
|
|
|
|
/*!< list of spaces with at least one unflushed
|
|
|
|
file we have written to */
|
|
|
|
bool is_in_unflushed_spaces;
|
|
|
|
/*!< true if this space is currently in
|
|
|
|
unflushed_spaces */
|
|
|
|
UT_LIST_NODE_T(fil_space_t) space_list;
|
|
|
|
/*!< list of all spaces */
|
2014-12-22 16:53:17 +02:00
|
|
|
fil_space_crypt_t* crypt_data;
|
2014-10-25 08:21:52 +03:00
|
|
|
ulint magic_n;/*!< FIL_SPACE_MAGIC_N */
|
|
|
|
};
|
|
|
|
|
|
|
|
/** Value of fil_space_t::magic_n */
|
|
|
|
#define FIL_SPACE_MAGIC_N 89472
|
|
|
|
|
|
|
|
/** The tablespace memory cache; also the totality of logs (the log
|
|
|
|
data space) is stored here; below we talk about tablespaces, but also
|
|
|
|
the ib_logfiles form a 'space' and it is handled here */
|
|
|
|
struct fil_system_t {
|
|
|
|
#ifndef UNIV_HOTBACKUP
|
|
|
|
ib_mutex_t mutex; /*!< The mutex protecting the cache */
|
|
|
|
#endif /* !UNIV_HOTBACKUP */
|
|
|
|
hash_table_t* spaces; /*!< The hash table of spaces in the
|
|
|
|
system; they are hashed on the space
|
|
|
|
id */
|
|
|
|
hash_table_t* name_hash; /*!< hash table based on the space
|
|
|
|
name */
|
|
|
|
UT_LIST_BASE_NODE_T(fil_node_t) LRU;
|
|
|
|
/*!< base node for the LRU list of the
|
|
|
|
most recently used open files with no
|
|
|
|
pending i/o's; if we start an i/o on
|
|
|
|
the file, we first remove it from this
|
|
|
|
list, and return it to the start of
|
|
|
|
the list when the i/o ends;
|
|
|
|
log files and the system tablespace are
|
|
|
|
not put to this list: they are opened
|
|
|
|
after the startup, and kept open until
|
|
|
|
shutdown */
|
|
|
|
UT_LIST_BASE_NODE_T(fil_space_t) unflushed_spaces;
|
|
|
|
/*!< base node for the list of those
|
|
|
|
tablespaces whose files contain
|
|
|
|
unflushed writes; those spaces have
|
|
|
|
at least one file node where
|
|
|
|
modification_counter > flush_counter */
|
|
|
|
ulint n_open; /*!< number of files currently open */
|
|
|
|
ulint max_n_open; /*!< n_open is not allowed to exceed
|
|
|
|
this */
|
|
|
|
ib_int64_t modification_counter;/*!< when we write to a file we
|
|
|
|
increment this by one */
|
|
|
|
ulint max_assigned_id;/*!< maximum space id in the existing
|
|
|
|
tables, or assigned during the time
|
|
|
|
mysqld has been up; at an InnoDB
|
|
|
|
startup we scan the data dictionary
|
|
|
|
and set here the maximum of the
|
|
|
|
space id's of the tables there */
|
|
|
|
ib_int64_t tablespace_version;
|
|
|
|
/*!< a counter which is incremented for
|
|
|
|
every space object memory creation;
|
|
|
|
every space mem object gets a
|
|
|
|
'timestamp' from this; in DISCARD/
|
|
|
|
IMPORT this is used to check if we
|
|
|
|
should ignore an insert buffer merge
|
|
|
|
request */
|
|
|
|
UT_LIST_BASE_NODE_T(fil_space_t) space_list;
|
|
|
|
/*!< list of all file spaces */
|
|
|
|
ibool space_id_reuse_warned;
|
|
|
|
/* !< TRUE if fil_space_create()
|
|
|
|
has issued a warning about
|
|
|
|
potential space_id reuse */
|
|
|
|
};
|
|
|
|
|
|
|
|
/** The tablespace memory cache. This variable is NULL before the module is
|
|
|
|
initialized. */
|
|
|
|
extern fil_system_t* fil_system;
|
|
|
|
|
2014-02-26 19:11:54 +01:00
|
|
|
#ifndef UNIV_HOTBACKUP
|
|
|
|
/*******************************************************************//**
|
|
|
|
Returns the version number of a tablespace, -1 if not found.
|
|
|
|
@return version number, -1 if the tablespace does not exist in the
|
|
|
|
memory cache */
|
|
|
|
UNIV_INTERN
|
|
|
|
ib_int64_t
|
|
|
|
fil_space_get_version(
|
|
|
|
/*==================*/
|
|
|
|
ulint id); /*!< in: space id */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Returns the latch of a file space.
|
|
|
|
@return latch protecting storage allocation */
|
|
|
|
UNIV_INTERN
|
|
|
|
rw_lock_t*
|
|
|
|
fil_space_get_latch(
|
|
|
|
/*================*/
|
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
ulint* zip_size);/*!< out: compressed page size, or
|
|
|
|
0 for uncompressed tablespaces */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Returns the type of a file space.
|
|
|
|
@return FIL_TABLESPACE or FIL_LOG */
|
|
|
|
UNIV_INTERN
|
|
|
|
ulint
|
|
|
|
fil_space_get_type(
|
|
|
|
/*===============*/
|
|
|
|
ulint id); /*!< in: space id */
|
2013-12-19 14:36:38 +02:00
|
|
|
|
2014-02-26 19:11:54 +01:00
|
|
|
#endif /* !UNIV_HOTBACKUP */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Appends a new file to the chain of files of a space. File must be closed.
|
|
|
|
@return pointer to the file name, or NULL on error */
|
|
|
|
UNIV_INTERN
|
|
|
|
char*
|
|
|
|
fil_node_create(
|
|
|
|
/*============*/
|
|
|
|
const char* name, /*!< in: file name (file must be closed) */
|
|
|
|
ulint size, /*!< in: file size in database blocks, rounded
|
|
|
|
downwards to an integer */
|
|
|
|
ulint id, /*!< in: space id where to append */
|
|
|
|
ibool is_raw) /*!< in: TRUE if a raw device or
|
|
|
|
a raw disk partition */
|
|
|
|
__attribute__((nonnull, warn_unused_result));
|
|
|
|
#ifdef UNIV_LOG_ARCHIVE
|
|
|
|
/****************************************************************//**
|
|
|
|
Drops files from the start of a file space, so that its size is cut by
|
|
|
|
the amount given. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_space_truncate_start(
|
|
|
|
/*=====================*/
|
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
ulint trunc_len); /*!< in: truncate by this much; it is an error
|
|
|
|
if this does not equal to the combined size of
|
|
|
|
some initial files in the space */
|
|
|
|
#endif /* UNIV_LOG_ARCHIVE */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Creates a space memory object and puts it to the 'fil system' hash table.
|
|
|
|
If there is an error, prints an error message to the .err log.
|
|
|
|
@return TRUE if success */
|
|
|
|
UNIV_INTERN
|
|
|
|
ibool
|
|
|
|
fil_space_create(
|
|
|
|
/*=============*/
|
|
|
|
const char* name, /*!< in: space name */
|
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
ulint zip_size,/*!< in: compressed page size, or
|
|
|
|
0 for uncompressed tablespaces */
|
2014-12-22 16:53:17 +02:00
|
|
|
ulint purpose, /*!< in: FIL_TABLESPACE, or FIL_LOG if log */
|
|
|
|
fil_space_crypt_t* crypt_data); /*!< in: crypt data */
|
|
|
|
|
2014-02-26 19:11:54 +01:00
|
|
|
/*******************************************************************//**
|
|
|
|
Assigns a new space id for a new single-table tablespace. This works simply by
|
|
|
|
incrementing the global counter. If 4 billion id's is not enough, we may need
|
|
|
|
to recycle id's.
|
|
|
|
@return TRUE if assigned, FALSE if not */
|
|
|
|
UNIV_INTERN
|
|
|
|
ibool
|
|
|
|
fil_assign_new_space_id(
|
|
|
|
/*====================*/
|
|
|
|
ulint* space_id); /*!< in/out: space id */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Returns the path from the first fil_node_t found for the space ID sent.
|
|
|
|
The caller is responsible for freeing the memory allocated here for the
|
|
|
|
value returned.
|
|
|
|
@return a copy of fil_node_t::path, NULL if space is zero or not found. */
|
|
|
|
UNIV_INTERN
|
|
|
|
char*
|
|
|
|
fil_space_get_first_path(
|
|
|
|
/*=====================*/
|
|
|
|
ulint id); /*!< in: space id */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Returns the size of the space in pages. The tablespace must be cached in the
|
|
|
|
memory cache.
|
|
|
|
@return space size, 0 if space not found */
|
|
|
|
UNIV_INTERN
|
|
|
|
ulint
|
|
|
|
fil_space_get_size(
|
|
|
|
/*===============*/
|
|
|
|
ulint id); /*!< in: space id */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Returns the flags of the space. The tablespace must be cached
|
|
|
|
in the memory cache.
|
|
|
|
@return flags, ULINT_UNDEFINED if space not found */
|
|
|
|
UNIV_INTERN
|
|
|
|
ulint
|
|
|
|
fil_space_get_flags(
|
|
|
|
/*================*/
|
|
|
|
ulint id); /*!< in: space id */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Returns the compressed page size of the space, or 0 if the space
|
|
|
|
is not compressed. The tablespace must be cached in the memory cache.
|
|
|
|
@return compressed page size, ULINT_UNDEFINED if space not found */
|
|
|
|
UNIV_INTERN
|
|
|
|
ulint
|
|
|
|
fil_space_get_zip_size(
|
|
|
|
/*===================*/
|
|
|
|
ulint id); /*!< in: space id */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Checks if the pair space, page_no refers to an existing page in a tablespace
|
|
|
|
file space. The tablespace must be cached in the memory cache.
|
|
|
|
@return TRUE if the address is meaningful */
|
|
|
|
UNIV_INTERN
|
|
|
|
ibool
|
|
|
|
fil_check_adress_in_tablespace(
|
|
|
|
/*===========================*/
|
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
ulint page_no);/*!< in: page number */
|
|
|
|
/****************************************************************//**
|
|
|
|
Initializes the tablespace memory cache. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_init(
|
|
|
|
/*=====*/
|
|
|
|
ulint hash_size, /*!< in: hash table size */
|
|
|
|
ulint max_n_open); /*!< in: max number of open files */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Initializes the tablespace memory cache. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_close(void);
|
|
|
|
/*===========*/
|
|
|
|
/*******************************************************************//**
|
|
|
|
Opens all log files and system tablespace data files. They stay open until the
|
|
|
|
database server shutdown. This should be called at a server startup after the
|
|
|
|
space objects for the log and the system tablespace have been created. The
|
|
|
|
purpose of this operation is to make sure we never run out of file descriptors
|
|
|
|
if we need to read from the insert buffer or to write to the log. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_open_log_and_system_tablespace_files(void);
|
|
|
|
/*==========================================*/
|
|
|
|
/*******************************************************************//**
|
|
|
|
Closes all open files. There must not be any pending i/o's or not flushed
|
|
|
|
modifications in the files. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_close_all_files(void);
|
|
|
|
/*=====================*/
|
|
|
|
/*******************************************************************//**
|
|
|
|
Closes the redo log files. There must not be any pending i/o's or not
|
|
|
|
flushed modifications in the files. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_close_log_files(
|
|
|
|
/*================*/
|
|
|
|
bool free); /*!< in: whether to free the memory object */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Sets the max tablespace id counter if the given number is bigger than the
|
|
|
|
previous value. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_set_max_space_id_if_bigger(
|
|
|
|
/*===========================*/
|
|
|
|
ulint max_id);/*!< in: maximum known id */
|
|
|
|
#ifndef UNIV_HOTBACKUP
|
|
|
|
/****************************************************************//**
|
|
|
|
Writes the flushed lsn and the latest archived log number to the page
|
|
|
|
header of the first page of each data file in the system tablespace.
|
|
|
|
@return DB_SUCCESS or error number */
|
|
|
|
UNIV_INTERN
|
|
|
|
dberr_t
|
|
|
|
fil_write_flushed_lsn_to_data_files(
|
|
|
|
/*================================*/
|
|
|
|
lsn_t lsn, /*!< in: lsn to write */
|
|
|
|
ulint arch_log_no); /*!< in: latest archived log file number */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Reads the flushed lsn, arch no, and tablespace flag fields from a data
|
|
|
|
file at database startup.
|
|
|
|
@retval NULL on success, or if innodb_force_recovery is set
|
|
|
|
@return pointer to an error message string */
|
|
|
|
UNIV_INTERN
|
|
|
|
const char*
|
|
|
|
fil_read_first_page(
|
|
|
|
/*================*/
|
|
|
|
os_file_t data_file, /*!< in: open data file */
|
|
|
|
ibool one_read_already, /*!< in: TRUE if min and max
|
|
|
|
parameters below already
|
|
|
|
contain sensible data */
|
|
|
|
ulint* flags, /*!< out: tablespace flags */
|
|
|
|
ulint* space_id, /*!< out: tablespace ID */
|
|
|
|
#ifdef UNIV_LOG_ARCHIVE
|
|
|
|
ulint* min_arch_log_no, /*!< out: min of archived
|
|
|
|
log numbers in data files */
|
|
|
|
ulint* max_arch_log_no, /*!< out: max of archived
|
|
|
|
log numbers in data files */
|
|
|
|
#endif /* UNIV_LOG_ARCHIVE */
|
|
|
|
lsn_t* min_flushed_lsn, /*!< out: min of flushed
|
|
|
|
lsn values in data files */
|
2014-07-25 14:37:10 +03:00
|
|
|
lsn_t* max_flushed_lsn, /*!< out: max of flushed
|
2014-02-26 19:11:54 +01:00
|
|
|
lsn values in data files */
|
2014-12-22 16:53:17 +02:00
|
|
|
ulint orig_space_id, /*!< in: file space id or
|
2014-07-25 14:37:10 +03:00
|
|
|
ULINT_UNDEFINED */
|
2014-12-22 16:53:17 +02:00
|
|
|
fil_space_crypt_t** crypt_data) /*!< out: crypt data */
|
|
|
|
|
2014-02-26 19:11:54 +01:00
|
|
|
__attribute__((warn_unused_result));
|
|
|
|
/*******************************************************************//**
|
|
|
|
Increments the count of pending operation, if space is not being deleted.
|
|
|
|
@return TRUE if being deleted, and operation should be skipped */
|
|
|
|
UNIV_INTERN
|
|
|
|
ibool
|
|
|
|
fil_inc_pending_ops(
|
|
|
|
/*================*/
|
2015-01-19 00:11:05 +01:00
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
ibool print_err); /*!< in: need to print error or not */
|
2014-02-26 19:11:54 +01:00
|
|
|
/*******************************************************************//**
|
|
|
|
Decrements the count of pending operations. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_decr_pending_ops(
|
|
|
|
/*=================*/
|
|
|
|
ulint id); /*!< in: space id */
|
|
|
|
#endif /* !UNIV_HOTBACKUP */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Parses the body of a log record written about an .ibd file operation. That is,
|
|
|
|
the log record part after the standard (type, space id, page no) header of the
|
|
|
|
log record.
|
|
|
|
|
|
|
|
If desired, also replays the delete or rename operation if the .ibd file
|
|
|
|
exists and the space id in it matches. Replays the create operation if a file
|
|
|
|
at that path does not exist yet. If the database directory for the file to be
|
|
|
|
created does not exist, then we create the directory, too.
|
|
|
|
|
2014-09-11 10:13:35 +02:00
|
|
|
Note that mysqlbackup --apply-log sets fil_path_to_mysql_datadir to point to
|
|
|
|
the datadir that we should use in replaying the file operations.
|
2014-02-26 19:11:54 +01:00
|
|
|
@return end of log record, or NULL if the record was not completely
|
|
|
|
contained between ptr and end_ptr */
|
|
|
|
UNIV_INTERN
|
|
|
|
byte*
|
|
|
|
fil_op_log_parse_or_replay(
|
|
|
|
/*=======================*/
|
|
|
|
byte* ptr, /*!< in: buffer containing the log record body,
|
|
|
|
or an initial segment of it, if the record does
|
|
|
|
not fir completely between ptr and end_ptr */
|
|
|
|
byte* end_ptr, /*!< in: buffer end */
|
|
|
|
ulint type, /*!< in: the type of this log record */
|
|
|
|
ulint space_id, /*!< in: the space id of the tablespace in
|
|
|
|
question, or 0 if the log record should
|
|
|
|
only be parsed but not replayed */
|
|
|
|
ulint log_flags); /*!< in: redo log flags
|
|
|
|
(stored in the page number parameter) */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Deletes a single-table tablespace. The tablespace must be cached in the
|
|
|
|
memory cache.
|
|
|
|
@return TRUE if success */
|
|
|
|
UNIV_INTERN
|
|
|
|
dberr_t
|
|
|
|
fil_delete_tablespace(
|
|
|
|
/*==================*/
|
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
buf_remove_t buf_remove); /*!< in: specify the action to take
|
|
|
|
on the tables pages in the buffer
|
|
|
|
pool */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Closes a single-table tablespace. The tablespace must be cached in the
|
|
|
|
memory cache. Free all pages used by the tablespace.
|
|
|
|
@return DB_SUCCESS or error */
|
|
|
|
UNIV_INTERN
|
|
|
|
dberr_t
|
|
|
|
fil_close_tablespace(
|
|
|
|
/*=================*/
|
|
|
|
trx_t* trx, /*!< in/out: Transaction covering the close */
|
|
|
|
ulint id); /*!< in: space id */
|
|
|
|
#ifndef UNIV_HOTBACKUP
|
|
|
|
/*******************************************************************//**
|
|
|
|
Discards a single-table tablespace. The tablespace must be cached in the
|
|
|
|
memory cache. Discarding is like deleting a tablespace, but
|
|
|
|
|
|
|
|
1. We do not drop the table from the data dictionary;
|
|
|
|
|
|
|
|
2. We remove all insert buffer entries for the tablespace immediately;
|
|
|
|
in DROP TABLE they are only removed gradually in the background;
|
|
|
|
|
|
|
|
3. When the user does IMPORT TABLESPACE, the tablespace will have the
|
|
|
|
same id as it originally had.
|
|
|
|
|
|
|
|
4. Free all the pages in use by the tablespace if rename=TRUE.
|
|
|
|
@return DB_SUCCESS or error */
|
|
|
|
UNIV_INTERN
|
|
|
|
dberr_t
|
|
|
|
fil_discard_tablespace(
|
|
|
|
/*===================*/
|
|
|
|
ulint id) /*!< in: space id */
|
|
|
|
__attribute__((warn_unused_result));
|
|
|
|
#endif /* !UNIV_HOTBACKUP */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Renames a single-table tablespace. The tablespace must be cached in the
|
|
|
|
tablespace memory cache.
|
|
|
|
@return TRUE if success */
|
|
|
|
UNIV_INTERN
|
|
|
|
ibool
|
|
|
|
fil_rename_tablespace(
|
|
|
|
/*==================*/
|
|
|
|
const char* old_name_in, /*!< in: old table name in the
|
|
|
|
standard databasename/tablename
|
|
|
|
format of InnoDB, or NULL if we
|
|
|
|
do the rename based on the space
|
|
|
|
id only */
|
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
const char* new_name, /*!< in: new table name in the
|
|
|
|
standard databasename/tablename
|
|
|
|
format of InnoDB */
|
|
|
|
const char* new_path); /*!< in: new full datafile path
|
|
|
|
if the tablespace is remotely
|
|
|
|
located, or NULL if it is located
|
|
|
|
in the normal data directory. */
|
|
|
|
|
|
|
|
/*******************************************************************//**
|
|
|
|
Allocates a file name for a single-table tablespace. The string must be freed
|
|
|
|
by caller with mem_free().
|
|
|
|
@return own: file name */
|
|
|
|
UNIV_INTERN
|
|
|
|
char*
|
|
|
|
fil_make_ibd_name(
|
|
|
|
/*==============*/
|
|
|
|
const char* name, /*!< in: table name or a dir path */
|
|
|
|
bool is_full_path); /*!< in: TRUE if it is a dir path */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Allocates a file name for a tablespace ISL file (InnoDB Symbolic Link).
|
|
|
|
The string must be freed by caller with mem_free().
|
|
|
|
@return own: file name */
|
|
|
|
UNIV_INTERN
|
|
|
|
char*
|
|
|
|
fil_make_isl_name(
|
|
|
|
/*==============*/
|
|
|
|
const char* name); /*!< in: table name */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Creates a new InnoDB Symbolic Link (ISL) file. It is always created
|
|
|
|
under the 'datadir' of MySQL. The datadir is the directory of a
|
|
|
|
running mysqld program. We can refer to it by simply using the path '.'.
|
|
|
|
@return DB_SUCCESS or error code */
|
|
|
|
UNIV_INTERN
|
|
|
|
dberr_t
|
|
|
|
fil_create_link_file(
|
|
|
|
/*=================*/
|
|
|
|
const char* tablename, /*!< in: tablename */
|
|
|
|
const char* filepath); /*!< in: pathname of tablespace */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Deletes an InnoDB Symbolic Link (ISL) file. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_delete_link_file(
|
|
|
|
/*==================*/
|
|
|
|
const char* tablename); /*!< in: name of table */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Reads an InnoDB Symbolic Link (ISL) file.
|
|
|
|
It is always created under the 'datadir' of MySQL. The name is of the
|
|
|
|
form {databasename}/{tablename}. and the isl file is expected to be in a
|
|
|
|
'{databasename}' directory called '{tablename}.isl'. The caller must free
|
|
|
|
the memory of the null-terminated path returned if it is not null.
|
|
|
|
@return own: filepath found in link file, NULL if not found. */
|
|
|
|
UNIV_INTERN
|
|
|
|
char*
|
|
|
|
fil_read_link_file(
|
|
|
|
/*===============*/
|
|
|
|
const char* name); /*!< in: tablespace name */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Creates a new single-table tablespace to a database directory of MySQL.
|
|
|
|
Database directories are under the 'datadir' of MySQL. The datadir is the
|
|
|
|
directory of a running mysqld program. We can refer to it by simply the
|
|
|
|
path '.'. Tables created with CREATE TEMPORARY TABLE we place in the temp
|
|
|
|
dir of the mysqld server.
|
|
|
|
@return DB_SUCCESS or error code */
|
|
|
|
UNIV_INTERN
|
|
|
|
dberr_t
|
|
|
|
fil_create_new_single_table_tablespace(
|
|
|
|
/*===================================*/
|
|
|
|
ulint space_id, /*!< in: space id */
|
|
|
|
const char* tablename, /*!< in: the table name in the usual
|
|
|
|
databasename/tablename format
|
|
|
|
of InnoDB */
|
|
|
|
const char* dir_path, /*!< in: NULL or a dir path */
|
|
|
|
ulint flags, /*!< in: tablespace flags */
|
|
|
|
ulint flags2, /*!< in: table flags2 */
|
|
|
|
ulint size) /*!< in: the initial size of the
|
|
|
|
tablespace file in pages,
|
|
|
|
must be >= FIL_IBD_FILE_INITIAL_SIZE */
|
|
|
|
__attribute__((nonnull, warn_unused_result));
|
|
|
|
#ifndef UNIV_HOTBACKUP
|
|
|
|
/********************************************************************//**
|
|
|
|
Tries to open a single-table tablespace and optionally checks the space id is
|
|
|
|
right in it. If does not succeed, prints an error message to the .err log. This
|
|
|
|
function is used to open a tablespace when we start up mysqld, and also in
|
|
|
|
IMPORT TABLESPACE.
|
|
|
|
NOTE that we assume this operation is used either at the database startup
|
|
|
|
or under the protection of the dictionary mutex, so that two users cannot
|
|
|
|
race here. This operation does not leave the file associated with the
|
|
|
|
tablespace open, but closes it after we have looked at the space id in it.
|
|
|
|
|
|
|
|
If the validate boolean is set, we read the first page of the file and
|
|
|
|
check that the space id in the file is what we expect. We assume that
|
|
|
|
this function runs much faster if no check is made, since accessing the
|
|
|
|
file inode probably is much faster (the OS caches them) than accessing
|
|
|
|
the first page of the file. This boolean may be initially FALSE, but if
|
|
|
|
a remote tablespace is found it will be changed to true.
|
|
|
|
|
|
|
|
If the fix_dict boolean is set, then it is safe to use an internal SQL
|
|
|
|
statement to update the dictionary tables if they are incorrect.
|
|
|
|
|
|
|
|
@return DB_SUCCESS or error code */
|
|
|
|
UNIV_INTERN
|
|
|
|
dberr_t
|
|
|
|
fil_open_single_table_tablespace(
|
|
|
|
/*=============================*/
|
|
|
|
bool validate, /*!< in: Do we validate tablespace? */
|
|
|
|
bool fix_dict, /*!< in: Can we fix the dictionary? */
|
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
ulint flags, /*!< in: tablespace flags */
|
|
|
|
const char* tablename, /*!< in: table name in the
|
|
|
|
databasename/tablename format */
|
|
|
|
const char* filepath) /*!< in: tablespace filepath */
|
|
|
|
__attribute__((nonnull(5), warn_unused_result));
|
|
|
|
|
|
|
|
#endif /* !UNIV_HOTBACKUP */
|
|
|
|
/********************************************************************//**
|
|
|
|
At the server startup, if we need crash recovery, scans the database
|
|
|
|
directories under the MySQL datadir, looking for .ibd files. Those files are
|
|
|
|
single-table tablespaces. We need to know the space id in each of them so that
|
|
|
|
we know into which file we should look to check the contents of a page stored
|
|
|
|
in the doublewrite buffer, also to know where to apply log records where the
|
|
|
|
space id is != 0.
|
|
|
|
@return DB_SUCCESS or error number */
|
|
|
|
UNIV_INTERN
|
|
|
|
dberr_t
|
|
|
|
fil_load_single_table_tablespaces(void);
|
|
|
|
/*===================================*/
|
|
|
|
/*******************************************************************//**
|
|
|
|
Returns TRUE if a single-table tablespace does not exist in the memory cache,
|
|
|
|
or is being deleted there.
|
|
|
|
@return TRUE if does not exist or is being deleted */
|
|
|
|
UNIV_INTERN
|
|
|
|
ibool
|
|
|
|
fil_tablespace_deleted_or_being_deleted_in_mem(
|
|
|
|
/*===========================================*/
|
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
ib_int64_t version);/*!< in: tablespace_version should be this; if
|
|
|
|
you pass -1 as the value of this, then this
|
|
|
|
parameter is ignored */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Returns TRUE if a single-table tablespace exists in the memory cache.
|
|
|
|
@return TRUE if exists */
|
|
|
|
UNIV_INTERN
|
|
|
|
ibool
|
|
|
|
fil_tablespace_exists_in_mem(
|
|
|
|
/*=========================*/
|
|
|
|
ulint id); /*!< in: space id */
|
|
|
|
#ifndef UNIV_HOTBACKUP
|
|
|
|
/*******************************************************************//**
|
|
|
|
Returns TRUE if a matching tablespace exists in the InnoDB tablespace memory
|
|
|
|
cache. Note that if we have not done a crash recovery at the database startup,
|
|
|
|
there may be many tablespaces which are not yet in the memory cache.
|
|
|
|
@return TRUE if a matching tablespace exists in the memory cache */
|
|
|
|
UNIV_INTERN
|
|
|
|
ibool
|
|
|
|
fil_space_for_table_exists_in_mem(
|
|
|
|
/*==============================*/
|
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
const char* name, /*!< in: table name in the standard
|
|
|
|
'databasename/tablename' format */
|
|
|
|
ibool mark_space, /*!< in: in crash recovery, at database
|
|
|
|
startup we mark all spaces which have
|
|
|
|
an associated table in the InnoDB
|
|
|
|
data dictionary, so that
|
|
|
|
we can print a warning about orphaned
|
|
|
|
tablespaces */
|
|
|
|
ibool print_error_if_does_not_exist,
|
|
|
|
/*!< in: print detailed error
|
|
|
|
information to the .err log if a
|
|
|
|
matching tablespace is not found from
|
|
|
|
memory */
|
|
|
|
bool adjust_space, /*!< in: whether to adjust space id
|
|
|
|
when find table space mismatch */
|
|
|
|
mem_heap_t* heap, /*!< in: heap memory */
|
|
|
|
table_id_t table_id); /*!< in: table id */
|
|
|
|
#else /* !UNIV_HOTBACKUP */
|
|
|
|
/********************************************************************//**
|
|
|
|
Extends all tablespaces to the size stored in the space header. During the
|
2014-09-11 10:13:35 +02:00
|
|
|
mysqlbackup --apply-log phase we extended the spaces on-demand so that log
|
|
|
|
records could be appllied, but that may have left spaces still too small
|
|
|
|
compared to the size stored in the space header. */
|
2014-02-26 19:11:54 +01:00
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_extend_tablespaces_to_stored_len(void);
|
|
|
|
/*======================================*/
|
|
|
|
#endif /* !UNIV_HOTBACKUP */
|
|
|
|
/**********************************************************************//**
|
|
|
|
Tries to extend a data file so that it would accommodate the number of pages
|
|
|
|
given. The tablespace must be cached in the memory cache. If the space is big
|
|
|
|
enough already, does nothing.
|
|
|
|
@return TRUE if success */
|
|
|
|
UNIV_INTERN
|
|
|
|
ibool
|
|
|
|
fil_extend_space_to_desired_size(
|
|
|
|
/*=============================*/
|
|
|
|
ulint* actual_size, /*!< out: size of the space after extension;
|
|
|
|
if we ran out of disk space this may be lower
|
|
|
|
than the desired size */
|
|
|
|
ulint space_id, /*!< in: space id */
|
|
|
|
ulint size_after_extend);/*!< in: desired size in pages after the
|
|
|
|
extension; if the current space size is bigger
|
|
|
|
than this already, the function does nothing */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Tries to reserve free extents in a file space.
|
|
|
|
@return TRUE if succeed */
|
|
|
|
UNIV_INTERN
|
|
|
|
ibool
|
|
|
|
fil_space_reserve_free_extents(
|
|
|
|
/*===========================*/
|
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
ulint n_free_now, /*!< in: number of free extents now */
|
|
|
|
ulint n_to_reserve); /*!< in: how many one wants to reserve */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Releases free extents in a file space. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_space_release_free_extents(
|
|
|
|
/*===========================*/
|
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
ulint n_reserved); /*!< in: how many one reserved */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Gets the number of reserved extents. If the database is silent, this number
|
|
|
|
should be zero. */
|
|
|
|
UNIV_INTERN
|
|
|
|
ulint
|
|
|
|
fil_space_get_n_reserved_extents(
|
|
|
|
/*=============================*/
|
|
|
|
ulint id); /*!< in: space id */
|
|
|
|
/********************************************************************//**
|
|
|
|
Reads or writes data. This operation is asynchronous (aio).
|
|
|
|
@return DB_SUCCESS, or DB_TABLESPACE_DELETED if we are trying to do
|
|
|
|
i/o on a tablespace which does not exist */
|
|
|
|
UNIV_INTERN
|
|
|
|
dberr_t
|
|
|
|
fil_io(
|
|
|
|
/*===*/
|
|
|
|
ulint type, /*!< in: OS_FILE_READ or OS_FILE_WRITE,
|
|
|
|
ORed to OS_FILE_LOG, if a log i/o
|
|
|
|
and ORed to OS_AIO_SIMULATED_WAKE_LATER
|
|
|
|
if simulated aio and we want to post a
|
|
|
|
batch of i/os; NOTE that a simulated batch
|
|
|
|
may introduce hidden chances of deadlocks,
|
|
|
|
because i/os are not actually handled until
|
|
|
|
all have been posted: use with great
|
|
|
|
caution! */
|
|
|
|
bool sync, /*!< in: true if synchronous aio is desired */
|
|
|
|
ulint space_id, /*!< in: space id */
|
|
|
|
ulint zip_size, /*!< in: compressed page size in bytes;
|
|
|
|
0 for uncompressed pages */
|
|
|
|
ulint block_offset, /*!< in: offset in number of blocks */
|
|
|
|
ulint byte_offset, /*!< in: remainder of offset in bytes; in
|
|
|
|
aio this must be divisible by the OS block
|
|
|
|
size */
|
|
|
|
ulint len, /*!< in: how many bytes to read or write; this
|
|
|
|
must not cross a file boundary; in aio this
|
|
|
|
must be a block size multiple */
|
|
|
|
void* buf, /*!< in/out: buffer where to store read data
|
|
|
|
or from where to write; in aio this must be
|
|
|
|
appropriately aligned */
|
2013-12-19 14:36:38 +02:00
|
|
|
void* message, /*!< in: message for aio handler if non-sync
|
2014-02-26 19:11:54 +01:00
|
|
|
aio used, else ignored */
|
2014-12-22 16:53:17 +02:00
|
|
|
ulint* write_size, /*!< in/out: Actual write size initialized
|
2013-12-19 14:36:38 +02:00
|
|
|
after fist successfull trim
|
|
|
|
operation for this page and if
|
|
|
|
initialized we do not trim again if
|
|
|
|
actual page size does not decrease. */
|
2014-12-22 16:53:17 +02:00
|
|
|
lsn_t lsn) /* lsn of the newest modification */
|
2014-02-26 19:11:54 +01:00
|
|
|
__attribute__((nonnull(8)));
|
|
|
|
/**********************************************************************//**
|
|
|
|
Waits for an aio operation to complete. This function is used to write the
|
|
|
|
handler for completed requests. The aio array of pending requests is divided
|
|
|
|
into segments (see os0file.cc for more info). The thread specifies which
|
|
|
|
segment it wants to wait for. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_aio_wait(
|
|
|
|
/*=========*/
|
|
|
|
ulint segment); /*!< in: the number of the segment in the aio
|
|
|
|
array to wait for */
|
|
|
|
/**********************************************************************//**
|
|
|
|
Flushes to disk possible writes cached by the OS. If the space does not exist
|
|
|
|
or is being dropped, does not do anything. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_flush(
|
|
|
|
/*======*/
|
|
|
|
ulint space_id); /*!< in: file space id (this can be a group of
|
|
|
|
log files or a tablespace of the database) */
|
|
|
|
/**********************************************************************//**
|
|
|
|
Flushes to disk writes in file spaces of the given type possibly cached by
|
|
|
|
the OS. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_flush_file_spaces(
|
|
|
|
/*==================*/
|
|
|
|
ulint purpose); /*!< in: FIL_TABLESPACE, FIL_LOG */
|
|
|
|
/******************************************************************//**
|
|
|
|
Checks the consistency of the tablespace cache.
|
|
|
|
@return TRUE if ok */
|
|
|
|
UNIV_INTERN
|
|
|
|
ibool
|
|
|
|
fil_validate(void);
|
|
|
|
/*==============*/
|
|
|
|
/********************************************************************//**
|
|
|
|
Returns TRUE if file address is undefined.
|
|
|
|
@return TRUE if undefined */
|
|
|
|
UNIV_INTERN
|
|
|
|
ibool
|
|
|
|
fil_addr_is_null(
|
|
|
|
/*=============*/
|
|
|
|
fil_addr_t addr); /*!< in: address */
|
|
|
|
/********************************************************************//**
|
|
|
|
Get the predecessor of a file page.
|
|
|
|
@return FIL_PAGE_PREV */
|
|
|
|
UNIV_INTERN
|
|
|
|
ulint
|
|
|
|
fil_page_get_prev(
|
|
|
|
/*==============*/
|
|
|
|
const byte* page); /*!< in: file page */
|
|
|
|
/********************************************************************//**
|
|
|
|
Get the successor of a file page.
|
|
|
|
@return FIL_PAGE_NEXT */
|
|
|
|
UNIV_INTERN
|
|
|
|
ulint
|
|
|
|
fil_page_get_next(
|
|
|
|
/*==============*/
|
|
|
|
const byte* page); /*!< in: file page */
|
|
|
|
/*********************************************************************//**
|
|
|
|
Sets the file page type. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_page_set_type(
|
|
|
|
/*==============*/
|
|
|
|
byte* page, /*!< in/out: file page */
|
|
|
|
ulint type); /*!< in: type */
|
|
|
|
/*********************************************************************//**
|
|
|
|
Gets the file page type.
|
|
|
|
@return type; NOTE that if the type has not been written to page, the
|
|
|
|
return value not defined */
|
|
|
|
UNIV_INTERN
|
|
|
|
ulint
|
|
|
|
fil_page_get_type(
|
|
|
|
/*==============*/
|
|
|
|
const byte* page); /*!< in: file page */
|
|
|
|
|
|
|
|
/*******************************************************************//**
|
|
|
|
Returns TRUE if a single-table tablespace is being deleted.
|
|
|
|
@return TRUE if being deleted */
|
|
|
|
UNIV_INTERN
|
|
|
|
ibool
|
|
|
|
fil_tablespace_is_being_deleted(
|
|
|
|
/*============================*/
|
|
|
|
ulint id); /*!< in: space id */
|
|
|
|
|
|
|
|
/********************************************************************//**
|
|
|
|
Delete the tablespace file and any related files like .cfg.
|
|
|
|
This should not be called for temporary tables. */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_delete_file(
|
|
|
|
/*============*/
|
|
|
|
const char* path); /*!< in: filepath of the ibd tablespace */
|
|
|
|
|
|
|
|
/** Callback functor. */
|
|
|
|
struct PageCallback {
|
|
|
|
|
|
|
|
/**
|
|
|
|
Default constructor */
|
|
|
|
PageCallback()
|
|
|
|
:
|
|
|
|
m_zip_size(),
|
|
|
|
m_page_size(),
|
|
|
|
m_filepath() UNIV_NOTHROW {}
|
|
|
|
|
|
|
|
virtual ~PageCallback() UNIV_NOTHROW {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Called for page 0 in the tablespace file at the start.
|
|
|
|
@param file_size - size of the file in bytes
|
|
|
|
@param block - contents of the first page in the tablespace file
|
|
|
|
@retval DB_SUCCESS or error code.*/
|
|
|
|
virtual dberr_t init(
|
|
|
|
os_offset_t file_size,
|
|
|
|
const buf_block_t* block) UNIV_NOTHROW = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Called for every page in the tablespace. If the page was not
|
|
|
|
updated then its state must be set to BUF_PAGE_NOT_USED. For
|
|
|
|
compressed tables the page descriptor memory will be at offset:
|
|
|
|
block->frame + UNIV_PAGE_SIZE;
|
|
|
|
@param offset - physical offset within the file
|
|
|
|
@param block - block read from file, note it is not from the buffer pool
|
|
|
|
@retval DB_SUCCESS or error code. */
|
|
|
|
virtual dberr_t operator()(
|
|
|
|
os_offset_t offset,
|
|
|
|
buf_block_t* block) UNIV_NOTHROW = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the name of the physical file and the file handle that is used
|
|
|
|
to open it for the file that is being iterated over.
|
|
|
|
@param filename - then physical name of the tablespace file.
|
|
|
|
@param file - OS file handle */
|
|
|
|
void set_file(const char* filename, os_file_t file) UNIV_NOTHROW
|
|
|
|
{
|
|
|
|
m_file = file;
|
|
|
|
m_filepath = filename;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
@return the space id of the tablespace */
|
|
|
|
virtual ulint get_space_id() const UNIV_NOTHROW = 0;
|
|
|
|
|
|
|
|
/** The compressed page size
|
|
|
|
@return the compressed page size */
|
|
|
|
ulint get_zip_size() const
|
|
|
|
{
|
|
|
|
return(m_zip_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the tablespace compressed table size.
|
|
|
|
@return DB_SUCCESS if it is valie or DB_CORRUPTION if not */
|
|
|
|
dberr_t set_zip_size(const buf_frame_t* page) UNIV_NOTHROW;
|
|
|
|
|
|
|
|
/** The compressed page size
|
|
|
|
@return the compressed page size */
|
|
|
|
ulint get_page_size() const
|
|
|
|
{
|
|
|
|
return(m_page_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Compressed table page size */
|
|
|
|
ulint m_zip_size;
|
|
|
|
|
|
|
|
/** The tablespace page size. */
|
|
|
|
ulint m_page_size;
|
|
|
|
|
|
|
|
/** File handle to the tablespace */
|
|
|
|
os_file_t m_file;
|
|
|
|
|
|
|
|
/** Physical file path. */
|
|
|
|
const char* m_filepath;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
// Disable copying
|
|
|
|
PageCallback(const PageCallback&);
|
|
|
|
PageCallback& operator=(const PageCallback&);
|
|
|
|
};
|
|
|
|
|
|
|
|
/********************************************************************//**
|
|
|
|
Iterate over all the pages in the tablespace.
|
|
|
|
@param table - the table definiton in the server
|
|
|
|
@param n_io_buffers - number of blocks to read and write together
|
|
|
|
@param callback - functor that will do the page updates
|
|
|
|
@return DB_SUCCESS or error code */
|
|
|
|
UNIV_INTERN
|
|
|
|
dberr_t
|
|
|
|
fil_tablespace_iterate(
|
|
|
|
/*===================*/
|
|
|
|
dict_table_t* table,
|
|
|
|
ulint n_io_buffers,
|
|
|
|
PageCallback& callback)
|
|
|
|
__attribute__((nonnull, warn_unused_result));
|
|
|
|
|
|
|
|
/*******************************************************************//**
|
|
|
|
Checks if a single-table tablespace for a given table name exists in the
|
|
|
|
tablespace memory cache.
|
|
|
|
@return space id, ULINT_UNDEFINED if not found */
|
|
|
|
UNIV_INTERN
|
|
|
|
ulint
|
|
|
|
fil_get_space_id_for_table(
|
|
|
|
/*=======================*/
|
|
|
|
const char* name); /*!< in: table name in the standard
|
|
|
|
'databasename/tablename' format */
|
|
|
|
|
|
|
|
/**
|
|
|
|
Iterate over all the spaces in the space list and fetch the
|
|
|
|
tablespace names. It will return a copy of the name that must be
|
|
|
|
freed by the caller using: delete[].
|
|
|
|
@return DB_SUCCESS if all OK. */
|
|
|
|
UNIV_INTERN
|
|
|
|
dberr_t
|
|
|
|
fil_get_space_names(
|
|
|
|
/*================*/
|
|
|
|
space_name_list_t& space_name_list)
|
|
|
|
/*!< in/out: Vector for collecting the names. */
|
|
|
|
__attribute__((warn_unused_result));
|
|
|
|
|
|
|
|
/****************************************************************//**
|
|
|
|
Generate redo logs for swapping two .ibd files */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_mtr_rename_log(
|
|
|
|
/*===============*/
|
|
|
|
ulint old_space_id, /*!< in: tablespace id of the old
|
|
|
|
table. */
|
|
|
|
const char* old_name, /*!< in: old table name */
|
|
|
|
ulint new_space_id, /*!< in: tablespace id of the new
|
|
|
|
table */
|
|
|
|
const char* new_name, /*!< in: new table name */
|
|
|
|
const char* tmp_name, /*!< in: temp table name used while
|
|
|
|
swapping */
|
|
|
|
mtr_t* mtr) /*!< in/out: mini-transaction */
|
|
|
|
__attribute__((nonnull));
|
|
|
|
|
2014-05-06 21:13:16 +02:00
|
|
|
/*******************************************************************//**
|
|
|
|
Finds the given page_no of the given space id from the double write buffer,
|
|
|
|
and copies it to the corresponding .ibd file.
|
|
|
|
@return true if copy was successful, or false. */
|
|
|
|
bool
|
|
|
|
fil_user_tablespace_restore_page(
|
|
|
|
/*==============================*/
|
|
|
|
fsp_open_info* fsp, /* in: contains space id and .ibd
|
|
|
|
file information */
|
|
|
|
ulint page_no); /* in: page_no to obtain from double
|
|
|
|
write buffer */
|
|
|
|
|
2014-12-22 16:53:17 +02:00
|
|
|
/*******************************************************************//**
|
|
|
|
Return space flags */
|
|
|
|
ulint
|
|
|
|
fil_space_flags(
|
|
|
|
/*===========*/
|
|
|
|
fil_space_t* space); /*!< in: space */
|
|
|
|
|
2014-02-26 19:11:54 +01:00
|
|
|
#endif /* !UNIV_INNOCHECKSUM */
|
2013-12-19 14:36:38 +02:00
|
|
|
|
|
|
|
/****************************************************************//**
|
|
|
|
Acquire fil_system mutex */
|
|
|
|
void
|
|
|
|
fil_system_enter(void);
|
|
|
|
/*==================*/
|
|
|
|
/****************************************************************//**
|
|
|
|
Release fil_system mutex */
|
|
|
|
void
|
|
|
|
fil_system_exit(void);
|
|
|
|
/*==================*/
|
2014-02-28 08:53:09 +02:00
|
|
|
|
|
|
|
#ifndef UNIV_INNOCHECKSUM
|
2013-12-19 14:36:38 +02:00
|
|
|
/*******************************************************************//**
|
|
|
|
Returns the table space by a given id, NULL if not found. */
|
|
|
|
fil_space_t*
|
|
|
|
fil_space_get_by_id(
|
|
|
|
/*================*/
|
|
|
|
ulint id); /*!< in: space id */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Return space name */
|
|
|
|
char*
|
|
|
|
fil_space_name(
|
|
|
|
/*===========*/
|
|
|
|
fil_space_t* space); /*!< in: space */
|
2014-12-22 16:53:17 +02:00
|
|
|
|
|
|
|
/******************************************************************
|
|
|
|
Get id of first tablespace or ULINT_UNDEFINED if none */
|
|
|
|
UNIV_INTERN
|
|
|
|
ulint
|
|
|
|
fil_get_first_space();
|
|
|
|
|
|
|
|
/******************************************************************
|
|
|
|
Get id of next tablespace or ULINT_UNDEFINED if none */
|
|
|
|
UNIV_INTERN
|
|
|
|
ulint
|
|
|
|
fil_get_next_space(
|
|
|
|
ulint id); /*!< in: space id */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Init global resources needed for tablespace encryption/decryption */
|
|
|
|
void
|
|
|
|
fil_space_crypt_init();
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Cleanup global resources needed for tablespace encryption/decryption */
|
|
|
|
void
|
|
|
|
fil_space_crypt_cleanup();
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Create crypt data, i.e data that is used for a single tablespace */
|
|
|
|
fil_space_crypt_t *
|
|
|
|
fil_space_create_crypt_data();
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Destroy crypt data */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_space_destroy_crypt_data(
|
|
|
|
/*=========================*/
|
|
|
|
fil_space_crypt_t **crypt_data); /*!< in/out: crypt data */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Get crypt data for a space*/
|
|
|
|
fil_space_crypt_t *
|
|
|
|
fil_space_get_crypt_data(
|
|
|
|
/*======================*/
|
|
|
|
ulint space); /*!< in: tablespace id */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Set crypt data for a space*/
|
|
|
|
void
|
|
|
|
fil_space_set_crypt_data(
|
|
|
|
/*======================*/
|
|
|
|
ulint space, /*!< in: tablespace id */
|
|
|
|
fil_space_crypt_t* crypt_data); /*!< in: crypt data */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Compare crypt data*/
|
|
|
|
int
|
|
|
|
fil_space_crypt_compare(
|
|
|
|
/*======================*/
|
|
|
|
const fil_space_crypt_t* crypt_data1, /*!< in: crypt data */
|
|
|
|
const fil_space_crypt_t* crypt_data2); /*!< in: crypt data */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Read crypt data from buffer page */
|
|
|
|
fil_space_crypt_t *
|
|
|
|
fil_space_read_crypt_data(
|
|
|
|
/*======================*/
|
|
|
|
ulint space, /*!< in: tablespace id */
|
|
|
|
const byte* page, /*!< in: buffer page */
|
|
|
|
ulint offset); /*!< in: offset where crypt data is stored */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Write crypt data to buffer page */
|
|
|
|
void
|
|
|
|
fil_space_write_crypt_data(
|
|
|
|
/*=======================*/
|
|
|
|
ulint space, /*!< in: tablespace id */
|
|
|
|
byte* page, /*!< in: buffer page */
|
|
|
|
ulint offset, /*!< in: offset where to store data */
|
|
|
|
ulint maxsize, /*!< in: max space available to store crypt data in */
|
|
|
|
mtr_t * mtr); /*!< in: mini-transaction */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Clear crypt data from page 0 (used for import tablespace) */
|
|
|
|
void
|
|
|
|
fil_space_clear_crypt_data(
|
|
|
|
/*======================*/
|
|
|
|
byte* page, /*!< in: buffer page */
|
|
|
|
ulint offset); /*!< in: offset where crypt data is stored */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Parse crypt data log record */
|
|
|
|
byte*
|
|
|
|
fil_parse_write_crypt_data(
|
|
|
|
/*=======================*/
|
|
|
|
byte* ptr, /*!< in: start of log record */
|
|
|
|
byte* end_ptr, /*!< in: end of log record */
|
|
|
|
buf_block_t*); /*!< in: buffer page to apply record to */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Check if extra buffer shall be allocated for decrypting after read */
|
|
|
|
UNIV_INTERN
|
|
|
|
bool
|
|
|
|
fil_space_check_encryption_read(
|
|
|
|
/*==============================*/
|
|
|
|
ulint space); /*!< in: tablespace id */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Check if page shall be encrypted before write */
|
|
|
|
UNIV_INTERN
|
|
|
|
bool
|
|
|
|
fil_space_check_encryption_write(
|
|
|
|
/*==============================*/
|
|
|
|
ulint space); /*!< in: tablespace id */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Encrypt buffer page */
|
|
|
|
void
|
|
|
|
fil_space_encrypt(
|
|
|
|
/*===============*/
|
|
|
|
ulint space, /*!< in: tablespace id */
|
|
|
|
ulint offset, /*!< in: page no */
|
|
|
|
lsn_t lsn, /*!< in: page lsn */
|
|
|
|
const byte* src_frame,/*!< in: page frame */
|
|
|
|
ulint size, /*!< in: size of data to encrypt */
|
|
|
|
byte* dst_frame, /*!< in: where to encrypt to */
|
|
|
|
ulint page_encryption_key); /*!< in: page encryption key id if page
|
|
|
|
encrypted */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Decrypt buffer page */
|
|
|
|
void
|
|
|
|
fil_space_decrypt(
|
|
|
|
/*===============*/
|
|
|
|
ulint space, /*!< in: tablespace id */
|
|
|
|
const byte* src_frame,/*!< in: page frame */
|
|
|
|
ulint page_size, /*!< in: size of data to encrypt */
|
|
|
|
byte* dst_frame); /*!< in: where to decrypt to */
|
|
|
|
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Decrypt buffer page
|
|
|
|
@return true if page was encrypted */
|
|
|
|
bool
|
|
|
|
fil_space_decrypt(
|
|
|
|
/*===============*/
|
|
|
|
fil_space_crypt_t* crypt_data, /*!< in: crypt data */
|
|
|
|
const byte* src_frame,/*!< in: page frame */
|
|
|
|
ulint page_size, /*!< in: page size */
|
|
|
|
byte* dst_frame); /*!< in: where to decrypt to */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
fil_space_verify_crypt_checksum
|
|
|
|
NOTE: currently this function can only be run in single threaded mode
|
|
|
|
as it modifies srv_checksum_algorithm (temporarily)
|
|
|
|
@return true if page is encrypted AND OK, false otherwise */
|
|
|
|
bool
|
|
|
|
fil_space_verify_crypt_checksum(
|
|
|
|
/*===============*/
|
|
|
|
const byte* src_frame,/*!< in: page frame */
|
|
|
|
ulint zip_size); /*!< in: size of data to encrypt */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Init threads for key rotation */
|
|
|
|
void
|
|
|
|
fil_crypt_threads_init();
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Set thread count (e.g start or stops threads) used for key rotation */
|
|
|
|
void
|
|
|
|
fil_crypt_set_thread_cnt(
|
|
|
|
/*=====================*/
|
|
|
|
uint new_cnt); /*!< in: requested #threads */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
End threads for key rotation */
|
|
|
|
void
|
|
|
|
fil_crypt_threads_end();
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Cleanup resources for threads for key rotation */
|
|
|
|
void
|
|
|
|
fil_crypt_threads_cleanup();
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Set rotate key age */
|
|
|
|
void
|
|
|
|
fil_crypt_set_rotate_key_age(
|
|
|
|
/*=====================*/
|
|
|
|
uint rotate_age); /*!< in: requested rotate age */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Set rotation threads iops */
|
|
|
|
void
|
|
|
|
fil_crypt_set_rotation_iops(
|
|
|
|
/*=====================*/
|
|
|
|
uint iops); /*!< in: requested iops */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Mark a space as closing */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_space_crypt_mark_space_closing(
|
|
|
|
/*===============*/
|
|
|
|
ulint space); /*!< in: tablespace id */
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Wait for crypt threads to stop accessing space */
|
|
|
|
UNIV_INTERN
|
|
|
|
void
|
|
|
|
fil_space_crypt_close_tablespace(
|
|
|
|
/*===============*/
|
|
|
|
ulint space); /*!< in: tablespace id */
|
|
|
|
|
|
|
|
/** Struct for retreiving info about encryption */
|
|
|
|
struct fil_space_crypt_status_t {
|
|
|
|
ulint space; /*!< tablespace id */
|
|
|
|
ulint scheme; /*!< encryption scheme */
|
|
|
|
uint min_key_version; /*!< min key version */
|
|
|
|
uint current_key_version;/*!< current key version */
|
|
|
|
uint keyserver_requests;/*!< no of key requests to key server */
|
|
|
|
bool rotating; /*!< is key rotation ongoing */
|
|
|
|
bool flushing; /*!< is flush at end of rotation ongoing */
|
|
|
|
ulint rotate_next_page_number; /*!< next page if key rotating */
|
|
|
|
ulint rotate_max_page_number; /*!< max page if key rotating */
|
|
|
|
};
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Get crypt status for a space
|
|
|
|
@return 0 if crypt data found */
|
|
|
|
int
|
|
|
|
fil_space_crypt_get_status(
|
|
|
|
/*==================*/
|
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
struct fil_space_crypt_status_t * status); /*!< out: status */
|
|
|
|
|
|
|
|
/** Struct for retreiving statistics about encryption key rotation */
|
|
|
|
struct fil_crypt_stat_t {
|
|
|
|
ulint pages_read_from_cache;
|
|
|
|
ulint pages_read_from_disk;
|
|
|
|
ulint pages_modified;
|
|
|
|
ulint pages_flushed;
|
|
|
|
ulint estimated_iops;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Get crypt rotation statistics */
|
|
|
|
void
|
|
|
|
fil_crypt_total_stat(
|
|
|
|
/*==================*/
|
|
|
|
fil_crypt_stat_t* stat); /*!< out: crypt stat */
|
|
|
|
|
|
|
|
/** Struct for retreiving info about scrubbing */
|
|
|
|
struct fil_space_scrub_status_t {
|
|
|
|
ulint space; /*!< tablespace id */
|
|
|
|
bool compressed; /*!< is space compressed */
|
|
|
|
time_t last_scrub_completed; /*!< when was last scrub completed */
|
|
|
|
bool scrubbing; /*!< is scrubbing ongoing */
|
|
|
|
time_t current_scrub_started; /*!< when started current scrubbing */
|
|
|
|
ulint current_scrub_active_threads; /*!< current scrub active threads */
|
|
|
|
ulint current_scrub_page_number; /*!< current scrub page no */
|
|
|
|
ulint current_scrub_max_page_number; /*!< current scrub max page no */
|
|
|
|
};
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
Get scrub status for a space
|
|
|
|
@return 0 if no scrub info found */
|
|
|
|
int
|
|
|
|
fil_space_get_scrub_status(
|
|
|
|
/*==================*/
|
|
|
|
ulint id, /*!< in: space id */
|
|
|
|
struct fil_space_scrub_status_t * status); /*!< out: status */
|
|
|
|
|
2014-02-28 08:53:09 +02:00
|
|
|
#endif
|
2014-07-31 11:31:39 +03:00
|
|
|
|
|
|
|
/*******************************************************************//**
|
|
|
|
Return page type name */
|
2014-08-27 13:15:37 +03:00
|
|
|
const char*
|
2014-07-31 11:31:39 +03:00
|
|
|
fil_get_page_type_name(
|
|
|
|
/*===================*/
|
|
|
|
ulint page_type); /*!< in: FIL_PAGE_TYPE */
|
|
|
|
|
2014-02-26 19:11:54 +01:00
|
|
|
#endif /* fil0fil_h */
|