Commit df5a9376 authored by marko's avatar marko

branches/zip: buf_LRU_search_and_free_block(): Do not try to preserve

compressed pages, because doing so would require a call to
buf_buddy_alloc(), which in turn can invoke buf_LRU_get_free_block()
and buf_LRU_search_and_free_block(), potentially infinite recursion.
parent 9c663a0c
...@@ -272,21 +272,14 @@ buf_LRU_search_and_free_block( ...@@ -272,21 +272,14 @@ buf_LRU_search_and_free_block(
bpage = UT_LIST_GET_LAST(buf_pool->LRU); bpage = UT_LIST_GET_LAST(buf_pool->LRU);
if (UNIV_UNLIKELY(n_iterations > 10)) { if (UNIV_UNLIKELY(n_iterations > 10)) {
/* The buffer pool is scarce. Search the whole /* The buffer pool is scarce. Search the whole LRU list. */
LRU list, and also free any compressed pages. */
while (bpage != NULL) { while (bpage != NULL) {
mutex_t* block_mutex mutex_t* block_mutex
= buf_page_get_mutex(bpage); = buf_page_get_mutex(bpage);
mutex_enter(block_mutex); mutex_enter(block_mutex);
/* Discard also the compressed page. */
freed = buf_LRU_free_block(bpage, TRUE); freed = buf_LRU_free_block(bpage, TRUE);
if (!freed && bpage->zip.data) {
/* Could not free the compressed page;
try freeing the uncompressed page then. */
freed = buf_LRU_free_block(bpage, FALSE);
}
mutex_exit(block_mutex); mutex_exit(block_mutex);
if (freed) { if (freed) {
...@@ -309,8 +302,7 @@ buf_LRU_search_and_free_block( ...@@ -309,8 +302,7 @@ buf_LRU_search_and_free_block(
= buf_page_get_mutex(bpage); = buf_page_get_mutex(bpage);
mutex_enter(block_mutex); mutex_enter(block_mutex);
/* Preserve any compressed page. */ freed = buf_LRU_free_block(bpage, TRUE);
freed = buf_LRU_free_block(bpage, FALSE);
mutex_exit(block_mutex); mutex_exit(block_mutex);
if (freed) { if (freed) {
...@@ -327,7 +319,7 @@ buf_LRU_search_and_free_block( ...@@ -327,7 +319,7 @@ buf_LRU_search_and_free_block(
} else { } else {
/* There are few compressed blocks. Skip compressed-only /* There are few compressed blocks. Skip compressed-only
blocks in the search for the least recently used block blocks in the search for the least recently used block
that can be freed. Preserve any compressed page. */ that can be freed. */
ulint distance = 100 ulint distance = 100
+ (n_iterations * buf_pool->curr_size) / 10; + (n_iterations * buf_pool->curr_size) / 10;
...@@ -338,8 +330,7 @@ buf_LRU_search_and_free_block( ...@@ -338,8 +330,7 @@ buf_LRU_search_and_free_block(
buf_block_t* block = (buf_block_t*) bpage; buf_block_t* block = (buf_block_t*) bpage;
mutex_enter(&block->mutex); mutex_enter(&block->mutex);
/* Preserve any compressed page. */ freed = buf_LRU_free_block(bpage, TRUE);
freed = buf_LRU_free_block(bpage, FALSE);
mutex_exit(&block->mutex); mutex_exit(&block->mutex);
if (freed) { if (freed) {
......
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