Commit 9326dca3 authored by marko's avatar marko

branches/zip: Correct some bugs in the buddy allocator and add debug code.

buf_buddy_alloc_zip() [UNIV_DEBUG]: Byte-fill the allocated blocks with ~i.

buf_buddy_block_free() [UNIV_DEBUG]: Clear the frame before releasing it
to the buffer pool.

buf_buddy_alloc_from() [UNIV_DEBUG]: Byte-fill the free blocks with j.

buf_buddy_relocate(): Allow the buf_page_hash_get() lookup to fail,
and note the reason.

buf_buddy_free_low(): Correctly compute the address of the combined free block.

buf_page_struct: Clarify the mutex protection rules.  Note that
the pointer zip.data is also protected by buf_pool->mutex.
parent 82ce6462
...@@ -48,10 +48,18 @@ buf_buddy_alloc_zip( ...@@ -48,10 +48,18 @@ buf_buddy_alloc_zip(
buf_page_t* buddy = (buf_page_t*) buf_page_t* buddy = (buf_page_t*)
(((char*) bpage) + (BUF_BUDDY_LOW << i)); (((char*) bpage) + (BUF_BUDDY_LOW << i));
ut_d(memset(buddy, i, BUF_BUDDY_LOW << i));
buddy->state = BUF_BLOCK_ZIP_FREE;
UT_LIST_ADD_FIRST(list, buf_pool->zip_free[i], buddy); UT_LIST_ADD_FIRST(list, buf_pool->zip_free[i], buddy);
} }
} }
#ifdef UNIV_DEBUG
if (bpage) {
memset(bpage, ~i, BUF_BUDDY_LOW << i);
}
#endif /* UNIV_DEBUG */
return(bpage); return(bpage);
} }
...@@ -76,6 +84,7 @@ buf_buddy_block_free( ...@@ -76,6 +84,7 @@ buf_buddy_block_free(
((buf_block_t*) bpage)->frame == buf); ((buf_block_t*) bpage)->frame == buf);
ut_a(bpage); ut_a(bpage);
ut_a(buf_page_get_state(bpage) == BUF_BLOCK_MEMORY); ut_a(buf_page_get_state(bpage) == BUF_BLOCK_MEMORY);
ut_d(memset(buf, 0, UNIV_PAGE_SIZE));
block = (buf_block_t*) bpage; block = (buf_block_t*) bpage;
mutex_enter(&block->mutex); mutex_enter(&block->mutex);
...@@ -127,6 +136,7 @@ buf_buddy_alloc_from( ...@@ -127,6 +136,7 @@ buf_buddy_alloc_from(
j--; j--;
bpage = (buf_page_t*) ((byte*) buf + offs); bpage = (buf_page_t*) ((byte*) buf + offs);
ut_d(memset(bpage, j, BUF_BUDDY_LOW << j));
bpage->state = BUF_BLOCK_ZIP_FREE; bpage->state = BUF_BLOCK_ZIP_FREE;
UT_LIST_ADD_FIRST(list, buf_pool->zip_free[j], bpage); UT_LIST_ADD_FIRST(list, buf_pool->zip_free[j], bpage);
} }
...@@ -311,7 +321,16 @@ buf_buddy_relocate( ...@@ -311,7 +321,16 @@ buf_buddy_relocate(
+ FIL_PAGE_ARCH_LOG_NO_OR_SPACE_ID), + FIL_PAGE_ARCH_LOG_NO_OR_SPACE_ID),
mach_read_from_4(src mach_read_from_4(src
+ FIL_PAGE_OFFSET)); + FIL_PAGE_OFFSET));
ut_a(bpage);
if (!bpage || bpage->zip.data != src) {
/* The block has probably been freshly
allocated by buf_LRU_get_free_block() but not
added to buf_pool->page_hash yet. Obviously,
it cannot be relocated. */
return(FALSE);
}
mutex = buf_page_get_mutex(bpage); mutex = buf_page_get_mutex(bpage);
mutex_enter(mutex); mutex_enter(mutex);
...@@ -430,7 +449,7 @@ recombine: ...@@ -430,7 +449,7 @@ recombine:
buddy_free: buddy_free:
/* The buddy is free: recombine */ /* The buddy is free: recombine */
UT_LIST_REMOVE(list, buf_pool->zip_free[i], bpage); UT_LIST_REMOVE(list, buf_pool->zip_free[i], bpage);
buf = ut_align_down(buf, BUF_BUDDY_LOW << i); buf = ut_align_down(buf, BUF_BUDDY_LOW << (i + 1));
if (++i < BUF_BUDDY_SIZES) { if (++i < BUF_BUDDY_SIZES) {
...@@ -476,12 +495,14 @@ buddy_nonfree: ...@@ -476,12 +495,14 @@ buddy_nonfree:
if (buf_buddy_relocate(buddy, buf, i)) { if (buf_buddy_relocate(buddy, buf, i)) {
buf = bpage;
goto buddy_free; goto buddy_free;
} }
} }
/* Free the block to the buddy list. */ /* Free the block to the buddy list. */
bpage = buf; bpage = buf;
ut_d(memset(bpage, i, BUF_BUDDY_LOW << i));
bpage->state = BUF_BLOCK_ZIP_FREE; bpage->state = BUF_BLOCK_ZIP_FREE;
UT_LIST_ADD_FIRST(list, buf_pool->zip_free[i], bpage); UT_LIST_ADD_FIRST(list, buf_pool->zip_free[i], bpage);
} }
...@@ -900,9 +900,9 @@ for compressed and uncompressed frames */ ...@@ -900,9 +900,9 @@ for compressed and uncompressed frames */
struct buf_page_struct{ struct buf_page_struct{
/* None of the following bit-fields must be modified without /* None of the following bit-fields must be modified without
holding block->mutex, since they can be stored in the same holding block->mutex or buf_pool->zip_mutex, since they can be
machine word. Some of them are additionally protected by stored in the same machine word. Some of them are
buf_pool->mutex. */ additionally protected by buf_pool->mutex. */
unsigned space:32; /* tablespace id */ unsigned space:32; /* tablespace id */
unsigned offset:32; /* page number */ unsigned offset:32; /* page number */
...@@ -925,7 +925,9 @@ struct buf_page_struct{ ...@@ -925,7 +925,9 @@ struct buf_page_struct{
unsigned buf_fix_count:24;/* count of how manyfold this block unsigned buf_fix_count:24;/* count of how manyfold this block
is currently bufferfixed */ is currently bufferfixed */
page_zip_des_t zip; /* compressed page */ page_zip_des_t zip; /* compressed page; zip.data
(but not the data it points to) is
also protected by buf_pool->mutex */
buf_page_t* hash; /* node used in chaining to buf_page_t* hash; /* node used in chaining to
buf_pool->page_hash or buf_pool->page_hash or
buf_pool->zip_hash */ buf_pool->zip_hash */
......
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