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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
246d321f
Commit
246d321f
authored
Sep 20, 2017
by
Vicențiu Ciorbaru
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch '10.2' of github.com:MariaDB/server into 10.2
parents
e42c6d1a
c53f57c3
Changes
16
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
16 changed files
with
220 additions
and
388 deletions
+220
-388
extra/mariabackup/backup_mysql.cc
extra/mariabackup/backup_mysql.cc
+1
-1
mysql-test/suite/innodb_zip/r/wl6501_crash_4.result
mysql-test/suite/innodb_zip/r/wl6501_crash_4.result
+1
-4
storage/innobase/btr/btr0btr.cc
storage/innobase/btr/btr0btr.cc
+1
-1
storage/innobase/btr/btr0cur.cc
storage/innobase/btr/btr0cur.cc
+1
-1
storage/innobase/dict/dict0defrag_bg.cc
storage/innobase/dict/dict0defrag_bg.cc
+2
-2
storage/innobase/dict/dict0dict.cc
storage/innobase/dict/dict0dict.cc
+1
-1
storage/innobase/ibuf/ibuf0ibuf.cc
storage/innobase/ibuf/ibuf0ibuf.cc
+1
-1
storage/innobase/include/dict0dict.ic
storage/innobase/include/dict0dict.ic
+0
-14
storage/innobase/include/dict0mem.h
storage/innobase/include/dict0mem.h
+0
-2
storage/innobase/include/page0page.h
storage/innobase/include/page0page.h
+187
-131
storage/innobase/include/page0page.ic
storage/innobase/include/page0page.ic
+17
-223
storage/innobase/mtr/mtr0log.cc
storage/innobase/mtr/mtr0log.cc
+5
-3
storage/innobase/page/page0page.cc
storage/innobase/page/page0page.cc
+1
-1
storage/innobase/rem/rem0cmp.cc
storage/innobase/rem/rem0cmp.cc
+0
-1
storage/innobase/row/row0log.cc
storage/innobase/row/row0log.cc
+1
-1
storage/innobase/srv/srv0start.cc
storage/innobase/srv/srv0start.cc
+1
-1
No files found.
extra/mariabackup/backup_mysql.cc
View file @
246d321f
...
...
@@ -1647,7 +1647,7 @@ mdl_lock_init()
}
}
#ifndef DBU
F
_OFF
#ifndef DBU
G
_OFF
/* Test that table is really locked, if lock_ddl_per_table is set.
The test is executed in DBUG_EXECUTE_IF block inside mdl_lock_table().
*/
...
...
mysql-test/suite/innodb_zip/r/wl6501_crash_4.result
View file @
246d321f
...
...
@@ -461,10 +461,6 @@ i f c
drop table t;
set global innodb_file_per_table = 1;
call mtr.add_suppression("does not exist in the InnoDB internal");
Warnings:
Error 145 Table './mtr/test_suppressions' is marked as crashed and should be repaired
Error 1194 Table 'test_suppressions' is marked as crashed and should be repaired
Error 1034 1 client is using or hasn't closed the table properly
set global innodb_file_per_table = on;
"1. Hit crash point on completing drop of all indexes before creation"
" of index is commenced."
...
...
@@ -520,3 +516,4 @@ check table t;
Table Op Msg_type Msg_text
test.t check Error Table 'test.t' doesn't exist
test.t check status Operation failed
set global innodb_file_per_table = 1;
storage/innobase/btr/btr0btr.cc
View file @
246d321f
...
...
@@ -832,7 +832,7 @@ btr_node_ptr_set_child_page_no(
ulint
len
;
ut_ad
(
rec_offs_validate
(
rec
,
NULL
,
offsets
));
ut_ad
(
!
page_
is_leaf
(
page_align
(
rec
)
));
ut_ad
(
!
page_
rec_is_leaf
(
rec
));
ut_ad
(
!
rec_offs_comp
(
offsets
)
||
rec_get_node_ptr_flag
(
rec
));
/* The child address is in the last field */
...
...
storage/innobase/btr/btr0cur.cc
View file @
246d321f
...
...
@@ -4665,7 +4665,7 @@ btr_cur_del_mark_set_clust_rec(
ut_ad
(
rec_offs_validate
(
rec
,
index
,
offsets
));
ut_ad
(
!!
page_rec_is_comp
(
rec
)
==
dict_table_is_comp
(
index
->
table
));
ut_ad
(
buf_block_get_frame
(
block
)
==
page_align
(
rec
));
ut_ad
(
page_
is_leaf
(
page_align
(
rec
)
));
ut_ad
(
page_
rec_is_leaf
(
rec
));
ut_ad
(
mtr
->
is_named_space
(
index
->
space
));
if
(
rec_get_deleted_flag
(
rec
,
rec_offs_comp
(
offsets
)))
{
...
...
storage/innobase/dict/dict0defrag_bg.cc
View file @
246d321f
...
...
@@ -290,7 +290,7 @@ dict_stats_save_defrag_summary(
dberr_t
ret
=
DB_SUCCESS
;
lint
now
=
(
lint
)
ut_time
();
if
(
dict_index_is_
univ
(
index
))
{
if
(
dict_index_is_
ibuf
(
index
))
{
return
DB_SUCCESS
;
}
...
...
@@ -320,7 +320,7 @@ dict_stats_save_defrag_stats(
{
dberr_t
ret
;
if
(
dict_index_is_
univ
(
index
))
{
if
(
dict_index_is_
ibuf
(
index
))
{
return
DB_SUCCESS
;
}
...
...
storage/innobase/dict/dict0dict.cc
View file @
246d321f
...
...
@@ -5685,7 +5685,7 @@ dict_index_copy_rec_order_prefix(
ut_a
(
!
dict_table_is_comp
(
index
->
table
));
n
=
rec_get_n_fields_old
(
rec
);
}
else
{
if
(
page_
is_leaf
(
page_align
(
rec
)
))
{
if
(
page_
rec_is_leaf
(
rec
))
{
n
=
dict_index_get_n_unique_in_tree
(
index
);
}
else
{
n
=
dict_index_get_n_unique_in_tree_nonleaf
(
index
);
...
...
storage/innobase/ibuf/ibuf0ibuf.cc
View file @
246d321f
...
...
@@ -559,7 +559,7 @@ ibuf_init_at_db_start(void)
ibuf
->
index
=
dict_mem_index_create
(
"innodb_change_buffer"
,
"CLUST_IND"
,
IBUF_SPACE_ID
,
DICT_CLUSTERED
|
DICT_
UNIVERSAL
|
DICT_
IBUF
,
1
);
IBUF_SPACE_ID
,
DICT_CLUSTERED
|
DICT_IBUF
,
1
);
ibuf
->
index
->
id
=
DICT_IBUF_ID_MIN
+
IBUF_SPACE_ID
;
ibuf
->
index
->
table
=
dict_mem_table_create
(
"innodb_change_buffer"
,
IBUF_SPACE_ID
,
1
,
0
,
0
,
0
);
...
...
storage/innobase/include/dict0dict.ic
View file @
246d321f
...
...
@@ -326,20 +326,6 @@ dict_index_is_unique(
return(index->type & DICT_UNIQUE);
}
/********************************************************************//**
Check whether the index is an universal index tree.
@return nonzero for universal tree, zero for other indexes */
UNIV_INLINE
ulint
dict_index_is_univ(
/*===============*/
const dict_index_t* index) /*!< in: index */
{
ut_ad(index->magic_n == DICT_INDEX_MAGIC_N);
return(index->type & DICT_UNIVERSAL);
}
/********************************************************************//**
Check whether the index is a Spatial Index.
@return nonzero for Spatial Index, zero for other indexes */
...
...
storage/innobase/include/dict0mem.h
View file @
246d321f
...
...
@@ -66,8 +66,6 @@ combination of types */
auto-generated clustered indexes,
also DICT_UNIQUE will be set */
#define DICT_UNIQUE 2
/*!< unique index */
#define DICT_UNIVERSAL 4
/*!< index which can contain records from any
other index */
#define DICT_IBUF 8
/*!< insert buffer tree */
#define DICT_CORRUPT 16
/*!< bit to store the corrupted flag
in SYS_INDEXES.TYPE */
...
...
storage/innobase/include/page0page.h
View file @
246d321f
This diff is collapsed.
Click to expand it.
storage/innobase/include/page0page.ic
View file @
246d321f
...
...
@@ -40,32 +40,7 @@ Created 2/2/1994 Heikki Tuuri
#undef UNIV_INLINE
#define UNIV_INLINE
#endif
#endif /* !UNIV_INNOCHECKSUM */
/************************************************************//**
Gets the start of a page.
@return start of the page */
UNIV_INLINE
page_t*
page_align(
/*=======*/
const void* ptr) /*!< in: pointer to page frame */
{
return((page_t*) ut_align_down(ptr, UNIV_PAGE_SIZE));
}
#ifndef UNIV_INNOCHECKSUM
/************************************************************//**
Gets the offset within a page.
@return offset from the start of the page */
UNIV_INLINE
ulint
page_offset(
/*========*/
const void* ptr) /*!< in: pointer to page frame */
{
return(ut_align_offset(ptr, UNIV_PAGE_SIZE));
}
/*************************************************************//**
Returns the max trx id field value. */
UNIV_INLINE
...
...
@@ -286,34 +261,6 @@ page_header_reset_last_insert(
}
}
#endif /* !UNIV_INNOCHECKSUM */
/************************************************************//**
Determine whether the page is in new-style compact format.
@return nonzero if the page is in compact format, zero if it is in
old-style format */
UNIV_INLINE
ulint
page_is_comp(
/*=========*/
const page_t* page) /*!< in: index page */
{
return(page[PAGE_HEADER + PAGE_N_HEAP] & 0x80);
}
#ifndef UNIV_INNOCHECKSUM
/************************************************************//**
TRUE if the record is on a page in compact format.
@return nonzero if in compact format */
UNIV_INLINE
ulint
page_rec_is_comp(
/*=============*/
const rec_t* rec) /*!< in: record */
{
return(page_is_comp(page_align(rec)));
}
/***************************************************************//**
Returns the heap number of a record.
@return heap number */
...
...
@@ -330,33 +277,6 @@ page_rec_get_heap_no(
}
}
#endif /* !UNIV_INNOCHECKSUM */
/************************************************************//**
Determine whether the page is a B-tree leaf.
@return true if the page is a B-tree leaf (PAGE_LEVEL = 0) */
UNIV_INLINE
bool
page_is_leaf(
/*=========*/
const page_t* page) /*!< in: page */
{
return(!*(const uint16*) (page + (PAGE_HEADER + PAGE_LEVEL)));
}
#ifndef UNIV_INNOCHECKSUM
/************************************************************//**
Determine whether the page is empty.
@return true if the page is empty (PAGE_N_RECS = 0) */
UNIV_INLINE
bool
page_is_empty(
/*==========*/
const page_t* page) /*!< in: page */
{
return(!*(const uint16*) (page + (PAGE_HEADER + PAGE_N_RECS)));
}
/** Determine whether a page is an index root page.
@param[in] page page frame
@return true if the page is a root page of an index */
...
...
@@ -382,162 +302,36 @@ page_is_root(
== IB_UINT64_MAX);
}
/**
**********************************************************//**
Determine whether the page contains garbage.
@return true if
the page contains garbage (PAGE_GARBAGE is not 0)
*/
UNIV_INLINE
/**
Determine whether an index page record is a user record.
@param[in] rec record in an index page
@return true if
a user record
*/
inline
bool
page_has_garbage(
/*=============*/
const page_t* page) /*!< in: page */
{
return(!!*(const uint16*) (page + (PAGE_HEADER + PAGE_GARBAGE)));
}
/************************************************************//**
Gets the offset of the first record on the page.
@return offset of the first record in record list, relative from page */
UNIV_INLINE
ulint
page_get_infimum_offset(
/*====================*/
const page_t* page) /*!< in: page which must have record(s) */
{
ut_ad(page);
ut_ad(!page_offset(page));
if (page_is_comp(page)) {
return(PAGE_NEW_INFIMUM);
} else {
return(PAGE_OLD_INFIMUM);
}
}
/************************************************************//**
Gets the offset of the last record on the page.
@return offset of the last record in record list, relative from page */
UNIV_INLINE
ulint
page_get_supremum_offset(
/*=====================*/
const page_t* page) /*!< in: page which must have record(s) */
{
ut_ad(page);
ut_ad(!page_offset(page));
if (page_is_comp(page)) {
return(PAGE_NEW_SUPREMUM);
} else {
return(PAGE_OLD_SUPREMUM);
}
}
/************************************************************//**
TRUE if the record is a user record on the page.
@return TRUE if a user record */
UNIV_INLINE
ibool
page_rec_is_user_rec_low(
/*=====================*/
ulint offset) /*!< in: record offset on page */
{
ut_ad(offset >= PAGE_NEW_INFIMUM);
#if PAGE_OLD_INFIMUM < PAGE_NEW_INFIMUM
# error "PAGE_OLD_INFIMUM < PAGE_NEW_INFIMUM"
#endif
#if PAGE_OLD_SUPREMUM < PAGE_NEW_SUPREMUM
# error "PAGE_OLD_SUPREMUM < PAGE_NEW_SUPREMUM"
#endif
#if PAGE_NEW_INFIMUM > PAGE_OLD_SUPREMUM
# error "PAGE_NEW_INFIMUM > PAGE_OLD_SUPREMUM"
#endif
#if PAGE_OLD_INFIMUM > PAGE_NEW_SUPREMUM
# error "PAGE_OLD_INFIMUM > PAGE_NEW_SUPREMUM"
#endif
#if PAGE_NEW_SUPREMUM > PAGE_OLD_SUPREMUM_END
# error "PAGE_NEW_SUPREMUM > PAGE_OLD_SUPREMUM_END"
#endif
#if PAGE_OLD_SUPREMUM > PAGE_NEW_SUPREMUM_END
# error "PAGE_OLD_SUPREMUM > PAGE_NEW_SUPREMUM_END"
#endif
ut_ad(offset <= UNIV_PAGE_SIZE - PAGE_EMPTY_DIR_START);
return(offset != PAGE_NEW_SUPREMUM
&& offset != PAGE_NEW_INFIMUM
&& offset != PAGE_OLD_INFIMUM
&& offset != PAGE_OLD_SUPREMUM);
}
/************************************************************//**
TRUE if the record is the supremum record on a page.
@return TRUE if the supremum record */
UNIV_INLINE
ibool
page_rec_is_supremum_low(
/*=====================*/
ulint offset) /*!< in: record offset on page */
{
ut_ad(offset >= PAGE_NEW_INFIMUM);
ut_ad(offset <= UNIV_PAGE_SIZE - PAGE_EMPTY_DIR_START);
return(offset == PAGE_NEW_SUPREMUM
|| offset == PAGE_OLD_SUPREMUM);
}
/************************************************************//**
TRUE if the record is the infimum record on a page.
@return TRUE if the infimum record */
UNIV_INLINE
ibool
page_rec_is_infimum_low(
/*====================*/
ulint offset) /*!< in: record offset on page */
{
ut_ad(offset >= PAGE_NEW_INFIMUM);
ut_ad(offset <= UNIV_PAGE_SIZE - PAGE_EMPTY_DIR_START);
return(offset == PAGE_NEW_INFIMUM || offset == PAGE_OLD_INFIMUM);
}
/************************************************************//**
TRUE if the record is a user record on the page.
@return TRUE if a user record */
UNIV_INLINE
ibool
page_rec_is_user_rec(
/*=================*/
const rec_t* rec) /*!< in: record */
page_rec_is_user_rec(const rec_t* rec)
{
ut_ad(page_rec_check(rec));
return(page_rec_is_user_rec_low(page_offset(rec)));
}
/************************************************************//**
TRUE if the record is the supremum record on a page.
@return TRUE if the supremum record */
UNIV_INLINE
ibool
page_rec_is_supremum(
/*=================*/
const rec_t* rec) /*!< in: record */
/** Determine whether an index page record is the supremum record.
@param[in] rec record in an index page
@return true if the supremum record */
inline
bool
page_rec_is_supremum(const rec_t* rec)
{
ut_ad(page_rec_check(rec));
return(page_rec_is_supremum_low(page_offset(rec)));
}
/************************************************************//**
TRUE if the record is the infimum record on a page.
@return TRUE if the infimum record */
UNIV_INLINE
ibool
page_rec_is_infimum(
/*================*/
const rec_t* rec) /*!< in: record */
/** Determine whether an index page record is the infimum record.
@param[in] rec record in an index page
@return true if the infimum record */
inline
bool
page_rec_is_infimum(const rec_t* rec)
{
ut_ad(page_rec_check(rec));
return(page_rec_is_infimum_low(page_offset(rec)));
}
...
...
storage/innobase/mtr/mtr0log.cc
View file @
246d321f
/*****************************************************************************
Copyright (c) 1995, 2016, Oracle and/or its affiliates. All Rights Reserved.
Copyright (c) 2017, MariaDB Corporation.
This program is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free Software
...
...
@@ -443,10 +444,11 @@ mlog_open_and_write_index(
alloc
=
mtr_buf_t
::
MAX_DATA_SIZE
;
}
const
bool
is_leaf
=
page_is_leaf
(
page_align
(
rec
));
/* For spatial index, on non-leaf page, we just keep
2 fields, MBR and page no. */
if
(
dict_index_is_spatial
(
index
)
&&
!
page_is_leaf
(
page_align
(
rec
)))
{
if
(
!
is_leaf
&&
dict_index_is_spatial
(
index
))
{
n
=
DICT_INDEX_SPATIAL_NODEPTR_SIZE
;
}
...
...
@@ -464,7 +466,7 @@ mlog_open_and_write_index(
mach_write_to_2
(
log_ptr
,
n
);
log_ptr
+=
2
;
if
(
page_is_leaf
(
page_align
(
rec
))
)
{
if
(
is_leaf
)
{
mach_write_to_2
(
log_ptr
,
dict_index_get_n_unique_in_tree
(
index
));
}
else
{
...
...
storage/innobase/page/page0page.cc
View file @
246d321f
...
...
@@ -873,7 +873,7 @@ page_copy_rec_list_start(
max_trx_id is ignored for temp tables because it not required
for MVCC. */
if
(
dict_index_is_sec_or_ibuf
(
index
)
&&
page_
is_leaf
(
page_align
(
rec
)
)
&&
page_
rec_is_leaf
(
rec
)
&&
!
dict_table_is_temporary
(
index
->
table
))
{
page_update_max_trx_id
(
new_block
,
NULL
,
page_get_max_trx_id
(
page_align
(
rec
)),
...
...
storage/innobase/rem/rem0cmp.cc
View file @
246d321f
...
...
@@ -797,7 +797,6 @@ cmp_dtuple_rec_with_match_bytes(
ut_ad
(
dtuple_check_typed
(
dtuple
));
ut_ad
(
rec_offs_validate
(
rec
,
index
,
offsets
));
//ut_ad(page_is_leaf(page_align(rec)));
ut_ad
(
!
(
REC_INFO_MIN_REC_FLAG
&
dtuple_get_info_bits
(
dtuple
)));
ut_ad
(
!
(
REC_INFO_MIN_REC_FLAG
...
...
storage/innobase/row/row0log.cc
View file @
246d321f
...
...
@@ -972,7 +972,7 @@ row_log_table_low(
&
index
->
lock
,
RW_LOCK_FLAG_S
|
RW_LOCK_FLAG_X
|
RW_LOCK_FLAG_SX
));
ut_ad
(
fil_page_get_type
(
page_align
(
rec
))
==
FIL_PAGE_INDEX
);
ut_ad
(
page_
is_leaf
(
page_align
(
rec
)
));
ut_ad
(
page_
rec_is_leaf
(
rec
));
ut_ad
(
!
page_is_comp
(
page_align
(
rec
))
==
!
rec_offs_comp
(
offsets
));
/* old_pk=row_log_table_get_pk() [not needed in INSERT] is a prefix
of the clustered index record (PRIMARY KEY,DB_TRX_ID,DB_ROLL_PTR),
...
...
storage/innobase/srv/srv0start.cc
View file @
246d321f
...
...
@@ -2139,7 +2139,7 @@ innobase_start_or_create_for_mysql()
compile_time_assert
(
IBUF_SPACE_ID
==
0
);
ulint
ibuf_root
=
btr_create
(
DICT_CLUSTERED
|
DICT_
UNIVERSAL
|
DICT_
IBUF
,
DICT_CLUSTERED
|
DICT_IBUF
,
0
,
univ_page_size
,
DICT_IBUF_ID_MIN
,
dict_ind_redundant
,
NULL
,
&
mtr
);
...
...
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