Commit 1e4cb840 authored by Marko Mäkelä's avatar Marko Mäkelä

buf_page_io_complete(): Minor code cleanup

parent aec4734f
...@@ -6093,8 +6093,9 @@ buf_page_io_complete(buf_page_t* bpage, bool evict) ...@@ -6093,8 +6093,9 @@ buf_page_io_complete(buf_page_t* bpage, bool evict)
} }
} }
BPageMutex* block_mutex = buf_page_get_mutex(bpage);
buf_pool_mutex_enter(buf_pool); buf_pool_mutex_enter(buf_pool);
mutex_enter(buf_page_get_mutex(bpage)); mutex_enter(block_mutex);
#ifdef UNIV_IBUF_COUNT_DEBUG #ifdef UNIV_IBUF_COUNT_DEBUG
if (io_type == BUF_IO_WRITE || uncompressed) { if (io_type == BUF_IO_WRITE || uncompressed) {
...@@ -6112,8 +6113,7 @@ buf_page_io_complete(buf_page_t* bpage, bool evict) ...@@ -6112,8 +6113,7 @@ buf_page_io_complete(buf_page_t* bpage, bool evict)
buf_page_set_io_fix(bpage, BUF_IO_NONE); buf_page_set_io_fix(bpage, BUF_IO_NONE);
buf_page_monitor(bpage, io_type); buf_page_monitor(bpage, io_type);
switch (io_type) { if (io_type == BUF_IO_READ) {
case BUF_IO_READ:
/* NOTE that the call to ibuf may have moved the ownership of /* NOTE that the call to ibuf may have moved the ownership of
the x-latch to this OS thread: do not let this confuse you in the x-latch to this OS thread: do not let this confuse you in
debugging! */ debugging! */
...@@ -6127,11 +6127,8 @@ buf_page_io_complete(buf_page_t* bpage, bool evict) ...@@ -6127,11 +6127,8 @@ buf_page_io_complete(buf_page_t* bpage, bool evict)
BUF_IO_READ); BUF_IO_READ);
} }
mutex_exit(buf_page_get_mutex(bpage)); mutex_exit(block_mutex);
} else {
break;
case BUF_IO_WRITE:
/* Write means a flush operation: call the completion /* Write means a flush operation: call the completion
routine in the flush system */ routine in the flush system */
...@@ -6154,18 +6151,11 @@ buf_page_io_complete(buf_page_t* bpage, bool evict) ...@@ -6154,18 +6151,11 @@ buf_page_io_complete(buf_page_t* bpage, bool evict)
evict = true; evict = true;
} }
mutex_exit(block_mutex);
if (evict) { if (evict) {
mutex_exit(buf_page_get_mutex(bpage));
buf_LRU_free_page(bpage, true); buf_LRU_free_page(bpage, true);
} else {
mutex_exit(buf_page_get_mutex(bpage));
} }
break;
default:
ut_error;
} }
DBUG_PRINT("ib_buf", ("%s page %u:%u", DBUG_PRINT("ib_buf", ("%s page %u:%u",
......
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