Commit 9478ec03 authored by marko's avatar marko

branches/zip: buf_relocate(): Copy the block. Invalidate the source block.

buf_buddy_block_free(), buf_buddy_free_low(): Flag the freed bytes
uninitialized.

buf_page_init_for_read(), buf_buddy_relocate(): Do not refer to bpage
after invoking buf_relocate().

buf_buddy_relocate(): Flag src uninitialized.
parent 225e82c1
...@@ -113,6 +113,7 @@ buf_buddy_block_free( ...@@ -113,6 +113,7 @@ buf_buddy_block_free(
HASH_DELETE(buf_page_t, hash, buf_pool->zip_hash, fold, bpage); HASH_DELETE(buf_page_t, hash, buf_pool->zip_hash, fold, bpage);
ut_d(memset(buf, 0, UNIV_PAGE_SIZE)); ut_d(memset(buf, 0, UNIV_PAGE_SIZE));
UNIV_MEM_INVALID(buf, UNIV_PAGE_SIZE);
block = (buf_block_t*) bpage; block = (buf_block_t*) bpage;
mutex_enter(&block->mutex); mutex_enter(&block->mutex);
...@@ -416,6 +417,7 @@ buf_buddy_relocate( ...@@ -416,6 +417,7 @@ buf_buddy_relocate(
/* Relocate the compressed page. */ /* Relocate the compressed page. */
ut_a(bpage->zip.data == src); ut_a(bpage->zip.data == src);
memcpy(dst, src, size); memcpy(dst, src, size);
UNIV_MEM_INVALID(src, size);
bpage->zip.data = dst; bpage->zip.data = dst;
mutex_exit(mutex); mutex_exit(mutex);
return(TRUE); return(TRUE);
...@@ -447,13 +449,13 @@ buf_buddy_relocate( ...@@ -447,13 +449,13 @@ buf_buddy_relocate(
buf_page_t* dpage = (buf_page_t*) dst; buf_page_t* dpage = (buf_page_t*) dst;
buf_page_t* b; buf_page_t* b;
memcpy(dpage, bpage, size);
buf_relocate(bpage, dpage); buf_relocate(bpage, dpage);
UNIV_MEM_INVALID(src, size);
/* relocate buf_pool->zip_clean */ /* relocate buf_pool->zip_clean */
b = UT_LIST_GET_PREV(list, bpage); b = UT_LIST_GET_PREV(list, dpage);
UT_LIST_REMOVE(list, buf_pool->zip_clean, UT_LIST_REMOVE(list, buf_pool->zip_clean,
bpage); dpage);
if (b) { if (b) {
UT_LIST_INSERT_AFTER( UT_LIST_INSERT_AFTER(
...@@ -630,6 +632,7 @@ buf_buddy_free_low( ...@@ -630,6 +632,7 @@ buf_buddy_free_low(
memset(bpage, i, BUF_BUDDY_LOW << i); memset(bpage, i, BUF_BUDDY_LOW << i);
} }
#endif /* UNIV_DEBUG */ #endif /* UNIV_DEBUG */
UNIV_MEM_INVALID(buf, BUF_BUDDY_LOW << i);
bpage->state = BUF_BLOCK_ZIP_FREE; bpage->state = BUF_BLOCK_ZIP_FREE;
ut_ad(buf_pool->zip_free[i].start != bpage); ut_ad(buf_pool->zip_free[i].start != bpage);
UT_LIST_ADD_FIRST(list, buf_pool->zip_free[i], bpage); UT_LIST_ADD_FIRST(list, buf_pool->zip_free[i], bpage);
......
...@@ -975,14 +975,15 @@ buf_relocate( ...@@ -975,14 +975,15 @@ buf_relocate(
#ifdef UNIV_SYNC_DEBUG #ifdef UNIV_SYNC_DEBUG
ut_a(mutex_own(&buf_pool->mutex)); ut_a(mutex_own(&buf_pool->mutex));
ut_a(mutex_own(buf_page_get_mutex(bpage))); ut_a(mutex_own(buf_page_get_mutex(bpage)));
ut_a(mutex_own(buf_page_get_mutex(dpage)));
#endif /* UNIV_SYNC_DEBUG */ #endif /* UNIV_SYNC_DEBUG */
ut_a(buf_page_get_io_fix(bpage) == BUF_IO_NONE); ut_a(buf_page_get_io_fix(bpage) == BUF_IO_NONE);
ut_a(bpage->buf_fix_count == 0); ut_a(bpage->buf_fix_count == 0);
ut_a(buf_page_in_file(bpage)); ut_a(buf_page_in_file(bpage));
ut_ad(bpage == buf_page_hash_get(bpage->space, bpage->offset));
/* relocate buf_pool->LRU */ memcpy(dpage, bpage, sizeof *dpage);
/* relocate buf_pool->LRU */
b = UT_LIST_GET_PREV(LRU, bpage); b = UT_LIST_GET_PREV(LRU, bpage);
UT_LIST_REMOVE(LRU, buf_pool->LRU, bpage); UT_LIST_REMOVE(LRU, buf_pool->LRU, bpage);
...@@ -1003,6 +1004,8 @@ buf_relocate( ...@@ -1003,6 +1004,8 @@ buf_relocate(
HASH_DELETE(buf_page_t, hash, buf_pool->page_hash, fold, bpage); HASH_DELETE(buf_page_t, hash, buf_pool->page_hash, fold, bpage);
HASH_INSERT(buf_page_t, hash, buf_pool->page_hash, fold, dpage); HASH_INSERT(buf_page_t, hash, buf_pool->page_hash, fold, dpage);
UNIV_MEM_INVALID(bpage, sizeof *bpage);
} }
/************************************************************************ /************************************************************************
...@@ -2134,25 +2137,21 @@ buf_page_init_for_read( ...@@ -2134,25 +2137,21 @@ buf_page_init_for_read(
and uncompress it. */ and uncompress it. */
mutex_enter(&buf_pool->zip_mutex); mutex_enter(&buf_pool->zip_mutex);
memcpy(&block->page, bpage, sizeof *bpage);
block->page.state = BUF_BLOCK_FILE_PAGE;
buf_relocate(bpage, &block->page); buf_relocate(bpage, &block->page);
if (buf_page_get_state(bpage) == BUF_BLOCK_ZIP_PAGE) { if (buf_page_get_state(&block->page)
== BUF_BLOCK_ZIP_PAGE) {
UT_LIST_REMOVE(list, buf_pool->zip_clean, UT_LIST_REMOVE(list, buf_pool->zip_clean,
bpage); &block->page);
} else { } else {
/* Relocate buf_pool->flush_list. */ /* Relocate buf_pool->flush_list. */
buf_page_t* b; buf_page_t* b;
b = UT_LIST_GET_PREV(list, bpage); b = UT_LIST_GET_PREV(list, &block->page);
ut_ad(bpage->in_flush_list); ut_ad(block->page.in_flush_list);
ut_ad(!block->page.in_flush_list);
ut_d(bpage->in_flush_list = FALSE);
ut_d(block->page.in_flush_list = TRUE);
UT_LIST_REMOVE(list, buf_pool->flush_list, UT_LIST_REMOVE(list, buf_pool->flush_list,
bpage); &block->page);
if (b) { if (b) {
UT_LIST_INSERT_AFTER( UT_LIST_INSERT_AFTER(
...@@ -2165,6 +2164,7 @@ buf_page_init_for_read( ...@@ -2165,6 +2164,7 @@ buf_page_init_for_read(
} }
} }
block->page.state = BUF_BLOCK_FILE_PAGE;
ut_a(!block->page.buf_fix_count); ut_a(!block->page.buf_fix_count);
block->page.buf_fix_count++;; block->page.buf_fix_count++;;
rw_lock_x_lock(&block->lock); rw_lock_x_lock(&block->lock);
......
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