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
993b7b95
Commit
993b7b95
authored
Nov 22, 2012
by
Sergei Golubchik
Browse files
Options
Browse Files
Download
Plain Diff
XtraDB from Percona-Server-5.5.28-rel29.1
parents
6bae35d8
b1b939f4
Changes
30
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
30 changed files
with
2446 additions
and
266 deletions
+2446
-266
mysql-test/include/have_innodb.combinations
mysql-test/include/have_innodb.combinations
+9
-0
mysql-test/suite/innodb/t/innodb_information_schema_buffer.test
...test/suite/innodb/t/innodb_information_schema_buffer.test
+0
-5
mysql-test/t/mysqlshow.test
mysql-test/t/mysqlshow.test
+1
-1
storage/xtradb/btr/btr0btr.c
storage/xtradb/btr/btr0btr.c
+15
-6
storage/xtradb/btr/btr0cur.c
storage/xtradb/btr/btr0cur.c
+22
-17
storage/xtradb/btr/btr0pcur.c
storage/xtradb/btr/btr0pcur.c
+31
-36
storage/xtradb/buf/buf0buf.c
storage/xtradb/buf/buf0buf.c
+8
-14
storage/xtradb/buf/buf0lru.c
storage/xtradb/buf/buf0lru.c
+1
-1
storage/xtradb/buf/buf0rea.c
storage/xtradb/buf/buf0rea.c
+2
-2
storage/xtradb/handler/ha_innodb.cc
storage/xtradb/handler/ha_innodb.cc
+233
-108
storage/xtradb/handler/i_s.cc
storage/xtradb/handler/i_s.cc
+1834
-2
storage/xtradb/handler/i_s.h
storage/xtradb/handler/i_s.h
+3
-0
storage/xtradb/ibuf/ibuf0ibuf.c
storage/xtradb/ibuf/ibuf0ibuf.c
+12
-5
storage/xtradb/include/buf0buf.h
storage/xtradb/include/buf0buf.h
+32
-2
storage/xtradb/include/buf0buf.ic
storage/xtradb/include/buf0buf.ic
+19
-0
storage/xtradb/include/fil0fil.h
storage/xtradb/include/fil0fil.h
+2
-0
storage/xtradb/include/ha_prototypes.h
storage/xtradb/include/ha_prototypes.h
+1
-1
storage/xtradb/include/log0log.h
storage/xtradb/include/log0log.h
+3
-0
storage/xtradb/include/os0proc.h
storage/xtradb/include/os0proc.h
+2
-1
storage/xtradb/include/srv0srv.h
storage/xtradb/include/srv0srv.h
+1
-0
storage/xtradb/include/trx0sys.h
storage/xtradb/include/trx0sys.h
+15
-1
storage/xtradb/include/univ.i
storage/xtradb/include/univ.i
+1
-1
storage/xtradb/os/os0proc.c
storage/xtradb/os/os0proc.c
+55
-3
storage/xtradb/page/page0page.c
storage/xtradb/page/page0page.c
+11
-10
storage/xtradb/row/row0ins.c
storage/xtradb/row/row0ins.c
+8
-1
storage/xtradb/row/row0merge.c
storage/xtradb/row/row0merge.c
+15
-1
storage/xtradb/srv/srv0srv.c
storage/xtradb/srv/srv0srv.c
+2
-0
storage/xtradb/srv/srv0start.c
storage/xtradb/srv/srv0start.c
+2
-1
storage/xtradb/trx/trx0sys.c
storage/xtradb/trx/trx0sys.c
+87
-45
storage/xtradb/trx/trx0trx.c
storage/xtradb/trx/trx0trx.c
+19
-2
No files found.
mysql-test/include/have_innodb.combinations
View file @
993b7b95
...
@@ -4,6 +4,9 @@ plugin-load=$HA_INNODB_SO
...
@@ -4,6 +4,9 @@ plugin-load=$HA_INNODB_SO
innodb
innodb
innodb-cmpmem
innodb-cmpmem
innodb-trx
innodb-trx
innodb-buffer-pool-stats
innodb-buffer-page
innodb-buffer-page-lru
[xtradb_plugin]
[xtradb_plugin]
ignore-builtin-innodb
ignore-builtin-innodb
...
@@ -11,8 +14,14 @@ plugin-load=$HA_XTRADB_SO
...
@@ -11,8 +14,14 @@ plugin-load=$HA_XTRADB_SO
innodb
innodb
innodb-cmpmem
innodb-cmpmem
innodb-trx
innodb-trx
innodb-buffer-pool-stats
innodb-buffer-page
innodb-buffer-page-lru
[xtradb]
[xtradb]
innodb
innodb
innodb-cmpmem
innodb-cmpmem
innodb-trx
innodb-trx
innodb-buffer-pool-stats
innodb-buffer-page
innodb-buffer-page-lru
mysql-test/suite/innodb/t/innodb_information_schema_buffer.test
View file @
993b7b95
...
@@ -3,11 +3,6 @@
...
@@ -3,11 +3,6 @@
--
source
include
/
have_innodb
.
inc
--
source
include
/
have_innodb
.
inc
if
(
`select plugin_auth_version <= "1.1.8-29.0" from information_schema.plugins where plugin_name='innodb'`
)
{
--
skip
Not
fixed
in
XtraDB
1.1
.
8
-
29.0
or
earlier
}
--
disable_result_log
--
disable_result_log
SELECT
*
FROM
INFORMATION_SCHEMA
.
INNODB_BUFFER_POOL_STATS
;
SELECT
*
FROM
INFORMATION_SCHEMA
.
INNODB_BUFFER_POOL_STATS
;
...
...
mysql-test/t/mysqlshow.test
View file @
993b7b95
...
@@ -29,7 +29,7 @@ select "---- -v -v -t ------" as "";
...
@@ -29,7 +29,7 @@ select "---- -v -v -t ------" as "";
DROP
TABLE
t1
,
t2
;
DROP
TABLE
t1
,
t2
;
if
(
`select count(*) from information_schema.plugins where plugin_name='innodb' and plugin_auth_version > "1.1.8-29.
0
"`
)
if
(
`select count(*) from information_schema.plugins where plugin_name='innodb' and plugin_auth_version > "1.1.8-29.
1
"`
)
{
{
# because of lp:1066512 this test shows xtradb I_S plugins, even when
# because of lp:1066512 this test shows xtradb I_S plugins, even when
# xtradb is supposed to be disabled
# xtradb is supposed to be disabled
...
...
storage/xtradb/btr/btr0btr.c
View file @
993b7b95
...
@@ -1891,6 +1891,7 @@ btr_root_raise_and_insert(
...
@@ -1891,6 +1891,7 @@ btr_root_raise_and_insert(
root
=
btr_cur_get_page
(
cursor
);
root
=
btr_cur_get_page
(
cursor
);
root_block
=
btr_cur_get_block
(
cursor
);
root_block
=
btr_cur_get_block
(
cursor
);
root_page_zip
=
buf_block_get_page_zip
(
root_block
);
root_page_zip
=
buf_block_get_page_zip
(
root_block
);
ut_ad
(
page_get_n_recs
(
root
)
>
0
);
#ifdef UNIV_ZIP_DEBUG
#ifdef UNIV_ZIP_DEBUG
ut_a
(
!
root_page_zip
||
page_zip_validate
(
root_page_zip
,
root
));
ut_a
(
!
root_page_zip
||
page_zip_validate
(
root_page_zip
,
root
));
#endif
/* UNIV_ZIP_DEBUG */
#endif
/* UNIV_ZIP_DEBUG */
...
@@ -2371,12 +2372,20 @@ btr_insert_on_non_leaf_level_func(
...
@@ -2371,12 +2372,20 @@ btr_insert_on_non_leaf_level_func(
BTR_CONT_MODIFY_TREE
,
BTR_CONT_MODIFY_TREE
,
&
cursor
,
0
,
file
,
line
,
mtr
);
&
cursor
,
0
,
file
,
line
,
mtr
);
err
=
btr_cur_pessimistic_insert
(
BTR_NO_LOCKING_FLAG
ut_ad
(
cursor
.
flag
==
BTR_CUR_BINARY
);
|
BTR_KEEP_SYS_FLAG
|
BTR_NO_UNDO_LOG_FLAG
,
err
=
btr_cur_optimistic_insert
(
&
cursor
,
tuple
,
&
rec
,
BTR_NO_LOCKING_FLAG
|
BTR_KEEP_SYS_FLAG
&
dummy_big_rec
,
0
,
NULL
,
mtr
);
|
BTR_NO_UNDO_LOG_FLAG
,
&
cursor
,
tuple
,
&
rec
,
ut_a
(
err
==
DB_SUCCESS
);
&
dummy_big_rec
,
0
,
NULL
,
mtr
);
if
(
err
==
DB_FAIL
)
{
err
=
btr_cur_pessimistic_insert
(
BTR_NO_LOCKING_FLAG
|
BTR_KEEP_SYS_FLAG
|
BTR_NO_UNDO_LOG_FLAG
,
&
cursor
,
tuple
,
&
rec
,
&
dummy_big_rec
,
0
,
NULL
,
mtr
);
ut_a
(
err
==
DB_SUCCESS
);
}
}
}
/**************************************************************//**
/**************************************************************//**
...
...
storage/xtradb/btr/btr0cur.c
View file @
993b7b95
...
@@ -1412,7 +1412,12 @@ btr_cur_optimistic_insert(
...
@@ -1412,7 +1412,12 @@ btr_cur_optimistic_insert(
if
(
UNIV_UNLIKELY
(
reorg
))
{
if
(
UNIV_UNLIKELY
(
reorg
))
{
ut_a
(
zip_size
);
ut_a
(
zip_size
);
ut_a
(
*
rec
);
/* It's possible for rec to be NULL if the
page is compressed. This is because a
reorganized page may become incompressible. */
if
(
!*
rec
)
{
goto
fail
;
}
}
}
}
}
...
@@ -1548,20 +1553,9 @@ btr_cur_pessimistic_insert(
...
@@ -1548,20 +1553,9 @@ btr_cur_pessimistic_insert(
ut_ad
((
thr
&&
thr_get_trx
(
thr
)
->
fake_changes
)
||
mtr_memo_contains
(
mtr
,
btr_cur_get_block
(
cursor
),
ut_ad
((
thr
&&
thr_get_trx
(
thr
)
->
fake_changes
)
||
mtr_memo_contains
(
mtr
,
btr_cur_get_block
(
cursor
),
MTR_MEMO_PAGE_X_FIX
));
MTR_MEMO_PAGE_X_FIX
));
/* Try first an optimistic insert; reset the cursor flag: we do not
assume anything of how it was positioned */
cursor
->
flag
=
BTR_CUR_BINARY
;
cursor
->
flag
=
BTR_CUR_BINARY
;
err
=
btr_cur_optimistic_insert
(
flags
,
cursor
,
entry
,
rec
,
/* Check locks and write to undo log, if specified */
big_rec
,
n_ext
,
thr
,
mtr
);
if
(
err
!=
DB_FAIL
)
{
return
(
err
);
}
/* Retry with a pessimistic insert. Check locks and write to undo log,
if specified */
err
=
btr_cur_ins_lock_and_undo
(
flags
,
cursor
,
entry
,
err
=
btr_cur_ins_lock_and_undo
(
flags
,
cursor
,
entry
,
thr
,
mtr
,
&
dummy_inh
);
thr
,
mtr
,
&
dummy_inh
);
...
@@ -2188,8 +2182,12 @@ btr_cur_optimistic_update(
...
@@ -2188,8 +2182,12 @@ btr_cur_optimistic_update(
goto
err_exit
;
goto
err_exit
;
}
}
max_size
=
old_rec_size
/* We do not attempt to reorganize if the page is compressed.
+
page_get_max_insert_size_after_reorganize
(
page
,
1
);
This is because the page may fail to compress after reorganization. */
max_size
=
page_zip
?
page_get_max_insert_size
(
page
,
1
)
:
(
old_rec_size
+
page_get_max_insert_size_after_reorganize
(
page
,
1
));
if
(
!
(((
max_size
>=
BTR_CUR_PAGE_REORGANIZE_LIMIT
)
if
(
!
(((
max_size
>=
BTR_CUR_PAGE_REORGANIZE_LIMIT
)
&&
(
max_size
>=
new_rec_size
))
&&
(
max_size
>=
new_rec_size
))
...
@@ -2559,7 +2557,12 @@ btr_cur_pessimistic_update(
...
@@ -2559,7 +2557,12 @@ btr_cur_pessimistic_update(
err
=
DB_SUCCESS
;
err
=
DB_SUCCESS
;
goto
return_after_reservations
;
goto
return_after_reservations
;
}
else
{
}
else
{
ut_a
(
optim_err
!=
DB_UNDERFLOW
);
/* If the page is compressed and it initially
compresses very well, and there is a subsequent insert
of a badly-compressing record, it is possible for
btr_cur_optimistic_update() to return DB_UNDERFLOW and
btr_cur_insert_if_possible() to return FALSE. */
ut_a
(
page_zip
||
optim_err
!=
DB_UNDERFLOW
);
/* Out of space: reset the free bits. */
/* Out of space: reset the free bits. */
if
(
!
dict_index_is_clust
(
index
)
if
(
!
dict_index_is_clust
(
index
)
...
@@ -2588,7 +2591,9 @@ btr_cur_pessimistic_update(
...
@@ -2588,7 +2591,9 @@ btr_cur_pessimistic_update(
was_first
=
page_cur_is_before_first
(
page_cursor
);
was_first
=
page_cur_is_before_first
(
page_cursor
);
/* Lock checks and undo logging were already performed by
/* Lock checks and undo logging were already performed by
btr_cur_upd_lock_and_undo(). */
btr_cur_upd_lock_and_undo(). We do not try
btr_cur_optimistic_insert() because
btr_cur_insert_if_possible() already failed above. */
err
=
btr_cur_pessimistic_insert
(
BTR_NO_UNDO_LOG_FLAG
err
=
btr_cur_pessimistic_insert
(
BTR_NO_UNDO_LOG_FLAG
|
BTR_NO_LOCKING_FLAG
|
BTR_NO_LOCKING_FLAG
...
...
storage/xtradb/btr/btr0pcur.c
View file @
993b7b95
...
@@ -354,44 +354,39 @@ btr_pcur_restore_position_func(
...
@@ -354,44 +354,39 @@ btr_pcur_restore_position_func(
/* Restore the old search mode */
/* Restore the old search mode */
cursor
->
search_mode
=
old_mode
;
cursor
->
search_mode
=
old_mode
;
if
(
btr_pcur_is_on_user_rec
(
cursor
))
{
switch
(
cursor
->
rel_pos
)
{
switch
(
cursor
->
rel_pos
)
{
case
BTR_PCUR_ON
:
case
BTR_PCUR_ON
:
if
(
btr_pcur_is_on_user_rec
(
cursor
)
if
(
!
cmp_dtuple_rec
(
&&
!
cmp_dtuple_rec
(
tuple
,
btr_pcur_get_rec
(
cursor
),
tuple
,
btr_pcur_get_rec
(
cursor
),
rec_get_offsets
(
btr_pcur_get_rec
(
cursor
),
rec_get_offsets
(
btr_pcur_get_rec
(
cursor
),
index
,
NULL
,
index
,
NULL
,
ULINT_UNDEFINED
,
&
heap
)))
{
ULINT_UNDEFINED
,
&
heap
)))
{
/* We have to store the NEW value for
/* We have to store the NEW value for
the modify clock, since the cursor can
the modify clock, since the cursor can
now be on a different page! But we can
now be on a different page! But we can
retain the value of old_rec */
retain the value of old_rec */
cursor
->
block_when_stored
=
cursor
->
block_when_stored
=
btr_pcur_get_block
(
cursor
);
btr_pcur_get_block
(
cursor
);
cursor
->
modify_clock
=
cursor
->
modify_clock
=
buf_block_get_modify_clock
(
buf_block_get_modify_clock
(
cursor
->
block_when_stored
);
cursor
->
block_when_stored
);
cursor
->
old_stored
=
BTR_PCUR_OLD_STORED
;
cursor
->
old_stored
=
BTR_PCUR_OLD_STORED
;
mem_heap_free
(
heap
);
mem_heap_free
(
heap
);
return
(
TRUE
);
return
(
TRUE
);
}
}
break
;
case
BTR_PCUR_BEFORE
:
page_cur_move_to_next
(
btr_pcur_get_page_cur
(
cursor
));
break
;
case
BTR_PCUR_AFTER
:
page_cur_move_to_prev
(
btr_pcur_get_page_cur
(
cursor
));
break
;
#ifdef UNIV_DEBUG
#ifdef UNIV_DEBUG
default:
/* fall through */
ut_error
;
case
BTR_PCUR_BEFORE
:
case
BTR_PCUR_AFTER
:
break
;
default:
ut_error
;
#endif
/* UNIV_DEBUG */
#endif
/* UNIV_DEBUG */
}
}
}
mem_heap_free
(
heap
);
mem_heap_free
(
heap
);
...
...
storage/xtradb/buf/buf0buf.c
View file @
993b7b95
...
@@ -336,15 +336,6 @@ be effective only if PFS_GROUP_BUFFER_SYNC is defined. */
...
@@ -336,15 +336,6 @@ be effective only if PFS_GROUP_BUFFER_SYNC is defined. */
# endif
/* !PFS_SKIP_BUFFER_MUTEX_RWLOCK */
# endif
/* !PFS_SKIP_BUFFER_MUTEX_RWLOCK */
#endif
/* UNIV_PFS_MUTEX || UNIV_PFS_RWLOCK */
#endif
/* UNIV_PFS_MUTEX || UNIV_PFS_RWLOCK */
/** A chunk of buffers. The buffer pool is allocated in chunks. (moved to buf0buf.h)*/
//struct buf_chunk_struct{
// ulint mem_size; /*!< allocated size of the chunk */
// ulint size; /*!< size of frames[] and blocks[] */
// void* mem; /*!< pointer to the memory area which
// was allocated for the frames */
// buf_block_t* blocks; /*!< array of buffer control blocks */
//};
/********************************************************************//**
/********************************************************************//**
Gets the smallest oldest_modification lsn for any page in the pool. Returns
Gets the smallest oldest_modification lsn for any page in the pool. Returns
zero if all modified pages have been flushed to disk.
zero if all modified pages have been flushed to disk.
...
@@ -1028,7 +1019,8 @@ buf_chunk_init(
...
@@ -1028,7 +1019,8 @@ buf_chunk_init(
/*===========*/
/*===========*/
buf_pool_t
*
buf_pool
,
/*!< in: buffer pool instance */
buf_pool_t
*
buf_pool
,
/*!< in: buffer pool instance */
buf_chunk_t
*
chunk
,
/*!< out: chunk of buffers */
buf_chunk_t
*
chunk
,
/*!< out: chunk of buffers */
ulint
mem_size
)
/*!< in: requested size in bytes */
ulint
mem_size
,
/*!< in: requested size in bytes */
ibool
populate
)
/*!< in: virtual page preallocation */
{
{
buf_block_t
*
block
;
buf_block_t
*
block
;
byte
*
frame
;
byte
*
frame
;
...
@@ -1044,7 +1036,7 @@ buf_chunk_init(
...
@@ -1044,7 +1036,7 @@ buf_chunk_init(
+
(
UNIV_PAGE_SIZE
-
1
),
UNIV_PAGE_SIZE
);
+
(
UNIV_PAGE_SIZE
-
1
),
UNIV_PAGE_SIZE
);
chunk
->
mem_size
=
mem_size
;
chunk
->
mem_size
=
mem_size
;
chunk
->
mem
=
os_mem_alloc_large
(
&
chunk
->
mem_size
);
chunk
->
mem
=
os_mem_alloc_large
(
&
chunk
->
mem_size
,
populate
);
if
(
UNIV_UNLIKELY
(
chunk
->
mem
==
NULL
))
{
if
(
UNIV_UNLIKELY
(
chunk
->
mem
==
NULL
))
{
...
@@ -1254,6 +1246,7 @@ buf_pool_init_instance(
...
@@ -1254,6 +1246,7 @@ buf_pool_init_instance(
/*===================*/
/*===================*/
buf_pool_t
*
buf_pool
,
/*!< in: buffer pool instance */
buf_pool_t
*
buf_pool
,
/*!< in: buffer pool instance */
ulint
buf_pool_size
,
/*!< in: size in bytes */
ulint
buf_pool_size
,
/*!< in: size in bytes */
ibool
populate
,
/*!< in: virtual page preallocation */
ulint
instance_no
)
/*!< in: id of the instance */
ulint
instance_no
)
/*!< in: id of the instance */
{
{
ulint
i
;
ulint
i
;
...
@@ -1286,7 +1279,7 @@ buf_pool_init_instance(
...
@@ -1286,7 +1279,7 @@ buf_pool_init_instance(
UT_LIST_INIT
(
buf_pool
->
free
);
UT_LIST_INIT
(
buf_pool
->
free
);
if
(
!
buf_chunk_init
(
buf_pool
,
chunk
,
buf_pool_size
))
{
if
(
!
buf_chunk_init
(
buf_pool
,
chunk
,
buf_pool_size
,
populate
))
{
mem_free
(
chunk
);
mem_free
(
chunk
);
mem_free
(
buf_pool
);
mem_free
(
buf_pool
);
...
@@ -1381,6 +1374,7 @@ ulint
...
@@ -1381,6 +1374,7 @@ ulint
buf_pool_init
(
buf_pool_init
(
/*==========*/
/*==========*/
ulint
total_size
,
/*!< in: size of the total pool in bytes */
ulint
total_size
,
/*!< in: size of the total pool in bytes */
ibool
populate
,
/*!< in: virtual page preallocation */
ulint
n_instances
)
/*!< in: number of instances */
ulint
n_instances
)
/*!< in: number of instances */
{
{
ulint
i
;
ulint
i
;
...
@@ -1398,7 +1392,7 @@ buf_pool_init(
...
@@ -1398,7 +1392,7 @@ buf_pool_init(
for
(
i
=
0
;
i
<
n_instances
;
i
++
)
{
for
(
i
=
0
;
i
<
n_instances
;
i
++
)
{
buf_pool_t
*
ptr
=
&
buf_pool_ptr
[
i
];
buf_pool_t
*
ptr
=
&
buf_pool_ptr
[
i
];
if
(
buf_pool_init_instance
(
ptr
,
size
,
i
)
!=
DB_SUCCESS
)
{
if
(
buf_pool_init_instance
(
ptr
,
size
,
populate
,
i
)
!=
DB_SUCCESS
)
{
/* Free all the instances created so far. */
/* Free all the instances created so far. */
buf_pool_free
(
i
);
buf_pool_free
(
i
);
...
@@ -4973,7 +4967,7 @@ buf_stats_aggregate_pool_info(
...
@@ -4973,7 +4967,7 @@ buf_stats_aggregate_pool_info(
Collect buffer pool stats information for a buffer pool. Also
Collect buffer pool stats information for a buffer pool. Also
record aggregated stats if there are more than one buffer pool
record aggregated stats if there are more than one buffer pool
in the server */
in the server */
static
UNIV_INTERN
void
void
buf_stats_get_pool_info
(
buf_stats_get_pool_info
(
/*====================*/
/*====================*/
...
...
storage/xtradb/buf/buf0lru.c
View file @
993b7b95
...
@@ -2384,7 +2384,7 @@ buf_LRU_free_one_page(
...
@@ -2384,7 +2384,7 @@ buf_LRU_free_one_page(
#endif
#endif
mutex_t
*
block_mutex
=
buf_page_get_mutex
(
bpage
);
mutex_t
*
block_mutex
=
buf_page_get_mutex
(
bpage
);
ut_ad
(
buf_pool_mutex_own
(
buf_pool
));
ut_ad
(
mutex_own
(
&
buf_pool
->
LRU_list_mutex
));
ut_ad
(
mutex_own
(
block_mutex
));
ut_ad
(
mutex_own
(
block_mutex
));
if
(
buf_LRU_block_remove_hashed_page
(
bpage
,
TRUE
)
if
(
buf_LRU_block_remove_hashed_page
(
bpage
,
TRUE
)
...
...
storage/xtradb/buf/buf0rea.c
View file @
993b7b95
...
@@ -64,7 +64,7 @@ buf_read_page_handle_error(
...
@@ -64,7 +64,7 @@ buf_read_page_handle_error(
==
BUF_BLOCK_FILE_PAGE
);
==
BUF_BLOCK_FILE_PAGE
);
/* First unfix and release lock on the bpage */
/* First unfix and release lock on the bpage */
buf_pool_mutex_enter
(
buf_pool
);
mutex_enter
(
&
buf_pool
->
LRU_list_mutex
);
mutex_enter
(
buf_page_get_mutex
(
bpage
));
mutex_enter
(
buf_page_get_mutex
(
bpage
));
ut_ad
(
buf_page_get_io_fix
(
bpage
)
==
BUF_IO_READ
);
ut_ad
(
buf_page_get_io_fix
(
bpage
)
==
BUF_IO_READ
);
ut_ad
(
bpage
->
buf_fix_count
==
0
);
ut_ad
(
bpage
->
buf_fix_count
==
0
);
...
@@ -85,7 +85,7 @@ buf_read_page_handle_error(
...
@@ -85,7 +85,7 @@ buf_read_page_handle_error(
buf_pool
->
n_pend_reads
--
;
buf_pool
->
n_pend_reads
--
;
mutex_exit
(
buf_page_get_mutex
(
bpage
));
mutex_exit
(
buf_page_get_mutex
(
bpage
));
buf_pool_mutex_exit
(
buf_pool
);
mutex_exit
(
&
buf_pool
->
LRU_list_mutex
);
}
}
/********************************************************************//**
/********************************************************************//**
...
...
storage/xtradb/handler/ha_innodb.cc
View file @
993b7b95
This diff is collapsed.
Click to expand it.
storage/xtradb/handler/i_s.cc
View file @
993b7b95
This diff is collapsed.
Click to expand it.
storage/xtradb/handler/i_s.h
View file @
993b7b95
...
@@ -52,5 +52,8 @@ extern struct st_maria_plugin i_s_innodb_buffer_pool_pages;
...
@@ -52,5 +52,8 @@ extern struct st_maria_plugin i_s_innodb_buffer_pool_pages;
extern
struct
st_maria_plugin
i_s_innodb_buffer_pool_pages_index
;
extern
struct
st_maria_plugin
i_s_innodb_buffer_pool_pages_index
;
extern
struct
st_maria_plugin
i_s_innodb_buffer_pool_pages_blob
;
extern
struct
st_maria_plugin
i_s_innodb_buffer_pool_pages_blob
;
extern
struct
st_maria_plugin
i_s_innodb_changed_pages
;
extern
struct
st_maria_plugin
i_s_innodb_changed_pages
;
extern
struct
st_maria_plugin
i_s_innodb_buffer_page
;
extern
struct
st_maria_plugin
i_s_innodb_buffer_page_lru
;
extern
struct
st_maria_plugin
i_s_innodb_buffer_stats
;
#endif
/* i_s_h */
#endif
/* i_s_h */
storage/xtradb/ibuf/ibuf0ibuf.c
View file @
993b7b95
...
@@ -3650,11 +3650,18 @@ ibuf_insert_low(
...
@@ -3650,11 +3650,18 @@ ibuf_insert_low(
root
=
ibuf_tree_root_get
(
&
mtr
);
root
=
ibuf_tree_root_get
(
&
mtr
);
err
=
btr_cur_pessimistic_insert
(
BTR_NO_LOCKING_FLAG
err
=
btr_cur_optimistic_insert
(
|
BTR_NO_UNDO_LOG_FLAG
,
BTR_NO_LOCKING_FLAG
|
BTR_NO_UNDO_LOG_FLAG
,
cursor
,
cursor
,
ibuf_entry
,
&
ins_rec
,
ibuf_entry
,
&
ins_rec
,
&
dummy_big_rec
,
0
,
thr
,
&
mtr
);
&
dummy_big_rec
,
0
,
thr
,
&
mtr
);
if
(
err
==
DB_FAIL
)
{
err
=
btr_cur_pessimistic_insert
(
BTR_NO_LOCKING_FLAG
|
BTR_NO_UNDO_LOG_FLAG
,
cursor
,
ibuf_entry
,
&
ins_rec
,
&
dummy_big_rec
,
0
,
thr
,
&
mtr
);
}
mutex_exit
(
&
ibuf_pessimistic_insert_mutex
);
mutex_exit
(
&
ibuf_pessimistic_insert_mutex
);
ibuf_size_update
(
root
,
&
mtr
);
ibuf_size_update
(
root
,
&
mtr
);
mutex_exit
(
&
ibuf_mutex
);
mutex_exit
(
&
ibuf_mutex
);
...
...
storage/xtradb/include/buf0buf.h
View file @
993b7b95
...
@@ -68,7 +68,10 @@ Created 11/5/1995 Heikki Tuuri
...
@@ -68,7 +68,10 @@ Created 11/5/1995 Heikki Tuuri
position of the block. */
position of the block. */
/* @} */
/* @} */
#define MAX_BUFFER_POOLS 64
/*!< The maximum number of buffer
#define MAX_BUFFER_POOLS_BITS 6
/*!< Number of bits to representing
a buffer pool ID */
#define MAX_BUFFER_POOLS (1 << MAX_BUFFER_POOLS_BITS)
/*!< The maximum number of buffer
pools that can be defined */
pools that can be defined */
#define BUF_POOL_WATCH_SIZE 1
/*!< Maximum number of concurrent
#define BUF_POOL_WATCH_SIZE 1
/*!< Maximum number of concurrent
...
@@ -233,6 +236,7 @@ ulint
...
@@ -233,6 +236,7 @@ ulint
buf_pool_init
(
buf_pool_init
(
/*=========*/
/*=========*/
ulint
size
,
/*!< in: Size of the total pool in bytes */
ulint
size
,
/*!< in: Size of the total pool in bytes */
ibool
populate
,
/*!< in: Force virtual page preallocation */
ulint
n_instances
);
/*!< in: Number of instances */
ulint
n_instances
);
/*!< in: Number of instances */
/********************************************************************//**
/********************************************************************//**
Frees the buffer pool at shutdown. This must not be invoked before
Frees the buffer pool at shutdown. This must not be invoked before
...
@@ -778,6 +782,18 @@ void
...
@@ -778,6 +782,18 @@ void
buf_print_io
(
buf_print_io
(
/*=========*/
/*=========*/
FILE
*
file
);
/*!< in: file where to print */
FILE
*
file
);
/*!< in: file where to print */
/*******************************************************************//**
Collect buffer pool stats information for a buffer pool. Also
record aggregated stats if there are more than one buffer pool
in the server */
UNIV_INTERN
void
buf_stats_get_pool_info
(
/*====================*/
buf_pool_t
*
buf_pool
,
/*!< in: buffer pool */
ulint
pool_id
,
/*!< in: buffer pool ID */
buf_pool_info_t
*
all_pool_info
);
/*!< in/out: buffer pool info
to fill */
/*********************************************************************//**
/*********************************************************************//**
Returns the ratio in percents of modified pages in the buffer pool /
Returns the ratio in percents of modified pages in the buffer pool /
database pages in the buffer pool.
database pages in the buffer pool.
...
@@ -1364,12 +1380,25 @@ void
...
@@ -1364,12 +1380,25 @@ void
buf_get_total_stat
(
buf_get_total_stat
(
/*===============*/
/*===============*/
buf_pool_stat_t
*
tot_stat
);
/*!< out: buffer pool stats */
buf_pool_stat_t
*
tot_stat
);
/*!< out: buffer pool stats */
/*********************************************************************//**
Get the nth chunk's buffer block in the specified buffer pool.
@return the nth chunk's buffer block. */
UNIV_INLINE
buf_block_t
*
buf_get_nth_chunk_block
(
/*====================*/
const
buf_pool_t
*
buf_pool
,
/*!< in: buffer pool instance */
ulint
n
,
/*!< in: nth chunk in the buffer pool */
ulint
*
chunk_size
);
/*!< in: chunk size */
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
/** The common buffer control block structure
/** The common buffer control block structure
for compressed and uncompressed frames */
for compressed and uncompressed frames */
/** Number of bits used for buffer page states. */
#define BUF_PAGE_STATE_BITS 3
struct
buf_page_struct
{
struct
buf_page_struct
{
/** @name General fields
/** @name General fields
None of these bit-fields must be modified without holding
None of these bit-fields must be modified without holding
...
@@ -1384,7 +1413,8 @@ struct buf_page_struct{
...
@@ -1384,7 +1413,8 @@ struct buf_page_struct{
unsigned
offset
:
32
;
/*!< page number; also protected
unsigned
offset
:
32
;
/*!< page number; also protected
by buf_pool->mutex. */
by buf_pool->mutex. */
unsigned
state
:
3
;
/*!< state of the control block; also
unsigned
state
:
BUF_PAGE_STATE_BITS
;
/*!< state of the control block; also
protected by buf_pool->mutex.
protected by buf_pool->mutex.
State transitions from
State transitions from
BUF_BLOCK_READY_FOR_USE to
BUF_BLOCK_READY_FOR_USE to
...
...
storage/xtradb/include/buf0buf.ic
View file @
993b7b95
...
@@ -36,6 +36,8 @@ Created 11/5/1995 Heikki Tuuri
...
@@ -36,6 +36,8 @@ Created 11/5/1995 Heikki Tuuri
#include "buf0lru.h"
#include "buf0lru.h"
#include "buf0rea.h"
#include "buf0rea.h"
#include "srv0srv.h"
#include "srv0srv.h"
#include "buf0types.h"
/*********************************************************************//**
/*********************************************************************//**
Gets the current size of buffer buf_pool in bytes.
Gets the current size of buffer buf_pool in bytes.
@return size in bytes */
@return size in bytes */
...
@@ -1354,4 +1356,21 @@ buf_pool_page_hash_x_unlock_all(void)
...
@@ -1354,4 +1356,21 @@ buf_pool_page_hash_x_unlock_all(void)
rw_lock_x_unlock(&buf_pool->page_hash_latch);
rw_lock_x_unlock(&buf_pool->page_hash_latch);
}
}
}
}
/*********************************************************************//**
Get the nth chunk's buffer block in the specified buffer pool.
@return the nth chunk's buffer block. */
UNIV_INLINE
buf_block_t*
buf_get_nth_chunk_block(
/*====================*/
const buf_pool_t* buf_pool, /*!< in: buffer pool instance */
ulint n, /*!< in: nth chunk in the buffer pool */
ulint* chunk_size) /*!< in: chunk size */
{
const buf_chunk_t* chunk;
chunk = buf_pool->chunks + n;
*chunk_size = chunk->size;
return(chunk->blocks);
}
#endif /* !UNIV_HOTBACKUP */
#endif /* !UNIV_HOTBACKUP */
storage/xtradb/include/fil0fil.h
View file @
993b7b95
...
@@ -144,6 +144,8 @@ extern fil_addr_t fil_addr_null;
...
@@ -144,6 +144,8 @@ extern fil_addr_t fil_addr_null;
#define FIL_PAGE_TYPE_BLOB 10
/*!< Uncompressed BLOB page */
#define FIL_PAGE_TYPE_BLOB 10
/*!< Uncompressed BLOB page */
#define FIL_PAGE_TYPE_ZBLOB 11
/*!< First compressed BLOB page */
#define FIL_PAGE_TYPE_ZBLOB 11
/*!< First compressed BLOB page */
#define FIL_PAGE_TYPE_ZBLOB2 12
/*!< Subsequent compressed BLOB page */
#define FIL_PAGE_TYPE_ZBLOB2 12
/*!< Subsequent compressed BLOB page */
#define FIL_PAGE_TYPE_LAST FIL_PAGE_TYPE_ZBLOB2
/*!< Last page type */
/* @} */
/* @} */
/** Space types @{ */
/** Space types @{ */
...
...
storage/xtradb/include/ha_prototypes.h
View file @
993b7b95
...
@@ -111,7 +111,7 @@ UNIV_INTERN
...
@@ -111,7 +111,7 @@ UNIV_INTERN
ibool
ibool
thd_is_replication_slave_thread
(
thd_is_replication_slave_thread
(
/*============================*/
/*============================*/
void
*
thd
);
/*!< in: thread handle (THD*) */
const
void
*
thd
);
/*!< in: thread handle (THD*) */
/******************************************************************//**
/******************************************************************//**
Returns true if the transaction this thread is processing has edited
Returns true if the transaction this thread is processing has edited
...
...
storage/xtradb/include/log0log.h
View file @
993b7b95
...
@@ -41,6 +41,9 @@ Created 12/9/1995 Heikki Tuuri
...
@@ -41,6 +41,9 @@ Created 12/9/1995 Heikki Tuuri
#include "sync0rw.h"
#include "sync0rw.h"
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
/* Type used for all log sequence number storage and arithmetics */
typedef
ib_uint64_t
lsn_t
;
/** Redo log buffer */
/** Redo log buffer */
typedef
struct
log_struct
log_t
;
typedef
struct
log_struct
log_t
;
/** Redo log group */
/** Redo log group */
...
...
storage/xtradb/include/os0proc.h
View file @
993b7b95
...
@@ -58,7 +58,8 @@ UNIV_INTERN
...
@@ -58,7 +58,8 @@ UNIV_INTERN
void
*
void
*
os_mem_alloc_large
(
os_mem_alloc_large
(
/*===============*/
/*===============*/
ulint
*
n
);
/*!< in/out: number of bytes */
ulint
*
n
,
/*!< in/out: number of bytes */
ibool
populate
);
/*!< in: virtual page preallocation */
/****************************************************************//**
/****************************************************************//**
Frees large pages memory. */
Frees large pages memory. */
UNIV_INTERN
UNIV_INTERN
...
...
storage/xtradb/include/srv0srv.h
View file @
993b7b95
...
@@ -182,6 +182,7 @@ extern my_bool srv_use_sys_malloc;
...
@@ -182,6 +182,7 @@ extern my_bool srv_use_sys_malloc;
extern
ibool
srv_use_sys_malloc
;
extern
ibool
srv_use_sys_malloc
;
#endif
/* UNIV_HOTBACKUP */
#endif
/* UNIV_HOTBACKUP */
extern
ulint
srv_buf_pool_size
;
/*!< requested size in bytes */
extern
ulint
srv_buf_pool_size
;
/*!< requested size in bytes */
extern
my_bool
srv_buf_pool_populate
;
/*!< virtual page preallocation */
extern
ulint
srv_buf_pool_instances
;
/*!< requested number of buffer pool instances */
extern
ulint
srv_buf_pool_instances
;
/*!< requested number of buffer pool instances */
extern
ulint
srv_buf_pool_old_size
;
/*!< previously requested size */
extern
ulint
srv_buf_pool_old_size
;
/*!< previously requested size */
extern
ulint
srv_buf_pool_curr_size
;
/*!< current size in bytes */
extern
ulint
srv_buf_pool_curr_size
;
/*!< current size in bytes */
...
...
storage/xtradb/include/trx0sys.h
View file @
993b7b95
...
@@ -342,6 +342,14 @@ void
...
@@ -342,6 +342,14 @@ void
trx_sys_print_mysql_binlog_offset
(
void
);
trx_sys_print_mysql_binlog_offset
(
void
);
/*===================================*/
/*===================================*/
/*****************************************************************//**
/*****************************************************************//**
Prints to stderr the MySQL master log offset info in the trx system header
COMMIT set of fields if the magic number shows it valid and stores it
in global variables. */
UNIV_INTERN
void
trx_sys_print_committed_mysql_master_log_pos
(
void
);
/*==============================================*/
/*****************************************************************//**
Prints to stderr the MySQL master log offset info in the trx system header if
Prints to stderr the MySQL master log offset info in the trx system header if
the magic number shows it valid. */
the magic number shows it valid. */
UNIV_INTERN
UNIV_INTERN
...
@@ -534,10 +542,16 @@ We must remember this limit in order to keep file compatibility. */
...
@@ -534,10 +542,16 @@ We must remember this limit in order to keep file compatibility. */
//# error "UNIV_PAGE_SIZE < 4096"
//# error "UNIV_PAGE_SIZE < 4096"
//#endif
//#endif
/** The offset of the MySQL replication info in the trx system header;
/** The offset of the MySQL replication info in the trx system header;
this contains the same fields as TRX_SYS_MYSQL_LOG_INFO below */
this contains the same fields as TRX_SYS_MYSQL_LOG_INFO below. These are
written at prepare time and are the main copy. */
#define TRX_SYS_MYSQL_MASTER_LOG_INFO (UNIV_PAGE_SIZE - 2000)
#define TRX_SYS_MYSQL_MASTER_LOG_INFO (UNIV_PAGE_SIZE - 2000)
#define TRX_SYS_MYSQL_RELAY_LOG_INFO (UNIV_PAGE_SIZE - 1500)
#define TRX_SYS_MYSQL_RELAY_LOG_INFO (UNIV_PAGE_SIZE - 1500)
/** The copy of the above which is made at transaction COMMIT time. If binlog
crash recovery rollbacks a PREPAREd transaction, they are copied back. */
#define TRX_SYS_COMMIT_MASTER_LOG_INFO (UNIV_PAGE_SIZE - 3000)
#define TRX_SYS_COMMIT_RELAY_LOG_INFO (UNIV_PAGE_SIZE - 2500)
/** The offset of the MySQL binlog offset info in the trx system header */
/** The offset of the MySQL binlog offset info in the trx system header */
#define TRX_SYS_MYSQL_LOG_INFO (UNIV_PAGE_SIZE - 1000)
#define TRX_SYS_MYSQL_LOG_INFO (UNIV_PAGE_SIZE - 1000)
#define TRX_SYS_MYSQL_LOG_MAGIC_N_FLD 0
/*!< magic number which is
#define TRX_SYS_MYSQL_LOG_MAGIC_N_FLD 0
/*!< magic number which is
...
...
storage/xtradb/include/univ.i
View file @
993b7b95
...
@@ -54,7 +54,7 @@ Created 1/20/1994 Heikki Tuuri
...
@@ -54,7 +54,7 @@ Created 1/20/1994 Heikki Tuuri
#
define
INNODB_VERSION_BUGFIX
8
#
define
INNODB_VERSION_BUGFIX
8
#
ifndef
PERCONA_INNODB_VERSION
#
ifndef
PERCONA_INNODB_VERSION
#
define
PERCONA_INNODB_VERSION
29.
0
#
define
PERCONA_INNODB_VERSION
29.
1
#
endif
#
endif
/* The following is the InnoDB version as shown in
/* The following is the InnoDB version as shown in
...
...
storage/xtradb/os/os0proc.c
View file @
993b7b95
...
@@ -32,6 +32,12 @@ Created 9/30/1995 Heikki Tuuri
...
@@ -32,6 +32,12 @@ Created 9/30/1995 Heikki Tuuri
#include "ut0mem.h"
#include "ut0mem.h"
#include "ut0byte.h"
#include "ut0byte.h"
/* Linux release version */
#if defined(UNIV_LINUX) && defined(_GNU_SOURCE)
#include <string.h>
/* strverscmp() */
#include <sys/utsname.h>
/* uname() */
#endif
/* FreeBSD for example has only MAP_ANON, Linux has MAP_ANONYMOUS and
/* FreeBSD for example has only MAP_ANON, Linux has MAP_ANONYMOUS and
MAP_ANON but MAP_ANON is marked as deprecated */
MAP_ANON but MAP_ANON is marked as deprecated */
#if defined(MAP_ANONYMOUS)
#if defined(MAP_ANONYMOUS)
...
@@ -40,6 +46,13 @@ MAP_ANON but MAP_ANON is marked as deprecated */
...
@@ -40,6 +46,13 @@ MAP_ANON but MAP_ANON is marked as deprecated */
#define OS_MAP_ANON MAP_ANON
#define OS_MAP_ANON MAP_ANON
#endif
#endif
/* Linux's MAP_POPULATE */
#if defined(MAP_POPULATE)
#define OS_MAP_POPULATE MAP_POPULATE
#else
#define OS_MAP_POPULATE 0
#endif
UNIV_INTERN
ibool
os_use_large_pages
;
UNIV_INTERN
ibool
os_use_large_pages
;
/* Large page size. This may be a boot-time option on some platforms */
/* Large page size. This may be a boot-time option on some platforms */
UNIV_INTERN
ulint
os_large_page_size
;
UNIV_INTERN
ulint
os_large_page_size
;
...
@@ -62,6 +75,24 @@ os_proc_get_number(void)
...
@@ -62,6 +75,24 @@ os_proc_get_number(void)
#endif
#endif
}
}
/****************************************************************//**
Retrieve and compare operating system release.
@return TRUE if the OS release is equal to, or later than release. */
UNIV_INTERN
ibool
os_compare_release
(
/*===============*/
const
char
*
release
/*!< in: OS release */
__attribute__
((
unused
)))
{
#if defined(UNIV_LINUX) && defined(_GNU_SOURCE)
struct
utsname
name
;
return
uname
(
&
name
)
==
0
&&
strverscmp
(
name
.
release
,
release
)
>=
0
;
#else
return
0
;
#endif
}
/****************************************************************//**
/****************************************************************//**
Allocates large pages memory.
Allocates large pages memory.
@return allocated memory */
@return allocated memory */
...
@@ -69,7 +100,8 @@ UNIV_INTERN
...
@@ -69,7 +100,8 @@ UNIV_INTERN
void
*
void
*
os_mem_alloc_large
(
os_mem_alloc_large
(
/*===============*/
/*===============*/
ulint
*
n
)
/*!< in/out: number of bytes */
ulint
*
n
,
/*!< in/out: number of bytes */
ibool
populate
)
/*!< in: virtual page preallocation */
{
{
void
*
ptr
;
void
*
ptr
;
ulint
size
;
ulint
size
;
...
@@ -155,12 +187,13 @@ os_mem_alloc_large(
...
@@ -155,12 +187,13 @@ os_mem_alloc_large(
ut_ad
(
ut_is_2pow
(
size
));
ut_ad
(
ut_is_2pow
(
size
));
size
=
*
n
=
ut_2pow_round
(
*
n
+
(
size
-
1
),
size
);
size
=
*
n
=
ut_2pow_round
(
*
n
+
(
size
-
1
),
size
);
ptr
=
mmap
(
NULL
,
size
,
PROT_READ
|
PROT_WRITE
,
ptr
=
mmap
(
NULL
,
size
,
PROT_READ
|
PROT_WRITE
,
MAP_PRIVATE
|
OS_MAP_ANON
,
-
1
,
0
);
MAP_PRIVATE
|
OS_MAP_ANON
|
(
populate
?
OS_MAP_POPULATE
:
0
),
-
1
,
0
);
if
(
UNIV_UNLIKELY
(
ptr
==
(
void
*
)
-
1
))
{
if
(
UNIV_UNLIKELY
(
ptr
==
(
void
*
)
-
1
))
{
fprintf
(
stderr
,
"InnoDB: mmap(%lu bytes) failed;"
fprintf
(
stderr
,
"InnoDB: mmap(%lu bytes) failed;"
" errno %lu
\n
"
,
" errno %lu
\n
"
,
(
ulong
)
size
,
(
ulong
)
errno
);
(
ulong
)
size
,
(
ulong
)
errno
);
ptr
=
NULL
;
return
(
NULL
)
;
}
else
{
}
else
{
os_fast_mutex_lock
(
&
ut_list_mutex
);
os_fast_mutex_lock
(
&
ut_list_mutex
);
ut_total_allocated_memory
+=
size
;
ut_total_allocated_memory
+=
size
;
...
@@ -168,6 +201,25 @@ os_mem_alloc_large(
...
@@ -168,6 +201,25 @@ os_mem_alloc_large(
UNIV_MEM_ALLOC
(
ptr
,
size
);
UNIV_MEM_ALLOC
(
ptr
,
size
);
}
}
#endif
#endif
#if OS_MAP_ANON && OS_MAP_POPULATE
/* MAP_POPULATE is only supported for private mappings
since Linux 2.6.23. */
populate
=
populate
&&
!
os_compare_release
(
"2.6.23"
);
if
(
populate
)
{
fprintf
(
stderr
,
"InnoDB: Warning: mmap(MAP_POPULATE) "
"is not supported for private mappings. "
"Forcing preallocation by faulting in pages.
\n
"
);
}
#endif
/* Initialize the entire buffer to force the allocation
of physical memory page frames. */
if
(
populate
)
{
memset
(
ptr
,
'\0'
,
size
);
}
return
(
ptr
);
return
(
ptr
);
}
}
...
...
storage/xtradb/page/page0page.c
View file @
993b7b95
...
@@ -781,12 +781,18 @@ page_copy_rec_list_start(
...
@@ -781,12 +781,18 @@ page_copy_rec_list_start(
if
(
UNIV_LIKELY_NULL
(
new_page_zip
))
{
if
(
UNIV_LIKELY_NULL
(
new_page_zip
))
{
mtr_set_log_mode
(
mtr
,
log_mode
);
mtr_set_log_mode
(
mtr
,
log_mode
);
DBUG_EXECUTE_IF
(
"page_copy_rec_list_start_compress_fail"
,
goto
zip_reorganize
;);
if
(
UNIV_UNLIKELY
if
(
UNIV_UNLIKELY
(
!
page_zip_compress
(
new_page_zip
,
new_page
,
index
,
mtr
)))
{
(
!
page_zip_compress
(
new_page_zip
,
new_page
,
index
,
mtr
)))
{
ulint
ret_pos
;
#ifndef DBUG_OFF
zip_reorganize:
#endif
/* DBUG_OFF */
/* Before trying to reorganize the page,
/* Before trying to reorganize the page,
store the number of preceding records on the page. */
store the number of preceding records on the page. */
ulint
ret_pos
ret_pos
=
page_rec_get_n_recs_before
(
ret
);
=
page_rec_get_n_recs_before
(
ret
);
/* Before copying, "ret" was the predecessor
/* Before copying, "ret" was the predecessor
of the predefined supremum record. If it was
of the predefined supremum record. If it was
the predefined infimum record, then it would
the predefined infimum record, then it would
...
@@ -807,15 +813,10 @@ page_copy_rec_list_start(
...
@@ -807,15 +813,10 @@ page_copy_rec_list_start(
btr_blob_dbg_add
(
new_page
,
index
,
btr_blob_dbg_add
(
new_page
,
index
,
"copy_start_reorg_fail"
);
"copy_start_reorg_fail"
);
return
(
NULL
);
return
(
NULL
);
}
else
{
/* The page was reorganized:
Seek to ret_pos. */
ret
=
new_page
+
PAGE_NEW_INFIMUM
;
do
{
ret
=
rec_get_next_ptr
(
ret
,
TRUE
);
}
while
(
--
ret_pos
);
}
}
/* The page was reorganized: Seek to ret_pos. */
ret
=
page_rec_get_nth
(
new_page
,
ret_pos
);
}
}
}
}
...
...
storage/xtradb/row/row0ins.c
View file @
993b7b95
...
@@ -2181,9 +2181,16 @@ row_ins_index_entry_low(
...
@@ -2181,9 +2181,16 @@ row_ins_index_entry_low(
goto
function_exit
;
goto
function_exit
;
}
}
err
=
btr_cur_pessimistic_insert
(
err
=
btr_cur_optimistic_insert
(
0
,
&
cursor
,
entry
,
&
insert_rec
,
&
big_rec
,
0
,
&
cursor
,
entry
,
&
insert_rec
,
&
big_rec
,
n_ext
,
thr
,
&
mtr
);
n_ext
,
thr
,
&
mtr
);
if
(
err
==
DB_FAIL
)
{
err
=
btr_cur_pessimistic_insert
(
0
,
&
cursor
,
entry
,
&
insert_rec
,
&
big_rec
,
n_ext
,
thr
,
&
mtr
);
}
}
}
}
}
...
...
storage/xtradb/row/row0merge.c
View file @
993b7b95
...
@@ -1254,11 +1254,25 @@ row_merge_read_clustered_index(
...
@@ -1254,11 +1254,25 @@ row_merge_read_clustered_index(
goto
err_exit
;
goto
err_exit
;
}
}
/* Store the cursor position on the last user
record on the page. */
btr_pcur_move_to_prev_on_page
(
&
pcur
);
/* Leaf pages must never be empty, unless
this is the only page in the index tree. */
ut_ad
(
btr_pcur_is_on_user_rec
(
&
pcur
)
||
buf_block_get_page_no
(
btr_pcur_get_block
(
&
pcur
))
==
clust_index
->
page
);
btr_pcur_store_position
(
&
pcur
,
&
mtr
);
btr_pcur_store_position
(
&
pcur
,
&
mtr
);
mtr_commit
(
&
mtr
);
mtr_commit
(
&
mtr
);
mtr_start
(
&
mtr
);
mtr_start
(
&
mtr
);
/* Restore position on the record, or its
predecessor if the record was purged
meanwhile. */
btr_pcur_restore_position
(
BTR_SEARCH_LEAF
,
btr_pcur_restore_position
(
BTR_SEARCH_LEAF
,
&
pcur
,
&
mtr
);
&
pcur
,
&
mtr
);
/* Move to the successor of the original record. */
has_next
=
btr_pcur_move_to_next_user_rec
(
&
pcur
,
&
mtr
);
has_next
=
btr_pcur_move_to_next_user_rec
(
&
pcur
,
&
mtr
);
}
}
...
@@ -2720,7 +2734,7 @@ row_merge_build_indexes(
...
@@ -2720,7 +2734,7 @@ row_merge_build_indexes(
merge_files
=
mem_alloc
(
n_indexes
*
sizeof
*
merge_files
);
merge_files
=
mem_alloc
(
n_indexes
*
sizeof
*
merge_files
);
block_size
=
3
*
merge_sort_block_size
;
block_size
=
3
*
merge_sort_block_size
;
block_mem
=
os_mem_alloc_large
(
&
block_size
);
block_mem
=
os_mem_alloc_large
(
&
block_size
,
FALSE
);
for
(
i
=
0
;
i
<
UT_ARR_SIZE
(
block
);
i
++
)
{
for
(
i
=
0
;
i
<
UT_ARR_SIZE
(
block
);
i
++
)
{
block
[
i
]
=
(
row_merge_block_t
)
((
byte
*
)
block_mem
+
block
[
i
]
=
(
row_merge_block_t
)
((
byte
*
)
block_mem
+
...
...
storage/xtradb/srv/srv0srv.c
View file @
993b7b95
...
@@ -232,6 +232,8 @@ UNIV_INTERN const byte* srv_latin1_ordering;
...
@@ -232,6 +232,8 @@ UNIV_INTERN const byte* srv_latin1_ordering;
UNIV_INTERN
my_bool
srv_use_sys_malloc
=
TRUE
;
UNIV_INTERN
my_bool
srv_use_sys_malloc
=
TRUE
;
/* requested size in kilobytes */
/* requested size in kilobytes */
UNIV_INTERN
ulint
srv_buf_pool_size
=
ULINT_MAX
;
UNIV_INTERN
ulint
srv_buf_pool_size
=
ULINT_MAX
;
/* force virtual page preallocation (prefault) */
UNIV_INTERN
my_bool
srv_buf_pool_populate
=
FALSE
;
/* requested number of buffer pool instances */
/* requested number of buffer pool instances */
UNIV_INTERN
ulint
srv_buf_pool_instances
=
1
;
UNIV_INTERN
ulint
srv_buf_pool_instances
=
1
;
/* previously requested size */
/* previously requested size */
...
...
storage/xtradb/srv/srv0start.c
View file @
993b7b95
...
@@ -1543,7 +1543,8 @@ innobase_start_or_create_for_mysql(void)
...
@@ -1543,7 +1543,8 @@ innobase_start_or_create_for_mysql(void)
((
double
)
srv_buf_pool_size
)
/
(
1024
*
1024
));
((
double
)
srv_buf_pool_size
)
/
(
1024
*
1024
));
}
}
err
=
buf_pool_init
(
srv_buf_pool_size
,
srv_buf_pool_instances
);
err
=
buf_pool_init
(
srv_buf_pool_size
,
(
ibool
)
srv_buf_pool_populate
,
srv_buf_pool_instances
);
ut_print_timestamp
(
stderr
);
ut_print_timestamp
(
stderr
);
fprintf
(
stderr
,
fprintf
(
stderr
,
...
...
storage/xtradb/trx/trx0sys.c
View file @
993b7b95
...
@@ -959,8 +959,31 @@ trx_sys_print_mysql_binlog_offset(void)
...
@@ -959,8 +959,31 @@ trx_sys_print_mysql_binlog_offset(void)
}
}
/*****************************************************************//**
/*****************************************************************//**
Prints to stderr the MySQL master log offset info in the trx system header if
Reads the log coordinates at the given offset in the trx sys header. */
the magic number shows it valid. */
static
void
trx_sys_read_log_pos
(
/*=================*/
const
trx_sysf_t
*
sys_header
,
/*!< in: the trx sys header */
uint
header_offset
,
/*!< in: coord offset in the
header */
char
*
log_fn
,
/*!< out: the log file name */
ib_int64_t
*
log_pos
)
/*!< out: the log poistion */
{
ut_memcpy
(
log_fn
,
sys_header
+
header_offset
+
TRX_SYS_MYSQL_LOG_NAME
,
TRX_SYS_MYSQL_MASTER_LOG_NAME_LEN
);
*
log_pos
=
(((
ib_int64_t
)
mach_read_from_4
(
sys_header
+
header_offset
+
TRX_SYS_MYSQL_LOG_OFFSET_HIGH
))
<<
32
)
+
mach_read_from_4
(
sys_header
+
header_offset
+
TRX_SYS_MYSQL_LOG_OFFSET_LOW
);
}
/*****************************************************************//**
Prints to stderr the MySQL master log offset info in the trx system header
PREPARE set of fields if the magic number shows it valid and stores it
in global variables. */
UNIV_INTERN
UNIV_INTERN
void
void
trx_sys_print_mysql_master_log_pos
(
void
)
trx_sys_print_mysql_master_log_pos
(
void
)
...
@@ -982,60 +1005,79 @@ trx_sys_print_mysql_master_log_pos(void)
...
@@ -982,60 +1005,79 @@ trx_sys_print_mysql_master_log_pos(void)
return
;
return
;
}
}
/* Copy the master log position info to global variables we can
use in ha_innobase.cc to initialize glob_mi to right values */
trx_sys_read_log_pos
(
sys_header
,
TRX_SYS_MYSQL_MASTER_LOG_INFO
,
trx_sys_mysql_master_log_name
,
&
trx_sys_mysql_master_log_pos
);
trx_sys_read_log_pos
(
sys_header
,
TRX_SYS_MYSQL_RELAY_LOG_INFO
,
trx_sys_mysql_relay_log_name
,
&
trx_sys_mysql_relay_log_pos
);
mtr_commit
(
&
mtr
);
fprintf
(
stderr
,
fprintf
(
stderr
,
"InnoDB: In a MySQL replication slave the last"
"InnoDB: In a MySQL replication slave the last"
" master binlog file
\n
"
" master binlog file
\n
"
"InnoDB: position %lu %lu, file name %s
\n
"
,
"InnoDB: position %llu, file name %s
\n
"
,
(
ulong
)
mach_read_from_4
(
sys_header
trx_sys_mysql_master_log_pos
,
+
TRX_SYS_MYSQL_MASTER_LOG_INFO
trx_sys_mysql_master_log_name
);
+
TRX_SYS_MYSQL_LOG_OFFSET_HIGH
),
(
ulong
)
mach_read_from_4
(
sys_header
+
TRX_SYS_MYSQL_MASTER_LOG_INFO
+
TRX_SYS_MYSQL_LOG_OFFSET_LOW
),
sys_header
+
TRX_SYS_MYSQL_MASTER_LOG_INFO
+
TRX_SYS_MYSQL_LOG_NAME
);
fprintf
(
stderr
,
fprintf
(
stderr
,
"InnoDB: and relay log file
\n
"
"InnoDB: and relay log file
\n
"
"InnoDB: position %lu %lu, file name %s
\n
"
,
"InnoDB: position %llu, file name %s
\n
"
,
(
ulong
)
mach_read_from_4
(
sys_header
trx_sys_mysql_relay_log_pos
,
+
TRX_SYS_MYSQL_RELAY_LOG_INFO
trx_sys_mysql_relay_log_name
);
+
TRX_SYS_MYSQL_LOG_OFFSET_HIGH
),
}
(
ulong
)
mach_read_from_4
(
sys_header
+
TRX_SYS_MYSQL_RELAY_LOG_INFO
+
TRX_SYS_MYSQL_LOG_OFFSET_LOW
),
sys_header
+
TRX_SYS_MYSQL_RELAY_LOG_INFO
+
TRX_SYS_MYSQL_LOG_NAME
);
/* Copy the master log position info to global variables we can
/*****************************************************************//**
use in ha_innobase.cc to initialize glob_mi to right values */
Prints to stderr the MySQL master log offset info in the trx system header
COMMIT set of fields if the magic number shows it valid and stores it
in global variables. */
UNIV_INTERN
void
trx_sys_print_committed_mysql_master_log_pos
(
void
)
/*==============================================*/
{
trx_sysf_t
*
sys_header
;
mtr_t
mtr
;
ut_memcpy
(
trx_sys_mysql_master_log_name
,
mtr_start
(
&
mtr
);
sys_header
+
TRX_SYS_MYSQL_MASTER_LOG_INFO
+
TRX_SYS_MYSQL_LOG_NAME
,
TRX_SYS_MYSQL_MASTER_LOG_NAME_LEN
);
trx_sys_mysql_master_log_pos
sys_header
=
trx_sysf_get
(
&
mtr
);
=
(((
ib_int64_t
)
mach_read_from_4
(
sys_header
+
TRX_SYS_MYSQL_MASTER_LOG_INFO
if
(
mach_read_from_4
(
sys_header
+
TRX_SYS_COMMIT_MASTER_LOG_INFO
+
TRX_SYS_MYSQL_LOG_OFFSET_HIGH
))
<<
32
)
+
TRX_SYS_MYSQL_LOG_MAGIC_N_FLD
)
+
((
ib_int64_t
)
mach_read_from_4
(
!=
TRX_SYS_MYSQL_LOG_MAGIC_N
)
{
sys_header
+
TRX_SYS_MYSQL_MASTER_LOG_INFO
+
TRX_SYS_MYSQL_LOG_OFFSET_LOW
));
mtr_commit
(
&
mtr
);
ut_memcpy
(
trx_sys_mysql_relay_log_name
,
return
;
sys_header
+
TRX_SYS_MYSQL_RELAY_LOG_INFO
}
+
TRX_SYS_MYSQL_LOG_NAME
,
TRX_SYS_MYSQL_MASTER_LOG_NAME_LEN
);
/* Copy the master log position info to global variables we can
use in ha_innobase.cc to initialize glob_mi to right values */
trx_sys_read_log_pos
(
sys_header
,
TRX_SYS_COMMIT_MASTER_LOG_INFO
,
trx_sys_mysql_master_log_name
,
&
trx_sys_mysql_master_log_pos
);
trx_sys_read_log_pos
(
sys_header
,
TRX_SYS_COMMIT_RELAY_LOG_INFO
,
trx_sys_mysql_relay_log_name
,
&
trx_sys_mysql_relay_log_pos
);
trx_sys_mysql_relay_log_pos
=
(((
ib_int64_t
)
mach_read_from_4
(
sys_header
+
TRX_SYS_MYSQL_RELAY_LOG_INFO
+
TRX_SYS_MYSQL_LOG_OFFSET_HIGH
))
<<
32
)
+
((
ib_int64_t
)
mach_read_from_4
(
sys_header
+
TRX_SYS_MYSQL_RELAY_LOG_INFO
+
TRX_SYS_MYSQL_LOG_OFFSET_LOW
));
mtr_commit
(
&
mtr
);
mtr_commit
(
&
mtr
);
fprintf
(
stderr
,
"InnoDB: In a MySQL replication slave the last"
" master binlog file
\n
"
"InnoDB: position %llu, file name %s
\n
"
,
trx_sys_mysql_master_log_pos
,
trx_sys_mysql_master_log_name
);
fprintf
(
stderr
,
"InnoDB: and relay log file
\n
"
"InnoDB: position %llu, file name %s
\n
"
,
trx_sys_mysql_relay_log_pos
,
trx_sys_mysql_relay_log_name
);
}
}
/****************************************************************//**
/****************************************************************//**
...
...
storage/xtradb/trx/trx0trx.c
View file @
993b7b95
...
@@ -938,13 +938,13 @@ trx_write_serialisation_history(
...
@@ -938,13 +938,13 @@ trx_write_serialisation_history(
sys_header
,
sys_header
,
trx
->
mysql_relay_log_file_name
,
trx
->
mysql_relay_log_file_name
,
trx
->
mysql_relay_log_pos
,
trx
->
mysql_relay_log_pos
,
TRX_SYS_
MYSQL
_RELAY_LOG_INFO
,
&
mtr
);
TRX_SYS_
COMMIT
_RELAY_LOG_INFO
,
&
mtr
);
trx_sys_update_mysql_binlog_offset
(
trx_sys_update_mysql_binlog_offset
(
sys_header
,
sys_header
,
trx
->
mysql_master_log_file_name
,
trx
->
mysql_master_log_file_name
,
trx
->
mysql_master_log_pos
,
trx
->
mysql_master_log_pos
,
TRX_SYS_
MYSQL
_MASTER_LOG_INFO
,
&
mtr
);
TRX_SYS_
COMMIT
_MASTER_LOG_INFO
,
&
mtr
);
trx
->
mysql_master_log_file_name
=
""
;
trx
->
mysql_master_log_file_name
=
""
;
}
}
...
@@ -2050,6 +2050,23 @@ trx_prepare_off_kernel(
...
@@ -2050,6 +2050,23 @@ trx_prepare_off_kernel(
mutex_exit
(
&
(
rseg
->
mutex
));
mutex_exit
(
&
(
rseg
->
mutex
));
if
(
trx
->
mysql_master_log_file_name
[
0
]
!=
'\0'
)
{
/* This database server is a MySQL replication slave */
trx_sysf_t
*
sys_header
=
trx_sysf_get
(
&
mtr
);
trx_sys_update_mysql_binlog_offset
(
sys_header
,
trx
->
mysql_relay_log_file_name
,
trx
->
mysql_relay_log_pos
,
TRX_SYS_MYSQL_RELAY_LOG_INFO
,
&
mtr
);
trx_sys_update_mysql_binlog_offset
(
sys_header
,
trx
->
mysql_master_log_file_name
,
trx
->
mysql_master_log_pos
,
TRX_SYS_MYSQL_MASTER_LOG_INFO
,
&
mtr
);
trx
->
mysql_master_log_file_name
=
""
;
}
/*--------------*/
/*--------------*/
mtr_commit
(
&
mtr
);
/* This mtr commit makes the
mtr_commit
(
&
mtr
);
/* This mtr commit makes the
transaction prepared in the file-based
transaction prepared in the file-based
...
...
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