Commit 40b401a6 authored by marko's avatar marko

branches/zip: Fix some bugs.

btr_cur_pessimistic_insert(): Remove local variable "block".  Replace
an extraneous call to btr_cur_position() [with wrong "block", in r948]
with a debug assertion that the cursor is positioned on the preceding
record after the page split.

btr_pcur_restore_position(): Do not use btr_pcur_get_page(), because
the debug assertion there could fail.  This bug was introduced in r928.
parent 94c77111
...@@ -1242,7 +1242,6 @@ btr_cur_pessimistic_insert( ...@@ -1242,7 +1242,6 @@ btr_cur_pessimistic_insert(
ulint zip_size = dict_table_zip_size(index->table); ulint zip_size = dict_table_zip_size(index->table);
big_rec_t* big_rec_vec = NULL; big_rec_t* big_rec_vec = NULL;
mem_heap_t* heap = NULL; mem_heap_t* heap = NULL;
buf_block_t* block;
ulint err; ulint err;
ibool dummy_inh; ibool dummy_inh;
ibool success; ibool success;
...@@ -1253,12 +1252,11 @@ btr_cur_pessimistic_insert( ...@@ -1253,12 +1252,11 @@ btr_cur_pessimistic_insert(
*big_rec = NULL; *big_rec = NULL;
block = btr_cur_get_block(cursor);
ut_ad(mtr_memo_contains(mtr, ut_ad(mtr_memo_contains(mtr,
dict_index_get_lock(btr_cur_get_index(cursor)), dict_index_get_lock(btr_cur_get_index(cursor)),
MTR_MEMO_X_LOCK)); MTR_MEMO_X_LOCK));
ut_ad(mtr_memo_contains(mtr, block, MTR_MEMO_PAGE_X_FIX)); ut_ad(mtr_memo_contains(mtr, btr_cur_get_block(cursor),
MTR_MEMO_PAGE_X_FIX));
/* Try first an optimistic insert; reset the cursor flag: we do not /* Try first an optimistic insert; reset the cursor flag: we do not
assume anything of how it was positioned */ assume anything of how it was positioned */
...@@ -1369,7 +1367,8 @@ btr_cur_pessimistic_insert( ...@@ -1369,7 +1367,8 @@ btr_cur_pessimistic_insert(
} }
} }
if (dict_index_get_page(index) == buf_block_get_page_no(block)) { if (dict_index_get_page(index)
== buf_block_get_page_no(btr_cur_get_block(cursor))) {
/* The page is the root page */ /* The page is the root page */
*rec = btr_root_raise_and_insert(cursor, entry, *rec = btr_root_raise_and_insert(cursor, entry,
...@@ -1383,7 +1382,7 @@ btr_cur_pessimistic_insert( ...@@ -1383,7 +1382,7 @@ btr_cur_pessimistic_insert(
mem_heap_free(heap); mem_heap_free(heap);
} }
btr_cur_position(index, page_rec_get_prev(*rec), block, cursor); ut_ad(page_rec_get_next(btr_cur_get_rec(cursor)) == *rec);
#ifdef BTR_CUR_ADAPT #ifdef BTR_CUR_ADAPT
btr_search_update_hash_on_insert(cursor); btr_search_update_hash_on_insert(cursor);
......
...@@ -235,7 +235,7 @@ btr_pcur_restore_position( ...@@ -235,7 +235,7 @@ btr_pcur_restore_position(
ut_a(cursor->old_rec); ut_a(cursor->old_rec);
ut_a(cursor->old_n_fields); ut_a(cursor->old_n_fields);
page = btr_pcur_get_page(cursor); page = btr_cur_get_page(btr_pcur_get_btr_cur(cursor));
if (UNIV_LIKELY(latch_mode == BTR_SEARCH_LEAF) if (UNIV_LIKELY(latch_mode == BTR_SEARCH_LEAF)
|| UNIV_LIKELY(latch_mode == BTR_MODIFY_LEAF)) { || UNIV_LIKELY(latch_mode == BTR_MODIFY_LEAF)) {
......
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