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
b0278302
Commit
b0278302
authored
Oct 17, 2019
by
Marko Mäkelä
Browse files
Options
Browse Files
Download
Plain Diff
MDEV-20850 Merge new release of InnoDB 5.7.28 to 10.2
parents
3ce14a66
fa32d28f
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
30 additions
and
31 deletions
+30
-31
mysql-test/suite/sys_vars/t/sysvars_innodb.test
mysql-test/suite/sys_vars/t/sysvars_innodb.test
+0
-5
storage/innobase/btr/btr0bulk.cc
storage/innobase/btr/btr0bulk.cc
+16
-14
storage/innobase/btr/btr0cur.cc
storage/innobase/btr/btr0cur.cc
+13
-11
storage/innobase/include/univ.i
storage/innobase/include/univ.i
+1
-1
No files found.
mysql-test/suite/sys_vars/t/sysvars_innodb.test
View file @
b0278302
...
@@ -3,11 +3,6 @@
...
@@ -3,11 +3,6 @@
--
source
include
/
not_valgrind
.
inc
--
source
include
/
not_valgrind
.
inc
--
source
include
/
word_size
.
inc
--
source
include
/
word_size
.
inc
if
(
`select plugin_auth_version <= "5.6.34-79.1" from information_schema.plugins where plugin_name='innodb'`
)
{
--
skip
Not
fixed
in
XtraDB
as
of
10.1
.
21
-
MariaDB
or
earlier
}
--
vertical_results
--
vertical_results
--
replace_regex
/^
\
/
\S
+/
PATH
/
/
\
.
\
//PATH/
--
replace_regex
/^
\
/
\S
+/
PATH
/
/
\
.
\
//PATH/
select
VARIABLE_NAME
,
SESSION_VALUE
,
DEFAULT_VALUE
,
VARIABLE_SCOPE
,
VARIABLE_TYPE
,
VARIABLE_COMMENT
,
NUMERIC_MIN_VALUE
,
NUMERIC_MAX_VALUE
,
NUMERIC_BLOCK_SIZE
,
ENUM_VALUE_LIST
,
READ_ONLY
,
COMMAND_LINE_ARGUMENT
from
information_schema
.
system_variables
select
VARIABLE_NAME
,
SESSION_VALUE
,
DEFAULT_VALUE
,
VARIABLE_SCOPE
,
VARIABLE_TYPE
,
VARIABLE_COMMENT
,
NUMERIC_MIN_VALUE
,
NUMERIC_MAX_VALUE
,
NUMERIC_BLOCK_SIZE
,
ENUM_VALUE_LIST
,
READ_ONLY
,
COMMAND_LINE_ARGUMENT
from
information_schema
.
system_variables
...
...
storage/innobase/btr/btr0bulk.cc
View file @
b0278302
/*****************************************************************************
/*****************************************************************************
Copyright (c) 2014, 201
6
, Oracle and/or its affiliates. All Rights Reserved.
Copyright (c) 2014, 201
9
, Oracle and/or its affiliates. All Rights Reserved.
Copyright (c) 2017, 2019, MariaDB Corporation.
Copyright (c) 2017, 2019, MariaDB Corporation.
This program is free software; you can redistribute it and/or modify it under
This program is free software; you can redistribute it and/or modify it under
...
@@ -51,7 +51,7 @@ PageBulk::init()
...
@@ -51,7 +51,7 @@ PageBulk::init()
m_heap
=
mem_heap_create
(
1000
);
m_heap
=
mem_heap_create
(
1000
);
m_mtr
.
start
();
m_mtr
.
start
();
mtr_x_lock
(
&
m_index
->
lock
,
&
m_mtr
);
if
(
m_flush_observer
)
{
if
(
m_flush_observer
)
{
m_mtr
.
set_log_mode
(
MTR_LOG_NO_REDO
);
m_mtr
.
set_log_mode
(
MTR_LOG_NO_REDO
);
m_mtr
.
set_flush_observer
(
m_flush_observer
);
m_mtr
.
set_flush_observer
(
m_flush_observer
);
...
@@ -611,22 +611,20 @@ PageBulk::storeExt(
...
@@ -611,22 +611,20 @@ PageBulk::storeExt(
btr_pcur
.
pos_state
=
BTR_PCUR_IS_POSITIONED
;
btr_pcur
.
pos_state
=
BTR_PCUR_IS_POSITIONED
;
btr_pcur
.
latch_mode
=
BTR_MODIFY_LEAF
;
btr_pcur
.
latch_mode
=
BTR_MODIFY_LEAF
;
btr_pcur
.
btr_cur
.
index
=
m_index
;
btr_pcur
.
btr_cur
.
index
=
m_index
;
btr_pcur
.
btr_cur
.
page_cur
.
index
=
m_index
;
page_cur_t
*
page_cur
=
&
btr_pcur
.
btr_cur
.
page_cur
;
btr_pcur
.
btr_cur
.
page_cur
.
rec
=
m_cur_rec
;
page_cur
->
index
=
m_index
;
btr_pcur
.
btr_cur
.
page_cur
.
offsets
=
offsets
;
page_cur
->
rec
=
m_cur_rec
;
btr_pcur
.
btr_cur
.
page_cur
.
block
=
m_block
;
page_cur
->
offsets
=
offsets
;
page_cur
->
block
=
m_block
;
dberr_t
err
=
btr_store_big_rec_extern_fields
(
dberr_t
err
=
btr_store_big_rec_extern_fields
(
&
btr_pcur
,
offsets
,
big_rec
,
&
m_mtr
,
BTR_STORE_INSERT_BULK
);
&
btr_pcur
,
offsets
,
big_rec
,
&
m_mtr
,
BTR_STORE_INSERT_BULK
);
ut_ad
(
page_offset
(
m_cur_rec
)
==
page_offset
(
page_cur
->
rec
));
/* Reset m_block and m_cur_rec from page cursor, because
/* Reset m_block and m_cur_rec from page cursor, because
block may be changed during blob insert. */
block may be changed during blob insert. (FIXME: Can it really?) */
m_block
=
page_cur
->
block
;
ut_ad
(
m_block
==
btr_pcur
.
btr_cur
.
page_cur
.
block
);
m_cur_rec
=
page_cur
->
rec
;
m_block
=
btr_pcur
.
btr_cur
.
page_cur
.
block
;
m_cur_rec
=
btr_pcur
.
btr_cur
.
page_cur
.
rec
;
m_page
=
buf_block_get_frame
(
m_block
);
m_page
=
buf_block_get_frame
(
m_block
);
return
(
err
);
return
(
err
);
...
@@ -653,7 +651,7 @@ dberr_t
...
@@ -653,7 +651,7 @@ dberr_t
PageBulk
::
latch
()
PageBulk
::
latch
()
{
{
m_mtr
.
start
();
m_mtr
.
start
();
mtr_x_lock
(
&
m_index
->
lock
,
&
m_mtr
);
if
(
m_flush_observer
)
{
if
(
m_flush_observer
)
{
m_mtr
.
set_log_mode
(
MTR_LOG_NO_REDO
);
m_mtr
.
set_log_mode
(
MTR_LOG_NO_REDO
);
m_mtr
.
set_flush_observer
(
m_flush_observer
);
m_mtr
.
set_flush_observer
(
m_flush_observer
);
...
@@ -758,6 +756,10 @@ BtrBulk::pageCommit(
...
@@ -758,6 +756,10 @@ BtrBulk::pageCommit(
page_bulk
->
setNext
(
FIL_NULL
);
page_bulk
->
setNext
(
FIL_NULL
);
}
}
ut_ad
(
!
rw_lock_own_flagged
(
&
m_index
->
lock
,
RW_LOCK_FLAG_X
|
RW_LOCK_FLAG_SX
|
RW_LOCK_FLAG_S
));
/* Compress page if it's a compressed table. */
/* Compress page if it's a compressed table. */
if
(
page_bulk
->
getPageZip
()
!=
NULL
&&
!
page_bulk
->
compress
())
{
if
(
page_bulk
->
getPageZip
()
!=
NULL
&&
!
page_bulk
->
compress
())
{
return
(
pageSplit
(
page_bulk
,
next_page_bulk
));
return
(
pageSplit
(
page_bulk
,
next_page_bulk
));
...
...
storage/innobase/btr/btr0cur.cc
View file @
b0278302
...
@@ -6775,7 +6775,7 @@ struct btr_blob_log_check_t {
...
@@ -6775,7 +6775,7 @@ struct btr_blob_log_check_t {
ulint
page_no
=
ULINT_UNDEFINED
;
ulint
page_no
=
ULINT_UNDEFINED
;
FlushObserver
*
observer
=
m_mtr
->
get_flush_observer
();
FlushObserver
*
observer
=
m_mtr
->
get_flush_observer
();
if
(
m_op
==
BTR_STORE_INSERT_BULK
)
{
if
(
UNIV_UNLIKELY
(
m_op
==
BTR_STORE_INSERT_BULK
)
)
{
offs
=
page_offset
(
*
m_rec
);
offs
=
page_offset
(
*
m_rec
);
page_no
=
page_get_page_no
(
page_no
=
page_get_page_no
(
buf_block_get_frame
(
*
m_block
));
buf_block_get_frame
(
*
m_block
));
...
@@ -6798,14 +6798,13 @@ struct btr_blob_log_check_t {
...
@@ -6798,14 +6798,13 @@ struct btr_blob_log_check_t {
m_mtr
->
set_named_space
(
index
->
space
);
m_mtr
->
set_named_space
(
index
->
space
);
m_mtr
->
set_flush_observer
(
observer
);
m_mtr
->
set_flush_observer
(
observer
);
if
(
m_op
==
BTR_STORE_INSERT_BULK
)
{
if
(
UNIV_UNLIKELY
(
m_op
==
BTR_STORE_INSERT_BULK
)
)
{
page_id_t
page_id
(
dict_index_get_space
(
index
),
page_id_t
page_id
(
dict_index_get_space
(
index
),
page_no
);
page_no
);
page_size_t
page_size
(
dict_table_page_size
(
page_size_t
page_size
(
dict_table_page_size
(
index
->
table
));
index
->
table
));
page_cur_t
*
page_cur
=
&
m_pcur
->
btr_cur
.
page_cur
;
page_cur_t
*
page_cur
=
&
m_pcur
->
btr_cur
.
page_cur
;
mtr_x_lock
(
dict_index_get_lock
(
index
),
m_mtr
);
page_cur
->
block
=
btr_block_get
(
page_cur
->
block
=
btr_block_get
(
page_id
,
page_size
,
RW_X_LATCH
,
index
,
m_mtr
);
page_id
,
page_size
,
RW_X_LATCH
,
index
,
m_mtr
);
page_cur
->
rec
=
buf_block_get_frame
(
page_cur
->
block
)
page_cur
->
rec
=
buf_block_get_frame
(
page_cur
->
block
)
...
@@ -6831,9 +6830,10 @@ struct btr_blob_log_check_t {
...
@@ -6831,9 +6830,10 @@ struct btr_blob_log_check_t {
*
m_rec
,
*
m_rec
,
MTR_MEMO_PAGE_X_FIX
|
MTR_MEMO_PAGE_SX_FIX
));
MTR_MEMO_PAGE_X_FIX
|
MTR_MEMO_PAGE_SX_FIX
));
ut_ad
(
mtr_memo_contains_flagged
(
m_mtr
,
ut_ad
((
m_op
==
BTR_STORE_INSERT_BULK
)
dict_index_get_lock
(
index
),
==
!
mtr_memo_contains_flagged
(
m_mtr
,
&
index
->
lock
,
MTR_MEMO_SX_LOCK
|
MTR_MEMO_X_LOCK
));
MTR_MEMO_SX_LOCK
|
MTR_MEMO_X_LOCK
));
}
}
};
};
...
@@ -6887,8 +6887,10 @@ btr_store_big_rec_extern_fields(
...
@@ -6887,8 +6887,10 @@ btr_store_big_rec_extern_fields(
ut_ad
(
rec_offs_validate
(
rec
,
index
,
offsets
));
ut_ad
(
rec_offs_validate
(
rec
,
index
,
offsets
));
ut_ad
(
rec_offs_any_extern
(
offsets
));
ut_ad
(
rec_offs_any_extern
(
offsets
));
ut_ad
(
mtr_memo_contains_flagged
(
btr_mtr
,
dict_index_get_lock
(
index
),
ut_ad
(
op
==
BTR_STORE_INSERT_BULK
MTR_MEMO_X_LOCK
|
MTR_MEMO_SX_LOCK
));
||
mtr_memo_contains_flagged
(
btr_mtr
,
&
index
->
lock
,
MTR_MEMO_X_LOCK
|
MTR_MEMO_SX_LOCK
));
ut_ad
(
mtr_is_block_fix
(
ut_ad
(
mtr_is_block_fix
(
btr_mtr
,
rec_block
,
MTR_MEMO_PAGE_X_FIX
,
index
->
table
));
btr_mtr
,
rec_block
,
MTR_MEMO_PAGE_X_FIX
,
index
->
table
));
ut_ad
(
buf_block_get_frame
(
rec_block
)
==
page_align
(
rec
));
ut_ad
(
buf_block_get_frame
(
rec_block
)
==
page_align
(
rec
));
...
@@ -7014,7 +7016,7 @@ btr_store_big_rec_extern_fields(
...
@@ -7014,7 +7016,7 @@ btr_store_big_rec_extern_fields(
mtr_t
*
alloc_mtr
;
mtr_t
*
alloc_mtr
;
if
(
op
==
BTR_STORE_INSERT_BULK
)
{
if
(
UNIV_UNLIKELY
(
op
==
BTR_STORE_INSERT_BULK
)
)
{
mtr_start
(
&
mtr_bulk
);
mtr_start
(
&
mtr_bulk
);
mtr_bulk
.
set_spaces
(
mtr
);
mtr_bulk
.
set_spaces
(
mtr
);
alloc_mtr
=
&
mtr_bulk
;
alloc_mtr
=
&
mtr_bulk
;
...
@@ -7036,7 +7038,7 @@ btr_store_big_rec_extern_fields(
...
@@ -7036,7 +7038,7 @@ btr_store_big_rec_extern_fields(
alloc_mtr
->
release_free_extents
(
r_extents
);
alloc_mtr
->
release_free_extents
(
r_extents
);
if
(
op
==
BTR_STORE_INSERT_BULK
)
{
if
(
UNIV_UNLIKELY
(
op
==
BTR_STORE_INSERT_BULK
)
)
{
mtr_commit
(
&
mtr_bulk
);
mtr_commit
(
&
mtr_bulk
);
}
}
...
@@ -7192,7 +7194,7 @@ btr_store_big_rec_extern_fields(
...
@@ -7192,7 +7194,7 @@ btr_store_big_rec_extern_fields(
}
}
/* We compress a page when finish bulk insert.*/
/* We compress a page when finish bulk insert.*/
if
(
op
!=
BTR_STORE_INSERT_BULK
)
{
if
(
UNIV_LIKELY
(
op
!=
BTR_STORE_INSERT_BULK
)
)
{
page_zip_write_blob_ptr
(
page_zip_write_blob_ptr
(
page_zip
,
rec
,
index
,
offsets
,
page_zip
,
rec
,
index
,
offsets
,
field_no
,
&
mtr
);
field_no
,
&
mtr
);
...
...
storage/innobase/include/univ.i
View file @
b0278302
...
@@ -41,7 +41,7 @@ Created 1/20/1994 Heikki Tuuri
...
@@ -41,7 +41,7 @@ Created 1/20/1994 Heikki Tuuri
#
define
INNODB_VERSION_MAJOR
5
#
define
INNODB_VERSION_MAJOR
5
#
define
INNODB_VERSION_MINOR
7
#
define
INNODB_VERSION_MINOR
7
#
define
INNODB_VERSION_BUGFIX
2
7
#
define
INNODB_VERSION_BUGFIX
2
8
/* The following is the InnoDB version as shown in
/* The following is the InnoDB version as shown in
SELECT plugin_version FROM information_schema.plugins;
SELECT plugin_version FROM information_schema.plugins;
...
...
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