Commit aedce8cd authored by marko's avatar marko

branches/zip: Move the fields related to the least-recently-used algorithm

of the buffer pool from buf_block_t to buf_page_t.  Replace some buf_block_t*
parameters with buf_page_t*.  Add accessor functions.
parent 69f87fb0
...@@ -907,7 +907,7 @@ btr_search_guess_on_hash( ...@@ -907,7 +907,7 @@ btr_search_guess_on_hash(
if (UNIV_LIKELY(!has_search_latch) if (UNIV_LIKELY(!has_search_latch)
&& buf_block_peek_if_too_old(block)) { && buf_block_peek_if_too_old(block)) {
buf_page_make_young(block); buf_page_make_young(&block->page);
} }
/* Increment the page get statistics though we did not really /* Increment the page get statistics though we did not really
...@@ -985,7 +985,7 @@ retry: ...@@ -985,7 +985,7 @@ retry:
#ifdef UNIV_SYNC_DEBUG #ifdef UNIV_SYNC_DEBUG
ut_ad(rw_lock_own(&(block->lock), RW_LOCK_SHARED) ut_ad(rw_lock_own(&(block->lock), RW_LOCK_SHARED)
|| rw_lock_own(&(block->lock), RW_LOCK_EX) || rw_lock_own(&(block->lock), RW_LOCK_EX)
|| (block->buf_fix_count == 0)); || (block->page.buf_fix_count == 0));
#endif /* UNIV_SYNC_DEBUG */ #endif /* UNIV_SYNC_DEBUG */
n_fields = block->curr_n_fields; n_fields = block->curr_n_fields;
......
This diff is collapsed.
...@@ -113,27 +113,31 @@ ibool ...@@ -113,27 +113,31 @@ ibool
buf_flush_ready_for_replace( buf_flush_ready_for_replace(
/*========================*/ /*========================*/
/* out: TRUE if can replace immediately */ /* out: TRUE if can replace immediately */
buf_block_t* block) /* in: buffer control block, must be in state buf_page_t* bpage) /* in: buffer control block, must be in state
BUF_BLOCK_FILE_PAGE and in the LRU list */ BUF_BLOCK_FILE_PAGE or BUF_BLOCK_ZIP_PAGE
and in the LRU list */
{ {
#ifdef UNIV_SYNC_DEBUG #ifdef UNIV_SYNC_DEBUG
ut_ad(mutex_own(&(buf_pool->mutex))); ut_ad(mutex_own(&(buf_pool->mutex)));
ut_ad(mutex_own(&block->mutex)); ut_ad(mutex_own(buf_page_get_mutex(bpage)));
#endif /* UNIV_SYNC_DEBUG */ #endif /* UNIV_SYNC_DEBUG */
if (UNIV_UNLIKELY(buf_block_get_state(block) != BUF_BLOCK_FILE_PAGE)) { ut_ad(bpage->in_LRU_list);
if (UNIV_LIKELY(buf_page_in_file(bpage))) {
return(bpage->oldest_modification == 0
&& buf_page_get_io_fix(bpage) == BUF_IO_NONE
&& bpage->buf_fix_count == 0);
}
ut_print_timestamp(stderr); ut_print_timestamp(stderr);
fprintf(stderr, fprintf(stderr,
" InnoDB: Error: buffer block state %lu" " InnoDB: Error: buffer block state %lu"
" in the LRU list!\n", " in the LRU list!\n",
(ulong) buf_block_get_state(block)); (ulong) buf_page_get_state(bpage));
ut_print_buf(stderr, block, sizeof(buf_block_t)); ut_print_buf(stderr, bpage, sizeof(buf_page_t));
return(FALSE); return(FALSE);
}
return(block->page.oldest_modification == 0
&& block->buf_fix_count == 0
&& block->io_fix == 0);
} }
/************************************************************************ /************************************************************************
...@@ -143,22 +147,24 @@ ibool ...@@ -143,22 +147,24 @@ ibool
buf_flush_ready_for_flush( 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_page_t* bpage, /* in: buffer control block, must be in state
BUF_BLOCK_FILE_PAGE */ BUF_BLOCK_FILE_PAGE */
enum buf_flush flush_type)/* in: BUF_FLUSH_LRU or BUF_FLUSH_LIST */ enum buf_flush flush_type)/* in: BUF_FLUSH_LRU or BUF_FLUSH_LIST */
{ {
ut_a(buf_page_in_file(bpage));
#ifdef UNIV_SYNC_DEBUG #ifdef UNIV_SYNC_DEBUG
ut_ad(mutex_own(&(buf_pool->mutex))); ut_ad(mutex_own(&(buf_pool->mutex)));
ut_ad(mutex_own(&(block->mutex))); ut_ad(mutex_own(buf_page_get_mutex(bpage)));
#endif /* UNIV_SYNC_DEBUG */ #endif /* UNIV_SYNC_DEBUG */
ut_a(buf_block_get_state(block) == BUF_BLOCK_FILE_PAGE);
if (block->page.oldest_modification != 0 && block->io_fix == 0) { if (bpage->oldest_modification != 0
&& buf_page_get_io_fix(bpage) == BUF_IO_NONE) {
if (flush_type != BUF_FLUSH_LRU) { if (flush_type != BUF_FLUSH_LRU) {
return(TRUE); return(TRUE);
} else if (block->buf_fix_count == 0) { } else if (bpage->buf_fix_count == 0) {
/* If we are flushing the LRU list, to avoid deadlocks /* If we are flushing the LRU list, to avoid deadlocks
we require the block not to be bufferfixed, and hence we require the block not to be bufferfixed, and hence
...@@ -177,30 +183,30 @@ Updates the flush system data structures when a write is completed. */ ...@@ -177,30 +183,30 @@ Updates the flush system data structures when a write is completed. */
void void
buf_flush_write_complete( buf_flush_write_complete(
/*=====================*/ /*=====================*/
buf_block_t* block) /* in: pointer to the block in question */ buf_page_t* bpage) /* in: pointer to the block in question */
{ {
enum buf_flush flush_type; enum buf_flush flush_type;
ut_ad(block); ut_ad(bpage);
#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_in_file(bpage));
block->page.oldest_modification = 0; bpage->oldest_modification = 0;
UT_LIST_REMOVE(flush_list, buf_pool->flush_list, &(block->page)); UT_LIST_REMOVE(flush_list, buf_pool->flush_list, bpage);
ut_d(UT_LIST_VALIDATE(flush_list, buf_page_t, buf_pool->flush_list)); ut_d(UT_LIST_VALIDATE(flush_list, buf_page_t, buf_pool->flush_list));
flush_type = buf_page_get_flush_type(&block->page); flush_type = buf_page_get_flush_type(bpage);
buf_pool->n_flush[flush_type]--; buf_pool->n_flush[flush_type]--;
if (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 */
buf_LRU_make_block_old(block); buf_LRU_make_block_old(bpage);
buf_pool->LRU_flush_ended++; buf_pool->LRU_flush_ended++;
} }
...@@ -409,8 +415,8 @@ flush: ...@@ -409,8 +415,8 @@ flush:
" the doublewrite buffer.\n" " the doublewrite buffer.\n"
"InnoDB: Page buf fix count %lu," "InnoDB: Page buf fix count %lu,"
" io fix %lu, state %lu\n", " io fix %lu, state %lu\n",
(ulong)block->buf_fix_count, (ulong)block->page.buf_fix_count,
(ulong)block->io_fix, (ulong)buf_block_get_io_fix(block),
(ulong)buf_block_get_state(block)); (ulong)buf_block_get_state(block));
} }
...@@ -652,9 +658,9 @@ buf_flush_try_page( ...@@ -652,9 +658,9 @@ buf_flush_try_page(
mutex_enter(&block->mutex); mutex_enter(&block->mutex);
if (flush_type == BUF_FLUSH_LIST if (flush_type == BUF_FLUSH_LIST
&& buf_flush_ready_for_flush(block, flush_type)) { && buf_flush_ready_for_flush(&block->page, flush_type)) {
block->io_fix = BUF_IO_WRITE; buf_block_set_io_fix(block, BUF_IO_WRITE);
buf_page_set_flush_type(&block->page, flush_type); buf_page_set_flush_type(&block->page, flush_type);
...@@ -671,7 +677,7 @@ buf_flush_try_page( ...@@ -671,7 +677,7 @@ buf_flush_try_page(
not wait for any latch, as we may end up in a deadlock: not wait for any latch, as we may end up in a deadlock:
if buf_fix_count == 0, then we know we need not wait */ if buf_fix_count == 0, then we know we need not wait */
if (block->buf_fix_count == 0) { if (block->page.buf_fix_count == 0) {
rw_lock_s_lock_gen(&(block->lock), BUF_IO_WRITE); rw_lock_s_lock_gen(&(block->lock), BUF_IO_WRITE);
locked = TRUE; locked = TRUE;
...@@ -700,7 +706,7 @@ buf_flush_try_page( ...@@ -700,7 +706,7 @@ buf_flush_try_page(
return(1); return(1);
} else if (flush_type == BUF_FLUSH_LRU } else if (flush_type == BUF_FLUSH_LRU
&& buf_flush_ready_for_flush(block, flush_type)) { && buf_flush_ready_for_flush(&block->page, flush_type)) {
/* VERY IMPORTANT: /* VERY IMPORTANT:
Because any thread may call the LRU flush, even when owning Because any thread may call the LRU flush, even when owning
...@@ -710,7 +716,7 @@ buf_flush_try_page( ...@@ -710,7 +716,7 @@ buf_flush_try_page(
the page not to be bufferfixed (in function the page not to be bufferfixed (in function
..._ready_for_flush). */ ..._ready_for_flush). */
block->io_fix = BUF_IO_WRITE; buf_block_set_io_fix(block, BUF_IO_WRITE);
buf_page_set_flush_type(&block->page, flush_type); buf_page_set_flush_type(&block->page, flush_type);
...@@ -735,9 +741,9 @@ buf_flush_try_page( ...@@ -735,9 +741,9 @@ buf_flush_try_page(
return(1); return(1);
} else if (flush_type == BUF_FLUSH_SINGLE_PAGE } else if (flush_type == BUF_FLUSH_SINGLE_PAGE
&& buf_flush_ready_for_flush(block, flush_type)) { && buf_flush_ready_for_flush(&block->page, flush_type)) {
block->io_fix = BUF_IO_WRITE; buf_block_set_io_fix(block, BUF_IO_WRITE);
buf_page_set_flush_type(&block->page, flush_type); buf_page_set_flush_type(&block->page, flush_type);
...@@ -823,7 +829,7 @@ buf_flush_try_neighbors( ...@@ -823,7 +829,7 @@ buf_flush_try_neighbors(
continue; continue;
} else if (flush_type == BUF_FLUSH_LRU && i != offset } else if (flush_type == BUF_FLUSH_LRU && i != offset
&& !block->old) { && !buf_page_is_old(&block->page)) {
/* We avoid flushing 'non-old' blocks in an LRU flush, /* We avoid flushing 'non-old' blocks in an LRU flush,
because the flushed blocks are soon freed */ because the flushed blocks are soon freed */
...@@ -833,8 +839,8 @@ buf_flush_try_neighbors( ...@@ -833,8 +839,8 @@ buf_flush_try_neighbors(
mutex_enter(&block->mutex); mutex_enter(&block->mutex);
if (buf_flush_ready_for_flush(block, flush_type) if (buf_flush_ready_for_flush(&block->page, flush_type)
&& (i == offset || block->buf_fix_count == 0)) { && (i == offset || !block->page.buf_fix_count)) {
/* We only try to flush those /* We only try to flush those
neighbors != offset where the buf fix count is neighbors != offset where the buf fix count is
zero, as we then know that we probably can zero, as we then know that we probably can
...@@ -895,7 +901,7 @@ buf_flush_batch( ...@@ -895,7 +901,7 @@ buf_flush_batch(
(if their number does not exceed (if their number does not exceed
min_n), otherwise ignored */ min_n), otherwise ignored */
{ {
buf_block_t* block; buf_page_t* bpage;
ulint page_count = 0; ulint page_count = 0;
ulint old_page_count; ulint old_page_count;
ulint space; ulint space;
...@@ -933,13 +939,13 @@ buf_flush_batch( ...@@ -933,13 +939,13 @@ buf_flush_batch(
block to be flushed. */ block to be flushed. */
if (flush_type == BUF_FLUSH_LRU) { if (flush_type == BUF_FLUSH_LRU) {
block = UT_LIST_GET_LAST(buf_pool->LRU); bpage = UT_LIST_GET_LAST(buf_pool->LRU);
} else { } else {
ut_ad(flush_type == BUF_FLUSH_LIST); ut_ad(flush_type == BUF_FLUSH_LIST);
block = UT_LIST_GET_LAST(buf_pool->flush_list); bpage = UT_LIST_GET_LAST(buf_pool->flush_list);
if (!block if (!bpage
|| block->page.oldest_modification >= lsn_limit) { || bpage->oldest_modification >= lsn_limit) {
/* We have flushed enough */ /* We have flushed enough */
break; break;
...@@ -954,19 +960,21 @@ buf_flush_batch( ...@@ -954,19 +960,21 @@ buf_flush_batch(
during the flushing and we cannot safely preserve within this during the flushing and we cannot safely preserve within this
function a pointer to a block in the list! */ function a pointer to a block in the list! */
while ((block != NULL) && !found) { while ((bpage != NULL) && !found) {
ut_a(buf_block_get_state(block) == BUF_BLOCK_FILE_PAGE); mutex_t* block_mutex = buf_page_get_mutex(bpage);
mutex_enter(&block->mutex); ut_a(buf_page_in_file(bpage));
mutex_enter(block_mutex);
if (buf_flush_ready_for_flush(block, flush_type)) { if (buf_flush_ready_for_flush(bpage, flush_type)) {
found = TRUE; found = TRUE;
space = buf_block_get_space(block); space = buf_page_get_space(bpage);
offset = buf_block_get_page_no(block); offset = buf_page_get_page_no(bpage);
mutex_exit(&block->mutex);
mutex_exit(&(buf_pool->mutex)); mutex_exit(&(buf_pool->mutex));
mutex_exit(block_mutex);
old_page_count = page_count; old_page_count = page_count;
...@@ -982,16 +990,15 @@ buf_flush_batch( ...@@ -982,16 +990,15 @@ buf_flush_batch(
} else if (flush_type == BUF_FLUSH_LRU) { } else if (flush_type == BUF_FLUSH_LRU) {
mutex_exit(&block->mutex); mutex_exit(block_mutex);
block = UT_LIST_GET_PREV(LRU, block); bpage = UT_LIST_GET_PREV(LRU, bpage);
} else { } else {
ut_ad(flush_type == BUF_FLUSH_LIST); ut_ad(flush_type == BUF_FLUSH_LIST);
mutex_exit(&block->mutex); mutex_exit(block_mutex);
block = UT_LIST_GET_PREV(flush_list, bpage = UT_LIST_GET_PREV(flush_list, bpage);
(&block->page));
} }
} }
...@@ -1058,7 +1065,7 @@ buf_flush_LRU_recommendation(void) ...@@ -1058,7 +1065,7 @@ buf_flush_LRU_recommendation(void)
/* out: number of blocks which should be flushed /* out: number of blocks which should be flushed
from the end of the LRU list */ from the end of the LRU list */
{ {
buf_block_t* block; buf_page_t* bpage;
ulint n_replaceable; ulint n_replaceable;
ulint distance = 0; ulint distance = 0;
...@@ -1066,24 +1073,26 @@ buf_flush_LRU_recommendation(void) ...@@ -1066,24 +1073,26 @@ buf_flush_LRU_recommendation(void)
n_replaceable = UT_LIST_GET_LEN(buf_pool->free); n_replaceable = UT_LIST_GET_LEN(buf_pool->free);
block = UT_LIST_GET_LAST(buf_pool->LRU); bpage = UT_LIST_GET_LAST(buf_pool->LRU);
while ((block != NULL) while ((bpage != NULL)
&& (n_replaceable < BUF_FLUSH_FREE_BLOCK_MARGIN && (n_replaceable < BUF_FLUSH_FREE_BLOCK_MARGIN
+ BUF_FLUSH_EXTRA_MARGIN) + BUF_FLUSH_EXTRA_MARGIN)
&& (distance < BUF_LRU_FREE_SEARCH_LEN)) { && (distance < BUF_LRU_FREE_SEARCH_LEN)) {
mutex_enter(&block->mutex); mutex_t* block_mutex = buf_page_get_mutex(bpage);
if (buf_flush_ready_for_replace(block)) { mutex_enter(block_mutex);
if (buf_flush_ready_for_replace(bpage)) {
n_replaceable++; n_replaceable++;
} }
mutex_exit(&block->mutex); mutex_exit(block_mutex);
distance++; distance++;
block = UT_LIST_GET_PREV(LRU, block); bpage = UT_LIST_GET_PREV(LRU, bpage);
} }
mutex_exit(&(buf_pool->mutex)); mutex_exit(&(buf_pool->mutex));
......
This diff is collapsed.
...@@ -175,7 +175,6 @@ buf_read_ahead_random( ...@@ -175,7 +175,6 @@ buf_read_ahead_random(
wants to access */ wants to access */
{ {
ib_longlong tablespace_version; ib_longlong tablespace_version;
buf_block_t* block;
ulint recent_blocks = 0; ulint recent_blocks = 0;
ulint count; ulint count;
ulint LRU_recent_limit; ulint LRU_recent_limit;
...@@ -233,11 +232,11 @@ buf_read_ahead_random( ...@@ -233,11 +232,11 @@ buf_read_ahead_random(
that is, reside near the start of the LRU list. */ that is, reside near the start of the LRU list. */
for (i = low; i < high; i++) { for (i = low; i < high; i++) {
block = buf_page_hash_get(space, i); const buf_page_t* bpage = buf_page_hash_get(space, i);
if ((block) if (bpage
&& block->accessed && buf_page_is_accessed(bpage)
&& (block->LRU_position > LRU_recent_limit)) { && (buf_page_get_LRU_position(bpage) > LRU_recent_limit)) {
recent_blocks++; recent_blocks++;
...@@ -386,9 +385,9 @@ buf_read_ahead_linear( ...@@ -386,9 +385,9 @@ buf_read_ahead_linear(
must want access to this page (see NOTE 3 above) */ must want access to this page (see NOTE 3 above) */
{ {
ib_longlong tablespace_version; ib_longlong tablespace_version;
buf_block_t* block; buf_page_t* bpage;
buf_frame_t* frame; buf_frame_t* frame;
buf_block_t* pred_block = NULL; buf_page_t* pred_bpage = NULL;
ulint pred_offset; ulint pred_offset;
ulint succ_offset; ulint succ_offset;
ulint count; ulint count;
...@@ -461,20 +460,21 @@ buf_read_ahead_linear( ...@@ -461,20 +460,21 @@ buf_read_ahead_linear(
fail_count = 0; fail_count = 0;
for (i = low; i < high; i++) { for (i = low; i < high; i++) {
block = buf_page_hash_get(space, i); bpage = buf_page_hash_get(space, i);
if ((block == NULL) || !block->accessed) { if ((bpage == NULL) || !buf_page_is_accessed(bpage)) {
/* Not accessed */ /* Not accessed */
fail_count++; fail_count++;
} else if (pred_block } else if (pred_bpage
&& (ut_ulint_cmp(block->LRU_position, && (ut_ulint_cmp(
pred_block->LRU_position) buf_page_get_LRU_position(bpage),
buf_page_get_LRU_position(pred_bpage))
!= asc_or_desc)) { != asc_or_desc)) {
/* Accesses not in the right order */ /* Accesses not in the right order */
fail_count++; fail_count++;
pred_block = block; pred_bpage = bpage;
} }
} }
...@@ -490,15 +490,25 @@ buf_read_ahead_linear( ...@@ -490,15 +490,25 @@ buf_read_ahead_linear(
/* If we got this far, we know that enough pages in the area have /* If we got this far, we know that enough pages in the area have
been accessed in the right order: linear read-ahead can be sensible */ been accessed in the right order: linear read-ahead can be sensible */
block = buf_page_hash_get(space, offset); bpage = buf_page_hash_get(space, offset);
if (block == NULL) { if (bpage == NULL) {
mutex_exit(&(buf_pool->mutex)); mutex_exit(&(buf_pool->mutex));
return(0); return(0);
} }
frame = block->frame; switch (buf_page_get_state(bpage)) {
case BUF_BLOCK_ZIP_PAGE:
frame = bpage->zip.data;
break;
case BUF_BLOCK_FILE_PAGE:
frame = ((buf_block_t*) bpage)->frame;
break;
default:
ut_error;
break;
}
/* Read the natural predecessor and successor page addresses from /* Read the natural predecessor and successor page addresses from
the page; NOTE that because the calling thread may have an x-latch the page; NOTE that because the calling thread may have an x-latch
......
This diff is collapsed.
This diff is collapsed.
...@@ -20,7 +20,7 @@ Updates the flush system data structures when a write is completed. */ ...@@ -20,7 +20,7 @@ Updates the flush system data structures when a write is completed. */
void void
buf_flush_write_complete( buf_flush_write_complete(
/*=====================*/ /*=====================*/
buf_block_t* block); /* in: pointer to the block in question */ buf_page_t* bpage); /* in: pointer to the block in question */
/************************************************************************* /*************************************************************************
Flushes pages from the end of the LRU list if there is too small Flushes pages from the end of the LRU list if there is too small
a margin of replaceable pages there. */ a margin of replaceable pages there. */
...@@ -99,8 +99,8 @@ ibool ...@@ -99,8 +99,8 @@ ibool
buf_flush_ready_for_replace( buf_flush_ready_for_replace(
/*========================*/ /*========================*/
/* out: TRUE if can replace immediately */ /* out: TRUE if can replace immediately */
buf_block_t* block); /* in: buffer control block, must buf_page_t* bpage); /* in: buffer control block, must be in state
be in state BUF_BLOCK_FILE_PAGE BUF_BLOCK_FILE_PAGE or BUF_BLOCK_ZIP_PAGE
and in the LRU list */ and in the LRU list */
#if defined UNIV_DEBUG || defined UNIV_BUF_DEBUG #if defined UNIV_DEBUG || defined UNIV_BUF_DEBUG
/********************************************************************** /**********************************************************************
......
...@@ -39,7 +39,7 @@ buf_flush_note_modification( ...@@ -39,7 +39,7 @@ buf_flush_note_modification(
{ {
ut_ad(block); ut_ad(block);
ut_ad(buf_block_get_state(block) == BUF_BLOCK_FILE_PAGE); ut_ad(buf_block_get_state(block) == BUF_BLOCK_FILE_PAGE);
ut_ad(block->buf_fix_count > 0); ut_ad(block->page.buf_fix_count > 0);
#ifdef UNIV_SYNC_DEBUG #ifdef UNIV_SYNC_DEBUG
ut_ad(rw_lock_own(&(block->lock), RW_LOCK_EX)); ut_ad(rw_lock_own(&(block->lock), RW_LOCK_EX));
ut_ad(mutex_own(&(buf_pool->mutex))); ut_ad(mutex_own(&(buf_pool->mutex)));
...@@ -78,7 +78,7 @@ buf_flush_recv_note_modification( ...@@ -78,7 +78,7 @@ buf_flush_recv_note_modification(
{ {
ut_ad(block); ut_ad(block);
ut_ad(buf_block_get_state(block) == BUF_BLOCK_FILE_PAGE); ut_ad(buf_block_get_state(block) == BUF_BLOCK_FILE_PAGE);
ut_ad(block->buf_fix_count > 0); ut_ad(block->page.buf_fix_count > 0);
#ifdef UNIV_SYNC_DEBUG #ifdef UNIV_SYNC_DEBUG
ut_ad(rw_lock_own(&(block->lock), RW_LOCK_EX)); ut_ad(rw_lock_own(&(block->lock), RW_LOCK_EX));
#endif /* UNIV_SYNC_DEBUG */ #endif /* UNIV_SYNC_DEBUG */
......
...@@ -72,7 +72,7 @@ ibool ...@@ -72,7 +72,7 @@ ibool
buf_LRU_free_block( buf_LRU_free_block(
/*===============*/ /*===============*/
/* out: TRUE if freed */ /* out: TRUE if freed */
buf_block_t* block); /* in: block to be freed */ buf_page_t* block); /* in: block to be freed */
/********************************************************************** /**********************************************************************
Look for a replaceable block from the end of the LRU list and put it to Look for a replaceable block from the end of the LRU list and put it to
the free list if found. */ the free list if found. */
...@@ -112,7 +112,7 @@ Adds a block to the LRU list. */ ...@@ -112,7 +112,7 @@ Adds a block to the LRU list. */
void void
buf_LRU_add_block( buf_LRU_add_block(
/*==============*/ /*==============*/
buf_block_t* block, /* in: control block */ buf_page_t* bpage, /* in: control block */
ibool old); /* in: TRUE if should be put to the old ibool old); /* in: TRUE if should be put to the old
blocks in the LRU list, else put to the blocks in the LRU list, else put to the
start; if the LRU list is very short, added to start; if the LRU list is very short, added to
...@@ -123,14 +123,14 @@ Moves a block to the start of the LRU list. */ ...@@ -123,14 +123,14 @@ Moves a block to the start of the LRU list. */
void void
buf_LRU_make_block_young( buf_LRU_make_block_young(
/*=====================*/ /*=====================*/
buf_block_t* block); /* in: control block */ buf_page_t* bpage); /* in: control block */
/********************************************************************** /**********************************************************************
Moves a block to the end of the LRU list. */ Moves a block to the end of the LRU list. */
void void
buf_LRU_make_block_old( buf_LRU_make_block_old(
/*===================*/ /*===================*/
buf_block_t* block); /* in: control block */ buf_page_t* bpage); /* in: control block */
#if defined UNIV_DEBUG || defined UNIV_BUF_DEBUG #if defined UNIV_DEBUG || defined UNIV_BUF_DEBUG
/************************************************************************** /**************************************************************************
Validates the LRU list. */ Validates the LRU list. */
......
...@@ -25,5 +25,12 @@ enum buf_flush { ...@@ -25,5 +25,12 @@ enum buf_flush {
BUF_FLUSH_N_TYPES /* index of last element + 1 */ BUF_FLUSH_N_TYPES /* index of last element + 1 */
}; };
/* Flags for io_fix types */
enum buf_io_fix {
BUF_IO_NONE = 0, /**< no pending I/O */
BUF_IO_READ, /**< read pending */
BUF_IO_WRITE /**< write pending */
};
#endif #endif
...@@ -223,7 +223,7 @@ ibuf_update_free_bits_if_full( ...@@ -223,7 +223,7 @@ ibuf_update_free_bits_if_full(
cannot make inserts using the insert buffer from slipping cannot make inserts using the insert buffer from slipping
out of the buffer pool */ out of the buffer pool */
buf_page_make_young(block); buf_page_make_young(&block->page);
} }
if (before > after) { if (before > after) {
......
...@@ -3805,7 +3805,7 @@ wrong_offs: ...@@ -3805,7 +3805,7 @@ wrong_offs:
" buf block fix count %lu\n", " buf block fix count %lu\n",
(void*) rec, (ulong) (void*) rec, (ulong)
btr_cur_get_block(btr_pcur_get_btr_cur(pcur)) btr_cur_get_block(btr_pcur_get_btr_cur(pcur))
->buf_fix_count); ->page.buf_fix_count);
fprintf(stderr, fprintf(stderr,
"InnoDB: Index corruption: rec offs %lu" "InnoDB: Index corruption: rec offs %lu"
" next offs %lu, page no %lu,\n" " next offs %lu, page no %lu,\n"
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment