Commit a78bf6dd authored by marko's avatar marko

branches/innodb+: ibuf_insert_low(): Combine two nested if statements

to one.  Note that buf_pool_watch_occurred(space, page_no) could start
to hold again and explain why it is not a problem.
parent 7d552257
...@@ -3257,17 +3257,12 @@ ibuf_insert_low( ...@@ -3257,17 +3257,12 @@ ibuf_insert_low(
? &min_n_recs ? &min_n_recs
: NULL, &mtr); : NULL, &mtr);
if (op == IBUF_OP_DELETE) { if (op == IBUF_OP_DELETE
if (min_n_recs < 2 && (min_n_recs < 2
|| buf_pool_watch_occurred(space, page_no)) { || buf_pool_watch_occurred(space, page_no))) {
/* The page could become empty after the /* The page could become empty after the record is
record is deleted, or the page has been read deleted, or the page has been read in to the buffer
in to the buffer pool. Refuse to buffer the pool. Refuse to buffer the operation. */
operation. */
err = DB_STRONG_FAIL;
goto function_exit;
}
/* The buffer pool watch is needed for IBUF_OP_DELETE /* The buffer pool watch is needed for IBUF_OP_DELETE
because of latching order considerations. We can because of latching order considerations. We can
...@@ -3281,8 +3276,22 @@ ibuf_insert_low( ...@@ -3281,8 +3276,22 @@ ibuf_insert_low(
that no changes for the user page will be merged that no changes for the user page will be merged
before mtr_commit(&mtr). We must not mtr_commit(&mtr) before mtr_commit(&mtr). We must not mtr_commit(&mtr)
until after the IBUF_OP_DELETE has been buffered. */ until after the IBUF_OP_DELETE has been buffered. */
err = DB_STRONG_FAIL;
goto function_exit;
} }
/* After this point, buf_pool_watch_occurred(space, page_no)
may still become true, but we do not have to care about it,
since we are holding a latch on the insert buffer leaf page
that contains buffered changes for (space, page_no). If
buf_pool_watch_occurred(space, page_no) becomes true,
buf_page_io_complete() for (space, page_no) will have to
acquire a latch on the same insert buffer leaf page, which it
cannot do until we have buffered the IBUF_OP_DELETE and done
mtr_commit(&mtr) to release the latch. */
#ifdef UNIV_IBUF_COUNT_DEBUG #ifdef UNIV_IBUF_COUNT_DEBUG
ut_a((buffered == 0) || ibuf_count_get(space, page_no)); ut_a((buffered == 0) || ibuf_count_get(space, page_no));
#endif #endif
......
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