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
61e26289
Commit
61e26289
authored
Jul 03, 2019
by
Marko Mäkelä
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
MDEV-18582 preparation: Allocate ibuf statically
parent
d09aec7a
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
110 additions
and
117 deletions
+110
-117
storage/innobase/buf/buf0buf.cc
storage/innobase/buf/buf0buf.cc
+1
-1
storage/innobase/ibuf/ibuf0ibuf.cc
storage/innobase/ibuf/ibuf0ibuf.cc
+97
-102
storage/innobase/include/ibuf0ibuf.h
storage/innobase/include/ibuf0ibuf.h
+1
-1
storage/innobase/include/ibuf0ibuf.ic
storage/innobase/include/ibuf0ibuf.ic
+1
-1
storage/innobase/srv/srv0mon.cc
storage/innobase/srv/srv0mon.cc
+8
-8
storage/innobase/srv/srv0start.cc
storage/innobase/srv/srv0start.cc
+2
-4
No files found.
storage/innobase/buf/buf0buf.cc
View file @
61e26289
...
@@ -3099,7 +3099,7 @@ buf_pool_resize()
...
@@ -3099,7 +3099,7 @@ buf_pool_resize()
" dictionary."
;
" dictionary."
;
}
}
/* normalize ibuf
->
max_size */
/* normalize ibuf
.
max_size */
ibuf_max_size_update
(
srv_change_buffer_max_size
);
ibuf_max_size_update
(
srv_change_buffer_max_size
);
if
(
srv_buf_pool_old_size
!=
srv_buf_pool_size
)
{
if
(
srv_buf_pool_old_size
!=
srv_buf_pool_size
)
{
...
...
storage/innobase/ibuf/ibuf0ibuf.cc
View file @
61e26289
...
@@ -190,7 +190,7 @@ uint ibuf_debug;
...
@@ -190,7 +190,7 @@ uint ibuf_debug;
#endif
/* UNIV_DEBUG || UNIV_IBUF_DEBUG */
#endif
/* UNIV_DEBUG || UNIV_IBUF_DEBUG */
/** The insert buffer control structure */
/** The insert buffer control structure */
ibuf_t
*
ibuf
=
NULL
;
ibuf_t
ibuf
;
/** @name Offsets to the per-page bits in the insert buffer bitmap */
/** @name Offsets to the per-page bits in the insert buffer bitmap */
/* @{ */
/* @{ */
...
@@ -257,17 +257,17 @@ const ulint IBUF_MERGE_THRESHOLD = 4;
...
@@ -257,17 +257,17 @@ const ulint IBUF_MERGE_THRESHOLD = 4;
batch, in order to merge the entries for them in the insert buffer */
batch, in order to merge the entries for them in the insert buffer */
const
ulint
IBUF_MAX_N_PAGES_MERGED
=
IBUF_MERGE_AREA
;
const
ulint
IBUF_MAX_N_PAGES_MERGED
=
IBUF_MERGE_AREA
;
/** If the combined size of the ibuf trees exceeds ibuf
->
max_size by this
/** If the combined size of the ibuf trees exceeds ibuf
.
max_size by this
many pages, we start to contract it in connection to inserts there, using
many pages, we start to contract it in connection to inserts there, using
non-synchronous contract */
non-synchronous contract */
const
ulint
IBUF_CONTRACT_ON_INSERT_NON_SYNC
=
0
;
const
ulint
IBUF_CONTRACT_ON_INSERT_NON_SYNC
=
0
;
/** If the combined size of the ibuf trees exceeds ibuf
->
max_size by this
/** If the combined size of the ibuf trees exceeds ibuf
.
max_size by this
many pages, we start to contract it in connection to inserts there, using
many pages, we start to contract it in connection to inserts there, using
synchronous contract */
synchronous contract */
const
ulint
IBUF_CONTRACT_ON_INSERT_SYNC
=
5
;
const
ulint
IBUF_CONTRACT_ON_INSERT_SYNC
=
5
;
/** If the combined size of the ibuf trees exceeds ibuf
->
max_size by
/** If the combined size of the ibuf trees exceeds ibuf
.
max_size by
this many pages, we start to contract it synchronous contract, but do
this many pages, we start to contract it synchronous contract, but do
not insert */
not insert */
const
ulint
IBUF_CONTRACT_DO_NOT_INSERT
=
10
;
const
ulint
IBUF_CONTRACT_DO_NOT_INSERT
=
10
;
...
@@ -360,7 +360,7 @@ ibuf_tree_root_get(
...
@@ -360,7 +360,7 @@ ibuf_tree_root_get(
ut_ad
(
ibuf_inside
(
mtr
));
ut_ad
(
ibuf_inside
(
mtr
));
ut_ad
(
mutex_own
(
&
ibuf_mutex
));
ut_ad
(
mutex_own
(
&
ibuf_mutex
));
mtr_sx_lock
(
dict_index_get_lock
(
ibuf
->
index
),
mtr
);
mtr_sx_lock
(
dict_index_get_lock
(
ibuf
.
index
),
mtr
);
/* only segment list access is exclusive each other */
/* only segment list access is exclusive each other */
block
=
buf_page_get
(
block
=
buf_page_get
(
...
@@ -373,7 +373,7 @@ ibuf_tree_root_get(
...
@@ -373,7 +373,7 @@ ibuf_tree_root_get(
ut_ad
(
page_get_space_id
(
root
)
==
IBUF_SPACE_ID
);
ut_ad
(
page_get_space_id
(
root
)
==
IBUF_SPACE_ID
);
ut_ad
(
page_get_page_no
(
root
)
==
FSP_IBUF_TREE_ROOT_PAGE_NO
);
ut_ad
(
page_get_page_no
(
root
)
==
FSP_IBUF_TREE_ROOT_PAGE_NO
);
ut_ad
(
ibuf
->
empty
==
page_is_empty
(
root
));
ut_ad
(
ibuf
.
empty
==
page_is_empty
(
root
));
return
(
root
);
return
(
root
);
}
}
...
@@ -384,7 +384,7 @@ void
...
@@ -384,7 +384,7 @@ void
ibuf_close
(
void
)
ibuf_close
(
void
)
/*============*/
/*============*/
{
{
if
(
ibuf
==
NULL
)
{
if
(
!
ibuf
.
index
)
{
return
;
return
;
}
}
...
@@ -394,13 +394,11 @@ ibuf_close(void)
...
@@ -394,13 +394,11 @@ ibuf_close(void)
mutex_free
(
&
ibuf_bitmap_mutex
);
mutex_free
(
&
ibuf_bitmap_mutex
);
dict_table_t
*
ibuf_table
=
ibuf
->
index
->
table
;
dict_table_t
*
ibuf_table
=
ibuf
.
index
->
table
;
rw_lock_free
(
&
ibuf
->
index
->
lock
);
rw_lock_free
(
&
ibuf
.
index
->
lock
);
dict_mem_index_free
(
ibuf
->
index
);
dict_mem_index_free
(
ibuf
.
index
);
dict_mem_table_free
(
ibuf_table
);
dict_mem_table_free
(
ibuf_table
);
ibuf
.
index
=
NULL
;
ut_free
(
ibuf
);
ibuf
=
NULL
;
}
}
/******************************************************************//**
/******************************************************************//**
...
@@ -414,13 +412,13 @@ ibuf_size_update(
...
@@ -414,13 +412,13 @@ ibuf_size_update(
{
{
ut_ad
(
mutex_own
(
&
ibuf_mutex
));
ut_ad
(
mutex_own
(
&
ibuf_mutex
));
ibuf
->
free_list_len
=
flst_get_len
(
root
+
PAGE_HEADER
ibuf
.
free_list_len
=
flst_get_len
(
root
+
PAGE_HEADER
+
PAGE_BTR_IBUF_FREE_LIST
);
+
PAGE_BTR_IBUF_FREE_LIST
);
ibuf
->
height
=
1
+
btr_page_get_level
(
root
);
ibuf
.
height
=
1
+
btr_page_get_level
(
root
);
/* the '1 +' is the ibuf header page */
/* the '1 +' is the ibuf header page */
ibuf
->
size
=
ibuf
->
seg_size
-
(
1
+
ibuf
->
free_list_len
);
ibuf
.
size
=
ibuf
.
seg_size
-
(
1
+
ibuf
.
free_list_len
);
}
}
/******************************************************************//**
/******************************************************************//**
...
@@ -432,19 +430,28 @@ ibuf_init_at_db_start(void)
...
@@ -432,19 +430,28 @@ ibuf_init_at_db_start(void)
/*=======================*/
/*=======================*/
{
{
page_t
*
root
;
page_t
*
root
;
mtr_t
mtr
;
ulint
n_used
;
ulint
n_used
;
page_t
*
header_page
;
page_t
*
header_page
;
dberr_t
error
=
DB_SUCCESS
;
ibuf
=
static_cast
<
ibuf_t
*>
(
ut_zalloc_nokey
(
sizeof
(
ibuf_t
)));
ut_ad
(
!
ibuf
.
index
);
mtr_t
mtr
;
mtr
.
start
();
compile_time_assert
(
IBUF_SPACE_ID
==
TRX_SYS_SPACE
);
compile_time_assert
(
IBUF_SPACE_ID
==
0
);
mtr_x_lock
(
&
fil_system
.
sys_space
->
latch
,
&
mtr
);
header_page
=
ibuf_header_page_get
(
&
mtr
);
if
(
!
header_page
)
{
mtr
.
commit
();
return
DB_DECRYPTION_FAILED
;
}
/* At startup we intialize ibuf to have a maximum of
/* At startup we intialize ibuf to have a maximum of
CHANGE_BUFFER_DEFAULT_SIZE in terms of percentage of the
CHANGE_BUFFER_DEFAULT_SIZE in terms of percentage of the
buffer pool size. Once ibuf struct is initialized this
buffer pool size. Once ibuf struct is initialized this
value is updated with the user supplied size by calling
value is updated with the user supplied size by calling
ibuf_max_size_update(). */
ibuf_max_size_update(). */
ibuf
->
max_size
=
((
buf_pool_get_curr_size
()
>>
srv_page_size_shift
)
ibuf
.
max_size
=
((
buf_pool_get_curr_size
()
>>
srv_page_size_shift
)
*
CHANGE_BUFFER_DEFAULT_SIZE
)
/
100
;
*
CHANGE_BUFFER_DEFAULT_SIZE
)
/
100
;
mutex_create
(
LATCH_ID_IBUF
,
&
ibuf_mutex
);
mutex_create
(
LATCH_ID_IBUF
,
&
ibuf_mutex
);
...
@@ -454,26 +461,14 @@ ibuf_init_at_db_start(void)
...
@@ -454,26 +461,14 @@ ibuf_init_at_db_start(void)
mutex_create
(
LATCH_ID_IBUF_PESSIMISTIC_INSERT
,
mutex_create
(
LATCH_ID_IBUF_PESSIMISTIC_INSERT
,
&
ibuf_pessimistic_insert_mutex
);
&
ibuf_pessimistic_insert_mutex
);
mtr_start
(
&
mtr
);
compile_time_assert
(
IBUF_SPACE_ID
==
TRX_SYS_SPACE
);
compile_time_assert
(
IBUF_SPACE_ID
==
0
);
mtr_x_lock
(
&
fil_system
.
sys_space
->
latch
,
&
mtr
);
mutex_enter
(
&
ibuf_mutex
);
mutex_enter
(
&
ibuf_mutex
);
header_page
=
ibuf_header_page_get
(
&
mtr
);
if
(
!
header_page
)
{
return
(
DB_DECRYPTION_FAILED
);
}
fseg_n_reserved_pages
(
header_page
+
IBUF_HEADER
+
IBUF_TREE_SEG_HEADER
,
fseg_n_reserved_pages
(
header_page
+
IBUF_HEADER
+
IBUF_TREE_SEG_HEADER
,
&
n_used
,
&
mtr
);
&
n_used
,
&
mtr
);
ut_ad
(
n_used
>=
2
);
ut_ad
(
n_used
>=
2
);
ibuf
->
seg_size
=
n_used
;
ibuf
.
seg_size
=
n_used
;
{
{
buf_block_t
*
block
;
buf_block_t
*
block
;
...
@@ -490,24 +485,24 @@ ibuf_init_at_db_start(void)
...
@@ -490,24 +485,24 @@ ibuf_init_at_db_start(void)
ibuf_size_update
(
root
);
ibuf_size_update
(
root
);
mutex_exit
(
&
ibuf_mutex
);
mutex_exit
(
&
ibuf_mutex
);
ibuf
->
empty
=
page_is_empty
(
root
);
ibuf
.
empty
=
page_is_empty
(
root
);
mtr
.
commit
();
mtr
.
commit
();
ibuf
->
index
=
dict_mem_index_create
(
ibuf
.
index
=
dict_mem_index_create
(
dict_mem_table_create
(
"innodb_change_buffer"
,
dict_mem_table_create
(
"innodb_change_buffer"
,
fil_system
.
sys_space
,
1
,
0
,
0
,
0
),
fil_system
.
sys_space
,
1
,
0
,
0
,
0
),
"CLUST_IND"
,
"CLUST_IND"
,
DICT_CLUSTERED
|
DICT_IBUF
,
1
);
DICT_CLUSTERED
|
DICT_IBUF
,
1
);
ibuf
->
index
->
id
=
DICT_IBUF_ID_MIN
+
IBUF_SPACE_ID
;
ibuf
.
index
->
id
=
DICT_IBUF_ID_MIN
+
IBUF_SPACE_ID
;
ibuf
->
index
->
n_uniq
=
REC_MAX_N_FIELDS
;
ibuf
.
index
->
n_uniq
=
REC_MAX_N_FIELDS
;
rw_lock_create
(
index_tree_rw_lock_key
,
&
ibuf
->
index
->
lock
,
rw_lock_create
(
index_tree_rw_lock_key
,
&
ibuf
.
index
->
lock
,
SYNC_IBUF_INDEX_TREE
);
SYNC_IBUF_INDEX_TREE
);
#ifdef BTR_CUR_ADAPT
#ifdef BTR_CUR_ADAPT
ibuf
->
index
->
search_info
=
btr_search_info_create
(
ibuf
->
index
->
heap
);
ibuf
.
index
->
search_info
=
btr_search_info_create
(
ibuf
.
index
->
heap
);
#endif
/* BTR_CUR_ADAPT */
#endif
/* BTR_CUR_ADAPT */
ibuf
->
index
->
page
=
FSP_IBUF_TREE_ROOT_PAGE_NO
;
ibuf
.
index
->
page
=
FSP_IBUF_TREE_ROOT_PAGE_NO
;
ut_d
(
ibuf
->
index
->
cached
=
TRUE
);
ut_d
(
ibuf
.
index
->
cached
=
TRUE
);
return
(
error
)
;
return
DB_SUCCESS
;
}
}
/*********************************************************************//**
/*********************************************************************//**
...
@@ -521,7 +516,7 @@ ibuf_max_size_update(
...
@@ -521,7 +516,7 @@ ibuf_max_size_update(
ulint
new_size
=
((
buf_pool_get_curr_size
()
>>
srv_page_size_shift
)
ulint
new_size
=
((
buf_pool_get_curr_size
()
>>
srv_page_size_shift
)
*
new_val
)
/
100
;
*
new_val
)
/
100
;
mutex_enter
(
&
ibuf_mutex
);
mutex_enter
(
&
ibuf_mutex
);
ibuf
->
max_size
=
new_size
;
ibuf
.
max_size
=
new_size
;
mutex_exit
(
&
ibuf_mutex
);
mutex_exit
(
&
ibuf_mutex
);
}
}
...
@@ -1873,7 +1868,7 @@ static inline bool ibuf_data_enough_free_for_insert()
...
@@ -1873,7 +1868,7 @@ static inline bool ibuf_data_enough_free_for_insert()
inserts buffered for pages that we read to the buffer pool, without
inserts buffered for pages that we read to the buffer pool, without
any risk of running out of free space in the insert buffer. */
any risk of running out of free space in the insert buffer. */
return
(
ibuf
->
free_list_len
>=
(
ibuf
->
size
/
2
)
+
3
*
ibuf
->
height
);
return
(
ibuf
.
free_list_len
>=
(
ibuf
.
size
/
2
)
+
3
*
ibuf
.
height
);
}
}
/*********************************************************************//**
/*********************************************************************//**
...
@@ -1887,7 +1882,7 @@ ibuf_data_too_much_free(void)
...
@@ -1887,7 +1882,7 @@ ibuf_data_too_much_free(void)
{
{
ut_ad
(
mutex_own
(
&
ibuf_mutex
));
ut_ad
(
mutex_own
(
&
ibuf_mutex
));
return
(
ibuf
->
free_list_len
>=
3
+
(
ibuf
->
size
/
2
)
+
3
*
ibuf
->
height
);
return
(
ibuf
.
free_list_len
>=
3
+
(
ibuf
.
size
/
2
)
+
3
*
ibuf
.
height
);
}
}
/*********************************************************************//**
/*********************************************************************//**
...
@@ -1948,8 +1943,8 @@ ibuf_add_free_page(void)
...
@@ -1948,8 +1943,8 @@ ibuf_add_free_page(void)
mlog_write_ulint
(
page
+
FIL_PAGE_TYPE
,
FIL_PAGE_IBUF_FREE_LIST
,
mlog_write_ulint
(
page
+
FIL_PAGE_TYPE
,
FIL_PAGE_IBUF_FREE_LIST
,
MLOG_2BYTES
,
&
mtr
);
MLOG_2BYTES
,
&
mtr
);
ibuf
->
seg_size
++
;
ibuf
.
seg_size
++
;
ibuf
->
free_list_len
++
;
ibuf
.
free_list_len
++
;
/* Set the bit indicating that this page is now an ibuf tree page
/* Set the bit indicating that this page is now an ibuf tree page
(level 2 page) */
(level 2 page) */
...
@@ -2062,8 +2057,8 @@ ibuf_remove_free_page(void)
...
@@ -2062,8 +2057,8 @@ ibuf_remove_free_page(void)
mutex_exit
(
&
ibuf_pessimistic_insert_mutex
);
mutex_exit
(
&
ibuf_pessimistic_insert_mutex
);
ibuf
->
seg_size
--
;
ibuf
.
seg_size
--
;
ibuf
->
free_list_len
--
;
ibuf
.
free_list_len
--
;
/* Set the bit indicating that this page is no more an ibuf tree page
/* Set the bit indicating that this page is no more an ibuf tree page
(level 2 page) */
(level 2 page) */
...
@@ -2403,18 +2398,18 @@ ibuf_merge_pages(
...
@@ -2403,18 +2398,18 @@ ibuf_merge_pages(
position within the leaf */
position within the leaf */
bool
available
;
bool
available
;
available
=
btr_pcur_open_at_rnd_pos
(
ibuf
->
index
,
BTR_SEARCH_LEAF
,
available
=
btr_pcur_open_at_rnd_pos
(
ibuf
.
index
,
BTR_SEARCH_LEAF
,
&
pcur
,
&
mtr
);
&
pcur
,
&
mtr
);
/* No one should make this index unavailable when server is running */
/* No one should make this index unavailable when server is running */
ut_a
(
available
);
ut_a
(
available
);
ut_ad
(
page_validate
(
btr_pcur_get_page
(
&
pcur
),
ibuf
->
index
));
ut_ad
(
page_validate
(
btr_pcur_get_page
(
&
pcur
),
ibuf
.
index
));
if
(
page_is_empty
(
btr_pcur_get_page
(
&
pcur
)))
{
if
(
page_is_empty
(
btr_pcur_get_page
(
&
pcur
)))
{
/* If a B-tree page is empty, it must be the root page
/* If a B-tree page is empty, it must be the root page
and the whole B-tree must be empty. InnoDB does not
and the whole B-tree must be empty. InnoDB does not
allow empty B-tree pages other than the root. */
allow empty B-tree pages other than the root. */
ut_ad
(
ibuf
->
empty
);
ut_ad
(
ibuf
.
empty
);
ut_ad
(
page_get_space_id
(
btr_pcur_get_page
(
&
pcur
))
ut_ad
(
page_get_space_id
(
btr_pcur_get_page
(
&
pcur
))
==
IBUF_SPACE_ID
);
==
IBUF_SPACE_ID
);
ut_ad
(
page_get_page_no
(
btr_pcur_get_page
(
&
pcur
))
ut_ad
(
page_get_page_no
(
btr_pcur_get_page
(
&
pcur
))
...
@@ -2465,12 +2460,12 @@ ibuf_merge_space(
...
@@ -2465,12 +2460,12 @@ ibuf_merge_space(
/* Position the cursor on the first matching record. */
/* Position the cursor on the first matching record. */
btr_pcur_open
(
btr_pcur_open
(
ibuf
->
index
,
tuple
,
PAGE_CUR_GE
,
BTR_SEARCH_LEAF
,
&
pcur
,
ibuf
.
index
,
tuple
,
PAGE_CUR_GE
,
BTR_SEARCH_LEAF
,
&
pcur
,
&
mtr
);
&
mtr
);
mem_heap_free
(
heap
);
mem_heap_free
(
heap
);
ut_ad
(
page_validate
(
btr_pcur_get_page
(
&
pcur
),
ibuf
->
index
));
ut_ad
(
page_validate
(
btr_pcur_get_page
(
&
pcur
),
ibuf
.
index
));
ulint
sum_sizes
=
0
;
ulint
sum_sizes
=
0
;
ulint
pages
[
IBUF_MAX_N_PAGES_MERGED
];
ulint
pages
[
IBUF_MAX_N_PAGES_MERGED
];
...
@@ -2480,7 +2475,7 @@ ibuf_merge_space(
...
@@ -2480,7 +2475,7 @@ ibuf_merge_space(
/* If a B-tree page is empty, it must be the root page
/* If a B-tree page is empty, it must be the root page
and the whole B-tree must be empty. InnoDB does not
and the whole B-tree must be empty. InnoDB does not
allow empty B-tree pages other than the root. */
allow empty B-tree pages other than the root. */
ut_ad
(
ibuf
->
empty
);
ut_ad
(
ibuf
.
empty
);
ut_ad
(
page_get_space_id
(
btr_pcur_get_page
(
&
pcur
))
ut_ad
(
page_get_space_id
(
btr_pcur_get_page
(
&
pcur
))
==
IBUF_SPACE_ID
);
==
IBUF_SPACE_ID
);
ut_ad
(
page_get_page_no
(
btr_pcur_get_page
(
&
pcur
))
ut_ad
(
page_get_page_no
(
btr_pcur_get_page
(
&
pcur
))
...
@@ -2530,12 +2525,12 @@ ibuf_merge(
...
@@ -2530,12 +2525,12 @@ ibuf_merge(
{
{
*
n_pages
=
0
;
*
n_pages
=
0
;
/* We perform a dirty read of ibuf
->
empty, without latching
/* We perform a dirty read of ibuf
.
empty, without latching
the insert buffer root page. We trust this dirty read except
the insert buffer root page. We trust this dirty read except
when a slow shutdown is being executed. During a slow
when a slow shutdown is being executed. During a slow
shutdown, the insert buffer merge must be completed. */
shutdown, the insert buffer merge must be completed. */
if
(
ibuf
->
empty
&&
!
srv_shutdown_state
)
{
if
(
ibuf
.
empty
&&
!
srv_shutdown_state
)
{
return
(
0
);
return
(
0
);
#if defined UNIV_DEBUG || defined UNIV_IBUF_DEBUG
#if defined UNIV_DEBUG || defined UNIV_IBUF_DEBUG
}
else
if
(
ibuf_debug
)
{
}
else
if
(
ibuf_debug
)
{
...
@@ -2592,13 +2587,13 @@ ibuf_merge_in_background(
...
@@ -2592,13 +2587,13 @@ ibuf_merge_in_background(
mutex_enter
(
&
ibuf_mutex
);
mutex_enter
(
&
ibuf_mutex
);
/* If the ibuf
->
size is more than half the max_size
/* If the ibuf
.
size is more than half the max_size
then we make more agreesive contraction.
then we make more agreesive contraction.
+1 is to avoid division by zero. */
+1 is to avoid division by zero. */
if
(
ibuf
->
size
>
ibuf
->
max_size
/
2
)
{
if
(
ibuf
.
size
>
ibuf
.
max_size
/
2
)
{
ulint
diff
=
ibuf
->
size
-
ibuf
->
max_size
/
2
;
ulint
diff
=
ibuf
.
size
-
ibuf
.
max_size
/
2
;
n_pages
+=
PCT_IO
((
diff
*
100
)
n_pages
+=
PCT_IO
((
diff
*
100
)
/
(
ibuf
->
max_size
+
1
));
/
(
ibuf
.
max_size
+
1
));
}
}
mutex_exit
(
&
ibuf_mutex
);
mutex_exit
(
&
ibuf_mutex
);
...
@@ -2640,15 +2635,15 @@ ibuf_contract_after_insert(
...
@@ -2640,15 +2635,15 @@ ibuf_contract_after_insert(
ulint
size
;
ulint
size
;
ulint
max_size
;
ulint
max_size
;
/* Perform dirty reads of ibuf
->size and ibuf->
max_size, to
/* Perform dirty reads of ibuf
.size and ibuf.
max_size, to
reduce ibuf_mutex contention. ibuf
->
max_size remains constant
reduce ibuf_mutex contention. ibuf
.
max_size remains constant
after ibuf_init_at_db_start(), but ibuf
->
size should be
after ibuf_init_at_db_start(), but ibuf
.
size should be
protected by ibuf_mutex. Given that ibuf
->
size fits in a
protected by ibuf_mutex. Given that ibuf
.
size fits in a
machine word, this should be OK; at worst we are doing some
machine word, this should be OK; at worst we are doing some
excessive ibuf_contract() or occasionally skipping a
excessive ibuf_contract() or occasionally skipping a
ibuf_contract(). */
ibuf_contract(). */
size
=
ibuf
->
size
;
size
=
ibuf
.
size
;
max_size
=
ibuf
->
max_size
;
max_size
=
ibuf
.
max_size
;
if
(
size
<
max_size
+
IBUF_CONTRACT_ON_INSERT_NON_SYNC
)
{
if
(
size
<
max_size
+
IBUF_CONTRACT_ON_INSERT_NON_SYNC
)
{
return
;
return
;
...
@@ -2889,7 +2884,7 @@ ibuf_get_volume_buffered(
...
@@ -2889,7 +2884,7 @@ ibuf_get_volume_buffered(
rec
=
btr_pcur_get_rec
(
pcur
);
rec
=
btr_pcur_get_rec
(
pcur
);
page
=
page_align
(
rec
);
page
=
page_align
(
rec
);
ut_ad
(
page_validate
(
page
,
ibuf
->
index
));
ut_ad
(
page_validate
(
page
,
ibuf
.
index
));
if
(
page_rec_is_supremum
(
rec
))
{
if
(
page_rec_is_supremum
(
rec
))
{
rec
=
page_rec_get_prev_const
(
rec
);
rec
=
page_rec_get_prev_const
(
rec
);
...
@@ -2929,7 +2924,7 @@ ibuf_get_volume_buffered(
...
@@ -2929,7 +2924,7 @@ ibuf_get_volume_buffered(
buf_block_dbg_add_level
(
block
,
SYNC_IBUF_TREE_NODE
);
buf_block_dbg_add_level
(
block
,
SYNC_IBUF_TREE_NODE
);
prev_page
=
buf_block_get_frame
(
block
);
prev_page
=
buf_block_get_frame
(
block
);
ut_ad
(
page_validate
(
prev_page
,
ibuf
->
index
));
ut_ad
(
page_validate
(
prev_page
,
ibuf
.
index
));
}
}
#ifdef UNIV_BTR_DEBUG
#ifdef UNIV_BTR_DEBUG
...
@@ -3001,7 +2996,7 @@ ibuf_get_volume_buffered(
...
@@ -3001,7 +2996,7 @@ ibuf_get_volume_buffered(
buf_block_dbg_add_level
(
block
,
SYNC_IBUF_TREE_NODE
);
buf_block_dbg_add_level
(
block
,
SYNC_IBUF_TREE_NODE
);
next_page
=
buf_block_get_frame
(
block
);
next_page
=
buf_block_get_frame
(
block
);
ut_ad
(
page_validate
(
next_page
,
ibuf
->
index
));
ut_ad
(
page_validate
(
next_page
,
ibuf
.
index
));
}
}
#ifdef UNIV_BTR_DEBUG
#ifdef UNIV_BTR_DEBUG
...
@@ -3047,14 +3042,14 @@ ibuf_update_max_tablespace_id(void)
...
@@ -3047,14 +3042,14 @@ ibuf_update_max_tablespace_id(void)
btr_pcur_t
pcur
;
btr_pcur_t
pcur
;
mtr_t
mtr
;
mtr_t
mtr
;
ut_a
(
!
dict_table_is_comp
(
ibuf
->
index
->
table
));
ut_a
(
!
dict_table_is_comp
(
ibuf
.
index
->
table
));
ibuf_mtr_start
(
&
mtr
);
ibuf_mtr_start
(
&
mtr
);
btr_pcur_open_at_index_side
(
btr_pcur_open_at_index_side
(
false
,
ibuf
->
index
,
BTR_SEARCH_LEAF
,
&
pcur
,
true
,
0
,
&
mtr
);
false
,
ibuf
.
index
,
BTR_SEARCH_LEAF
,
&
pcur
,
true
,
0
,
&
mtr
);
ut_ad
(
page_validate
(
btr_pcur_get_page
(
&
pcur
),
ibuf
->
index
));
ut_ad
(
page_validate
(
btr_pcur_get_page
(
&
pcur
),
ibuf
.
index
));
btr_pcur_move_to_prev
(
&
pcur
,
&
mtr
);
btr_pcur_move_to_prev
(
&
pcur
,
&
mtr
);
...
@@ -3185,7 +3180,7 @@ ibuf_get_entry_counter_func(
...
@@ -3185,7 +3180,7 @@ ibuf_get_entry_counter_func(
{
{
ut_ad
(
ibuf_inside
(
mtr
));
ut_ad
(
ibuf_inside
(
mtr
));
ut_ad
(
mtr_memo_contains_page
(
mtr
,
rec
,
MTR_MEMO_PAGE_X_FIX
));
ut_ad
(
mtr_memo_contains_page
(
mtr
,
rec
,
MTR_MEMO_PAGE_X_FIX
));
ut_ad
(
page_validate
(
page_align
(
rec
),
ibuf
->
index
));
ut_ad
(
page_validate
(
page_align
(
rec
),
ibuf
.
index
));
if
(
page_rec_is_supremum
(
rec
))
{
if
(
page_rec_is_supremum
(
rec
))
{
/* This is just for safety. The record should be a
/* This is just for safety. The record should be a
...
@@ -3285,16 +3280,16 @@ ibuf_insert_low(
...
@@ -3285,16 +3280,16 @@ ibuf_insert_low(
do_merge
=
FALSE
;
do_merge
=
FALSE
;
/* Perform dirty reads of ibuf
->size and ibuf->
max_size, to
/* Perform dirty reads of ibuf
.size and ibuf.
max_size, to
reduce ibuf_mutex contention. Given that ibuf
->
max_size and
reduce ibuf_mutex contention. Given that ibuf
.
max_size and
ibuf
->
size fit in a machine word, this should be OK; at worst
ibuf
.
size fit in a machine word, this should be OK; at worst
we are doing some excessive ibuf_contract() or occasionally
we are doing some excessive ibuf_contract() or occasionally
skipping an ibuf_contract(). */
skipping an ibuf_contract(). */
if
(
ibuf
->
max_size
==
0
)
{
if
(
ibuf
.
max_size
==
0
)
{
return
(
DB_STRONG_FAIL
);
return
(
DB_STRONG_FAIL
);
}
}
if
(
ibuf
->
size
>=
ibuf
->
max_size
+
IBUF_CONTRACT_DO_NOT_INSERT
)
{
if
(
ibuf
.
size
>=
ibuf
.
max_size
+
IBUF_CONTRACT_DO_NOT_INSERT
)
{
/* Insert buffer is now too big, contract it but do not try
/* Insert buffer is now too big, contract it but do not try
to insert */
to insert */
...
@@ -3348,8 +3343,8 @@ ibuf_insert_low(
...
@@ -3348,8 +3343,8 @@ ibuf_insert_low(
ibuf_mtr_start
(
&
mtr
);
ibuf_mtr_start
(
&
mtr
);
btr_pcur_open
(
ibuf
->
index
,
ibuf_entry
,
PAGE_CUR_LE
,
mode
,
&
pcur
,
&
mtr
);
btr_pcur_open
(
ibuf
.
index
,
ibuf_entry
,
PAGE_CUR_LE
,
mode
,
&
pcur
,
&
mtr
);
ut_ad
(
page_validate
(
btr_pcur_get_page
(
&
pcur
),
ibuf
->
index
));
ut_ad
(
page_validate
(
btr_pcur_get_page
(
&
pcur
),
ibuf
.
index
));
/* Find out the volume of already buffered inserts for the same index
/* Find out the volume of already buffered inserts for the same index
page */
page */
...
@@ -3488,7 +3483,7 @@ ibuf_insert_low(
...
@@ -3488,7 +3483,7 @@ ibuf_insert_low(
block
=
btr_cur_get_block
(
cursor
);
block
=
btr_cur_get_block
(
cursor
);
ut_ad
(
block
->
page
.
id
.
space
()
==
IBUF_SPACE_ID
);
ut_ad
(
block
->
page
.
id
.
space
()
==
IBUF_SPACE_ID
);
/* If this is the root page, update ibuf
->
empty. */
/* If this is the root page, update ibuf
.
empty. */
if
(
block
->
page
.
id
.
page_no
()
==
FSP_IBUF_TREE_ROOT_PAGE_NO
)
{
if
(
block
->
page
.
id
.
page_no
()
==
FSP_IBUF_TREE_ROOT_PAGE_NO
)
{
const
page_t
*
root
=
buf_block_get_frame
(
block
);
const
page_t
*
root
=
buf_block_get_frame
(
block
);
...
@@ -3496,7 +3491,7 @@ ibuf_insert_low(
...
@@ -3496,7 +3491,7 @@ ibuf_insert_low(
ut_ad
(
page_get_page_no
(
root
)
ut_ad
(
page_get_page_no
(
root
)
==
FSP_IBUF_TREE_ROOT_PAGE_NO
);
==
FSP_IBUF_TREE_ROOT_PAGE_NO
);
ibuf
->
empty
=
page_is_empty
(
root
);
ibuf
.
empty
=
page_is_empty
(
root
);
}
}
}
else
{
}
else
{
ut_ad
(
BTR_LATCH_MODE_WITHOUT_INTENTION
(
mode
)
ut_ad
(
BTR_LATCH_MODE_WITHOUT_INTENTION
(
mode
)
...
@@ -3526,7 +3521,7 @@ ibuf_insert_low(
...
@@ -3526,7 +3521,7 @@ ibuf_insert_low(
mutex_exit
(
&
ibuf_pessimistic_insert_mutex
);
mutex_exit
(
&
ibuf_pessimistic_insert_mutex
);
ibuf_size_update
(
root
);
ibuf_size_update
(
root
);
mutex_exit
(
&
ibuf_mutex
);
mutex_exit
(
&
ibuf_mutex
);
ibuf
->
empty
=
page_is_empty
(
root
);
ibuf
.
empty
=
page_is_empty
(
root
);
block
=
btr_cur_get_block
(
cursor
);
block
=
btr_cur_get_block
(
cursor
);
ut_ad
(
block
->
page
.
id
.
space
()
==
IBUF_SPACE_ID
);
ut_ad
(
block
->
page
.
id
.
space
()
==
IBUF_SPACE_ID
);
...
@@ -4220,10 +4215,10 @@ ibuf_delete_rec(
...
@@ -4220,10 +4215,10 @@ ibuf_delete_rec(
ut_ad
(
page_get_page_no
(
root
)
ut_ad
(
page_get_page_no
(
root
)
==
FSP_IBUF_TREE_ROOT_PAGE_NO
);
==
FSP_IBUF_TREE_ROOT_PAGE_NO
);
/* ibuf
->
empty is protected by the root page latch.
/* ibuf
.
empty is protected by the root page latch.
Before the deletion, it had to be FALSE. */
Before the deletion, it had to be FALSE. */
ut_ad
(
!
ibuf
->
empty
);
ut_ad
(
!
ibuf
.
empty
);
ibuf
->
empty
=
true
;
ibuf
.
empty
=
true
;
}
}
return
(
FALSE
);
return
(
FALSE
);
...
@@ -4264,7 +4259,7 @@ ibuf_delete_rec(
...
@@ -4264,7 +4259,7 @@ ibuf_delete_rec(
ibuf_size_update
(
root
);
ibuf_size_update
(
root
);
mutex_exit
(
&
ibuf_mutex
);
mutex_exit
(
&
ibuf_mutex
);
ibuf
->
empty
=
page_is_empty
(
root
);
ibuf
.
empty
=
page_is_empty
(
root
);
ibuf_btr_pcur_commit_specify_mtr
(
pcur
,
mtr
);
ibuf_btr_pcur_commit_specify_mtr
(
pcur
,
mtr
);
func_exit:
func_exit:
...
@@ -4410,7 +4405,7 @@ ibuf_merge_or_delete_for_page(
...
@@ -4410,7 +4405,7 @@ ibuf_merge_or_delete_for_page(
/* Position pcur in the insert buffer at the first entry for this
/* Position pcur in the insert buffer at the first entry for this
index page */
index page */
btr_pcur_open_on_user_rec
(
btr_pcur_open_on_user_rec
(
ibuf
->
index
,
search_tuple
,
PAGE_CUR_GE
,
BTR_MODIFY_LEAF
,
ibuf
.
index
,
search_tuple
,
PAGE_CUR_GE
,
BTR_MODIFY_LEAF
,
&
pcur
,
&
mtr
);
&
pcur
,
&
mtr
);
if
(
block
!=
NULL
)
{
if
(
block
!=
NULL
)
{
...
@@ -4478,7 +4473,7 @@ ibuf_merge_or_delete_for_page(
...
@@ -4478,7 +4473,7 @@ ibuf_merge_or_delete_for_page(
page_update_max_trx_id
(
block
,
page_zip
,
max_trx_id
,
page_update_max_trx_id
(
block
,
page_zip
,
max_trx_id
,
&
mtr
);
&
mtr
);
ut_ad
(
page_validate
(
page_align
(
rec
),
ibuf
->
index
));
ut_ad
(
page_validate
(
page_align
(
rec
),
ibuf
.
index
));
entry
=
ibuf_build_entry_from_ibuf_rec
(
entry
=
ibuf_build_entry_from_ibuf_rec
(
&
mtr
,
rec
,
heap
,
&
dummy_index
);
&
mtr
,
rec
,
heap
,
&
dummy_index
);
...
@@ -4626,9 +4621,9 @@ ibuf_merge_or_delete_for_page(
...
@@ -4626,9 +4621,9 @@ ibuf_merge_or_delete_for_page(
btr_pcur_close
(
&
pcur
);
btr_pcur_close
(
&
pcur
);
mem_heap_free
(
heap
);
mem_heap_free
(
heap
);
ibuf
->
n_merges
++
;
ibuf
.
n_merges
++
;
ibuf_add_ops
(
ibuf
->
n_merged_ops
,
mops
);
ibuf_add_ops
(
ibuf
.
n_merged_ops
,
mops
);
ibuf_add_ops
(
ibuf
->
n_discarded_ops
,
dops
);
ibuf_add_ops
(
ibuf
.
n_discarded_ops
,
dops
);
}
}
/*********************************************************************//**
/*********************************************************************//**
...
@@ -4665,7 +4660,7 @@ ibuf_delete_for_discarded_space(
...
@@ -4665,7 +4660,7 @@ ibuf_delete_for_discarded_space(
/* Position pcur in the insert buffer at the first entry for the
/* Position pcur in the insert buffer at the first entry for the
space */
space */
btr_pcur_open_on_user_rec
(
btr_pcur_open_on_user_rec
(
ibuf
->
index
,
search_tuple
,
PAGE_CUR_GE
,
BTR_MODIFY_LEAF
,
ibuf
.
index
,
search_tuple
,
PAGE_CUR_GE
,
BTR_MODIFY_LEAF
,
&
pcur
,
&
mtr
);
&
pcur
,
&
mtr
);
if
(
!
btr_pcur_is_on_user_rec
(
&
pcur
))
{
if
(
!
btr_pcur_is_on_user_rec
(
&
pcur
))
{
...
@@ -4710,7 +4705,7 @@ ibuf_delete_for_discarded_space(
...
@@ -4710,7 +4705,7 @@ ibuf_delete_for_discarded_space(
ibuf_mtr_commit
(
&
mtr
);
ibuf_mtr_commit
(
&
mtr
);
btr_pcur_close
(
&
pcur
);
btr_pcur_close
(
&
pcur
);
ibuf_add_ops
(
ibuf
->
n_discarded_ops
,
dops
);
ibuf_add_ops
(
ibuf
.
n_discarded_ops
,
dops
);
mem_heap_free
(
heap
);
mem_heap_free
(
heap
);
}
}
...
@@ -4733,7 +4728,7 @@ ibuf_is_empty(void)
...
@@ -4733,7 +4728,7 @@ ibuf_is_empty(void)
mutex_exit
(
&
ibuf_mutex
);
mutex_exit
(
&
ibuf_mutex
);
is_empty
=
page_is_empty
(
root
);
is_empty
=
page_is_empty
(
root
);
ut_a
(
is_empty
==
ibuf
->
empty
);
ut_a
(
is_empty
==
ibuf
.
empty
);
ibuf_mtr_commit
(
&
mtr
);
ibuf_mtr_commit
(
&
mtr
);
return
(
is_empty
);
return
(
is_empty
);
...
@@ -4751,16 +4746,16 @@ ibuf_print(
...
@@ -4751,16 +4746,16 @@ ibuf_print(
fprintf
(
file
,
fprintf
(
file
,
"Ibuf: size "
ULINTPF
", free list len "
ULINTPF
","
"Ibuf: size "
ULINTPF
", free list len "
ULINTPF
","
" seg size "
ULINTPF
", "
ULINTPF
" merges
\n
"
,
" seg size "
ULINTPF
", "
ULINTPF
" merges
\n
"
,
ibuf
->
size
,
ibuf
.
size
,
ibuf
->
free_list_len
,
ibuf
.
free_list_len
,
ibuf
->
seg_size
,
ibuf
.
seg_size
,
ulint
{
ibuf
->
n_merges
});
ulint
{
ibuf
.
n_merges
});
fputs
(
"merged operations:
\n
"
,
file
);
fputs
(
"merged operations:
\n
"
,
file
);
ibuf_print_ops
(
ibuf
->
n_merged_ops
,
file
);
ibuf_print_ops
(
ibuf
.
n_merged_ops
,
file
);
fputs
(
"discarded operations:
\n
"
,
file
);
fputs
(
"discarded operations:
\n
"
,
file
);
ibuf_print_ops
(
ibuf
->
n_discarded_ops
,
file
);
ibuf_print_ops
(
ibuf
.
n_discarded_ops
,
file
);
mutex_exit
(
&
ibuf_mutex
);
mutex_exit
(
&
ibuf_mutex
);
}
}
...
...
storage/innobase/include/ibuf0ibuf.h
View file @
61e26289
...
@@ -62,7 +62,7 @@ enum ibuf_use_t {
...
@@ -62,7 +62,7 @@ enum ibuf_use_t {
extern
ulong
innodb_change_buffering
;
extern
ulong
innodb_change_buffering
;
/** The insert buffer control structure */
/** The insert buffer control structure */
extern
ibuf_t
*
ibuf
;
extern
ibuf_t
ibuf
;
/* The purpose of the insert buffer is to reduce random disk access.
/* The purpose of the insert buffer is to reduce random disk access.
When we wish to insert a record into a non-unique secondary index and
When we wish to insert a record into a non-unique secondary index and
...
...
storage/innobase/include/ibuf0ibuf.ic
View file @
61e26289
...
@@ -126,7 +126,7 @@ ibuf_should_try(
...
@@ -126,7 +126,7 @@ ibuf_should_try(
decide */
decide */
{
{
return(innodb_change_buffering
return(innodb_change_buffering
&& ibuf
->
max_size != 0
&& ibuf
.
max_size != 0
&& !dict_index_is_clust(index)
&& !dict_index_is_clust(index)
&& !dict_index_is_spatial(index)
&& !dict_index_is_spatial(index)
&& index->table->quiesce == QUIESCE_NONE
&& index->table->quiesce == QUIESCE_NONE
...
...
storage/innobase/srv/srv0mon.cc
View file @
61e26289
...
@@ -1951,35 +1951,35 @@ srv_mon_process_existing_counter(
...
@@ -1951,35 +1951,35 @@ srv_mon_process_existing_counter(
break
;
break
;
case
MONITOR_OVLD_IBUF_MERGE_INSERT
:
case
MONITOR_OVLD_IBUF_MERGE_INSERT
:
value
=
ibuf
->
n_merged_ops
[
IBUF_OP_INSERT
];
value
=
ibuf
.
n_merged_ops
[
IBUF_OP_INSERT
];
break
;
break
;
case
MONITOR_OVLD_IBUF_MERGE_DELETE
:
case
MONITOR_OVLD_IBUF_MERGE_DELETE
:
value
=
ibuf
->
n_merged_ops
[
IBUF_OP_DELETE_MARK
];
value
=
ibuf
.
n_merged_ops
[
IBUF_OP_DELETE_MARK
];
break
;
break
;
case
MONITOR_OVLD_IBUF_MERGE_PURGE
:
case
MONITOR_OVLD_IBUF_MERGE_PURGE
:
value
=
ibuf
->
n_merged_ops
[
IBUF_OP_DELETE
];
value
=
ibuf
.
n_merged_ops
[
IBUF_OP_DELETE
];
break
;
break
;
case
MONITOR_OVLD_IBUF_MERGE_DISCARD_INSERT
:
case
MONITOR_OVLD_IBUF_MERGE_DISCARD_INSERT
:
value
=
ibuf
->
n_discarded_ops
[
IBUF_OP_INSERT
];
value
=
ibuf
.
n_discarded_ops
[
IBUF_OP_INSERT
];
break
;
break
;
case
MONITOR_OVLD_IBUF_MERGE_DISCARD_DELETE
:
case
MONITOR_OVLD_IBUF_MERGE_DISCARD_DELETE
:
value
=
ibuf
->
n_discarded_ops
[
IBUF_OP_DELETE_MARK
];
value
=
ibuf
.
n_discarded_ops
[
IBUF_OP_DELETE_MARK
];
break
;
break
;
case
MONITOR_OVLD_IBUF_MERGE_DISCARD_PURGE
:
case
MONITOR_OVLD_IBUF_MERGE_DISCARD_PURGE
:
value
=
ibuf
->
n_discarded_ops
[
IBUF_OP_DELETE
];
value
=
ibuf
.
n_discarded_ops
[
IBUF_OP_DELETE
];
break
;
break
;
case
MONITOR_OVLD_IBUF_MERGES
:
case
MONITOR_OVLD_IBUF_MERGES
:
value
=
ibuf
->
n_merges
;
value
=
ibuf
.
n_merges
;
break
;
break
;
case
MONITOR_OVLD_IBUF_SIZE
:
case
MONITOR_OVLD_IBUF_SIZE
:
value
=
ibuf
->
size
;
value
=
ibuf
.
size
;
break
;
break
;
case
MONITOR_OVLD_SERVER_ACTIVITY
:
case
MONITOR_OVLD_SERVER_ACTIVITY
:
...
...
storage/innobase/srv/srv0start.cc
View file @
61e26289
...
@@ -2483,7 +2483,7 @@ void innodb_shutdown()
...
@@ -2483,7 +2483,7 @@ void innodb_shutdown()
#ifdef BTR_CUR_HASH_ADAPT
#ifdef BTR_CUR_HASH_ADAPT
ut_ad
(
btr_search_sys
||
!
srv_was_started
);
ut_ad
(
btr_search_sys
||
!
srv_was_started
);
#endif
/* BTR_CUR_HASH_ADAPT */
#endif
/* BTR_CUR_HASH_ADAPT */
ut_ad
(
ibuf
||
!
srv_was_started
);
ut_ad
(
ibuf
.
index
||
!
srv_was_started
);
if
(
dict_stats_event
)
{
if
(
dict_stats_event
)
{
dict_stats_thread_deinit
();
dict_stats_thread_deinit
();
...
@@ -2507,9 +2507,7 @@ void innodb_shutdown()
...
@@ -2507,9 +2507,7 @@ void innodb_shutdown()
btr_search_disable
(
true
);
btr_search_disable
(
true
);
}
}
#endif
/* BTR_CUR_HASH_ADAPT */
#endif
/* BTR_CUR_HASH_ADAPT */
if
(
ibuf
)
{
ibuf_close
();
ibuf_close
();
}
log_sys
.
close
();
log_sys
.
close
();
purge_sys
.
close
();
purge_sys
.
close
();
trx_sys
.
close
();
trx_sys
.
close
();
...
...
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