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
b03460d9
Commit
b03460d9
authored
Nov 27, 2006
by
marko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
branches/zip: Move the page flushing fields from buf_block_t to
buf_page_t and page_zip_des_t.
parent
0d7111c9
Changes
10
Show whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
201 additions
and
118 deletions
+201
-118
buf/buf0buf.c
buf/buf0buf.c
+3
-3
buf/buf0flu.c
buf/buf0flu.c
+58
-51
buf/buf0lru.c
buf/buf0lru.c
+6
-5
include/buf0buf.h
include/buf0buf.h
+47
-31
include/buf0buf.ic
include/buf0buf.ic
+57
-9
include/buf0flu.h
include/buf0flu.h
+2
-2
include/buf0flu.ic
include/buf0flu.ic
+15
-15
include/buf0types.h
include/buf0types.h
+7
-0
include/page0types.h
include/page0types.h
+5
-1
include/page0zip.h
include/page0zip.h
+1
-1
No files found.
buf/buf0buf.c
View file @
b03460d9
...
@@ -863,7 +863,7 @@ buf_pool_init(void)
...
@@ -863,7 +863,7 @@ buf_pool_init(void)
-------------------------------- */
-------------------------------- */
UT_LIST_INIT
(
buf_pool
->
flush_list
);
UT_LIST_INIT
(
buf_pool
->
flush_list
);
for
(
i
=
BUF_FLUSH_LRU
;
i
<
=
BUF_FLUSH_LIST
;
i
++
)
{
for
(
i
=
BUF_FLUSH_LRU
;
i
<
BUF_FLUSH_N_TYPES
;
i
++
)
{
buf_pool
->
n_flush
[
i
]
=
0
;
buf_pool
->
n_flush
[
i
]
=
0
;
buf_pool
->
init_flush
[
i
]
=
FALSE
;
buf_pool
->
init_flush
[
i
]
=
FALSE
;
buf_pool
->
no_flush
[
i
]
=
os_event_create
(
NULL
);
buf_pool
->
no_flush
[
i
]
=
os_event_create
(
NULL
);
...
@@ -1855,8 +1855,8 @@ buf_page_init(
...
@@ -1855,8 +1855,8 @@ buf_page_init(
block
->
freed_page_clock
=
0
;
block
->
freed_page_clock
=
0
;
block
->
newest_modification
=
0
;
block
->
page
.
newest_modification
=
0
;
block
->
oldest_modification
=
0
;
block
->
page
.
oldest_modification
=
0
;
block
->
accessed
=
FALSE
;
block
->
accessed
=
FALSE
;
block
->
buf_fix_count
=
0
;
block
->
buf_fix_count
=
0
;
...
...
buf/buf0flu.c
View file @
b03460d9
...
@@ -49,19 +49,19 @@ Inserts a modified block into the flush list. */
...
@@ -49,19 +49,19 @@ Inserts a modified block into the flush list. */
void
void
buf_flush_insert_into_flush_list
(
buf_flush_insert_into_flush_list
(
/*=============================*/
/*=============================*/
buf_
block_t
*
block
)
/* in: block which is modified */
buf_
page_t
*
bpage
)
/* in: block which is modified */
{
{
#ifdef UNIV_SYNC_DEBUG
#ifdef UNIV_SYNC_DEBUG
ut_ad
(
mutex_own
(
&
(
buf_pool
->
mutex
)));
ut_ad
(
mutex_own
(
&
(
buf_pool
->
mutex
)));
#endif
/* UNIV_SYNC_DEBUG */
#endif
/* UNIV_SYNC_DEBUG */
ut_a
(
buf_
block_get_state
(
block
)
==
BUF_BLOCK_FILE_PAGE
);
ut_a
(
buf_
page_get_state
(
bpage
)
==
BUF_BLOCK_FILE_PAGE
);
ut_ad
((
UT_LIST_GET_FIRST
(
buf_pool
->
flush_list
)
==
NULL
)
ut_ad
((
UT_LIST_GET_FIRST
(
buf_pool
->
flush_list
)
==
NULL
)
||
(
UT_LIST_GET_FIRST
(
buf_pool
->
flush_list
)
->
oldest_modification
||
(
UT_LIST_GET_FIRST
(
buf_pool
->
flush_list
)
->
oldest_modification
<=
b
lock
->
oldest_modification
));
<=
b
page
->
oldest_modification
));
UT_LIST_ADD_FIRST
(
flush_list
,
buf_pool
->
flush_list
,
b
lock
);
UT_LIST_ADD_FIRST
(
flush_list
,
buf_pool
->
flush_list
,
b
page
);
#if defined UNIV_DEBUG || defined UNIV_BUF_DEBUG
#if defined UNIV_DEBUG || defined UNIV_BUF_DEBUG
ut_a
(
buf_flush_validate_low
());
ut_a
(
buf_flush_validate_low
());
...
@@ -76,10 +76,10 @@ necessarily come in the order of lsn's. */
...
@@ -76,10 +76,10 @@ necessarily come in the order of lsn's. */
void
void
buf_flush_insert_sorted_into_flush_list
(
buf_flush_insert_sorted_into_flush_list
(
/*====================================*/
/*====================================*/
buf_
block_t
*
block
)
/* in: block which is modified */
buf_
page_t
*
bpage
)
/* in: block which is modified */
{
{
buf_
block
_t
*
prev_b
;
buf_
page
_t
*
prev_b
;
buf_
block
_t
*
b
;
buf_
page
_t
*
b
;
#ifdef UNIV_SYNC_DEBUG
#ifdef UNIV_SYNC_DEBUG
ut_ad
(
mutex_own
(
&
(
buf_pool
->
mutex
)));
ut_ad
(
mutex_own
(
&
(
buf_pool
->
mutex
)));
...
@@ -88,16 +88,16 @@ buf_flush_insert_sorted_into_flush_list(
...
@@ -88,16 +88,16 @@ buf_flush_insert_sorted_into_flush_list(
prev_b
=
NULL
;
prev_b
=
NULL
;
b
=
UT_LIST_GET_FIRST
(
buf_pool
->
flush_list
);
b
=
UT_LIST_GET_FIRST
(
buf_pool
->
flush_list
);
while
(
b
&&
b
->
oldest_modification
>
b
lock
->
oldest_modification
)
{
while
(
b
&&
b
->
oldest_modification
>
b
page
->
oldest_modification
)
{
prev_b
=
b
;
prev_b
=
b
;
b
=
UT_LIST_GET_NEXT
(
flush_list
,
b
);
b
=
UT_LIST_GET_NEXT
(
flush_list
,
b
);
}
}
if
(
prev_b
==
NULL
)
{
if
(
prev_b
==
NULL
)
{
UT_LIST_ADD_FIRST
(
flush_list
,
buf_pool
->
flush_list
,
b
lock
);
UT_LIST_ADD_FIRST
(
flush_list
,
buf_pool
->
flush_list
,
b
page
);
}
else
{
}
else
{
UT_LIST_INSERT_AFTER
(
flush_list
,
buf_pool
->
flush_list
,
prev_b
,
UT_LIST_INSERT_AFTER
(
flush_list
,
buf_pool
->
flush_list
,
prev_b
,
b
lock
);
b
page
);
}
}
#if defined UNIV_DEBUG || defined UNIV_BUF_DEBUG
#if defined UNIV_DEBUG || defined UNIV_BUF_DEBUG
...
@@ -131,7 +131,7 @@ buf_flush_ready_for_replace(
...
@@ -131,7 +131,7 @@ buf_flush_ready_for_replace(
return
(
FALSE
);
return
(
FALSE
);
}
}
return
(
block
->
oldest_modification
==
0
return
(
block
->
page
.
oldest_modification
==
0
&&
block
->
buf_fix_count
==
0
&&
block
->
buf_fix_count
==
0
&&
block
->
io_fix
==
0
);
&&
block
->
io_fix
==
0
);
}
}
...
@@ -145,7 +145,7 @@ buf_flush_ready_for_flush(
...
@@ -145,7 +145,7 @@ buf_flush_ready_for_flush(
/* out: TRUE if can flush immediately */
/* out: TRUE if can flush immediately */
buf_block_t
*
block
,
/* in: buffer control block, must be in state
buf_block_t
*
block
,
/* in: buffer control block, must be in state
BUF_BLOCK_FILE_PAGE */
BUF_BLOCK_FILE_PAGE */
ulint
flush_type
)
/* in: BUF_FLUSH_LRU or BUF_FLUSH_LIST */
enum
buf_flush
flush_type
)
/* in: BUF_FLUSH_LRU or BUF_FLUSH_LIST */
{
{
#ifdef UNIV_SYNC_DEBUG
#ifdef UNIV_SYNC_DEBUG
ut_ad
(
mutex_own
(
&
(
buf_pool
->
mutex
)));
ut_ad
(
mutex_own
(
&
(
buf_pool
->
mutex
)));
...
@@ -153,7 +153,7 @@ buf_flush_ready_for_flush(
...
@@ -153,7 +153,7 @@ buf_flush_ready_for_flush(
#endif
/* UNIV_SYNC_DEBUG */
#endif
/* UNIV_SYNC_DEBUG */
ut_a
(
buf_block_get_state
(
block
)
==
BUF_BLOCK_FILE_PAGE
);
ut_a
(
buf_block_get_state
(
block
)
==
BUF_BLOCK_FILE_PAGE
);
if
(
block
->
oldest_modification
!=
0
&&
block
->
io_fix
==
0
)
{
if
(
block
->
page
.
oldest_modification
!=
0
&&
block
->
io_fix
==
0
)
{
if
(
flush_type
!=
BUF_FLUSH_LRU
)
{
if
(
flush_type
!=
BUF_FLUSH_LRU
)
{
return
(
TRUE
);
return
(
TRUE
);
...
@@ -179,21 +179,24 @@ buf_flush_write_complete(
...
@@ -179,21 +179,24 @@ buf_flush_write_complete(
/*=====================*/
/*=====================*/
buf_block_t
*
block
)
/* in: pointer to the block in question */
buf_block_t
*
block
)
/* in: pointer to the block in question */
{
{
enum
buf_flush
flush_type
;
ut_ad
(
block
);
ut_ad
(
block
);
#ifdef UNIV_SYNC_DEBUG
#ifdef UNIV_SYNC_DEBUG
ut_ad
(
mutex_own
(
&
(
buf_pool
->
mutex
)));
ut_ad
(
mutex_own
(
&
(
buf_pool
->
mutex
)));
#endif
/* UNIV_SYNC_DEBUG */
#endif
/* UNIV_SYNC_DEBUG */
ut_a
(
buf_block_get_state
(
block
)
==
BUF_BLOCK_FILE_PAGE
);
ut_a
(
buf_block_get_state
(
block
)
==
BUF_BLOCK_FILE_PAGE
);
block
->
oldest_modification
=
0
;
block
->
page
.
oldest_modification
=
0
;
UT_LIST_REMOVE
(
flush_list
,
buf_pool
->
flush_list
,
block
);
UT_LIST_REMOVE
(
flush_list
,
buf_pool
->
flush_list
,
&
(
block
->
page
)
);
ut_d
(
UT_LIST_VALIDATE
(
flush_list
,
buf_block_t
,
buf_pool
->
flush_list
));
ut_d
(
UT_LIST_VALIDATE
(
flush_list
,
buf_block_t
,
buf_pool
->
flush_list
));
buf_pool
->
n_flush
[
block
->
flush_type
]
--
;
flush_type
=
buf_page_get_flush_type
(
&
block
->
page
);
buf_pool
->
n_flush
[
flush_type
]
--
;
if
(
block
->
flush_type
==
BUF_FLUSH_LRU
)
{
if
(
flush_type
==
BUF_FLUSH_LRU
)
{
/* Put the block to the end of the LRU list to wait to be
/* Put the block to the end of the LRU list to wait to be
moved to the free list */
moved to the free list */
...
@@ -203,14 +206,14 @@ buf_flush_write_complete(
...
@@ -203,14 +206,14 @@ buf_flush_write_complete(
}
}
/* fprintf(stderr, "n pending flush %lu\n",
/* fprintf(stderr, "n pending flush %lu\n",
buf_pool->n_flush[
block->
flush_type]); */
buf_pool->n_flush[flush_type]); */
if
((
buf_pool
->
n_flush
[
block
->
flush_type
]
==
0
)
if
((
buf_pool
->
n_flush
[
flush_type
]
==
0
)
&&
(
buf_pool
->
init_flush
[
block
->
flush_type
]
==
FALSE
))
{
&&
(
buf_pool
->
init_flush
[
flush_type
]
==
FALSE
))
{
/* The running flush batch has ended */
/* The running flush batch has ended */
os_event_set
(
buf_pool
->
no_flush
[
block
->
flush_type
]);
os_event_set
(
buf_pool
->
no_flush
[
flush_type
]);
}
}
}
}
...
@@ -582,7 +585,7 @@ buf_flush_write_block_low(
...
@@ -582,7 +585,7 @@ buf_flush_write_block_low(
ut_a
(
ibuf_count_get
(
buf_block_get_space
(
block
),
ut_a
(
ibuf_count_get
(
buf_block_get_space
(
block
),
buf_block_get_page_no
(
block
))
==
0
);
buf_block_get_page_no
(
block
))
==
0
);
#endif
#endif
ut_ad
(
block
->
newest_modification
!=
0
);
ut_ad
(
block
->
page
.
newest_modification
!=
0
);
#ifdef UNIV_LOG_DEBUG
#ifdef UNIV_LOG_DEBUG
if
(
!
univ_log_debug_warned
)
{
if
(
!
univ_log_debug_warned
)
{
...
@@ -594,11 +597,12 @@ buf_flush_write_block_low(
...
@@ -594,11 +597,12 @@ buf_flush_write_block_low(
}
}
#else
#else
/* Force the log to the disk before writing the modified block */
/* Force the log to the disk before writing the modified block */
log_write_up_to
(
block
->
newest_modification
,
LOG_WAIT_ALL_GROUPS
,
TRUE
);
log_write_up_to
(
block
->
page
.
newest_modification
,
LOG_WAIT_ALL_GROUPS
,
TRUE
);
#endif
#endif
buf_flush_init_for_writing
(
block
->
frame
,
buf_flush_init_for_writing
(
block
->
frame
,
buf_block_get_page_zip
(
block
),
buf_block_get_page_zip
(
block
),
block
->
newest_modification
);
block
->
page
.
newest_modification
);
if
(
!
srv_use_doublewrite_buf
||
!
trx_doublewrite
)
{
if
(
!
srv_use_doublewrite_buf
||
!
trx_doublewrite
)
{
ulint
zip_size
=
buf_block_get_zip_size
(
block
);
ulint
zip_size
=
buf_block_get_zip_size
(
block
);
...
@@ -621,11 +625,12 @@ static
...
@@ -621,11 +625,12 @@ static
ulint
ulint
buf_flush_try_page
(
buf_flush_try_page
(
/*===============*/
/*===============*/
/* out: 1 if a page was flushed, 0 otherwise */
/* out: 1 if a page was
flushed, 0 otherwise */
ulint
space
,
/* in: space id */
ulint
space
,
/* in: space id */
ulint
offset
,
/* in: page offset */
ulint
offset
,
/* in: page offset */
ulint
flush_type
)
/* in: BUF_FLUSH_LRU, BUF_FLUSH_LIST, or
enum
buf_flush
flush_type
)
/* in: BUF_FLUSH_LRU, BUF_FLUSH_LIST,
BUF_FLUSH_SINGLE_PAGE */
or
BUF_FLUSH_SINGLE_PAGE */
{
{
buf_block_t
*
block
;
buf_block_t
*
block
;
ibool
locked
;
ibool
locked
;
...
@@ -651,7 +656,7 @@ buf_flush_try_page(
...
@@ -651,7 +656,7 @@ buf_flush_try_page(
block
->
io_fix
=
BUF_IO_WRITE
;
block
->
io_fix
=
BUF_IO_WRITE
;
b
lock
->
flush_type
=
flush_type
;
b
uf_page_set_flush_type
(
&
block
->
page
,
flush_type
)
;
if
(
buf_pool
->
n_flush
[
flush_type
]
==
0
)
{
if
(
buf_pool
->
n_flush
[
flush_type
]
==
0
)
{
...
@@ -707,7 +712,7 @@ buf_flush_try_page(
...
@@ -707,7 +712,7 @@ buf_flush_try_page(
block
->
io_fix
=
BUF_IO_WRITE
;
block
->
io_fix
=
BUF_IO_WRITE
;
b
lock
->
flush_type
=
flush_type
;
b
uf_page_set_flush_type
(
&
block
->
page
,
flush_type
)
;
if
(
buf_pool
->
n_flush
[
flush_type
]
==
0
)
{
if
(
buf_pool
->
n_flush
[
flush_type
]
==
0
)
{
...
@@ -734,11 +739,11 @@ buf_flush_try_page(
...
@@ -734,11 +739,11 @@ buf_flush_try_page(
block
->
io_fix
=
BUF_IO_WRITE
;
block
->
io_fix
=
BUF_IO_WRITE
;
b
lock
->
flush_type
=
flush_type
;
b
uf_page_set_flush_type
(
&
block
->
page
,
flush_type
)
;
if
(
buf_pool
->
n_flush
[
block
->
flush_type
]
==
0
)
{
if
(
buf_pool
->
n_flush
[
flush_type
]
==
0
)
{
os_event_reset
(
buf_pool
->
no_flush
[
block
->
flush_type
]);
os_event_reset
(
buf_pool
->
no_flush
[
flush_type
]);
}
}
buf_pool
->
n_flush
[
flush_type
]
++
;
buf_pool
->
n_flush
[
flush_type
]
++
;
...
@@ -778,7 +783,8 @@ buf_flush_try_neighbors(
...
@@ -778,7 +783,8 @@ buf_flush_try_neighbors(
/* out: number of pages flushed */
/* out: number of pages flushed */
ulint
space
,
/* in: space id */
ulint
space
,
/* in: space id */
ulint
offset
,
/* in: page offset */
ulint
offset
,
/* in: page offset */
ulint
flush_type
)
/* in: BUF_FLUSH_LRU or BUF_FLUSH_LIST */
enum
buf_flush
flush_type
)
/* in: BUF_FLUSH_LRU or
BUF_FLUSH_LIST */
{
{
buf_block_t
*
block
;
buf_block_t
*
block
;
ulint
low
,
high
;
ulint
low
,
high
;
...
@@ -875,7 +881,7 @@ buf_flush_batch(
...
@@ -875,7 +881,7 @@ buf_flush_batch(
write request was queued;
write request was queued;
ULINT_UNDEFINED if there was a flush
ULINT_UNDEFINED if there was a flush
of the same type already running */
of the same type already running */
ulint
flush_type
,
/* in: BUF_FLUSH_LRU or
enum
buf_flush
flush_type
,
/* in: BUF_FLUSH_LRU or
BUF_FLUSH_LIST; if BUF_FLUSH_LIST,
BUF_FLUSH_LIST; if BUF_FLUSH_LIST,
then the caller must not own any
then the caller must not own any
latches on pages */
latches on pages */
...
@@ -932,7 +938,7 @@ buf_flush_batch(
...
@@ -932,7 +938,7 @@ buf_flush_batch(
block
=
UT_LIST_GET_LAST
(
buf_pool
->
flush_list
);
block
=
UT_LIST_GET_LAST
(
buf_pool
->
flush_list
);
if
(
!
block
if
(
!
block
||
block
->
oldest_modification
>=
lsn_limit
)
{
||
block
->
page
.
oldest_modification
>=
lsn_limit
)
{
/* We have flushed enough */
/* We have flushed enough */
break
;
break
;
...
@@ -983,7 +989,8 @@ buf_flush_batch(
...
@@ -983,7 +989,8 @@ buf_flush_batch(
mutex_exit
(
&
block
->
mutex
);
mutex_exit
(
&
block
->
mutex
);
block
=
UT_LIST_GET_PREV
(
flush_list
,
block
);
block
=
UT_LIST_GET_PREV
(
flush_list
,
(
&
block
->
page
));
}
}
}
}
...
@@ -1032,7 +1039,7 @@ Waits until a flush batch of the given type ends */
...
@@ -1032,7 +1039,7 @@ Waits until a flush batch of the given type ends */
void
void
buf_flush_wait_batch_end
(
buf_flush_wait_batch_end
(
/*=====================*/
/*=====================*/
ulint
type
)
/* in: BUF_FLUSH_LRU or BUF_FLUSH_LIST */
enum
buf_flush
type
)
/* in: BUF_FLUSH_LRU or BUF_FLUSH_LIST */
{
{
ut_ad
((
type
==
BUF_FLUSH_LRU
)
||
(
type
==
BUF_FLUSH_LIST
));
ut_ad
((
type
==
BUF_FLUSH_LRU
)
||
(
type
==
BUF_FLUSH_LIST
));
...
@@ -1125,22 +1132,22 @@ buf_flush_validate_low(void)
...
@@ -1125,22 +1132,22 @@ buf_flush_validate_low(void)
/*========================*/
/*========================*/
/* out: TRUE if ok */
/* out: TRUE if ok */
{
{
buf_
block_t
*
block
;
buf_
page_t
*
bpage
;
ib_ulonglong
om
;
ib_ulonglong
om
;
UT_LIST_VALIDATE
(
flush_list
,
buf_
block
_t
,
buf_pool
->
flush_list
);
UT_LIST_VALIDATE
(
flush_list
,
buf_
page
_t
,
buf_pool
->
flush_list
);
b
lock
=
UT_LIST_GET_FIRST
(
buf_pool
->
flush_list
);
b
page
=
UT_LIST_GET_FIRST
(
buf_pool
->
flush_list
);
while
(
b
lock
!=
NULL
)
{
while
(
b
page
!=
NULL
)
{
om
=
b
lock
->
oldest_modification
;
om
=
b
page
->
oldest_modification
;
ut_a
(
buf_
block_get_state
(
block
)
==
BUF_BLOCK_FILE_PAGE
);
ut_a
(
buf_
page_get_state
(
bpage
)
==
BUF_BLOCK_FILE_PAGE
);
ut_a
(
om
>
0
);
ut_a
(
om
>
0
);
b
lock
=
UT_LIST_GET_NEXT
(
flush_list
,
block
);
b
page
=
UT_LIST_GET_NEXT
(
flush_list
,
bpage
);
if
(
b
lock
)
{
if
(
b
page
)
{
ut_a
(
om
>=
b
lock
->
oldest_modification
);
ut_a
(
om
>=
b
page
->
oldest_modification
);
}
}
}
}
...
...
buf/buf0lru.c
View file @
b03460d9
...
@@ -130,14 +130,15 @@ buf_LRU_invalidate_tablespace(
...
@@ -130,14 +130,15 @@ buf_LRU_invalidate_tablespace(
goto
scan_again
;
goto
scan_again
;
}
}
if
(
block
->
oldest_modification
!=
0
)
{
if
(
block
->
page
.
oldest_modification
!=
0
)
{
/* Remove from the flush list of modified
/* Remove from the flush list of modified
blocks */
blocks */
block
->
oldest_modification
=
0
;
block
->
page
.
oldest_modification
=
0
;
UT_LIST_REMOVE
(
flush_list
,
UT_LIST_REMOVE
(
flush_list
,
buf_pool
->
flush_list
,
block
);
buf_pool
->
flush_list
,
&
(
block
->
page
));
}
}
/* Remove from the LRU list */
/* Remove from the LRU list */
...
@@ -913,7 +914,7 @@ buf_LRU_block_remove_hashed_page(
...
@@ -913,7 +914,7 @@ buf_LRU_block_remove_hashed_page(
ut_a
(
buf_block_get_state
(
block
)
==
BUF_BLOCK_FILE_PAGE
);
ut_a
(
buf_block_get_state
(
block
)
==
BUF_BLOCK_FILE_PAGE
);
ut_a
(
block
->
io_fix
==
0
);
ut_a
(
block
->
io_fix
==
0
);
ut_a
(
block
->
buf_fix_count
==
0
);
ut_a
(
block
->
buf_fix_count
==
0
);
ut_a
(
block
->
oldest_modification
==
0
);
ut_a
(
block
->
page
.
oldest_modification
==
0
);
buf_LRU_remove_block
(
block
);
buf_LRU_remove_block
(
block
);
...
@@ -1091,7 +1092,7 @@ buf_LRU_print(void)
...
@@ -1091,7 +1092,7 @@ buf_LRU_print(void)
fprintf
(
stderr
,
"io_fix %lu "
,
(
ulong
)
block
->
io_fix
);
fprintf
(
stderr
,
"io_fix %lu "
,
(
ulong
)
block
->
io_fix
);
}
}
if
(
block
->
oldest_modification
)
{
if
(
block
->
page
.
oldest_modification
)
{
fputs
(
"modif. "
,
stderr
);
fputs
(
"modif. "
,
stderr
);
}
}
...
...
include/buf0buf.h
View file @
b03460d9
...
@@ -33,13 +33,6 @@ Created 11/5/1995 Heikki Tuuri
...
@@ -33,13 +33,6 @@ Created 11/5/1995 Heikki Tuuri
#include "os0proc.h"
#include "os0proc.h"
#include "page0types.h"
#include "page0types.h"
/* Flags for flush types */
#define BUF_FLUSH_LRU 1
#define BUF_FLUSH_SINGLE_PAGE 2
#define BUF_FLUSH_LIST 3
/* An array in the pool struct
has size BUF_FLUSH_LIST + 1: if you
add more flush types, put them in
the middle! */
/* Modes for buf_page_get_gen */
/* Modes for buf_page_get_gen */
#define BUF_GET 10
/* get always */
#define BUF_GET 10
/* get always */
#define BUF_GET_IF_IN_POOL 11
/* get if in pool */
#define BUF_GET_IF_IN_POOL 11
/* get if in pool */
...
@@ -541,6 +534,14 @@ buf_block_dbg_add_level(
...
@@ -541,6 +534,14 @@ buf_block_dbg_add_level(
Gets the state of a block. */
Gets the state of a block. */
UNIV_INLINE
UNIV_INLINE
enum
buf_page_state
enum
buf_page_state
buf_page_get_state
(
/*===============*/
/* out: state */
const
buf_page_t
*
bpage
);
/* in: pointer to the control block */
/*************************************************************************
Gets the state of a block. */
UNIV_INLINE
enum
buf_page_state
buf_block_get_state
(
buf_block_get_state
(
/*================*/
/*================*/
/* out: state */
/* out: state */
...
@@ -555,6 +556,23 @@ buf_block_set_state(
...
@@ -555,6 +556,23 @@ buf_block_set_state(
buf_block_t
*
block
,
/* in/out: pointer to control block */
buf_block_t
*
block
,
/* in/out: pointer to control block */
enum
buf_page_state
state
);
/* in: state */
enum
buf_page_state
state
);
/* in: state */
/*************************************************************************
/*************************************************************************
Get the flush type of a page. */
UNIV_INLINE
enum
buf_flush
buf_page_get_flush_type
(
/*====================*/
/* out: flush type */
const
buf_page_t
*
bpage
)
/* in: buffer page */
__attribute__
((
pure
));
/*************************************************************************
Set the flush type of a page. */
UNIV_INLINE
void
buf_page_set_flush_type
(
/*====================*/
buf_page_t
*
bpage
,
/* in: buffer page */
enum
buf_flush
flush_type
);
/* in: flush type */
/*************************************************************************
Map a block to a file page. */
Map a block to a file page. */
UNIV_INLINE
UNIV_INLINE
void
void
...
@@ -713,7 +731,24 @@ struct buf_page_struct{
...
@@ -713,7 +731,24 @@ struct buf_page_struct{
ulint
space
:
32
;
/* tablespace id */
ulint
space
:
32
;
/* tablespace id */
ulint
offset
:
32
;
/* page number */
ulint
offset
:
32
;
/* page number */
page_zip_des_t
zip
;
/* compressed page; zip.state
page_zip_des_t
zip
;
/* compressed page; zip.state
is relevant for all pages */
and zip.flush_type are relevant
for all pages */
/* 2. Page flushing fields; protected by buf_pool->mutex */
UT_LIST_NODE_T
(
buf_page_t
)
flush_list
;
/* node of the modified, not yet
flushed blocks list */
ib_ulonglong
newest_modification
;
/* log sequence number of the youngest
modification to this block, zero if
not modified */
ib_ulonglong
oldest_modification
;
/* log sequence number of the START of
the log entry written of the oldest
modification to this block which has
not yet been flushed on disk; zero if
all modifications are on disk */
};
};
/* The buffer control block structure */
/* The buffer control block structure */
...
@@ -750,25 +785,6 @@ struct buf_block_struct{
...
@@ -750,25 +785,6 @@ struct buf_block_struct{
buffer pool which are index pages,
buffer pool which are index pages,
but this flag is not set because
but this flag is not set because
we do not keep track of all pages */
we do not keep track of all pages */
/* 2. Page flushing fields */
UT_LIST_NODE_T
(
buf_block_t
)
flush_list
;
/* node of the modified, not yet
flushed blocks list */
ib_ulonglong
newest_modification
;
/* log sequence number of the youngest
modification to this block, zero if
not modified */
ib_ulonglong
oldest_modification
;
/* log sequence number of the START of
the log entry written of the oldest
modification to this block which has
not yet been flushed on disk; zero if
all modifications are on disk */
ulint
flush_type
;
/* if this block is currently being
flushed to disk, this tells the
flush_type: BUF_FLUSH_LRU or
BUF_FLUSH_LIST */
/* 3. LRU replacement algorithm fields */
/* 3. LRU replacement algorithm fields */
...
@@ -921,16 +937,16 @@ struct buf_pool_struct{
...
@@ -921,16 +937,16 @@ struct buf_pool_struct{
the pool with no read */
the pool with no read */
/* 2. Page flushing algorithm fields */
/* 2. Page flushing algorithm fields */
UT_LIST_BASE_NODE_T
(
buf_
block
_t
)
flush_list
;
UT_LIST_BASE_NODE_T
(
buf_
page
_t
)
flush_list
;
/* base node of the modified block
/* base node of the modified block
list */
list */
ibool
init_flush
[
BUF_FLUSH_
LIST
+
1
];
ibool
init_flush
[
BUF_FLUSH_
N_TYPES
];
/* this is TRUE when a flush of the
/* this is TRUE when a flush of the
given type is being initialized */
given type is being initialized */
ulint
n_flush
[
BUF_FLUSH_
LIST
+
1
];
ulint
n_flush
[
BUF_FLUSH_
N_TYPES
];
/* this is the number of pending
/* this is the number of pending
writes in the given flush type */
writes in the given flush type */
os_event_t
no_flush
[
BUF_FLUSH_
LIST
+
1
];
os_event_t
no_flush
[
BUF_FLUSH_
N_TYPES
];
/* this is in the set state when there
/* this is in the set state when there
is no flush batch of the given type
is no flush batch of the given type
running */
running */
...
...
include/buf0buf.ic
View file @
b03460d9
...
@@ -47,17 +47,17 @@ buf_pool_get_oldest_modification(void)
...
@@ -47,17 +47,17 @@ buf_pool_get_oldest_modification(void)
/* out: oldest modification in pool,
/* out: oldest modification in pool,
zero if none */
zero if none */
{
{
buf_
block_t* block
;
buf_
page_t* bpage
;
ib_ulonglong lsn;
ib_ulonglong lsn;
mutex_enter(&(buf_pool->mutex));
mutex_enter(&(buf_pool->mutex));
b
lock
= UT_LIST_GET_LAST(buf_pool->flush_list);
b
page
= UT_LIST_GET_LAST(buf_pool->flush_list);
if (b
lock
== NULL) {
if (b
page
== NULL) {
lsn = 0;
lsn = 0;
} else {
} else {
lsn = b
lock
->oldest_modification;
lsn = b
page
->oldest_modification;
}
}
mutex_exit(&(buf_pool->mutex));
mutex_exit(&(buf_pool->mutex));
...
@@ -87,12 +87,12 @@ buf_pool_clock_tic(void)
...
@@ -87,12 +87,12 @@ buf_pool_clock_tic(void)
Gets the state of a block. */
Gets the state of a block. */
UNIV_INLINE
UNIV_INLINE
enum buf_page_state
enum buf_page_state
buf_
block
_get_state(
buf_
page
_get_state(
/*===============
=
*/
/*===============*/
/* out: state */
/* out: state */
const buf_
block_t* block
) /* in: pointer to the control block */
const buf_
page_t* bpage
) /* in: pointer to the control block */
{
{
enum buf_page_state state = b
lock->page.
zip.state;
enum buf_page_state state = b
page->
zip.state;
#ifdef UNIV_DEBUG
#ifdef UNIV_DEBUG
switch (state) {
switch (state) {
...
@@ -111,6 +111,17 @@ buf_block_get_state(
...
@@ -111,6 +111,17 @@ buf_block_get_state(
return(state);
return(state);
}
}
/*************************************************************************
/*************************************************************************
Gets the state of a block. */
UNIV_INLINE
enum buf_page_state
buf_block_get_state(
/*================*/
/* out: state */
const buf_block_t* block) /* in: pointer to the control block */
{
return(buf_page_get_state(&block->page));
}
/*************************************************************************
Sets the state of a block. */
Sets the state of a block. */
UNIV_INLINE
UNIV_INLINE
void
void
...
@@ -149,6 +160,43 @@ buf_block_set_state(
...
@@ -149,6 +160,43 @@ buf_block_set_state(
block->page.zip.state = state;
block->page.zip.state = state;
ut_ad(buf_block_get_state(block) == state);
ut_ad(buf_block_get_state(block) == state);
}
}
/*************************************************************************
Get the flush type of a page. */
UNIV_INLINE
enum buf_flush
buf_page_get_flush_type(
/*====================*/
/* out: flush type */
const buf_page_t* bpage) /* in: buffer page */
{
enum buf_flush flush_type = bpage->zip.flush_type;
#ifdef UNIV_DEBUG
switch (flush_type) {
case BUF_FLUSH_LRU:
case BUF_FLUSH_SINGLE_PAGE:
case BUF_FLUSH_LIST:
return(flush_type);
case BUF_FLUSH_N_TYPES:
}
ut_error;
#endif /* UNIV_DEBUG */
return(flush_type);
}
/*************************************************************************
Set the flush type of a page. */
UNIV_INLINE
void
buf_page_set_flush_type(
/*====================*/
buf_page_t* bpage, /* in: buffer page */
enum buf_flush flush_type) /* in: flush type */
{
bpage->zip.flush_type = flush_type;
ut_ad(buf_page_get_flush_type(bpage) == flush_type);
}
/*************************************************************************
/*************************************************************************
Map a block to a file page. */
Map a block to a file page. */
UNIV_INLINE
UNIV_INLINE
...
@@ -422,7 +470,7 @@ buf_block_get_newest_modification(
...
@@ -422,7 +470,7 @@ buf_block_get_newest_modification(
mutex_enter(&(buf_pool->mutex));
mutex_enter(&(buf_pool->mutex));
if (buf_block_get_state(block) == BUF_BLOCK_FILE_PAGE) {
if (buf_block_get_state(block) == BUF_BLOCK_FILE_PAGE) {
lsn = block->newest_modification;
lsn = block->
page.
newest_modification;
} else {
} else {
lsn = 0;
lsn = 0;
}
}
...
...
include/buf0flu.h
View file @
b03460d9
...
@@ -52,7 +52,7 @@ buf_flush_batch(
...
@@ -52,7 +52,7 @@ buf_flush_batch(
write request was queued;
write request was queued;
ULINT_UNDEFINED if there was a flush
ULINT_UNDEFINED if there was a flush
of the same type already running */
of the same type already running */
ulint
flush_type
,
/* in: BUF_FLUSH_LRU or
enum
buf_flush
flush_type
,
/* in: BUF_FLUSH_LRU or
BUF_FLUSH_LIST; if BUF_FLUSH_LIST,
BUF_FLUSH_LIST; if BUF_FLUSH_LIST,
then the caller must not own any
then the caller must not own any
latches on pages */
latches on pages */
...
@@ -70,7 +70,7 @@ Waits until a flush batch of the given type ends */
...
@@ -70,7 +70,7 @@ Waits until a flush batch of the given type ends */
void
void
buf_flush_wait_batch_end
(
buf_flush_wait_batch_end
(
/*=====================*/
/*=====================*/
ulint
type
);
/* in: BUF_FLUSH_LRU or BUF_FLUSH_LIST */
enum
buf_flush
type
);
/* in: BUF_FLUSH_LRU or BUF_FLUSH_LIST */
/************************************************************************
/************************************************************************
This function should be called at a mini-transaction commit, if a page was
This function should be called at a mini-transaction commit, if a page was
modified in it. Puts the block to the list of modified blocks, if it not
modified in it. Puts the block to the list of modified blocks, if it not
...
...
include/buf0flu.ic
View file @
b03460d9
...
@@ -15,7 +15,7 @@ Inserts a modified block into the flush list. */
...
@@ -15,7 +15,7 @@ Inserts a modified block into the flush list. */
void
void
buf_flush_insert_into_flush_list(
buf_flush_insert_into_flush_list(
/*=============================*/
/*=============================*/
buf_
block
_t* block); /* in: block which is modified */
buf_
page
_t* block); /* in: block which is modified */
/************************************************************************
/************************************************************************
Inserts a modified block into the flush list in the right sorted position.
Inserts a modified block into the flush list in the right sorted position.
This function is used by recovery, because there the modifications do not
This function is used by recovery, because there the modifications do not
...
@@ -24,7 +24,7 @@ necessarily come in the order of lsn's. */
...
@@ -24,7 +24,7 @@ necessarily come in the order of lsn's. */
void
void
buf_flush_insert_sorted_into_flush_list(
buf_flush_insert_sorted_into_flush_list(
/*====================================*/
/*====================================*/
buf_
block
_t* block); /* in: block which is modified */
buf_
page
_t* block); /* in: block which is modified */
/************************************************************************
/************************************************************************
This function should be called at a mini-transaction commit, if a page was
This function should be called at a mini-transaction commit, if a page was
...
@@ -49,16 +49,16 @@ buf_flush_note_modification(
...
@@ -49,16 +49,16 @@ buf_flush_note_modification(
ut_ad(mtr->modifications);
ut_ad(mtr->modifications);
ut_ad(block->newest_modification <= mtr->end_lsn);
ut_ad(block->newest_modification <= mtr->end_lsn);
block->newest_modification = mtr->end_lsn;
block->
page.
newest_modification = mtr->end_lsn;
if (!block->oldest_modification) {
if (!block->
page.
oldest_modification) {
block->oldest_modification = mtr->start_lsn;
block->
page.
oldest_modification = mtr->start_lsn;
ut_ad(block->oldest_modification != 0);
ut_ad(block->
page.
oldest_modification != 0);
buf_flush_insert_into_flush_list(
block
);
buf_flush_insert_into_flush_list(
&block->page
);
} else {
} else {
ut_ad(block->oldest_modification <= mtr->start_lsn);
ut_ad(block->
page.
oldest_modification <= mtr->start_lsn);
}
}
++srv_buf_pool_write_requests;
++srv_buf_pool_write_requests;
...
@@ -85,19 +85,19 @@ buf_flush_recv_note_modification(
...
@@ -85,19 +85,19 @@ buf_flush_recv_note_modification(
mutex_enter(&(buf_pool->mutex));
mutex_enter(&(buf_pool->mutex));
ut_ad(block->newest_modification <= end_lsn);
ut_ad(block->
page.
newest_modification <= end_lsn);
block->newest_modification = end_lsn;
block->
page.
newest_modification = end_lsn;
if (!block->oldest_modification) {
if (!block->
page.
oldest_modification) {
block->oldest_modification = start_lsn;
block->
page.
oldest_modification = start_lsn;
ut_ad(block->oldest_modification != 0);
ut_ad(block->
page.
oldest_modification != 0);
buf_flush_insert_sorted_into_flush_list(
block
);
buf_flush_insert_sorted_into_flush_list(
&block->page
);
} else {
} else {
ut_ad(block->oldest_modification <= start_lsn);
ut_ad(block->
page.
oldest_modification <= start_lsn);
}
}
mutex_exit(&(buf_pool->mutex));
mutex_exit(&(buf_pool->mutex));
...
...
include/buf0types.h
View file @
b03460d9
...
@@ -17,6 +17,13 @@ typedef struct buf_pool_struct buf_pool_t;
...
@@ -17,6 +17,13 @@ typedef struct buf_pool_struct buf_pool_t;
/* The 'type' used of a buffer frame */
/* The 'type' used of a buffer frame */
typedef
byte
buf_frame_t
;
typedef
byte
buf_frame_t
;
/* Flags for flush types */
enum
buf_flush
{
BUF_FLUSH_LRU
=
0
,
BUF_FLUSH_SINGLE_PAGE
,
BUF_FLUSH_LIST
,
BUF_FLUSH_N_TYPES
/* index of last element + 1 */
};
#endif
#endif
include/page0types.h
View file @
b03460d9
...
@@ -33,7 +33,11 @@ struct page_zip_des_struct
...
@@ -33,7 +33,11 @@ struct page_zip_des_struct
page_zip_t
*
data
;
/* compressed page data */
page_zip_t
*
data
;
/* compressed page data */
ulint
state
:
3
;
/* state of the control block
ulint
state
:
3
;
/* state of the control block
(cf. enum buf_page_state) */
(cf. enum buf_page_state) */
ulint
:
11
;
/* reserved */
ulint
flush_type
:
2
;
/* if this block is currently being
flushed to disk, this tells the
flush_type (cf. enum buf_flush);
protected by block->mutex */
ulint
:
9
;
/* reserved */
ulint
n_blobs
:
12
;
/* number of externally stored
ulint
n_blobs
:
12
;
/* number of externally stored
columns on the page; the maximum
columns on the page; the maximum
is 744 on a 16 KiB page */
is 744 on a 16 KiB page */
...
...
include/page0zip.h
View file @
b03460d9
...
@@ -28,7 +28,7 @@ page_zip_get_size(
...
@@ -28,7 +28,7 @@ page_zip_get_size(
/*==============*/
/*==============*/
/* out: size in bytes */
/* out: size in bytes */
const
page_zip_des_t
*
page_zip
)
/* in: compressed page */
const
page_zip_des_t
*
page_zip
)
/* in: compressed page */
__attribute__
((
nonnull
,
const
));
__attribute__
((
nonnull
,
pure
));
/**************************************************************************
/**************************************************************************
Set the size of a compressed page in bytes. */
Set the size of a compressed page in bytes. */
UNIV_INLINE
UNIV_INLINE
...
...
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