Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
065f8dac
Commit
065f8dac
authored
May 25, 2009
by
marko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
branches/zip: Add some Doxygen comments, mainly to structs, typedefs,
macros and global variables. Many more to go.
parent
fe01aebc
Changes
28
Hide whitespace changes
Inline
Side-by-side
Showing
28 changed files
with
601 additions
and
329 deletions
+601
-329
btr/btr0sea.c
btr/btr0sea.c
+11
-9
data/data0data.c
data/data0data.c
+4
-3
include/btr0btr.h
include/btr0btr.h
+33
-24
include/btr0sea.h
include/btr0sea.h
+43
-38
include/buf0buf.h
include/buf0buf.h
+24
-16
include/data0data.h
include/data0data.h
+27
-22
include/data0data.ic
include/data0data.ic
+3
-0
include/ha0storage.h
include/ha0storage.h
+15
-6
include/ha0storage.ic
include/ha0storage.ic
+8
-6
include/log0recv.h
include/log0recv.h
+123
-51
include/log0recv.ic
include/log0recv.ic
+1
-0
include/row0merge.h
include/row0merge.h
+12
-10
include/ut0byte.h
include/ut0byte.h
+7
-7
include/ut0dbg.h
include/ut0dbg.h
+8
-7
include/ut0mem.h
include/ut0mem.h
+35
-5
include/ut0mem.ic
include/ut0mem.ic
+33
-3
include/ut0rnd.ic
include/ut0rnd.ic
+1
-0
include/ut0ut.h
include/ut0ut.h
+27
-8
include/ut0vec.h
include/ut0vec.h
+6
-5
log/log0recv.c
log/log0recv.c
+42
-23
row/row0merge.c
row/row0merge.c
+49
-28
row/row0mysql.c
row/row0mysql.c
+24
-11
trx/trx0i_s.c
trx/trx0i_s.c
+36
-29
ut/ut0byte.c
ut/ut0byte.c
+2
-2
ut/ut0dbg.c
ut/ut0dbg.c
+7
-7
ut/ut0mem.c
ut/ut0mem.c
+13
-7
ut/ut0rnd.c
ut/ut0rnd.c
+4
-2
ut/ut0ut.c
ut/ut0ut.c
+3
-0
No files found.
btr/btr0sea.c
View file @
065f8dac
...
@@ -43,26 +43,29 @@ Created 2/17/1996 Heikki Tuuri
...
@@ -43,26 +43,29 @@ Created 2/17/1996 Heikki Tuuri
#include "btr0btr.h"
#include "btr0btr.h"
#include "ha0ha.h"
#include "ha0ha.h"
/* Flag: has the search system been enabled?
/*
*
Flag: has the search system been enabled?
Protected by btr_search_latch and btr_search_enabled_mutex. */
Protected by btr_search_latch and btr_search_enabled_mutex. */
UNIV_INTERN
char
btr_search_enabled
=
TRUE
;
UNIV_INTERN
char
btr_search_enabled
=
TRUE
;
/** Mutex protecting btr_search_enabled */
static
mutex_t
btr_search_enabled_mutex
;
static
mutex_t
btr_search_enabled_mutex
;
/* A dummy variable to fool the compiler */
/*
*
A dummy variable to fool the compiler */
UNIV_INTERN
ulint
btr_search_this_is_zero
=
0
;
UNIV_INTERN
ulint
btr_search_this_is_zero
=
0
;
#ifdef UNIV_SEARCH_PERF_STAT
#ifdef UNIV_SEARCH_PERF_STAT
/** Number of successful adaptive hash index lookups */
UNIV_INTERN
ulint
btr_search_n_succ
=
0
;
UNIV_INTERN
ulint
btr_search_n_succ
=
0
;
/** Number of failed adaptive hash index lookups */
UNIV_INTERN
ulint
btr_search_n_hash_fail
=
0
;
UNIV_INTERN
ulint
btr_search_n_hash_fail
=
0
;
#endif
/* UNIV_SEARCH_PERF_STAT */
#endif
/* UNIV_SEARCH_PERF_STAT */
/* padding to prevent other memory update
/*
*
padding to prevent other memory update
hotspots from residing on the same memory
hotspots from residing on the same memory
cache line as btr_search_latch */
cache line as btr_search_latch */
UNIV_INTERN
byte
btr_sea_pad1
[
64
];
UNIV_INTERN
byte
btr_sea_pad1
[
64
];
/* The latch protecting the adaptive search system: this latch protects the
/*
*
The latch protecting the adaptive search system: this latch protects the
(1) positions of records on those pages where a hash index has been built.
(1) positions of records on those pages where a hash index has been built.
NOTE: It does not protect values of non-ordering fields within a record from
NOTE: It does not protect values of non-ordering fields within a record from
being updated in-place! We can use fact (1) to perform unique searches to
being updated in-place! We can use fact (1) to perform unique searches to
...
@@ -72,21 +75,20 @@ indexes. */
...
@@ -72,21 +75,20 @@ indexes. */
same DRAM page as other hotspot semaphores */
same DRAM page as other hotspot semaphores */
UNIV_INTERN
rw_lock_t
*
btr_search_latch_temp
;
UNIV_INTERN
rw_lock_t
*
btr_search_latch_temp
;
/* padding to prevent other memory update hotspots from residing on
/*
*
padding to prevent other memory update hotspots from residing on
the same memory cache line */
the same memory cache line */
UNIV_INTERN
byte
btr_sea_pad2
[
64
];
UNIV_INTERN
byte
btr_sea_pad2
[
64
];
/** The adaptive hash index */
UNIV_INTERN
btr_search_sys_t
*
btr_search_sys
;
UNIV_INTERN
btr_search_sys_t
*
btr_search_sys
;
/* If the number of records on the page divided by this parameter
/*
*
If the number of records on the page divided by this parameter
would have been successfully accessed using a hash index, the index
would have been successfully accessed using a hash index, the index
is then built on the page, assuming the global limit has been reached */
is then built on the page, assuming the global limit has been reached */
#define BTR_SEARCH_PAGE_BUILD_LIMIT 16
#define BTR_SEARCH_PAGE_BUILD_LIMIT 16
/* The global limit for consecutive potentially successful hash searches,
/*
*
The global limit for consecutive potentially successful hash searches,
before hash index building is started */
before hash index building is started */
#define BTR_SEARCH_BUILD_LIMIT 100
#define BTR_SEARCH_BUILD_LIMIT 100
/********************************************************************//**
/********************************************************************//**
...
...
data/data0data.c
View file @
065f8dac
...
@@ -41,12 +41,13 @@ Created 5/30/1994 Heikki Tuuri
...
@@ -41,12 +41,13 @@ Created 5/30/1994 Heikki Tuuri
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
#ifdef UNIV_DEBUG
#ifdef UNIV_DEBUG
/* data pointers of tuple fields are initialized to point here
/** Dummy variable to catch access to uninitialized fields. In the
for error checking */
debug version, dtuple_create() will make all fields of dtuple_t point
to data_error. */
UNIV_INTERN
byte
data_error
;
UNIV_INTERN
byte
data_error
;
# ifndef UNIV_DEBUG_VALGRIND
# ifndef UNIV_DEBUG_VALGRIND
/* this is used to fool the compiler in dtuple_validate */
/*
*
this is used to fool the compiler in dtuple_validate */
UNIV_INTERN
ulint
data_dummy
;
UNIV_INTERN
ulint
data_dummy
;
# endif
/* !UNIV_DEBUG_VALGRIND */
# endif
/* !UNIV_DEBUG_VALGRIND */
#endif
/* UNIV_DEBUG */
#endif
/* UNIV_DEBUG */
...
...
include/btr0btr.h
View file @
065f8dac
...
@@ -35,41 +35,50 @@ Created 6/2/1994 Heikki Tuuri
...
@@ -35,41 +35,50 @@ Created 6/2/1994 Heikki Tuuri
#include "btr0types.h"
#include "btr0types.h"
#ifndef UNIV_HOTBACKUP
#ifndef UNIV_HOTBACKUP
/* Maximum record size which can be stored on a page, without using the
/*
*
Maximum record size which can be stored on a page, without using the
special big record storage structure */
special big record storage structure */
#define BTR_PAGE_MAX_REC_SIZE (UNIV_PAGE_SIZE / 2 - 200)
#define BTR_PAGE_MAX_REC_SIZE (UNIV_PAGE_SIZE / 2 - 200)
/* Maximum depth of a B-tree in InnoDB. Note that this isn't a maximum as
/** @brief Maximum depth of a B-tree in InnoDB.
such; none of the tree operations avoid producing trees bigger than this. It
is instead a "max depth that other code must work with", useful for e.g.
Note that this isn't a maximum as such; none of the tree operations
fixed-size arrays that must store some information about each level in a
avoid producing trees bigger than this. It is instead a "max depth
tree. In other words: if a B-tree with bigger depth than this is
that other code must work with", useful for e.g. fixed-size arrays
encountered, it is not acceptable for it to lead to mysterious memory
that must store some information about each level in a tree. In other
corruption, but it is acceptable for the program to die with a clear assert
words: if a B-tree with bigger depth than this is encountered, it is
failure. */
not acceptable for it to lead to mysterious memory corruption, but it
is acceptable for the program to die with a clear assert failure. */
#define BTR_MAX_LEVELS 100
#define BTR_MAX_LEVELS 100
/* Latching modes for btr_cur_search_to_nth_level(). */
/** Latching modes for btr_cur_search_to_nth_level(). */
#define BTR_SEARCH_LEAF RW_S_LATCH
enum
btr_latch_mode
{
#define BTR_MODIFY_LEAF RW_X_LATCH
/** Search a record on a leaf page and S-latch it. */
#define BTR_NO_LATCHES RW_NO_LATCH
BTR_SEARCH_LEAF
=
RW_S_LATCH
,
#define BTR_MODIFY_TREE 33
/** (Prepare to) modify a record on a leaf page and X-latch it. */
#define BTR_CONT_MODIFY_TREE 34
BTR_MODIFY_LEAF
=
RW_X_LATCH
,
#define BTR_SEARCH_PREV 35
/** Obtain no latches. */
#define BTR_MODIFY_PREV 36
BTR_NO_LATCHES
=
RW_NO_LATCH
,
/** Start modifying the entire B-tree. */
BTR_MODIFY_TREE
=
33
,
/** Continue modifying the entire B-tree. */
BTR_CONT_MODIFY_TREE
=
34
,
/** Search the previous record. */
BTR_SEARCH_PREV
=
35
,
/** Modify the previous record. */
BTR_MODIFY_PREV
=
36
};
/*
If this is ORed to the latch mode, it means that the search tuple will b
e
/*
* If this is ORed to btr_latch_mode, it means that the search tupl
e
inserted to the index, at the searched position */
will be
inserted to the index, at the searched position */
#define BTR_INSERT 512
#define BTR_INSERT 512
/*
This flag ORed to latch
mode says that we do the search in query
/*
* This flag ORed to btr_latch_
mode says that we do the search in query
optimization */
optimization */
#define BTR_ESTIMATE 1024
#define BTR_ESTIMATE 1024
/*
This flag ORed to latch
mode says that we can ignore possible
/*
* This flag ORed to btr_latch_
mode says that we can ignore possible
UNIQUE definition on secondary indexes when we decide if we can use
the
UNIQUE definition on secondary indexes when we decide if we can use
insert buffer to speed up inserts */
the
insert buffer to speed up inserts */
#define BTR_IGNORE_SEC_UNIQUE 2048
#define BTR_IGNORE_SEC_UNIQUE 2048
/**************************************************************//**
/**************************************************************//**
...
...
include/btr0sea.h
View file @
065f8dac
...
@@ -182,74 +182,81 @@ ibool
...
@@ -182,74 +182,81 @@ ibool
btr_search_validate
(
void
);
btr_search_validate
(
void
);
/*======================*/
/*======================*/
/* Flag: has the search system been enabled?
/*
*
Flag: has the search system been enabled?
Protected by btr_search_latch and btr_search_enabled_mutex. */
Protected by btr_search_latch and btr_search_enabled_mutex. */
extern
char
btr_search_enabled
;
extern
char
btr_search_enabled
;
/* The search info struct in an index */
/** The search info struct in an index */
struct
btr_search_struct
{
struct
btr_search_struct
{
ulint
ref_count
;
/* Number of blocks in this index tree
ulint
ref_count
;
/*
!<
Number of blocks in this index tree
that have search index built
that have search index built
i.e. block->index points to this index.
i.e. block->index points to this index.
Protected by btr_search_latch except
Protected by btr_search_latch except
when during initialization in
when during initialization in
btr_search_info_create(). */
btr_search_info_create(). */
/* The following fields are not protected by any latch.
/*
@{
The following fields are not protected by any latch.
Unfortunately, this means that they must be aligned to
Unfortunately, this means that they must be aligned to
the machine word, i.e., they cannot be turned into bit-fields. */
the machine word, i.e., they cannot be turned into bit-fields. */
buf_block_t
*
root_guess
;
/* the root page frame when it was last time
buf_block_t
*
root_guess
;
/*
!<
the root page frame when it was last time
fetched, or NULL */
fetched, or NULL */
ulint
hash_analysis
;
/* when this exceeds BTR_SEARCH_HASH_ANALYSIS,
ulint
hash_analysis
;
/*!< when this exceeds
the hash analysis starts; this is reset if no
BTR_SEARCH_HASH_ANALYSIS, the hash
analysis starts; this is reset if no
success noticed */
success noticed */
ibool
last_hash_succ
;
/* TRUE if the last search would have
ibool
last_hash_succ
;
/*
!<
TRUE if the last search would have
succeeded, or did succeed, using the hash
succeeded, or did succeed, using the hash
index; NOTE that the value here is not exact:
index; NOTE that the value here is not exact:
it is not calculated for every search, and the
it is not calculated for every search, and the
calculation itself is not always accurate! */
calculation itself is not always accurate! */
ulint
n_hash_potential
;
ulint
n_hash_potential
;
/* number of consecutive searches
/*
!<
number of consecutive searches
which would have succeeded, or did succeed,
which would have succeeded, or did succeed,
using the hash index;
using the hash index;
the range is 0 .. BTR_SEARCH_BUILD_LIMIT + 5 */
the range is 0 .. BTR_SEARCH_BUILD_LIMIT + 5 */
/*----------------------*/
/* @} */
ulint
n_fields
;
/* recommended prefix length for hash search:
/*---------------------- @{ */
ulint
n_fields
;
/*!< recommended prefix length for hash search:
number of full fields */
number of full fields */
ulint
n_bytes
;
/* recommended prefix: number of bytes in
ulint
n_bytes
;
/*
!<
recommended prefix: number of bytes in
an incomplete field
;
an incomplete field
see also
BTR_PAGE_MAX_REC_SIZE */
@see
BTR_PAGE_MAX_REC_SIZE */
ibool
left_side
;
/* TRUE or FALSE, depending on whether
ibool
left_side
;
/*
!<
TRUE or FALSE, depending on whether
the leftmost record of several records with
the leftmost record of several records with
the same prefix should be indexed in the
the same prefix should be indexed in the
hash index */
hash index */
/*----------------------*/
/*----------------------
@}
*/
#ifdef UNIV_SEARCH_PERF_STAT
#ifdef UNIV_SEARCH_PERF_STAT
ulint
n_hash_succ
;
/* number of successful hash searches thus
ulint
n_hash_succ
;
/*
!<
number of successful hash searches thus
far */
far */
ulint
n_hash_fail
;
/* number of failed hash searches */
ulint
n_hash_fail
;
/*
!<
number of failed hash searches */
ulint
n_patt_succ
;
/* number of successful pattern searches thus
ulint
n_patt_succ
;
/*
!<
number of successful pattern searches thus
far */
far */
ulint
n_searches
;
/* number of searches */
ulint
n_searches
;
/*
!<
number of searches */
#endif
/* UNIV_SEARCH_PERF_STAT */
#endif
/* UNIV_SEARCH_PERF_STAT */
#ifdef UNIV_DEBUG
#ifdef UNIV_DEBUG
ulint
magic_n
;
/* magic number */
ulint
magic_n
;
/*!< magic number @see BTR_SEARCH_MAGIC_N */
/** value of btr_search_struct::magic_n, used in assertions */
# define BTR_SEARCH_MAGIC_N 1112765
# define BTR_SEARCH_MAGIC_N 1112765
#endif
/* UNIV_DEBUG */
#endif
/* UNIV_DEBUG */
};
};
/* The hash index system */
/** The hash index system */
typedef
struct
btr_search_sys_struct
btr_search_sys_t
;
typedef
struct
btr_search_sys_struct
btr_search_sys_t
;
/** The hash index system */
struct
btr_search_sys_struct
{
struct
btr_search_sys_struct
{
hash_table_t
*
hash_index
;
hash_table_t
*
hash_index
;
/*!< the adaptive hash index,
mapping dtuple_fold values
to rec_t pointers on index pages */
};
};
/** The adaptive hash index */
extern
btr_search_sys_t
*
btr_search_sys
;
extern
btr_search_sys_t
*
btr_search_sys
;
/* The latch protecting the adaptive search system: this latch protects the
/** @brief The latch protecting the adaptive search system
This latch protects the
(1) hash index;
(1) hash index;
(2) columns of a record to which we have a pointer in the hash index;
(2) columns of a record to which we have a pointer in the hash index;
...
@@ -260,36 +267,34 @@ but does NOT protect:
...
@@ -260,36 +267,34 @@ but does NOT protect:
Bear in mind (3) and (4) when using the hash index.
Bear in mind (3) and (4) when using the hash index.
*/
*/
extern
rw_lock_t
*
btr_search_latch_temp
;
extern
rw_lock_t
*
btr_search_latch_temp
;
/** The latch protecting the adaptive search system */
#define btr_search_latch (*btr_search_latch_temp)
#define btr_search_latch (*btr_search_latch_temp)
#ifdef UNIV_SEARCH_PERF_STAT
#ifdef UNIV_SEARCH_PERF_STAT
/** Number of successful adaptive hash index lookups */
extern
ulint
btr_search_n_succ
;
extern
ulint
btr_search_n_succ
;
/** Number of failed adaptive hash index lookups */
extern
ulint
btr_search_n_hash_fail
;
extern
ulint
btr_search_n_hash_fail
;
#endif
/* UNIV_SEARCH_PERF_STAT */
#endif
/* UNIV_SEARCH_PERF_STAT */
/* After change in n_fields or n_bytes in info, this many rounds are waited
/*
*
After change in n_fields or n_bytes in info, this many rounds are waited
before starting the hash analysis again: this is to save CPU time when there
before starting the hash analysis again: this is to save CPU time when there
is no hope in building a hash index. */
is no hope in building a hash index. */
#define BTR_SEARCH_HASH_ANALYSIS 17
#define BTR_SEARCH_HASH_ANALYSIS 17
/* Limit of consecutive searches for trying a search shortcut on the search
/*
*
Limit of consecutive searches for trying a search shortcut on the search
pattern */
pattern */
#define BTR_SEARCH_ON_PATTERN_LIMIT 3
#define BTR_SEARCH_ON_PATTERN_LIMIT 3
/* Limit of consecutive searches for trying a search shortcut using the hash
/** Limit of consecutive searches for trying a search shortcut using
index */
the hash index */
#define BTR_SEARCH_ON_HASH_LIMIT 3
#define BTR_SEARCH_ON_HASH_LIMIT 3
/* We do this many searches before trying to keep the search latch over calls
/** We do this many searches before trying to keep the search latch
from MySQL. If we notice someone waiting for the latch, we again set this
over calls from MySQL. If we notice someone waiting for the latch, we
much timeout. This is to reduce contention. */
again set this much timeout. This is to reduce contention. */
#define BTR_SEA_TIMEOUT 10000
#define BTR_SEA_TIMEOUT 10000
#ifndef UNIV_NONINL
#ifndef UNIV_NONINL
...
...
include/buf0buf.h
View file @
065f8dac
...
@@ -64,23 +64,29 @@ extern buf_block_t* back_block2; /* second block, for page reorganize */
...
@@ -64,23 +64,29 @@ extern buf_block_t* back_block2; /* second block, for page reorganize */
/* Magic value to use instead of checksums when they are disabled */
/* Magic value to use instead of checksums when they are disabled */
#define BUF_NO_CHECKSUM_MAGIC 0xDEADBEEFUL
#define BUF_NO_CHECKSUM_MAGIC 0xDEADBEEFUL
/* States of a control block (@see buf_page_struct).
/** @brief States of a control block
@see buf_page_struct
The enumeration values must be 0..7. */
The enumeration values must be 0..7. */
enum
buf_page_state
{
enum
buf_page_state
{
BUF_BLOCK_ZIP_FREE
=
0
,
/* contains a free compressed page */
BUF_BLOCK_ZIP_FREE
=
0
,
/*!< contains a free
BUF_BLOCK_ZIP_PAGE
,
/* contains a clean compressed page */
compressed page */
BUF_BLOCK_ZIP_DIRTY
,
/* contains a compressed page that is
BUF_BLOCK_ZIP_PAGE
,
/*!< contains a clean
in the buf_pool->flush_list */
compressed page */
BUF_BLOCK_ZIP_DIRTY
,
/*!< contains a compressed
/* The constants for compressed-only pages must precede
page that is in the
BUF_BLOCK_NOT_USED; @see buf_block_state_valid() */
buf_pool->flush_list */
BUF_BLOCK_NOT_USED
,
/* is in the free list */
BUF_BLOCK_NOT_USED
,
/*!< is in the free list;
BUF_BLOCK_READY_FOR_USE
,
/* when buf_LRU_get_free_block returns
must be after the BUF_BLOCK_ZIP_
a block, it is in this state */
constants for compressed-only pages
BUF_BLOCK_FILE_PAGE
,
/* contains a buffered file page */
@see buf_block_state_valid() */
BUF_BLOCK_MEMORY
,
/* contains some main memory object */
BUF_BLOCK_READY_FOR_USE
,
/*!< when buf_LRU_get_free_block
BUF_BLOCK_REMOVE_HASH
/* hash index should be removed
returns a block, it is in this state */
BUF_BLOCK_FILE_PAGE
,
/*!< contains a buffered file page */
BUF_BLOCK_MEMORY
,
/*!< contains some main memory
object */
BUF_BLOCK_REMOVE_HASH
/*!< hash index should be removed
before putting to the free list */
before putting to the free list */
};
};
...
@@ -1241,7 +1247,9 @@ struct buf_block_struct{
...
@@ -1241,7 +1247,9 @@ struct buf_block_struct{
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
};
};
/* Check if a buf_block_t object is in a valid state. */
/** Check if a buf_block_t object is in a valid state
@param block buffer block
@return TRUE if valid */
#define buf_block_state_valid(block) \
#define buf_block_state_valid(block) \
(buf_block_get_state(block) >= BUF_BLOCK_NOT_USED \
(buf_block_get_state(block) >= BUF_BLOCK_NOT_USED \
&& (buf_block_get_state(block) <= BUF_BLOCK_REMOVE_HASH))
&& (buf_block_get_state(block) <= BUF_BLOCK_REMOVE_HASH))
...
...
include/data0data.h
View file @
065f8dac
...
@@ -33,6 +33,8 @@ Created 5/30/1994 Heikki Tuuri
...
@@ -33,6 +33,8 @@ Created 5/30/1994 Heikki Tuuri
#include "mem0mem.h"
#include "mem0mem.h"
#include "dict0types.h"
#include "dict0types.h"
/** Storage for overflow data in a big record, that is, a clustered
index record which needs external storage of data fields */
typedef
struct
big_rec_struct
big_rec_t
;
typedef
struct
big_rec_struct
big_rec_t
;
#ifdef UNIV_DEBUG
#ifdef UNIV_DEBUG
...
@@ -422,53 +424,56 @@ dtuple_big_rec_free(
...
@@ -422,53 +424,56 @@ dtuple_big_rec_free(
/*######################################################################*/
/*######################################################################*/
/* Structure for an SQL data field */
/*
*
Structure for an SQL data field */
struct
dfield_struct
{
struct
dfield_struct
{
void
*
data
;
/* pointer to data */
void
*
data
;
/*
!<
pointer to data */
unsigned
ext
:
1
;
/* TRUE=externally stored, FALSE=local */
unsigned
ext
:
1
;
/*
!<
TRUE=externally stored, FALSE=local */
unsigned
len
:
32
;
/* data length; UNIV_SQL_NULL if SQL null */
unsigned
len
:
32
;
/*
!<
data length; UNIV_SQL_NULL if SQL null */
dtype_t
type
;
/* type of data */
dtype_t
type
;
/*
!<
type of data */
};
};
/** Structure for an SQL data tuple of fields (logical record) */
struct
dtuple_struct
{
struct
dtuple_struct
{
ulint
info_bits
;
/* info bits of an index record:
ulint
info_bits
;
/*
!<
info bits of an index record:
the default is 0; this field is used
the default is 0; this field is used
if an index record is built from
if an index record is built from
a data tuple */
a data tuple */
ulint
n_fields
;
/* number of fields in dtuple */
ulint
n_fields
;
/*
!<
number of fields in dtuple */
ulint
n_fields_cmp
;
/* number of fields which should
ulint
n_fields_cmp
;
/*
!<
number of fields which should
be used in comparison services
be used in comparison services
of rem0cmp.*; the index search
of rem0cmp.*; the index search
is performed by comparing only these
is performed by comparing only these
fields, others are ignored; the
fields, others are ignored; the
default value in dtuple creation is
default value in dtuple creation is
the same value as n_fields */
the same value as n_fields */
dfield_t
*
fields
;
/* fields */
dfield_t
*
fields
;
/*
!<
fields */
UT_LIST_NODE_T
(
dtuple_t
)
tuple_list
;
UT_LIST_NODE_T
(
dtuple_t
)
tuple_list
;
/* data tuples can be linked into a
/*
!<
data tuples can be linked into a
list using this field */
list using this field */
#ifdef UNIV_DEBUG
#ifdef UNIV_DEBUG
ulint
magic_n
;
ulint
magic_n
;
/*!< magic number, used in
debug assertions */
/** Value of dtuple_struct::magic_n */
# define DATA_TUPLE_MAGIC_N 65478679
# define DATA_TUPLE_MAGIC_N 65478679
#endif
/* UNIV_DEBUG */
#endif
/* UNIV_DEBUG */
};
};
/* A slot for a field in a big rec vector */
/** A slot for a field in a big rec vector */
typedef
struct
big_rec_field_struct
big_rec_field_t
;
typedef
struct
big_rec_field_struct
big_rec_field_t
;
/** A slot for a field in a big rec vector */
struct
big_rec_field_struct
{
struct
big_rec_field_struct
{
ulint
field_no
;
/* field number in record */
ulint
field_no
;
/*
!<
field number in record */
ulint
len
;
/*
stored data len
*/
ulint
len
;
/*
!< stored data length, in bytes
*/
const
void
*
data
;
/* stored data */
const
void
*
data
;
/*
!<
stored data */
};
};
/* Storage format for overflow data in a big record, that is, a record
/** Storage format for overflow data in a big record, that is, a
which needs external storage of data fields */
clustered index record which needs external storage of data fields */
struct
big_rec_struct
{
struct
big_rec_struct
{
mem_heap_t
*
heap
;
/* memory heap from which allocated */
mem_heap_t
*
heap
;
/*!< memory heap from which
ulint
n_fields
;
/* number of stored fields */
allocated */
big_rec_field_t
*
fields
;
/* stored fields */
ulint
n_fields
;
/*!< number of stored fields */
big_rec_field_t
*
fields
;
/*!< stored fields */
};
};
#ifndef UNIV_NONINL
#ifndef UNIV_NONINL
...
...
include/data0data.ic
View file @
065f8dac
...
@@ -27,6 +27,9 @@ Created 5/30/1994 Heikki Tuuri
...
@@ -27,6 +27,9 @@ Created 5/30/1994 Heikki Tuuri
#include "ut0rnd.h"
#include "ut0rnd.h"
#ifdef UNIV_DEBUG
#ifdef UNIV_DEBUG
/** Dummy variable to catch access to uninitialized fields. In the
debug version, dtuple_create() will make all fields of dtuple_t point
to data_error. */
extern byte data_error;
extern byte data_error;
/*********************************************************************//**
/*********************************************************************//**
...
...
include/ha0storage.h
View file @
065f8dac
...
@@ -72,23 +72,32 @@ ha_storage_put_memlim(
...
@@ -72,23 +72,32 @@ ha_storage_put_memlim(
ulint
memlim
);
/*!< in: memory limit to obey */
ulint
memlim
);
/*!< in: memory limit to obey */
/*******************************************************************//**
/*******************************************************************//**
Same as ha_storage_put_memlim() but without memory limit. */
Same as ha_storage_put_memlim() but without memory limit.
@param storage in/out: hash storage
@param data in: data to store
@param data_len in: data length
@return pointer to the copy of the string */
#define ha_storage_put(storage, data, data_len) \
#define ha_storage_put(storage, data, data_len) \
ha_storage_put_memlim((storage), (data), (data_len), 0)
ha_storage_put_memlim((storage), (data), (data_len), 0)
/*******************************************************************//**
/*******************************************************************//**
Copies string into the storage and returns a pointer to the copy. If the
Copies string into the storage and returns a pointer to the copy. If the
same string is already present, then pointer to it is returned.
same string is already present, then pointer to it is returned.
Strings are considered to be equal if strcmp(str1, str2) == 0. */
Strings are considered to be equal if strcmp(str1, str2) == 0.
@param storage in/out: hash storage
@param str in: string to put
@return pointer to the copy of the string */
#define ha_storage_put_str(storage, str) \
#define ha_storage_put_str(storage, str) \
((const char*) ha_storage_put((storage), (str), strlen(str) + 1))
((const char*) ha_storage_put((storage), (str), strlen(str) + 1))
/*******************************************************************//**
/*******************************************************************//**
Copies string into the storage and returns a pointer to the copy obeying
Copies string into the storage and returns a pointer to the copy obeying
a memory limit. */
a memory limit.
If the same string is already present, then pointer to it is returned.
Strings are considered to be equal if strcmp(str1, str2) == 0.
@param storage in/out: hash storage
@param str in: string to put
@return pointer to the copy of the string */
#define ha_storage_put_str_memlim(storage, str, memlim) \
#define ha_storage_put_str_memlim(storage, str, memlim) \
((const char*) ha_storage_put_memlim((storage), (str), \
((const char*) ha_storage_put_memlim((storage), (str), \
strlen(str) + 1, (memlim)))
strlen(str) + 1, (memlim)))
...
...
include/ha0storage.ic
View file @
065f8dac
...
@@ -30,19 +30,21 @@ Created September 24, 2007 Vasil Dimov
...
@@ -30,19 +30,21 @@ Created September 24, 2007 Vasil Dimov
#include "hash0hash.h"
#include "hash0hash.h"
#include "mem0mem.h"
#include "mem0mem.h"
/** Hash storage for strings */
struct ha_storage_struct {
struct ha_storage_struct {
mem_heap_t* heap; /*
storage
from which memory is
mem_heap_t* heap; /*
!< memory heap
from which memory is
allocated */
allocated */
hash_table_t* hash; /* hash table used to avoid
hash_table_t* hash; /*
!<
hash table used to avoid
duplicates */
duplicates */
};
};
/*
Objects of this type are put in the hash
*/
/*
* Objects of this type are stored in ha_storage_t
*/
typedef struct ha_storage_node_struct ha_storage_node_t;
typedef struct ha_storage_node_struct ha_storage_node_t;
/** Objects of this type are stored in ha_storage_struct */
struct ha_storage_node_struct {
struct ha_storage_node_struct {
ulint data_len;/* length of the data */
ulint data_len;/*
!<
length of the data */
const void* data; /* pointer to data */
const void* data; /*
!<
pointer to data */
ha_storage_node_t* next; /* next node in hash chain */
ha_storage_node_t* next; /*
!<
next node in hash chain */
};
};
/*******************************************************************//**
/*******************************************************************//**
...
...
include/log0recv.h
View file @
065f8dac
...
@@ -98,13 +98,29 @@ recv_recover_page_func(
...
@@ -98,13 +98,29 @@ recv_recover_page_func(
/*===================*/
/*===================*/
#ifndef UNIV_HOTBACKUP
#ifndef UNIV_HOTBACKUP
ibool
just_read_in
,
ibool
just_read_in
,
/*!< in: TRUE if the i/o
-handler calls this for
/*!< in: TRUE if the i/o
handler calls
a freshly read page */
this for
a freshly read page */
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
buf_block_t
*
block
);
/*!< in: buffer block */
buf_block_t
*
block
);
/*!< in
/out
: buffer block */
#ifndef UNIV_HOTBACKUP
#ifndef UNIV_HOTBACKUP
/** Wrapper for recv_recover_page_func().
Applies the hashed log records to the page, if the page lsn is less than the
lsn of a log record. This can be called when a buffer page has just been
read in, or also for a page already in the buffer pool.
@param jri in: TRUE if just read in (the i/o handler calls this for
a freshly read page)
@param block in/out: the buffer block
*/
# define recv_recover_page(jri, block) recv_recover_page_func(jri, block)
# define recv_recover_page(jri, block) recv_recover_page_func(jri, block)
#else
/* !UNIV_HOTBACKUP */
#else
/* !UNIV_HOTBACKUP */
/** Wrapper for recv_recover_page_func().
Applies the hashed log records to the page, if the page lsn is less than the
lsn of a log record. This can be called when a buffer page has just been
read in, or also for a page already in the buffer pool.
@param jri in: TRUE if just read in (the i/o handler calls this for
a freshly read page)
@param block in/out: the buffer block
*/
# define recv_recover_page(jri, block) recv_recover_page_func(block)
# define recv_recover_page(jri, block) recv_recover_page_func(block)
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
/********************************************************//**
/********************************************************//**
...
@@ -118,7 +134,8 @@ ulint
...
@@ -118,7 +134,8 @@ ulint
recv_recovery_from_checkpoint_start_func
(
recv_recovery_from_checkpoint_start_func
(
/*=====================================*/
/*=====================================*/
#ifdef UNIV_LOG_ARCHIVE
#ifdef UNIV_LOG_ARCHIVE
ulint
type
,
/*!< in: LOG_CHECKPOINT or LOG_ARCHIVE */
ulint
type
,
/*!< in: LOG_CHECKPOINT or
LOG_ARCHIVE */
ib_uint64_t
limit_lsn
,
/*!< in: recover up to this lsn
ib_uint64_t
limit_lsn
,
/*!< in: recover up to this lsn
if possible */
if possible */
#endif
/* UNIV_LOG_ARCHIVE */
#endif
/* UNIV_LOG_ARCHIVE */
...
@@ -127,9 +144,29 @@ recv_recovery_from_checkpoint_start_func(
...
@@ -127,9 +144,29 @@ recv_recovery_from_checkpoint_start_func(
ib_uint64_t
max_flushed_lsn
);
/*!< in: max flushed lsn from
ib_uint64_t
max_flushed_lsn
);
/*!< in: max flushed lsn from
data files */
data files */
#ifdef UNIV_LOG_ARCHIVE
#ifdef UNIV_LOG_ARCHIVE
/** Wrapper for recv_recovery_from_checkpoint_start_func().
Recovers from a checkpoint. When this function returns, the database is able
to start processing of new user transactions, but the function
recv_recovery_from_checkpoint_finish should be called later to complete
the recovery and free the resources used in it.
@param type in: LOG_CHECKPOINT or LOG_ARCHIVE
@param lim in: recover up to this log sequence number if possible
@param min in: minimum flushed log sequence number from data files
@param max in: maximum flushed log sequence number from data files
@return error code or DB_SUCCESS */
# define recv_recovery_from_checkpoint_start(type,lim,min,max) \
# define recv_recovery_from_checkpoint_start(type,lim,min,max) \
recv_recovery_from_checkpoint_start_func(type,lim,min,max)
recv_recovery_from_checkpoint_start_func(type,lim,min,max)
#else
/* UNIV_LOG_ARCHIVE */
#else
/* UNIV_LOG_ARCHIVE */
/** Wrapper for recv_recovery_from_checkpoint_start_func().
Recovers from a checkpoint. When this function returns, the database is able
to start processing of new user transactions, but the function
recv_recovery_from_checkpoint_finish should be called later to complete
the recovery and free the resources used in it.
@param type ignored: LOG_CHECKPOINT or LOG_ARCHIVE
@param lim ignored: recover up to this log sequence number if possible
@param min in: minimum flushed log sequence number from data files
@param max in: maximum flushed log sequence number from data files
@return error code or DB_SUCCESS */
# define recv_recovery_from_checkpoint_start(type,lim,min,max) \
# define recv_recovery_from_checkpoint_start(type,lim,min,max) \
recv_recovery_from_checkpoint_start_func(min,max)
recv_recovery_from_checkpoint_start_func(min,max)
#endif
/* UNIV_LOG_ARCHIVE */
#endif
/* UNIV_LOG_ARCHIVE */
...
@@ -256,135 +293,170 @@ recv_recovery_from_archive_finish(void);
...
@@ -256,135 +293,170 @@ recv_recovery_from_archive_finish(void);
/*===================================*/
/*===================================*/
#endif
/* UNIV_LOG_ARCHIVE */
#endif
/* UNIV_LOG_ARCHIVE */
/* Block of log record data */
/*
*
Block of log record data */
typedef
struct
recv_data_struct
recv_data_t
;
typedef
struct
recv_data_struct
recv_data_t
;
/** Block of log record data */
struct
recv_data_struct
{
struct
recv_data_struct
{
recv_data_t
*
next
;
/* pointer to the next block or NULL */
recv_data_t
*
next
;
/*
!<
pointer to the next block or NULL */
/* the log record data is stored physically
/*
!<
the log record data is stored physically
immediately after this struct, max amount
immediately after this struct, max amount
RECV_DATA_BLOCK_SIZE bytes of it */
RECV_DATA_BLOCK_SIZE bytes of it */
};
};
/* Stored log record struct */
/*
*
Stored log record struct */
typedef
struct
recv_struct
recv_t
;
typedef
struct
recv_struct
recv_t
;
/** Stored log record struct */
struct
recv_struct
{
struct
recv_struct
{
byte
type
;
/* log record type */
byte
type
;
/*
!<
log record type */
ulint
len
;
/* log record body length in bytes */
ulint
len
;
/*
!<
log record body length in bytes */
recv_data_t
*
data
;
/* chain of blocks containing the log record
recv_data_t
*
data
;
/*
!<
chain of blocks containing the log record
body */
body */
ib_uint64_t
start_lsn
;
/* start lsn of the log segment written by
ib_uint64_t
start_lsn
;
/*
!<
start lsn of the log segment written by
the mtr which generated this log record: NOTE
the mtr which generated this log record: NOTE
that this is not necessarily the start lsn of
that this is not necessarily the start lsn of
this log record */
this log record */
ib_uint64_t
end_lsn
;
/* end lsn of the log segment written by
ib_uint64_t
end_lsn
;
/*
!<
end lsn of the log segment written by
the mtr which generated this log record: NOTE
the mtr which generated this log record: NOTE
that this is not necessarily the end lsn of
that this is not necessarily the end lsn of
this log record */
this log record */
UT_LIST_NODE_T
(
recv_t
)
UT_LIST_NODE_T
(
recv_t
)
rec_list
;
/* list of log records for this page */
rec_list
;
/*!< list of log records for this page */
};
/** States of recv_addr_struct */
enum
recv_addr_state
{
/** not yet processed */
RECV_NOT_PROCESSED
,
/** page is being read */
RECV_BEING_READ
,
/** log records are being applied on the page */
RECV_BEING_PROCESSED
,
/** log records have been applied on the page, or they have
been discarded because the tablespace does not exist */
RECV_PROCESSED
};
};
/* Hashed page file address struct */
/*
*
Hashed page file address struct */
typedef
struct
recv_addr_struct
recv_addr_t
;
typedef
struct
recv_addr_struct
recv_addr_t
;
/** Hashed page file address struct */
struct
recv_addr_struct
{
struct
recv_addr_struct
{
ulint
state
;
/* RECV_NOT_PROCESSED, RECV_BEING_PROCESSED,
enum
recv_addr_state
state
;
or RECV_PROCESSED
*/
/*!< recovery state of the page
*/
ulint
space
;
/* space id */
ulint
space
;
/*
!<
space id */
ulint
page_no
;
/* page number */
ulint
page_no
;
/*
!<
page number */
UT_LIST_BASE_NODE_T
(
recv_t
)
UT_LIST_BASE_NODE_T
(
recv_t
)
rec_list
;
/* list of log records for this page */
rec_list
;
/*
!<
list of log records for this page */
hash_node_t
addr_hash
;
hash_node_t
addr_hash
;
/*!< hash node in the hash bucket chain */
};
};
/* Recovery system data structure */
/*
*
Recovery system data structure */
typedef
struct
recv_sys_struct
recv_sys_t
;
typedef
struct
recv_sys_struct
recv_sys_t
;
/** Recovery system data structure */
struct
recv_sys_struct
{
struct
recv_sys_struct
{
#ifndef UNIV_HOTBACKUP
#ifndef UNIV_HOTBACKUP
mutex_t
mutex
;
/* mutex protecting the fields apply_log_recs,
mutex_t
mutex
;
/*
!<
mutex protecting the fields apply_log_recs,
n_addrs, and the state field in each recv_addr
n_addrs, and the state field in each recv_addr
struct */
struct */
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
ibool
apply_log_recs
;
ibool
apply_log_recs
;
/* this is TRUE when log rec application to
/*
!<
this is TRUE when log rec application to
pages is allowed; this flag tells the
pages is allowed; this flag tells the
i/o-handler if it should do log record
i/o-handler if it should do log record
application */
application */
ibool
apply_batch_on
;
ibool
apply_batch_on
;
/* this is TRUE when a log rec application
/*
!<
this is TRUE when a log rec application
batch is running */
batch is running */
ib_uint64_t
lsn
;
/* log sequence number */
ib_uint64_t
lsn
;
/*
!<
log sequence number */
ulint
last_log_buf_size
;
ulint
last_log_buf_size
;
/* size of the log buffer when the database
/*
!<
size of the log buffer when the database
last time wrote to the log */
last time wrote to the log */
byte
*
last_block
;
byte
*
last_block
;
/* possible incomplete last recovered log
/*
!<
possible incomplete last recovered log
block */
block */
byte
*
last_block_buf_start
;
byte
*
last_block_buf_start
;
/* the nonaligned start address of the
/*
!<
the nonaligned start address of the
preceding buffer */
preceding buffer */
byte
*
buf
;
/* buffer for parsing log records */
byte
*
buf
;
/*
!<
buffer for parsing log records */
ulint
len
;
/* amount of data in buf */
ulint
len
;
/*
!<
amount of data in buf */
ib_uint64_t
parse_start_lsn
;
ib_uint64_t
parse_start_lsn
;
/* this is the lsn from which we were able to
/*
!<
this is the lsn from which we were able to
start parsing log records and adding them to
start parsing log records and adding them to
the hash table; zero if a suitable
the hash table; zero if a suitable
start point not found yet */
start point not found yet */
ib_uint64_t
scanned_lsn
;
ib_uint64_t
scanned_lsn
;
/* the log data has been scanned up to this
/*
!<
the log data has been scanned up to this
lsn */
lsn */
ulint
scanned_checkpoint_no
;
ulint
scanned_checkpoint_no
;
/* the log data has been scanned up to this
/*
!<
the log data has been scanned up to this
checkpoint number (lowest 4 bytes) */
checkpoint number (lowest 4 bytes) */
ulint
recovered_offset
;
ulint
recovered_offset
;
/* start offset of non-parsed log records in
/*
!<
start offset of non-parsed log records in
buf */
buf */
ib_uint64_t
recovered_lsn
;
ib_uint64_t
recovered_lsn
;
/* the log records have been parsed up to
/*
!<
the log records have been parsed up to
this lsn */
this lsn */
ib_uint64_t
limit_lsn
;
/*
recovery should be made at most up to this
ib_uint64_t
limit_lsn
;
/*
!< recovery should be made at most
lsn */
up to this
lsn */
ibool
found_corrupt_log
;
ibool
found_corrupt_log
;
/* this is set to TRUE if we during log
/*
!<
this is set to TRUE if we during log
scan find a corrupt log block, or a corrupt
scan find a corrupt log block, or a corrupt
log record, or there is a log parsing
log record, or there is a log parsing
buffer overflow */
buffer overflow */
#ifdef UNIV_LOG_ARCHIVE
#ifdef UNIV_LOG_ARCHIVE
log_group_t
*
archive_group
;
log_group_t
*
archive_group
;
/* in archive recovery: the log group whose
/*
!<
in archive recovery: the log group whose
archive is read */
archive is read */
#endif
/* !UNIV_LOG_ARCHIVE */
#endif
/* !UNIV_LOG_ARCHIVE */
mem_heap_t
*
heap
;
/* memory heap of log records and file
mem_heap_t
*
heap
;
/*
!<
memory heap of log records and file
addresses*/
addresses*/
hash_table_t
*
addr_hash
;
/* hash table of file addresses of pages */
hash_table_t
*
addr_hash
;
/*
!<
hash table of file addresses of pages */
ulint
n_addrs
;
/* number of not processed hashed file
ulint
n_addrs
;
/*
!<
number of not processed hashed file
addresses in the hash table */
addresses in the hash table */
};
};
/** The recovery system */
extern
recv_sys_t
*
recv_sys
;
extern
recv_sys_t
*
recv_sys
;
/** TRUE when applying redo log records during crash recovery; FALSE
otherwise. Note that this is FALSE while a background thread is
rolling back incomplete transactions. */
extern
ibool
recv_recovery_on
;
extern
ibool
recv_recovery_on
;
/** If the following is TRUE, the buffer pool file pages must be invalidated
after recovery and no ibuf operations are allowed; this becomes TRUE if
the log record hash table becomes too full, and log records must be merged
to file pages already before the recovery is finished: in this case no
ibuf operations are allowed, as they could modify the pages read in the
buffer pool before the pages have been recovered to the up-to-date state.
TRUE means that recovery is running and no operations on the log files
are allowed yet: the variable name is misleading. */
extern
ibool
recv_no_ibuf_operations
;
extern
ibool
recv_no_ibuf_operations
;
/** TRUE when recv_init_crash_recovery() has been called. */
extern
ibool
recv_needed_recovery
;
extern
ibool
recv_needed_recovery
;
/** TRUE if buf_page_is_corrupted() should check if the log sequence
number (FIL_PAGE_LSN) is in the future. Initially FALSE, and set by
recv_recovery_from_checkpoint_start_func(). */
extern
ibool
recv_lsn_checks_on
;
extern
ibool
recv_lsn_checks_on
;
#ifdef UNIV_HOTBACKUP
#ifdef UNIV_HOTBACKUP
/** TRUE when the redo log is being backed up */
extern
ibool
recv_is_making_a_backup
;
extern
ibool
recv_is_making_a_backup
;
#endif
/* UNIV_HOTBACKUP */
#endif
/* UNIV_HOTBACKUP */
/** Maximum page number encountered in the redo log */
extern
ulint
recv_max_parsed_page_no
;
extern
ulint
recv_max_parsed_page_no
;
/* Size of the parsing buffer; it must accommodate RECV_SCAN_SIZE many
/*
*
Size of the parsing buffer; it must accommodate RECV_SCAN_SIZE many
times! */
times! */
#define RECV_PARSING_BUF_SIZE (2 * 1024 * 1024)
#define RECV_PARSING_BUF_SIZE (2 * 1024 * 1024)
/* Size of block reads when the log groups are scanned forward to do a
/*
*
Size of block reads when the log groups are scanned forward to do a
roll-forward */
roll-forward */
#define RECV_SCAN_SIZE (4 * UNIV_PAGE_SIZE)
#define RECV_SCAN_SIZE (4 * UNIV_PAGE_SIZE)
/* States of recv_addr_struct */
/** This many frames must be left free in the buffer pool when we scan
#define RECV_NOT_PROCESSED 71
the log and store the scanned log records in the buffer pool: we will
#define RECV_BEING_READ 72
use these free frames to read in pages when we start applying the
#define RECV_BEING_PROCESSED 73
log records to the database. */
#define RECV_PROCESSED 74
extern
ulint
recv_n_pool_free_frames
;
extern
ulint
recv_n_pool_free_frames
;
#ifndef UNIV_NONINL
#ifndef UNIV_NONINL
...
...
include/log0recv.ic
View file @
065f8dac
...
@@ -37,6 +37,7 @@ recv_recovery_is_on(void)
...
@@ -37,6 +37,7 @@ recv_recovery_is_on(void)
}
}
#ifdef UNIV_LOG_ARCHIVE
#ifdef UNIV_LOG_ARCHIVE
/** TRUE when applying redo log records from an archived log file */
extern ibool recv_recovery_from_backup_on;
extern ibool recv_recovery_from_backup_on;
/*******************************************************************//**
/*******************************************************************//**
...
...
include/row0merge.h
View file @
065f8dac
...
@@ -39,25 +39,27 @@ Created 13/06/2005 Jan Lindstrom
...
@@ -39,25 +39,27 @@ Created 13/06/2005 Jan Lindstrom
#include "row0mysql.h"
#include "row0mysql.h"
#include "lock0types.h"
#include "lock0types.h"
/* This structure holds index field definitions */
/** Index field definition */
struct
merge_index_field_struct
{
struct
merge_index_field_struct
{
ulint
prefix_len
;
/* Prefix len */
ulint
prefix_len
;
/*!< column prefix length, or 0
const
char
*
field_name
;
/* Field name */
if indexing the whole column */
const
char
*
field_name
;
/*!< field name */
};
};
/** Index field definition */
typedef
struct
merge_index_field_struct
merge_index_field_t
;
typedef
struct
merge_index_field_struct
merge_index_field_t
;
/* This structure holds index definitions */
/** Definition of an index being created */
struct
merge_index_def_struct
{
struct
merge_index_def_struct
{
const
char
*
name
;
/*
I
ndex name */
const
char
*
name
;
/*
!< i
ndex name */
ulint
ind_type
;
/* 0, DICT_UNIQUE,
ulint
ind_type
;
/*
!<
0, DICT_UNIQUE,
or DICT_CLUSTERED */
or DICT_CLUSTERED */
ulint
n_fields
;
/* Number of fields in index */
ulint
n_fields
;
/*!< number of fields
merge_index_field_t
*
fields
;
/* Field definitions */
in index */
merge_index_field_t
*
fields
;
/*!< field definitions */
};
};
/** Definition of an index being created */
typedef
struct
merge_index_def_struct
merge_index_def_t
;
typedef
struct
merge_index_def_struct
merge_index_def_t
;
/*********************************************************************//**
/*********************************************************************//**
...
...
include/ut0byte.h
View file @
065f8dac
...
@@ -29,21 +29,21 @@ Created 1/20/1994 Heikki Tuuri
...
@@ -29,21 +29,21 @@ Created 1/20/1994 Heikki Tuuri
#include "univ.i"
#include "univ.i"
/* Type definition for a 64-bit unsigned integer, which works also
/** Pair of ulint integers. */
typedef
struct
dulint_struct
dulint
;
/** Type definition for a 64-bit unsigned integer, which works also
in 32-bit machines. NOTE! Access the fields only with the accessor
in 32-bit machines. NOTE! Access the fields only with the accessor
functions. This definition appears here only for the compiler to
functions. This definition appears here only for the compiler to
know the size of a dulint. */
know the size of a dulint. */
typedef
struct
dulint_struct
dulint
;
struct
dulint_struct
{
struct
dulint_struct
{
ulint
high
;
/* most significant 32 bits */
ulint
high
;
/*
!<
most significant 32 bits */
ulint
low
;
/* least significant 32 bits */
ulint
low
;
/*
!<
least significant 32 bits */
};
};
/* Zero value for a dulint */
/*
*
Zero value for a dulint */
extern
const
dulint
ut_dulint_zero
;
extern
const
dulint
ut_dulint_zero
;
/* Maximum value for a dulint */
/*
*
Maximum value for a dulint */
extern
const
dulint
ut_dulint_max
;
extern
const
dulint
ut_dulint_max
;
/*******************************************************//**
/*******************************************************//**
...
...
include/ut0dbg.h
View file @
065f8dac
...
@@ -33,8 +33,8 @@ Created 1/30/1994 Heikki Tuuri
...
@@ -33,8 +33,8 @@ Created 1/30/1994 Heikki Tuuri
#if defined(__GNUC__) && (__GNUC__ > 2)
#if defined(__GNUC__) && (__GNUC__ > 2)
# define UT_DBG_FAIL(EXPR) UNIV_UNLIKELY(!((ulint)(EXPR)))
# define UT_DBG_FAIL(EXPR) UNIV_UNLIKELY(!((ulint)(EXPR)))
#else
#else
extern
ulint
ut_dbg_zero
;
/* This is used to eliminate
/** This is used to eliminate compiler warnings */
compiler warnings */
extern
ulint
ut_dbg_zero
;
# define UT_DBG_FAIL(EXPR) !((ulint)(EXPR) + ut_dbg_zero)
# define UT_DBG_FAIL(EXPR) !((ulint)(EXPR) + ut_dbg_zero)
#endif
#endif
...
@@ -49,8 +49,9 @@ ut_dbg_assertion_failed(
...
@@ -49,8 +49,9 @@ ut_dbg_assertion_failed(
ulint
line
);
/*!< in: line number of the assertion */
ulint
line
);
/*!< in: line number of the assertion */
#ifdef __NETWARE__
#ifdef __NETWARE__
/* Flag for ignoring further assertion failures.
/** Flag for ignoring further assertion failures. This is set to TRUE
On NetWare, have a graceful exit rather than a segfault to avoid abends. */
when on NetWare there happens an InnoDB assertion failure or other
fatal error condition that requires an immediate shutdown. */
extern
ibool
panic_shutdown
;
extern
ibool
panic_shutdown
;
/* Abort the execution. */
/* Abort the execution. */
void
ut_dbg_panic
(
void
);
void
ut_dbg_panic
(
void
);
...
@@ -65,13 +66,13 @@ void ut_dbg_panic(void);
...
@@ -65,13 +66,13 @@ void ut_dbg_panic(void);
# endif
# endif
# ifndef UT_DBG_USE_ABORT
# ifndef UT_DBG_USE_ABORT
/* A null pointer that will be dereferenced to trigger a memory trap */
/*
*
A null pointer that will be dereferenced to trigger a memory trap */
extern
ulint
*
ut_dbg_null_ptr
;
extern
ulint
*
ut_dbg_null_ptr
;
# endif
# endif
# if defined(UNIV_SYNC_DEBUG) || !defined(UT_DBG_USE_ABORT)
# if defined(UNIV_SYNC_DEBUG) || !defined(UT_DBG_USE_ABORT)
/*
Flag for indicating that all threads should stop. This will be set
/*
* If this is set to TRUE by ut_dbg_assertion_failed(), all threads
by ut_dbg_assertion_faile
d(). */
will stop at the next ut_a() or ut_a
d(). */
extern
ibool
ut_dbg_stop_threads
;
extern
ibool
ut_dbg_stop_threads
;
/*************************************************************//**
/*************************************************************//**
...
...
include/ut0mem.h
View file @
065f8dac
...
@@ -31,23 +31,41 @@ Created 5/30/1994 Heikki Tuuri
...
@@ -31,23 +31,41 @@ Created 5/30/1994 Heikki Tuuri
#ifndef UNIV_HOTBACKUP
#ifndef UNIV_HOTBACKUP
# include "os0sync.h"
# include "os0sync.h"
/* The total amount of memory currently allocated from the operating
/*
*
The total amount of memory currently allocated from the operating
system with os_mem_alloc_large() or malloc(). Does not count malloc()
system with os_mem_alloc_large() or malloc(). Does not count malloc()
if srv_use_sys_malloc is set. Protected by ut_list_mutex. */
if srv_use_sys_malloc is set. Protected by ut_list_mutex. */
extern
ulint
ut_total_allocated_memory
;
extern
ulint
ut_total_allocated_memory
;
/* Mutex protecting ut_total_allocated_memory and ut_mem_block_list */
/*
*
Mutex protecting ut_total_allocated_memory and ut_mem_block_list */
extern
os_fast_mutex_t
ut_list_mutex
;
extern
os_fast_mutex_t
ut_list_mutex
;
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
/** Wrapper for memcpy(3). Copy memory area when the source and
target are not overlapping.
* @param dest in: copy to
* @param sour in: copy from
* @param n in: number of bytes to copy
* @return dest */
UNIV_INLINE
UNIV_INLINE
void
*
void
*
ut_memcpy
(
void
*
dest
,
const
void
*
sour
,
ulint
n
);
ut_memcpy
(
void
*
dest
,
const
void
*
sour
,
ulint
n
);
/** Wrapper for memmove(3). Copy memory area when the source and
target are overlapping.
* @param dest in: copy to
* @param sour in: copy from
* @param n in: number of bytes to copy
* @return dest */
UNIV_INLINE
UNIV_INLINE
void
*
void
*
ut_memmove
(
void
*
dest
,
const
void
*
sour
,
ulint
n
);
ut_memmove
(
void
*
dest
,
const
void
*
sour
,
ulint
n
);
/** Wrapper for memcmp(3). Compare memory areas.
* @param str1 in: first memory block to compare
* @param str2 in: second memory block to compare
* @param n in: number of bytes to compare
* @return negative, 0, or positive if str1 is smaller, equal,
or greater than str2, respectively. */
UNIV_INLINE
UNIV_INLINE
int
int
ut_memcmp
(
const
void
*
str1
,
const
void
*
str2
,
ulint
n
);
ut_memcmp
(
const
void
*
str1
,
const
void
*
str2
,
ulint
n
);
...
@@ -141,14 +159,26 @@ ut_free_all_mem(void);
...
@@ -141,14 +159,26 @@ ut_free_all_mem(void);
/*=================*/
/*=================*/
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
/** Wrapper for strcpy(3). Copy a NUL-terminated string.
* @param dest in: copy to
* @param sour in: copy from
* @return dest */
UNIV_INLINE
UNIV_INLINE
char
*
char
*
ut_strcpy
(
char
*
dest
,
const
char
*
sour
);
ut_strcpy
(
char
*
dest
,
const
char
*
sour
);
/** Wrapper for strlen(3). Determine the length of a NUL-terminated string.
* @param str in: string
* @return length of the string in bytes, excluding the terminating NUL */
UNIV_INLINE
UNIV_INLINE
ulint
ulint
ut_strlen
(
const
char
*
str
);
ut_strlen
(
const
char
*
str
);
/** Wrapper for strcmp(3). Compare NUL-terminated strings.
* @param str1 in: first string to compare
* @param str2 in: second string to compare
* @return negative, 0, or positive if str1 is smaller, equal,
or greater than str2, respectively. */
UNIV_INLINE
UNIV_INLINE
int
int
ut_strcmp
(
const
char
*
str1
,
const
char
*
str2
);
ut_strcmp
(
const
char
*
str1
,
const
char
*
str2
);
...
@@ -239,10 +269,10 @@ ut_strreplace(
...
@@ -239,10 +269,10 @@ ut_strreplace(
const
char
*
s2
);
/*!< in: string to replace s1 with */
const
char
*
s2
);
/*!< in: string to replace s1 with */
/**********************************************************************//**
/**********************************************************************//**
Converts a raw binary data to a
'\0'
-terminated hex string. The output is
Converts a raw binary data to a
NUL
-terminated hex string. The output is
truncated if there is not enough space in "hex", make sure "hex_size" is at
truncated if there is not enough space in "hex", make sure "hex_size" is at
least (2 * raw_size + 1) if you do not want this to happen. Returns the
least (2 * raw_size + 1) if you do not want this to happen. Returns the
actual number of characters written to "hex" (including the
'\0'
).
actual number of characters written to "hex" (including the
NUL
).
@return number of chars written */
@return number of chars written */
UNIV_INLINE
UNIV_INLINE
ulint
ulint
...
@@ -256,7 +286,7 @@ ut_raw_to_hex(
...
@@ -256,7 +286,7 @@ ut_raw_to_hex(
/*******************************************************************//**
/*******************************************************************//**
Adds single quotes to the start and end of string and escapes any quotes
Adds single quotes to the start and end of string and escapes any quotes
by doubling them. Returns the number of bytes that were written to "buf"
by doubling them. Returns the number of bytes that were written to "buf"
(including the terminating
'\0'
). If buf_size is too small then the
(including the terminating
NUL
). If buf_size is too small then the
trailing bytes from "str" are discarded.
trailing bytes from "str" are discarded.
@return number of bytes that were written */
@return number of bytes that were written */
UNIV_INLINE
UNIV_INLINE
...
...
include/ut0mem.ic
View file @
065f8dac
...
@@ -26,6 +26,12 @@ Created 5/30/1994 Heikki Tuuri
...
@@ -26,6 +26,12 @@ Created 5/30/1994 Heikki Tuuri
#include "ut0byte.h"
#include "ut0byte.h"
#include "mach0data.h"
#include "mach0data.h"
/** Wrapper for memcpy(3). Copy memory area when the source and
target are not overlapping.
* @param dest in: copy to
* @param sour in: copy from
* @param n in: number of bytes to copy
* @return dest */
UNIV_INLINE
UNIV_INLINE
void*
void*
ut_memcpy(void* dest, const void* sour, ulint n)
ut_memcpy(void* dest, const void* sour, ulint n)
...
@@ -33,6 +39,12 @@ ut_memcpy(void* dest, const void* sour, ulint n)
...
@@ -33,6 +39,12 @@ ut_memcpy(void* dest, const void* sour, ulint n)
return(memcpy(dest, sour, n));
return(memcpy(dest, sour, n));
}
}
/** Wrapper for memmove(3). Copy memory area when the source and
target are overlapping.
* @param dest in: copy to
* @param sour in: copy from
* @param n in: number of bytes to copy
* @return dest */
UNIV_INLINE
UNIV_INLINE
void*
void*
ut_memmove(void* dest, const void* sour, ulint n)
ut_memmove(void* dest, const void* sour, ulint n)
...
@@ -40,6 +52,12 @@ ut_memmove(void* dest, const void* sour, ulint n)
...
@@ -40,6 +52,12 @@ ut_memmove(void* dest, const void* sour, ulint n)
return(memmove(dest, sour, n));
return(memmove(dest, sour, n));
}
}
/** Wrapper for memcmp(3). Compare memory areas.
* @param str1 in: first memory block to compare
* @param str2 in: second memory block to compare
* @param n in: number of bytes to compare
* @return negative, 0, or positive if str1 is smaller, equal,
or greater than str2, respectively. */
UNIV_INLINE
UNIV_INLINE
int
int
ut_memcmp(const void* str1, const void* str2, ulint n)
ut_memcmp(const void* str1, const void* str2, ulint n)
...
@@ -47,6 +65,10 @@ ut_memcmp(const void* str1, const void* str2, ulint n)
...
@@ -47,6 +65,10 @@ ut_memcmp(const void* str1, const void* str2, ulint n)
return(memcmp(str1, str2, n));
return(memcmp(str1, str2, n));
}
}
/** Wrapper for strcpy(3). Copy a NUL-terminated string.
* @param dest in: copy to
* @param sour in: copy from
* @return dest */
UNIV_INLINE
UNIV_INLINE
char*
char*
ut_strcpy(char* dest, const char* sour)
ut_strcpy(char* dest, const char* sour)
...
@@ -54,6 +76,9 @@ ut_strcpy(char* dest, const char* sour)
...
@@ -54,6 +76,9 @@ ut_strcpy(char* dest, const char* sour)
return(strcpy(dest, sour));
return(strcpy(dest, sour));
}
}
/** Wrapper for strlen(3). Determine the length of a NUL-terminated string.
* @param str in: string
* @return length of the string in bytes, excluding the terminating NUL */
UNIV_INLINE
UNIV_INLINE
ulint
ulint
ut_strlen(const char* str)
ut_strlen(const char* str)
...
@@ -61,6 +86,11 @@ ut_strlen(const char* str)
...
@@ -61,6 +86,11 @@ ut_strlen(const char* str)
return(strlen(str));
return(strlen(str));
}
}
/** Wrapper for strcmp(3). Compare NUL-terminated strings.
* @param str1 in: first string to compare
* @param str2 in: second string to compare
* @return negative, 0, or positive if str1 is smaller, equal,
or greater than str2, respectively. */
UNIV_INLINE
UNIV_INLINE
int
int
ut_strcmp(const char* str1, const char* str2)
ut_strcmp(const char* str1, const char* str2)
...
@@ -90,10 +120,10 @@ ut_strlenq(
...
@@ -90,10 +120,10 @@ ut_strlenq(
}
}
/**********************************************************************//**
/**********************************************************************//**
Converts a raw binary data to a
'\0'
-terminated hex string. The output is
Converts a raw binary data to a
NUL
-terminated hex string. The output is
truncated if there is not enough space in "hex", make sure "hex_size" is at
truncated if there is not enough space in "hex", make sure "hex_size" is at
least (2 * raw_size + 1) if you do not want this to happen. Returns the
least (2 * raw_size + 1) if you do not want this to happen. Returns the
actual number of characters written to "hex" (including the
'\0'
).
actual number of characters written to "hex" (including the
NUL
).
@return number of chars written */
@return number of chars written */
UNIV_INLINE
UNIV_INLINE
ulint
ulint
...
@@ -212,7 +242,7 @@ ut_raw_to_hex(
...
@@ -212,7 +242,7 @@ ut_raw_to_hex(
/*******************************************************************//**
/*******************************************************************//**
Adds single quotes to the start and end of string and escapes any quotes
Adds single quotes to the start and end of string and escapes any quotes
by doubling them. Returns the number of bytes that were written to "buf"
by doubling them. Returns the number of bytes that were written to "buf"
(including the terminating
'\0'
). If buf_size is too small then the
(including the terminating
NUL
). If buf_size is too small then the
trailing bytes from "str" are discarded.
trailing bytes from "str" are discarded.
@return number of bytes that were written */
@return number of bytes that were written */
UNIV_INLINE
UNIV_INLINE
...
...
include/ut0rnd.ic
View file @
065f8dac
...
@@ -35,6 +35,7 @@ Created 5/30/1994 Heikki Tuuri
...
@@ -35,6 +35,7 @@ Created 5/30/1994 Heikki Tuuri
#define UT_XOR_RND1 187678878
#define UT_XOR_RND1 187678878
#define UT_XOR_RND2 143537923
#define UT_XOR_RND2 143537923
/** Seed value of ut_rnd_gen_ulint() */
extern ulint ut_rnd_ulint_counter;
extern ulint ut_rnd_ulint_counter;
/********************************************************//**
/********************************************************//**
...
...
include/ut0ut.h
View file @
065f8dac
...
@@ -37,12 +37,14 @@ Created 1/20/1994 Heikki Tuuri
...
@@ -37,12 +37,14 @@ Created 1/20/1994 Heikki Tuuri
/** Index name prefix in fast index creation, as a string constant */
/** Index name prefix in fast index creation, as a string constant */
#define TEMP_INDEX_PREFIX_STR "\377"
#define TEMP_INDEX_PREFIX_STR "\377"
/** Time stamp */
typedef
time_t
ib_time_t
;
typedef
time_t
ib_time_t
;
/*********************************************************************//**
/*********************************************************************//**
Delays execution for at most max_wait_us microseconds or returns earlier
Delays execution for at most max_wait_us microseconds or returns earlier
if cond becomes true; cond is evaluated every 2 ms. */
if cond becomes true.
@param cond in: condition to wait for; evaluated every 2 ms
@param max_wait_us in: maximum delay to wait, in microseconds */
#define UT_WAIT_FOR(cond, max_wait_us) \
#define UT_WAIT_FOR(cond, max_wait_us) \
do { \
do { \
ullint start_us; \
ullint start_us; \
...
@@ -115,19 +117,34 @@ ut_pair_cmp(
...
@@ -115,19 +117,34 @@ ut_pair_cmp(
ulint
b1
,
/*!< in: more significant part of second pair */
ulint
b1
,
/*!< in: more significant part of second pair */
ulint
b2
);
/*!< in: less significant part of second pair */
ulint
b2
);
/*!< in: less significant part of second pair */
/*************************************************************//**
/*************************************************************//**
Determines if a number is zero or a power of two. */
Determines if a number is zero or a power of two.
@param n in: number
@return nonzero if n is zero or a power of two; zero otherwise */
#define ut_is_2pow(n) UNIV_LIKELY(!((n) & ((n) - 1)))
#define ut_is_2pow(n) UNIV_LIKELY(!((n) & ((n) - 1)))
/*************************************************************//**
/*************************************************************//**
Calculates fast the remainder of n/m when m is a power of two. */
Calculates fast the remainder of n/m when m is a power of two.
@param n in: numerator
@param m in: denominator, must be a power of two
@return the remainder of n/m */
#define ut_2pow_remainder(n, m) ((n) & ((m) - 1))
#define ut_2pow_remainder(n, m) ((n) & ((m) - 1))
/*************************************************************//**
/*************************************************************//**
Calculates the biggest multiple of m that is not bigger than n
Calculates the biggest multiple of m that is not bigger than n
when m is a power of two. In other words, rounds n down to m * k. */
when m is a power of two. In other words, rounds n down to m * k.
@param n in: number to round down
@param m in: alignment, must be a power of two
@return n rounded down to the biggest possible integer multiple of m */
#define ut_2pow_round(n, m) ((n) & ~((m) - 1))
#define ut_2pow_round(n, m) ((n) & ~((m) - 1))
/** Align a number down to a multiple of a power of two.
@param n in: number to round down
@param m in: alignment, must be a power of two
@return n rounded down to the biggest possible integer multiple of m */
#define ut_calc_align_down(n, m) ut_2pow_round(n, m)
#define ut_calc_align_down(n, m) ut_2pow_round(n, m)
/********************************************************//**
/********************************************************//**
Calculates the smallest multiple of m that is not smaller than n
Calculates the smallest multiple of m that is not smaller than n
when m is a power of two. In other words, rounds n up to m * k. */
when m is a power of two. In other words, rounds n up to m * k.
@param n in: number to round up
@param m in: alignment, must be a power of two
@return n rounded up to the smallest possible integer multiple of m */
#define ut_calc_align(n, m) (((n) + ((m) - 1)) & ~((m) - 1))
#define ut_calc_align(n, m) (((n) + ((m) - 1)) & ~((m) - 1))
/*************************************************************//**
/*************************************************************//**
Calculates fast the 2-logarithm of a number, rounded upward to an
Calculates fast the 2-logarithm of a number, rounded upward to an
...
@@ -156,8 +173,10 @@ ut_2_power_up(
...
@@ -156,8 +173,10 @@ ut_2_power_up(
ulint
n
)
/*!< in: number != 0 */
ulint
n
)
/*!< in: number != 0 */
__attribute__
((
const
));
__attribute__
((
const
));
/* Determine how many bytes (groups of 8 bits) are needed to
/** Determine how many bytes (groups of 8 bits) are needed to
store the given number of bits. */
store the given number of bits.
@param b in: bits
@return number of bytes (octets) needed to represent b */
#define UT_BITS_IN_BYTES(b) (((b) + 7) / 8)
#define UT_BITS_IN_BYTES(b) (((b) + 7) / 8)
/**********************************************************//**
/**********************************************************//**
...
...
include/ut0vec.h
View file @
065f8dac
...
@@ -29,6 +29,7 @@ Created 4/6/2006 Osku Salerma
...
@@ -29,6 +29,7 @@ Created 4/6/2006 Osku Salerma
#include "univ.i"
#include "univ.i"
#include "mem0mem.h"
#include "mem0mem.h"
/** An automatically resizing vector data type. */
typedef
struct
ib_vector_struct
ib_vector_t
;
typedef
struct
ib_vector_struct
ib_vector_t
;
/* An automatically resizing vector datatype with the following properties:
/* An automatically resizing vector datatype with the following properties:
...
@@ -109,12 +110,12 @@ ib_vector_free(
...
@@ -109,12 +110,12 @@ ib_vector_free(
/*===========*/
/*===========*/
ib_vector_t
*
vec
);
/*!< in,own: vector */
ib_vector_t
*
vec
);
/*!< in,own: vector */
/*
See comment at beginning of fil
e. */
/*
* An automatically resizing vector data typ
e. */
struct
ib_vector_struct
{
struct
ib_vector_struct
{
mem_heap_t
*
heap
;
/* heap */
mem_heap_t
*
heap
;
/*
!<
heap */
void
**
data
;
/* data elements */
void
**
data
;
/*
!<
data elements */
ulint
used
;
/* number of elements currently used */
ulint
used
;
/*
!<
number of elements currently used */
ulint
total
;
/* number of elements allocated */
ulint
total
;
/*
!<
number of elements allocated */
};
};
#ifndef UNIV_NONINL
#ifndef UNIV_NONINL
...
...
log/log0recv.c
View file @
065f8dac
...
@@ -51,31 +51,40 @@ Created 9/20/1997 Heikki Tuuri
...
@@ -51,31 +51,40 @@ Created 9/20/1997 Heikki Tuuri
# include "sync0sync.h"
# include "sync0sync.h"
#else
/* !UNIV_HOTBACKUP */
#else
/* !UNIV_HOTBACKUP */
/* This is set to FALSE if the backup was originally taken with the
/*
*
This is set to FALSE if the backup was originally taken with the
ibbackup --include regexp option: then we do not want to create tables in
ibbackup --include regexp option: then we do not want to create tables in
directories which were not included */
directories which were not included */
UNIV_INTERN
ibool
recv_replay_file_ops
=
TRUE
;
UNIV_INTERN
ibool
recv_replay_file_ops
=
TRUE
;
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
/* Log records are stored in the hash table in chunks at most of this size;
/*
*
Log records are stored in the hash table in chunks at most of this size;
this must be less than UNIV_PAGE_SIZE as it is stored in the buffer pool */
this must be less than UNIV_PAGE_SIZE as it is stored in the buffer pool */
#define RECV_DATA_BLOCK_SIZE (MEM_MAX_ALLOC_IN_BUF - sizeof(recv_data_t))
#define RECV_DATA_BLOCK_SIZE (MEM_MAX_ALLOC_IN_BUF - sizeof(recv_data_t))
/* Read-ahead area in applying log records to file pages */
/*
*
Read-ahead area in applying log records to file pages */
#define RECV_READ_AHEAD_AREA 32
#define RECV_READ_AHEAD_AREA 32
/** The recovery system */
UNIV_INTERN
recv_sys_t
*
recv_sys
=
NULL
;
UNIV_INTERN
recv_sys_t
*
recv_sys
=
NULL
;
/** TRUE when applying redo log records during crash recovery; FALSE
otherwise. Note that this is FALSE while a background thread is
rolling back incomplete transactions. */
UNIV_INTERN
ibool
recv_recovery_on
=
FALSE
;
UNIV_INTERN
ibool
recv_recovery_on
=
FALSE
;
#ifdef UNIV_LOG_ARCHIVE
#ifdef UNIV_LOG_ARCHIVE
/** TRUE when applying redo log records from an archived log file */
UNIV_INTERN
ibool
recv_recovery_from_backup_on
=
FALSE
;
UNIV_INTERN
ibool
recv_recovery_from_backup_on
=
FALSE
;
#endif
/* UNIV_LOG_ARCHIVE */
#endif
/* UNIV_LOG_ARCHIVE */
#ifndef UNIV_HOTBACKUP
#ifndef UNIV_HOTBACKUP
/** TRUE when recv_init_crash_recovery() has been called. */
UNIV_INTERN
ibool
recv_needed_recovery
=
FALSE
;
UNIV_INTERN
ibool
recv_needed_recovery
=
FALSE
;
/** TRUE if buf_page_is_corrupted() should check if the log sequence
number (FIL_PAGE_LSN) is in the future. Initially FALSE, and set by
recv_recovery_from_checkpoint_start_func(). */
UNIV_INTERN
ibool
recv_lsn_checks_on
=
FALSE
;
UNIV_INTERN
ibool
recv_lsn_checks_on
=
FALSE
;
/* There are two conditions under which we scan the logs, the first
/*
*
There are two conditions under which we scan the logs, the first
is normal startup and the second is when we do a recovery from an
is normal startup and the second is when we do a recovery from an
archive.
archive.
This flag is set if we are doing a scan from the last checkpoint during
This flag is set if we are doing a scan from the last checkpoint during
...
@@ -83,48 +92,53 @@ startup. If we find log entries that were written after the last checkpoint
...
@@ -83,48 +92,53 @@ startup. If we find log entries that were written after the last checkpoint
we know that the server was not cleanly shutdown. We must then initialize
we know that the server was not cleanly shutdown. We must then initialize
the crash recovery environment before attempting to store these entries in
the crash recovery environment before attempting to store these entries in
the log hash table. */
the log hash table. */
UNIV_INTERN
ibool
recv_log_scan_is_startup_type
=
FALSE
;
static
ibool
recv_log_scan_is_startup_type
=
FALSE
;
/* If the following is TRUE, the buffer pool file pages must be invalidated
/*
*
If the following is TRUE, the buffer pool file pages must be invalidated
after recovery and no ibuf operations are allowed; this becomes TRUE if
after recovery and no ibuf operations are allowed; this becomes TRUE if
the log record hash table becomes too full, and log records must be merged
the log record hash table becomes too full, and log records must be merged
to file pages already before the recovery is finished: in this case no
to file pages already before the recovery is finished: in this case no
ibuf operations are allowed, as they could modify the pages read in the
ibuf operations are allowed, as they could modify the pages read in the
buffer pool before the pages have been recovered to the up-to-date state */
buffer pool before the pages have been recovered to the up-to-date state.
/* Recovery is running and no operations on the log files are allowed
yet: the variable name is misleading */
TRUE means that recovery is running and no operations on the log files
are allowed yet: the variable name is misleading. */
UNIV_INTERN
ibool
recv_no_ibuf_operations
=
FALSE
;
UNIV_INTERN
ibool
recv_no_ibuf_operations
=
FALSE
;
/** TRUE when the redo log is being backed up */
# define recv_is_making_a_backup FALSE
# define recv_is_making_a_backup FALSE
/** TRUE when recovering from a backed up redo log file */
# define recv_is_from_backup FALSE
# define recv_is_from_backup FALSE
#else
/* !UNIV_HOTBACKUP */
#else
/* !UNIV_HOTBACKUP */
# define recv_needed_recovery FALSE
# define recv_needed_recovery FALSE
/** TRUE when the redo log is being backed up */
UNIV_INTERN
ibool
recv_is_making_a_backup
=
FALSE
;
UNIV_INTERN
ibool
recv_is_making_a_backup
=
FALSE
;
/** TRUE when recovering from a backed up redo log file */
UNIV_INTERN
ibool
recv_is_from_backup
=
FALSE
;
UNIV_INTERN
ibool
recv_is_from_backup
=
FALSE
;
# define buf_pool_get_curr_size() (5 * 1024 * 1024)
# define buf_pool_get_curr_size() (5 * 1024 * 1024)
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
/* The following counter is used to decide when to print info on
/*
*
The following counter is used to decide when to print info on
log scan */
log scan */
UNIV_INTERN
ulint
recv_scan_print_counter
=
0
;
static
ulint
recv_scan_print_counter
=
0
;
UNIV_INTERN
ulint
recv_previous_parsed_rec_type
=
999999
;
/** The type of the previous parsed redo log record */
UNIV_INTERN
ulint
recv_previous_parsed_rec_offset
=
0
;
static
ulint
recv_previous_parsed_rec_type
=
999999
;
UNIV_INTERN
ulint
recv_previous_parsed_rec_is_multi
=
0
;
/** The offset of the previous parsed redo log record */
static
ulint
recv_previous_parsed_rec_offset
=
0
;
/** The 'multi' flag of the previous parsed redo log record */
static
ulint
recv_previous_parsed_rec_is_multi
=
0
;
/** Maximum page number encountered in the redo log */
UNIV_INTERN
ulint
recv_max_parsed_page_no
=
0
;
UNIV_INTERN
ulint
recv_max_parsed_page_no
=
0
;
/* This many frames must be left free in the buffer pool when we scan
/*
*
This many frames must be left free in the buffer pool when we scan
the log and store the scanned log records in the buffer pool: we will
the log and store the scanned log records in the buffer pool: we will
use these free frames to read in pages when we start applying the
use these free frames to read in pages when we start applying the
log records to the database. */
log records to the database. */
UNIV_INTERN
ulint
recv_n_pool_free_frames
=
256
;
UNIV_INTERN
ulint
recv_n_pool_free_frames
=
256
;
/* The maximum lsn we see for a page during the recovery process. If this
/*
*
The maximum lsn we see for a page during the recovery process. If this
is bigger than the lsn we are able to scan up to, that is an indication that
is bigger than the lsn we are able to scan up to, that is an indication that
the recovery failed and the database may be corrupt. */
the recovery failed and the database may be corrupt. */
UNIV_INTERN
ib_uint64_t
recv_max_page_lsn
;
UNIV_INTERN
ib_uint64_t
recv_max_page_lsn
;
/* prototypes */
/* prototypes */
...
@@ -1307,10 +1321,10 @@ recv_recover_page_func(
...
@@ -1307,10 +1321,10 @@ recv_recover_page_func(
/*===================*/
/*===================*/
#ifndef UNIV_HOTBACKUP
#ifndef UNIV_HOTBACKUP
ibool
just_read_in
,
ibool
just_read_in
,
/*!< in: TRUE if the i/o
-handler calls this for
/*!< in: TRUE if the i/o
handler calls
a freshly read page */
this for
a freshly read page */
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
buf_block_t
*
block
)
/*!< in: buffer block */
buf_block_t
*
block
)
/*!< in
/out
: buffer block */
{
{
page_t
*
page
;
page_t
*
page
;
recv_addr_t
*
recv_addr
;
recv_addr_t
*
recv_addr
;
...
@@ -2680,7 +2694,8 @@ ulint
...
@@ -2680,7 +2694,8 @@ ulint
recv_recovery_from_checkpoint_start_func
(
recv_recovery_from_checkpoint_start_func
(
/*=====================================*/
/*=====================================*/
#ifdef UNIV_LOG_ARCHIVE
#ifdef UNIV_LOG_ARCHIVE
ulint
type
,
/*!< in: LOG_CHECKPOINT or LOG_ARCHIVE */
ulint
type
,
/*!< in: LOG_CHECKPOINT or
LOG_ARCHIVE */
ib_uint64_t
limit_lsn
,
/*!< in: recover up to this lsn
ib_uint64_t
limit_lsn
,
/*!< in: recover up to this lsn
if possible */
if possible */
#endif
/* UNIV_LOG_ARCHIVE */
#endif
/* UNIV_LOG_ARCHIVE */
...
@@ -2705,10 +2720,14 @@ recv_recovery_from_checkpoint_start_func(
...
@@ -2705,10 +2720,14 @@ recv_recovery_from_checkpoint_start_func(
#ifdef UNIV_LOG_ARCHIVE
#ifdef UNIV_LOG_ARCHIVE
ut_ad
(
type
!=
LOG_CHECKPOINT
||
limit_lsn
==
IB_ULONGLONG_MAX
);
ut_ad
(
type
!=
LOG_CHECKPOINT
||
limit_lsn
==
IB_ULONGLONG_MAX
);
/** TRUE when recovering from a checkpoint */
# define TYPE_CHECKPOINT (type == LOG_CHECKPOINT)
# define TYPE_CHECKPOINT (type == LOG_CHECKPOINT)
/** Recover up to this log sequence number */
# define LIMIT_LSN limit_lsn
# define LIMIT_LSN limit_lsn
#else
/* UNIV_LOG_ARCHIVE */
#else
/* UNIV_LOG_ARCHIVE */
/** TRUE when recovering from a checkpoint */
# define TYPE_CHECKPOINT 1
# define TYPE_CHECKPOINT 1
/** Recover up to this log sequence number */
# define LIMIT_LSN IB_ULONGLONG_MAX
# define LIMIT_LSN IB_ULONGLONG_MAX
#endif
/* UNIV_LOG_ARCHIVE */
#endif
/* UNIV_LOG_ARCHIVE */
...
...
row/row0merge.c
View file @
065f8dac
...
@@ -58,57 +58,62 @@ Completed by Sunny Bains and Marko Makela
...
@@ -58,57 +58,62 @@ Completed by Sunny Bains and Marko Makela
#include "handler0alter.h"
#include "handler0alter.h"
#ifdef UNIV_DEBUG
#ifdef UNIV_DEBUG
/* Set these in order ot enable debug printout. */
/** Set these in order ot enable debug printout. */
/* @{ */
static
ibool
row_merge_print_cmp
;
static
ibool
row_merge_print_cmp
;
static
ibool
row_merge_print_read
;
static
ibool
row_merge_print_read
;
static
ibool
row_merge_print_write
;
static
ibool
row_merge_print_write
;
/* @} */
#endif
/* UNIV_DEBUG */
#endif
/* UNIV_DEBUG */
/* Block size for I/O operations in merge sort. The minimum is
/** @brief Block size for I/O operations in merge sort.
UNIV_PAGE_SIZE, or page_get_free_space_of_empty() rounded to a power of 2.
The minimum is UNIV_PAGE_SIZE, or page_get_free_space_of_empty()
rounded to a power of 2.
When not creating a PRIMARY KEY that contains column prefixes, this
When not creating a PRIMARY KEY that contains column prefixes, this
can be set as small as UNIV_PAGE_SIZE / 2. See the comment above
can be set as small as UNIV_PAGE_SIZE / 2. See the comment above
ut_ad(data_size < sizeof(row_merge_block_t)). */
ut_ad(data_size < sizeof(row_merge_block_t)). */
typedef
byte
row_merge_block_t
[
1048576
];
typedef
byte
row_merge_block_t
[
1048576
];
/* Secondary buffer for I/O operations of merge records. This buffer
/** @brief Secondary buffer for I/O operations of merge records.
is used for writing or reading a record that spans two row_merge_block_t.
Thus, it must be able to hold one merge record, whose maximum size is
the same as the minimum size of row_merge_block_t. */
This buffer is used for writing or reading a record that spans two
row_merge_block_t. Thus, it must be able to hold one merge record,
whose maximum size is the same as the minimum size of
row_merge_block_t. */
typedef
byte
mrec_buf_t
[
UNIV_PAGE_SIZE
];
typedef
byte
mrec_buf_t
[
UNIV_PAGE_SIZE
];
/* Merge record in row_merge_block_t. The format is the same as a
/** @brief Merge record in row_merge_block_t.
record in ROW_FORMAT=COMPACT with the exception that the
REC_N_NEW_EXTRA_BYTES are omitted. */
The format is the same as a record in ROW_FORMAT=COMPACT with the
exception that the REC_N_NEW_EXTRA_BYTES are omitted. */
typedef
byte
mrec_t
;
typedef
byte
mrec_t
;
/* Buffer for sorting in main memory. */
/*
*
Buffer for sorting in main memory. */
struct
row_merge_buf_struct
{
struct
row_merge_buf_struct
{
mem_heap_t
*
heap
;
/* memory heap where allocated */
mem_heap_t
*
heap
;
/*
!<
memory heap where allocated */
dict_index_t
*
index
;
/* the index the tuples belong to */
dict_index_t
*
index
;
/*
!<
the index the tuples belong to */
ulint
total_size
;
/* total amount of data bytes */
ulint
total_size
;
/*
!<
total amount of data bytes */
ulint
n_tuples
;
/* number of data tuples */
ulint
n_tuples
;
/*
!<
number of data tuples */
ulint
max_tuples
;
/* maximum number of data tuples */
ulint
max_tuples
;
/*
!<
maximum number of data tuples */
const
dfield_t
**
tuples
;
/* array of pointers to
const
dfield_t
**
tuples
;
/*
!<
array of pointers to
arrays of fields that form
arrays of fields that form
the data tuples */
the data tuples */
const
dfield_t
**
tmp_tuples
;
/* temporary copy of tuples,
const
dfield_t
**
tmp_tuples
;
/*
!<
temporary copy of tuples,
for sorting */
for sorting */
};
};
/** Buffer for sorting in main memory. */
typedef
struct
row_merge_buf_struct
row_merge_buf_t
;
typedef
struct
row_merge_buf_struct
row_merge_buf_t
;
/* Information about temporary files used in merge sort are stored
/** Information about temporary files used in merge sort */
to this structure */
struct
merge_file_struct
{
struct
merge_file_struct
{
int
fd
;
/*
F
ile descriptor */
int
fd
;
/*
!< f
ile descriptor */
ulint
offset
;
/*
F
ile offset */
ulint
offset
;
/*
!< f
ile offset */
};
};
/** Information about temporary files used in merge sort */
typedef
struct
merge_file_struct
merge_file_t
;
typedef
struct
merge_file_struct
merge_file_t
;
#ifdef UNIV_DEBUG
#ifdef UNIV_DEBUG
...
@@ -389,13 +394,14 @@ row_merge_buf_add(
...
@@ -389,13 +394,14 @@ row_merge_buf_add(
return
(
TRUE
);
return
(
TRUE
);
}
}
/* Structure for reporting duplicate records. */
/*
*
Structure for reporting duplicate records. */
struct
row_merge_dup_struct
{
struct
row_merge_dup_struct
{
const
dict_index_t
*
index
;
/* index being sorted */
const
dict_index_t
*
index
;
/*
!<
index being sorted */
TABLE
*
table
;
/* MySQL table object */
TABLE
*
table
;
/*
!<
MySQL table object */
ulint
n_dup
;
/* number of duplicates */
ulint
n_dup
;
/*
!<
number of duplicates */
};
};
/** Structure for reporting duplicate records. */
typedef
struct
row_merge_dup_struct
row_merge_dup_t
;
typedef
struct
row_merge_dup_struct
row_merge_dup_t
;
/*************************************************************//**
/*************************************************************//**
...
@@ -498,8 +504,19 @@ row_merge_tuple_sort(
...
@@ -498,8 +504,19 @@ row_merge_tuple_sort(
ulint
high
)
/*!< in: upper bound of the
ulint
high
)
/*!< in: upper bound of the
sorting area, exclusive */
sorting area, exclusive */
{
{
/** Wrapper for row_merge_tuple_sort() to inject some more context to
UT_SORT_FUNCTION_BODY().
@param a array of tuples that being sorted
@param b aux (work area), same size as tuples[]
@param c lower bound of the sorting area, inclusive
@param d upper bound of the sorting area, inclusive */
#define row_merge_tuple_sort_ctx(a,b,c,d) \
#define row_merge_tuple_sort_ctx(a,b,c,d) \
row_merge_tuple_sort(n_field, dup, a, b, c, d)
row_merge_tuple_sort(n_field, dup, a, b, c, d)
/** Wrapper for row_merge_tuple_cmp() to inject some more context to
UT_SORT_FUNCTION_BODY().
@param a first tuple to be compared
@param b second tuple to be compared
@return 1, 0, -1 if a is greater, equal, less, respectively, than b */
#define row_merge_tuple_cmp_ctx(a,b) row_merge_tuple_cmp(n_field, a, b, dup)
#define row_merge_tuple_cmp_ctx(a,b) row_merge_tuple_cmp(n_field, a, b, dup)
UT_SORT_FUNCTION_BODY
(
row_merge_tuple_sort_ctx
,
UT_SORT_FUNCTION_BODY
(
row_merge_tuple_sort_ctx
,
...
@@ -1323,6 +1340,10 @@ row_merge_blocks(
...
@@ -1323,6 +1340,10 @@ row_merge_blocks(
/* Write a record and read the next record. Split the output
/* Write a record and read the next record. Split the output
file in two halves, which can be merged on the following pass. */
file in two halves, which can be merged on the following pass. */
/** Write a record via buffer 2 and read the next record to buffer N.
@param N number of the buffer (0 or 1)
@param AT_END statement to execute at end of input */
#define ROW_MERGE_WRITE_GET_NEXT(N, AT_END) \
#define ROW_MERGE_WRITE_GET_NEXT(N, AT_END) \
do { \
do { \
b2 = row_merge_write_rec(&block[2], &buf[2], b2, \
b2 = row_merge_write_rec(&block[2], &buf[2], b2, \
...
...
row/row0mysql.c
View file @
065f8dac
...
@@ -52,30 +52,43 @@ Created 9/17/2000 Heikki Tuuri
...
@@ -52,30 +52,43 @@ Created 9/17/2000 Heikki Tuuri
#include "fil0fil.h"
#include "fil0fil.h"
#include "ibuf0ibuf.h"
#include "ibuf0ibuf.h"
/* Provide optional 4.x backwards compatibility for 5.0 and above */
/*
*
Provide optional 4.x backwards compatibility for 5.0 and above */
UNIV_INTERN
ibool
row_rollback_on_timeout
=
FALSE
;
UNIV_INTERN
ibool
row_rollback_on_timeout
=
FALSE
;
/* List of tables we should drop in background. ALTER TABLE in MySQL requires
/** Chain node of the list of tables to drop in the background. */
that the table handler can drop the table in background when there are no
queries to it any more. Protected by the kernel mutex. */
typedef
struct
row_mysql_drop_struct
row_mysql_drop_t
;
typedef
struct
row_mysql_drop_struct
row_mysql_drop_t
;
/** Chain node of the list of tables to drop in the background. */
struct
row_mysql_drop_struct
{
struct
row_mysql_drop_struct
{
char
*
table_name
;
char
*
table_name
;
/*!< table name */
UT_LIST_NODE_T
(
row_mysql_drop_t
)
row_mysql_drop_list
;
UT_LIST_NODE_T
(
row_mysql_drop_t
)
row_mysql_drop_list
;
/*!< list chain node */
};
};
/** @brief List of tables we should drop in background.
ALTER TABLE in MySQL requires that the table handler can drop the
table in background when there are no queries to it any
more. Protected by kernel_mutex. */
static
UT_LIST_BASE_NODE_T
(
row_mysql_drop_t
)
row_mysql_drop_list
;
static
UT_LIST_BASE_NODE_T
(
row_mysql_drop_t
)
row_mysql_drop_list
;
/** Flag: has row_mysql_drop_list been initialized? */
static
ibool
row_mysql_drop_list_inited
=
FALSE
;
static
ibool
row_mysql_drop_list_inited
=
FALSE
;
/* Magic table names for invoking various monitor threads */
/** Magic table names for invoking various monitor threads */
/* @{ */
static
const
char
S_innodb_monitor
[]
=
"innodb_monitor"
;
static
const
char
S_innodb_monitor
[]
=
"innodb_monitor"
;
static
const
char
S_innodb_lock_monitor
[]
=
"innodb_lock_monitor"
;
static
const
char
S_innodb_lock_monitor
[]
=
"innodb_lock_monitor"
;
static
const
char
S_innodb_tablespace_monitor
[]
=
"innodb_tablespace_monitor"
;
static
const
char
S_innodb_tablespace_monitor
[]
=
"innodb_tablespace_monitor"
;
static
const
char
S_innodb_table_monitor
[]
=
"innodb_table_monitor"
;
static
const
char
S_innodb_table_monitor
[]
=
"innodb_table_monitor"
;
static
const
char
S_innodb_mem_validate
[]
=
"innodb_mem_validate"
;
static
const
char
S_innodb_mem_validate
[]
=
"innodb_mem_validate"
;
/* @} */
/* Evaluates to true if str1 equals str2_onstack, used for comparing
the above strings. */
/** Evaluates to true if str1 equals str2_onstack, used for comparing
the magic table names.
@param str1 in: string to compare
@param str1_len in: length of str1, in bytes, including terminating NUL
@param str2_onstack in: char[] array containing a NUL terminated string
@return TRUE if str1 equals str2_onstack */
#define STR_EQ(str1, str1_len, str2_onstack) \
#define STR_EQ(str1, str1_len, str2_onstack) \
((str1_len) == sizeof(str2_onstack) \
((str1_len) == sizeof(str2_onstack) \
&& memcmp(str1, str2_onstack, sizeof(str2_onstack)) == 0)
&& memcmp(str1, str2_onstack, sizeof(str2_onstack)) == 0)
...
@@ -3379,7 +3392,7 @@ drop_all_foreign_keys_in_db(
...
@@ -3379,7 +3392,7 @@ drop_all_foreign_keys_in_db(
pars_info_add_str_literal
(
pinfo
,
"dbname"
,
name
);
pars_info_add_str_literal
(
pinfo
,
"dbname"
,
name
);
/* true if for_name is not prefixed with dbname */
/*
*
true if for_name is not prefixed with dbname */
#define TABLE_NOT_IN_THIS_DB \
#define TABLE_NOT_IN_THIS_DB \
"SUBSTR(for_name, 0, LENGTH(:dbname)) <> :dbname"
"SUBSTR(for_name, 0, LENGTH(:dbname)) <> :dbname"
...
...
trx/trx0i_s.c
View file @
065f8dac
...
@@ -54,15 +54,17 @@ Created July 17, 2007 Vasil Dimov
...
@@ -54,15 +54,17 @@ Created July 17, 2007 Vasil Dimov
#include "ut0mem.h"
#include "ut0mem.h"
#include "ut0ut.h"
#include "ut0ut.h"
/** Initial number of rows in the table cache */
#define TABLE_CACHE_INITIAL_ROWSNUM 1024
#define TABLE_CACHE_INITIAL_ROWSNUM 1024
/* Table cache's rows are stored in a set of chunks. When a new row is
/** @brief The maximum number of chunks to allocate for a table cache.
added a new chunk is allocated if necessary. MEM_CHUNKS_IN_TABLE_CACHE
specifies the maximum number of chunks.
The rows of a table cache are stored in a set of chunks. When a new
Assuming that the first one is 1024 rows (TABLE_CACHE_INITIAL_ROWSNUM)
row is added a new chunk is allocated if necessary. Assuming that the
and each subsequent is N/2 where N is the number of rows we have
first one is 1024 rows (TABLE_CACHE_INITIAL_ROWSNUM) and each
allocated till now, then 39th chunk would have 1677416425 number of rows
subsequent is N/2 where N is the number of rows we have allocated till
and all chunks would have 3354832851 number of rows. */
now, then 39th chunk would accommodate 1677416425 rows and all chunks
would accommodate 3354832851 rows. */
#define MEM_CHUNKS_IN_TABLE_CACHE 39
#define MEM_CHUNKS_IN_TABLE_CACHE 39
/* The following are some testing auxiliary macros. Do not enable them
/* The following are some testing auxiliary macros. Do not enable them
...
@@ -113,62 +115,67 @@ noop because it will be empty. */
...
@@ -113,62 +115,67 @@ noop because it will be empty. */
- (cache)->mem_allocd \
- (cache)->mem_allocd \
- ha_storage_get_size((cache)->storage))
- ha_storage_get_size((cache)->storage))
/* Memory for each table in the intermediate buffer is allocated in
/*
*
Memory for each table in the intermediate buffer is allocated in
separate chunks. These chunks are considered to be concatenated to
separate chunks. These chunks are considered to be concatenated to
represent one flat array of rows. */
represent one flat array of rows. */
typedef
struct
i_s_mem_chunk_struct
{
typedef
struct
i_s_mem_chunk_struct
{
ulint
offset
;
/* offset, in number of rows */
ulint
offset
;
/*
!<
offset, in number of rows */
ulint
rows_allocd
;
/* the size of this chunk, in number
ulint
rows_allocd
;
/*
!<
the size of this chunk, in number
of rows */
of rows */
void
*
base
;
/* start of the chunk */
void
*
base
;
/*
!<
start of the chunk */
}
i_s_mem_chunk_t
;
}
i_s_mem_chunk_t
;
/* This represents one table's cache. */
/*
*
This represents one table's cache. */
typedef
struct
i_s_table_cache_struct
{
typedef
struct
i_s_table_cache_struct
{
ulint
rows_used
;
/* number of used rows */
ulint
rows_used
;
/*
!<
number of used rows */
ulint
rows_allocd
;
/* number of allocated rows */
ulint
rows_allocd
;
/*
!<
number of allocated rows */
ulint
row_size
;
/* size of a single row */
ulint
row_size
;
/*
!<
size of a single row */
i_s_mem_chunk_t
chunks
[
MEM_CHUNKS_IN_TABLE_CACHE
];
/* array of
i_s_mem_chunk_t
chunks
[
MEM_CHUNKS_IN_TABLE_CACHE
];
/*
!<
array of
memory chunks that stores the
memory chunks that stores the
rows */
rows */
}
i_s_table_cache_t
;
}
i_s_table_cache_t
;
/* This structure describes the intermediate buffer */
/*
*
This structure describes the intermediate buffer */
struct
trx_i_s_cache_struct
{
struct
trx_i_s_cache_struct
{
rw_lock_t
rw_lock
;
/* read-write lock protecting
rw_lock_t
rw_lock
;
/*
!<
read-write lock protecting
the rest of this structure */
the rest of this structure */
ullint
last_read
;
/* last time the cache was read;
ullint
last_read
;
/*
!<
last time the cache was read;
measured in microseconds since
measured in microseconds since
epoch */
epoch */
mutex_t
last_read_mutex
;
/* mutex protecting the
mutex_t
last_read_mutex
;
/*
!<
mutex protecting the
last_read member - it is updated
last_read member - it is updated
inside a shared lock of the
inside a shared lock of the
rw_lock member */
rw_lock member */
i_s_table_cache_t
innodb_trx
;
/* innodb_trx table */
i_s_table_cache_t
innodb_trx
;
/*
!<
innodb_trx table */
i_s_table_cache_t
innodb_locks
;
/* innodb_locks table */
i_s_table_cache_t
innodb_locks
;
/*
!<
innodb_locks table */
i_s_table_cache_t
innodb_lock_waits
;
/* innodb_lock_waits table */
i_s_table_cache_t
innodb_lock_waits
;
/*
!<
innodb_lock_waits table */
/* the hash table size is LOCKS_HASH_CELLS_NUM * sizeof(void*) bytes */
/*
*
the hash table size is LOCKS_HASH_CELLS_NUM * sizeof(void*) bytes */
#define LOCKS_HASH_CELLS_NUM 10000
#define LOCKS_HASH_CELLS_NUM 10000
hash_table_t
*
locks_hash
;
/* hash table used to eliminate
hash_table_t
*
locks_hash
;
/*
!<
hash table used to eliminate
duplicate entries in the
duplicate entries in the
innodb_locks table */
innodb_locks table */
/** Initial size of the cache storage */
#define CACHE_STORAGE_INITIAL_SIZE 1024
#define CACHE_STORAGE_INITIAL_SIZE 1024
/** Number of hash cells in the cache storage */
#define CACHE_STORAGE_HASH_CELLS 2048
#define CACHE_STORAGE_HASH_CELLS 2048
ha_storage_t
*
storage
;
/* storage for external volatile
ha_storage_t
*
storage
;
/*
!<
storage for external volatile
data that can possibly not be
data that can possibly not be
available later, when we release
available later, when we release
the kernel mutex */
the kernel mutex */
ulint
mem_allocd
;
/* the amount of memory
ulint
mem_allocd
;
/*
!<
the amount of memory
allocated with mem_alloc*() */
allocated with mem_alloc*() */
ibool
is_truncated
;
/* this is TRUE if the memory
ibool
is_truncated
;
/*
!<
this is TRUE if the memory
limit was hit and thus the data
limit was hit and thus the data
in the cache is truncated */
in the cache is truncated */
};
};
/* This is the intermediate buffer where data needed to fill the
/*
*
This is the intermediate buffer where data needed to fill the
INFORMATION SCHEMA tables is fetched and later retrieved by the C++
INFORMATION SCHEMA tables is fetched and later retrieved by the C++
code in handler/i_s.cc. */
code in handler/i_s.cc. */
static
trx_i_s_cache_t
trx_i_s_cache_static
;
static
trx_i_s_cache_t
trx_i_s_cache_static
;
/** This is the intermediate buffer where data needed to fill the
INFORMATION SCHEMA tables is fetched and later retrieved by the C++
code in handler/i_s.cc. */
UNIV_INTERN
trx_i_s_cache_t
*
trx_i_s_cache
=
&
trx_i_s_cache_static
;
UNIV_INTERN
trx_i_s_cache_t
*
trx_i_s_cache
=
&
trx_i_s_cache_static
;
/*******************************************************************//**
/*******************************************************************//**
...
...
ut/ut0byte.c
View file @
065f8dac
...
@@ -29,10 +29,10 @@ Created 5/11/1994 Heikki Tuuri
...
@@ -29,10 +29,10 @@ Created 5/11/1994 Heikki Tuuri
#include "ut0byte.ic"
#include "ut0byte.ic"
#endif
#endif
/* Zero value for a dulint */
/*
*
Zero value for a dulint */
UNIV_INTERN
const
dulint
ut_dulint_zero
=
{
0
,
0
};
UNIV_INTERN
const
dulint
ut_dulint_zero
=
{
0
,
0
};
/* Maximum value for a dulint */
/*
*
Maximum value for a dulint */
UNIV_INTERN
const
dulint
ut_dulint_max
=
{
0xFFFFFFFFUL
,
0xFFFFFFFFUL
};
UNIV_INTERN
const
dulint
ut_dulint_max
=
{
0xFFFFFFFFUL
,
0xFFFFFFFFUL
};
#ifdef notdefined
/* unused code */
#ifdef notdefined
/* unused code */
...
...
ut/ut0dbg.c
View file @
065f8dac
...
@@ -28,22 +28,22 @@ Created 1/30/1994 Heikki Tuuri
...
@@ -28,22 +28,22 @@ Created 1/30/1994 Heikki Tuuri
#if defined(__GNUC__) && (__GNUC__ > 2)
#if defined(__GNUC__) && (__GNUC__ > 2)
#else
#else
/* This is used to eliminate compiler warnings */
/*
*
This is used to eliminate compiler warnings */
UNIV_INTERN
ulint
ut_dbg_zero
=
0
;
UNIV_INTERN
ulint
ut_dbg_zero
=
0
;
#endif
#endif
#if defined(UNIV_SYNC_DEBUG) || !defined(UT_DBG_USE_ABORT)
#if defined(UNIV_SYNC_DEBUG) || !defined(UT_DBG_USE_ABORT)
/*
If this is set to TRUE all threads will stop into the next assertion
/*
* If this is set to TRUE by ut_dbg_assertion_failed(), all threads
and assert
*/
will stop at the next ut_a() or ut_ad().
*/
UNIV_INTERN
ibool
ut_dbg_stop_threads
=
FALSE
;
UNIV_INTERN
ibool
ut_dbg_stop_threads
=
FALSE
;
#endif
#endif
#ifdef __NETWARE__
#ifdef __NETWARE__
/*
This is set to TRUE when on NetWare there happens an InnoDB
/*
* Flag for ignoring further assertion failures. This is set to TRUE
assertion failure or other fatal error condition that requires an
when on NetWare there happens an InnoDB assertion failure or other
immediate shutdown. */
fatal error condition that requires an
immediate shutdown. */
UNIV_INTERN
ibool
panic_shutdown
=
FALSE
;
UNIV_INTERN
ibool
panic_shutdown
=
FALSE
;
#elif !defined(UT_DBG_USE_ABORT)
#elif !defined(UT_DBG_USE_ABORT)
/*
Null pointer used to generate
memory trap */
/*
* A null pointer that will be dereferenced to trigger a
memory trap */
UNIV_INTERN
ulint
*
ut_dbg_null_ptr
=
NULL
;
UNIV_INTERN
ulint
*
ut_dbg_null_ptr
=
NULL
;
#endif
#endif
...
...
ut/ut0mem.c
View file @
065f8dac
...
@@ -35,32 +35,38 @@ Created 5/11/1994 Heikki Tuuri
...
@@ -35,32 +35,38 @@ Created 5/11/1994 Heikki Tuuri
#include <stdlib.h>
#include <stdlib.h>
/* This struct is placed first in every allocated memory block */
/*
*
This struct is placed first in every allocated memory block */
typedef
struct
ut_mem_block_struct
ut_mem_block_t
;
typedef
struct
ut_mem_block_struct
ut_mem_block_t
;
/* The total amount of memory currently allocated from the operating
/*
*
The total amount of memory currently allocated from the operating
system with os_mem_alloc_large() or malloc(). Does not count malloc()
system with os_mem_alloc_large() or malloc(). Does not count malloc()
if srv_use_sys_malloc is set. Protected by ut_list_mutex. */
if srv_use_sys_malloc is set. Protected by ut_list_mutex. */
UNIV_INTERN
ulint
ut_total_allocated_memory
=
0
;
UNIV_INTERN
ulint
ut_total_allocated_memory
=
0
;
/* Mutex protecting ut_total_allocated_memory and ut_mem_block_list */
/*
*
Mutex protecting ut_total_allocated_memory and ut_mem_block_list */
UNIV_INTERN
os_fast_mutex_t
ut_list_mutex
;
UNIV_INTERN
os_fast_mutex_t
ut_list_mutex
;
/** Dynamically allocated memory block */
struct
ut_mem_block_struct
{
struct
ut_mem_block_struct
{
UT_LIST_NODE_T
(
ut_mem_block_t
)
mem_block_list
;
UT_LIST_NODE_T
(
ut_mem_block_t
)
mem_block_list
;
/* mem block list node */
/*
!<
mem block list node */
ulint
size
;
/* size of allocated memory */
ulint
size
;
/*
!<
size of allocated memory */
ulint
magic_n
;
ulint
magic_n
;
/*!< magic number (UT_MEM_MAGIC_N) */
};
};
/** The value of ut_mem_block_struct::magic_n. Used in detecting
memory corruption. */
#define UT_MEM_MAGIC_N 1601650166
#define UT_MEM_MAGIC_N 1601650166
/* List of all memory blocks allocated from the operating system
/*
*
List of all memory blocks allocated from the operating system
with malloc. Protected by ut_list_mutex. */
with malloc. Protected by ut_list_mutex. */
static
UT_LIST_BASE_NODE_T
(
ut_mem_block_t
)
ut_mem_block_list
;
static
UT_LIST_BASE_NODE_T
(
ut_mem_block_t
)
ut_mem_block_list
;
/** Flag: has ut_mem_block_list been initialized? */
static
ibool
ut_mem_block_list_inited
=
FALSE
;
static
ibool
ut_mem_block_list_inited
=
FALSE
;
/** A dummy pointer for generating a null pointer exception in
ut_malloc_low() */
static
ulint
*
ut_mem_null_ptr
=
NULL
;
static
ulint
*
ut_mem_null_ptr
=
NULL
;
/**********************************************************************//**
/**********************************************************************//**
...
...
ut/ut0rnd.c
View file @
065f8dac
...
@@ -29,12 +29,14 @@ Created 5/11/1994 Heikki Tuuri
...
@@ -29,12 +29,14 @@ Created 5/11/1994 Heikki Tuuri
#include "ut0rnd.ic"
#include "ut0rnd.ic"
#endif
#endif
/* These random numbers are used in ut_find_prime */
/** These random numbers are used in ut_find_prime */
/*@{*/
#define UT_RANDOM_1 1.0412321
#define UT_RANDOM_1 1.0412321
#define UT_RANDOM_2 1.1131347
#define UT_RANDOM_2 1.1131347
#define UT_RANDOM_3 1.0132677
#define UT_RANDOM_3 1.0132677
/*@}*/
/** Seed value of ut_rnd_gen_ulint(). */
UNIV_INTERN
ulint
ut_rnd_ulint_counter
=
65654363
;
UNIV_INTERN
ulint
ut_rnd_ulint_counter
=
65654363
;
/***********************************************************//**
/***********************************************************//**
...
...
ut/ut0ut.c
View file @
065f8dac
...
@@ -39,6 +39,7 @@ Created 5/11/1994 Heikki Tuuri
...
@@ -39,6 +39,7 @@ Created 5/11/1994 Heikki Tuuri
# include "mysql_com.h"
/* NAME_LEN */
# include "mysql_com.h"
/* NAME_LEN */
#endif
/* UNIV_HOTBACKUP */
#endif
/* UNIV_HOTBACKUP */
/** A constant to prevent the compiler from optimizing ut_delay() away. */
UNIV_INTERN
ibool
ut_always_false
=
FALSE
;
UNIV_INTERN
ibool
ut_always_false
=
FALSE
;
#ifdef __WIN__
#ifdef __WIN__
...
@@ -87,6 +88,8 @@ ut_gettimeofday(
...
@@ -87,6 +88,8 @@ ut_gettimeofday(
return
(
0
);
return
(
0
);
}
}
#else
#else
/** An alias for gettimeofday(2). On Microsoft Windows, we have to
reimplement this function. */
#define ut_gettimeofday gettimeofday
#define ut_gettimeofday gettimeofday
#endif
#endif
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment