Commit a3190b1f authored by marko's avatar marko

branches/zip: buf_page_get_gen(): Note that the guessed block may also

point to a buffer pool chunk that has been released when resizing the
buffer pool.

buf_block_is_uncompressed(): Check that the pointer is aligned.  Thanks
to this check, it is safe to pass an arbitrary pointer as a guess
to buf_page_get_gen().
parent 4e37e2f8
...@@ -1671,6 +1671,11 @@ buf_block_is_uncompressed( ...@@ -1671,6 +1671,11 @@ buf_block_is_uncompressed(
ut_ad(mutex_own(&buf_pool->mutex)); ut_ad(mutex_own(&buf_pool->mutex));
if (UNIV_UNLIKELY(ut_align_offset(block, sizeof *block) != 0)) {
/* The pointer should be aligned. */
return(FALSE);
}
while (chunk < echunk) { while (chunk < echunk) {
if (block >= chunk->blocks if (block >= chunk->blocks
&& block < chunk->blocks + chunk->size) { && block < chunk->blocks + chunk->size) {
...@@ -1726,11 +1731,13 @@ loop: ...@@ -1726,11 +1731,13 @@ loop:
mutex_enter_fast(&(buf_pool->mutex)); mutex_enter_fast(&(buf_pool->mutex));
if (block) { if (block) {
/* If this is a compressed page descriptor that /* If the guess is a compressed page descriptor that
has been allocated by buf_buddy_alloc(), it may have has been allocated by buf_buddy_alloc(), it may have
been invalidated by buf_buddy_relocate(). In that been invalidated by buf_buddy_relocate(). In that
case, block could point to something that happens to case, block could point to something that happens to
contain the expected bits in block->page. */ contain the expected bits in block->page. Similarly,
the guess may be pointing to a buffer pool chunk that
has been released when resizing the buffer pool. */
if (!buf_block_is_uncompressed(block) if (!buf_block_is_uncompressed(block)
|| offset != block->page.offset || offset != block->page.offset
......
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