mirror of
https://github.com/MariaDB/server.git
synced 2025-01-19 13:32:33 +01:00
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.
This commit is contained in:
parent
0a70979184
commit
483cf9bee9
2 changed files with 29 additions and 6 deletions
|
@ -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(
|
||||||
((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(
|
||||||
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(
|
||||||
+ 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:
|
||||||
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:
|
||||||
|
|
||||||
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 */
|
||||||
|
|
||||||
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{
|
||||||
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 */
|
||||||
|
|
Loading…
Reference in a new issue