Commit add0bdeb authored by marko's avatar marko

branches/zip: buf_pool_resize(): When shrinking the buffer pool, do not

assume that non-file pages are free.  After trying to free or flush
file pages, do not proceed to buf_chunk_free(), because the calls will
temporarily release buf_pool->mutex.  Do not flush if there are non-free
blocks, because it would not achieve anything.
parent e803e137
...@@ -978,12 +978,21 @@ shrink_again: ...@@ -978,12 +978,21 @@ shrink_again:
/* Move the blocks of chunk to the end of the /* Move the blocks of chunk to the end of the
LRU list and try to flush them. */ LRU list and try to flush them. */
for (; block < bend; block++) { for (; block < bend; block++) {
if (block->state != BUF_BLOCK_FILE_PAGE) { switch (block->state) {
case BUF_BLOCK_NOT_USED:
continue;
case BUF_BLOCK_FILE_PAGE:
break;
default:
nonfree++;
continue; continue;
} }
mutex_enter(&block->mutex); mutex_enter(&block->mutex);
/* The following calls will temporarily
release block->mutex and buf_pool->mutex.
Therefore, we have to always retry,
even if !dirty && !nonfree. */
if (!buf_flush_ready_for_replace(block)) { if (!buf_flush_ready_for_replace(block)) {
...@@ -996,30 +1005,28 @@ shrink_again: ...@@ -996,30 +1005,28 @@ shrink_again:
mutex_exit(&block->mutex); mutex_exit(&block->mutex);
} }
/* See if the chunk was in fact free. */
if (!dirty && !nonfree) {
goto is_free;
}
mutex_exit(&buf_pool->mutex); mutex_exit(&buf_pool->mutex);
/* Request for a flush of the chunk. */ /* Request for a flush of the chunk if it helps.
if (buf_flush_batch(BUF_FLUSH_LRU, dirty, Do not flush if there are non-free blocks, since
flushing will not make the chunk freeable. */
if (nonfree) {
/* Avoid busy-waiting. */
os_thread_sleep(100000);
} else if (dirty
&& buf_flush_batch(BUF_FLUSH_LRU, dirty,
ut_dulint_zero) ut_dulint_zero)
== ULINT_UNDEFINED) { == ULINT_UNDEFINED) {
buf_flush_wait_batch_end(BUF_FLUSH_LRU); buf_flush_wait_batch_end(BUF_FLUSH_LRU);
} }
/* Retry after flushing. */
goto try_again; goto try_again;
} }
max_size = max_free_size; max_size = max_free_size;
max_chunk = max_free_chunk; max_chunk = max_free_chunk;
is_free:
srv_buf_pool_old_size = srv_buf_pool_size; srv_buf_pool_old_size = srv_buf_pool_size;
/* Rewrite buf_pool->chunks. Copy everything but max_chunk. */ /* Rewrite buf_pool->chunks. Copy everything but max_chunk. */
......
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