Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
eb5c1882
Commit
eb5c1882
authored
Nov 16, 2012
by
Inaam Rana
Browse files
Options
Browse Files
Download
Plain Diff
merge from 5.1
parents
67efef09
a46adb0f
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
40 additions
and
62 deletions
+40
-62
storage/innobase/buf/buf0buf.c
storage/innobase/buf/buf0buf.c
+31
-53
storage/innobase/include/buf0buf.h
storage/innobase/include/buf0buf.h
+5
-5
storage/innobase/include/buf0buf.ic
storage/innobase/include/buf0buf.ic
+4
-4
No files found.
storage/innobase/buf/buf0buf.c
View file @
eb5c1882
...
@@ -1657,34 +1657,24 @@ buf_page_make_young(
...
@@ -1657,34 +1657,24 @@ buf_page_make_young(
}
}
/********************************************************************//**
/********************************************************************//**
Sets the time of the first access of a page and moves a page to the
Moves a page to the start of the buffer pool LRU list if it is too old.
start of the buffer pool LRU list if it is too old. This high-level
This high-level function can be used to prevent an important page from
function can be used to prevent an important page from slipping
slipping out of the buffer pool. */
out of the buffer pool. */
static
static
void
void
buf_page_
set_accessed_make_young
(
buf_page_
make_young_if_needed
(
/*==========================
===
*/
/*==========================*/
buf_page_t
*
bpage
,
/*!< in/out: buffer block of a
buf_page_t
*
bpage
)
/*!< in/out: buffer block of a
file page */
file page */
unsigned
access_time
)
/*!< in: bpage->access_time
read under mutex protection,
or 0 if unknown */
{
{
#ifdef UNIV_DEBUG
buf_pool_t
*
buf_pool
=
buf_pool_from_bpage
(
bpage
);
buf_pool_t
*
buf_pool
=
buf_pool_from_bpage
(
bpage
);
ut_ad
(
!
buf_pool_mutex_own
(
buf_pool
));
ut_ad
(
!
buf_pool_mutex_own
(
buf_pool
));
#endif
/* UNIV_DEBUG */
ut_a
(
buf_page_in_file
(
bpage
));
ut_a
(
buf_page_in_file
(
bpage
));
if
(
buf_page_peek_if_too_old
(
bpage
))
{
if
(
buf_page_peek_if_too_old
(
bpage
))
{
buf_pool_mutex_enter
(
buf_pool
);
buf_page_make_young
(
bpage
);
buf_LRU_make_block_young
(
bpage
);
buf_pool_mutex_exit
(
buf_pool
);
}
else
if
(
!
access_time
)
{
ulint
time_ms
=
ut_time_ms
();
buf_pool_mutex_enter
(
buf_pool
);
buf_page_set_accessed
(
bpage
,
time_ms
);
buf_pool_mutex_exit
(
buf_pool
);
}
}
}
}
...
@@ -1797,7 +1787,6 @@ buf_page_get_zip(
...
@@ -1797,7 +1787,6 @@ buf_page_get_zip(
buf_page_t
*
bpage
;
buf_page_t
*
bpage
;
mutex_t
*
block_mutex
;
mutex_t
*
block_mutex
;
ibool
must_read
;
ibool
must_read
;
unsigned
access_time
;
buf_pool_t
*
buf_pool
=
buf_pool_get
(
space
,
offset
);
buf_pool_t
*
buf_pool
=
buf_pool_get
(
space
,
offset
);
buf_pool
->
stat
.
n_page_gets
++
;
buf_pool
->
stat
.
n_page_gets
++
;
...
@@ -1865,13 +1854,14 @@ err_exit:
...
@@ -1865,13 +1854,14 @@ err_exit:
got_block:
got_block:
must_read
=
buf_page_get_io_fix
(
bpage
)
==
BUF_IO_READ
;
must_read
=
buf_page_get_io_fix
(
bpage
)
==
BUF_IO_READ
;
access_time
=
buf_page_is_accessed
(
bpage
);
buf_pool_mutex_exit
(
buf_pool
);
buf_pool_mutex_exit
(
buf_pool
);
buf_page_set_accessed
(
bpage
);
mutex_exit
(
block_mutex
);
mutex_exit
(
block_mutex
);
buf_page_
set_accessed_make_young
(
bpage
,
access_tim
e
);
buf_page_
make_young_if_needed
(
bpag
e
);
#if defined UNIV_DEBUG_FILE_ACCESSES || defined UNIV_DEBUG
#if defined UNIV_DEBUG_FILE_ACCESSES || defined UNIV_DEBUG
ut_a
(
!
bpage
->
file_page_was_freed
);
ut_a
(
!
bpage
->
file_page_was_freed
);
...
@@ -2550,16 +2540,17 @@ wait_until_unfixed:
...
@@ -2550,16 +2540,17 @@ wait_until_unfixed:
ut_a
(
mode
==
BUF_GET_POSSIBLY_FREED
ut_a
(
mode
==
BUF_GET_POSSIBLY_FREED
||
!
block
->
page
.
file_page_was_freed
);
||
!
block
->
page
.
file_page_was_freed
);
#endif
#endif
mutex_exit
(
&
block
->
mutex
);
buf_pool_mutex_exit
(
buf_pool
);
/* Check if this is the first access to the page */
/* Check if this is the first access to the page */
access_time
=
buf_page_is_accessed
(
&
block
->
page
);
access_time
=
buf_page_is_accessed
(
&
block
->
page
);
buf_p
ool_mutex_exit
(
buf_pool
);
buf_p
age_set_accessed
(
&
block
->
page
);
if
(
UNIV_LIKELY
(
mode
!=
BUF_PEEK_IF_IN_POOL
))
{
mutex_exit
(
&
block
->
mutex
);
buf_page_set_accessed_make_young
(
&
block
->
page
,
access_time
);
if
(
mode
!=
BUF_PEEK_IF_IN_POOL
)
{
buf_page_make_young_if_needed
(
&
block
->
page
);
}
}
#if defined UNIV_DEBUG || defined UNIV_BUF_DEBUG
#if defined UNIV_DEBUG || defined UNIV_BUF_DEBUG
...
@@ -2610,7 +2601,7 @@ wait_until_unfixed:
...
@@ -2610,7 +2601,7 @@ wait_until_unfixed:
mtr_memo_push
(
mtr
,
block
,
fix_type
);
mtr_memo_push
(
mtr
,
block
,
fix_type
);
if
(
UNIV_LIKELY
(
mode
!=
BUF_PEEK_IF_IN_POOL
)
&&
!
access_time
)
{
if
(
mode
!=
BUF_PEEK_IF_IN_POOL
&&
!
access_time
)
{
/* In the case of a first access, try to apply linear
/* In the case of a first access, try to apply linear
read-ahead */
read-ahead */
...
@@ -2662,15 +2653,13 @@ buf_page_optimistic_get(
...
@@ -2662,15 +2653,13 @@ buf_page_optimistic_get(
buf_block_buf_fix_inc
(
block
,
file
,
line
);
buf_block_buf_fix_inc
(
block
,
file
,
line
);
mutex_exit
(
&
block
->
mutex
);
access_time
=
buf_page_is_accessed
(
&
block
->
page
);
/* Check if this is the first access to the page.
buf_page_set_accessed
(
&
block
->
page
);
We do a dirty read on purpose, to avoid mutex contention.
This field is only used for heuristic purposes; it does not
affect correctness. */
access_time
=
buf_page_is_accessed
(
&
block
->
page
);
mutex_exit
(
&
block
->
mutex
);
buf_page_set_accessed_make_young
(
&
block
->
page
,
access_time
);
buf_page_make_young_if_needed
(
&
block
->
page
);
ut_ad
(
!
ibuf_inside
(
mtr
)
ut_ad
(
!
ibuf_inside
(
mtr
)
||
ibuf_page
(
buf_block_get_space
(
block
),
||
ibuf_page
(
buf_block_get_space
(
block
),
...
@@ -2722,7 +2711,7 @@ buf_page_optimistic_get(
...
@@ -2722,7 +2711,7 @@ buf_page_optimistic_get(
#if defined UNIV_DEBUG_FILE_ACCESSES || defined UNIV_DEBUG
#if defined UNIV_DEBUG_FILE_ACCESSES || defined UNIV_DEBUG
ut_a
(
block
->
page
.
file_page_was_freed
==
FALSE
);
ut_a
(
block
->
page
.
file_page_was_freed
==
FALSE
);
#endif
#endif
if
(
UNIV_UNLIKELY
(
!
access_time
)
)
{
if
(
!
access_time
)
{
/* In the case of a first access, try to apply linear
/* In the case of a first access, try to apply linear
read-ahead */
read-ahead */
...
@@ -2785,24 +2774,14 @@ buf_page_get_known_nowait(
...
@@ -2785,24 +2774,14 @@ buf_page_get_known_nowait(
buf_block_buf_fix_inc
(
block
,
file
,
line
);
buf_block_buf_fix_inc
(
block
,
file
,
line
);
buf_page_set_accessed
(
&
block
->
page
);
mutex_exit
(
&
block
->
mutex
);
mutex_exit
(
&
block
->
mutex
);
buf_pool
=
buf_pool_from_block
(
block
);
buf_pool
=
buf_pool_from_block
(
block
);
if
(
mode
==
BUF_MAKE_YOUNG
&&
buf_page_peek_if_too_old
(
&
block
->
page
))
{
if
(
mode
==
BUF_MAKE_YOUNG
)
{
buf_pool_mutex_enter
(
buf_pool
);
buf_page_make_young_if_needed
(
&
block
->
page
);
buf_LRU_make_block_young
(
&
block
->
page
);
buf_pool_mutex_exit
(
buf_pool
);
}
else
if
(
!
buf_page_is_accessed
(
&
block
->
page
))
{
/* Above, we do a dirty read on purpose, to avoid
mutex contention. The field buf_page_t::access_time
is only used for heuristic purposes. Writes to the
field must be protected by mutex, however. */
ulint
time_ms
=
ut_time_ms
();
buf_pool_mutex_enter
(
buf_pool
);
buf_page_set_accessed
(
&
block
->
page
,
time_ms
);
buf_pool_mutex_exit
(
buf_pool
);
}
}
ut_ad
(
!
ibuf_inside
(
mtr
)
||
mode
==
BUF_KEEP_OLD
);
ut_ad
(
!
ibuf_inside
(
mtr
)
||
mode
==
BUF_KEEP_OLD
);
...
@@ -3284,7 +3263,6 @@ buf_page_create(
...
@@ -3284,7 +3263,6 @@ buf_page_create(
buf_block_t
*
block
;
buf_block_t
*
block
;
ulint
fold
;
ulint
fold
;
buf_block_t
*
free_block
=
NULL
;
buf_block_t
*
free_block
=
NULL
;
ulint
time_ms
=
ut_time_ms
();
buf_pool_t
*
buf_pool
=
buf_pool_get
(
space
,
offset
);
buf_pool_t
*
buf_pool
=
buf_pool_get
(
space
,
offset
);
ut_ad
(
mtr
);
ut_ad
(
mtr
);
...
@@ -3375,12 +3353,12 @@ buf_page_create(
...
@@ -3375,12 +3353,12 @@ buf_page_create(
rw_lock_x_unlock
(
&
block
->
lock
);
rw_lock_x_unlock
(
&
block
->
lock
);
}
}
buf_page_set_accessed
(
&
block
->
page
,
time_ms
);
buf_pool_mutex_exit
(
buf_pool
);
buf_pool_mutex_exit
(
buf_pool
);
mtr_memo_push
(
mtr
,
block
,
MTR_MEMO_BUF_FIX
);
mtr_memo_push
(
mtr
,
block
,
MTR_MEMO_BUF_FIX
);
buf_page_set_accessed
(
&
block
->
page
);
mutex_exit
(
&
block
->
mutex
);
mutex_exit
(
&
block
->
mutex
);
/* Delete possible entries for the page from the insert buffer:
/* Delete possible entries for the page from the insert buffer:
...
...
storage/innobase/include/buf0buf.h
View file @
eb5c1882
...
@@ -1024,8 +1024,7 @@ UNIV_INLINE
...
@@ -1024,8 +1024,7 @@ UNIV_INLINE
void
void
buf_page_set_accessed
(
buf_page_set_accessed
(
/*==================*/
/*==================*/
buf_page_t
*
bpage
,
/*!< in/out: control block */
buf_page_t
*
bpage
)
/*!< in/out: control block */
ulint
time_ms
)
/*!< in: ut_time_ms() */
__attribute__
((
nonnull
));
__attribute__
((
nonnull
));
/*********************************************************************//**
/*********************************************************************//**
Gets the buf_block_t handle of a buffered file block if an uncompressed
Gets the buf_block_t handle of a buffered file block if an uncompressed
...
@@ -1504,10 +1503,11 @@ struct buf_page_struct{
...
@@ -1504,10 +1503,11 @@ struct buf_page_struct{
to read this for heuristic
to read this for heuristic
purposes without holding any
purposes without holding any
mutex or latch */
mutex or latch */
unsigned
access_time
:
32
;
/*!< time of first access, or
0 if the block was never accessed
in the buffer pool */
/* @} */
/* @} */
unsigned
access_time
;
/*!< time of first access, or
0 if the block was never accessed
in the buffer pool. Protected by
block mutex */
# if defined UNIV_DEBUG_FILE_ACCESSES || defined UNIV_DEBUG
# if defined UNIV_DEBUG_FILE_ACCESSES || defined UNIV_DEBUG
ibool
file_page_was_freed
;
ibool
file_page_was_freed
;
/*!< this is set to TRUE when fsp
/*!< this is set to TRUE when fsp
...
...
storage/innobase/include/buf0buf.ic
View file @
eb5c1882
...
@@ -614,18 +614,18 @@ UNIV_INLINE
...
@@ -614,18 +614,18 @@ UNIV_INLINE
void
void
buf_page_set_accessed(
buf_page_set_accessed(
/*==================*/
/*==================*/
buf_page_t* bpage, /*!< in/out: control block */
buf_page_t* bpage) /*!< in/out: control block */
ulint time_ms) /*!< in: ut_time_ms() */
{
{
#ifdef UNIV_DEBUG
#ifdef UNIV_DEBUG
buf_pool_t* buf_pool = buf_pool_from_bpage(bpage);
buf_pool_t* buf_pool = buf_pool_from_bpage(bpage);
ut_ad(buf_pool_mutex_own(buf_pool));
ut_ad(!buf_pool_mutex_own(buf_pool));
ut_ad(mutex_own(buf_page_get_mutex(bpage)));
#endif
#endif
ut_a(buf_page_in_file(bpage));
ut_a(buf_page_in_file(bpage));
if (!bpage->access_time) {
if (!bpage->access_time) {
/* Make this the time of the first access. */
/* Make this the time of the first access. */
bpage->access_time =
time_ms
;
bpage->access_time =
ut_time_ms()
;
}
}
}
}
...
...
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