Commit edb0f042 authored by marko's avatar marko

branches/zip: ibuf_merge_or_delete_for_page(): Do not invoke

fil_space_get_zip_size() unless zip_size is really needed
(update_ibuf_bitmap || page).  This avoids an assertion failure
when discarding ibuf entries for a deleted tablespace, for which
fil_space_get_zip_size() would return ULINT_UNDEFINED.

Also, reindent ibuf0ibuf.c.
parent e966a2f1
...@@ -3134,7 +3134,7 @@ ibuf_merge_or_delete_for_page( ...@@ -3134,7 +3134,7 @@ ibuf_merge_or_delete_for_page(
#ifdef UNIV_IBUF_DEBUG #ifdef UNIV_IBUF_DEBUG
ulint volume; ulint volume;
#endif #endif
ulint zip_size; ulint zip_size = 0; /* remove bogus warning */
page_zip_des_t* page_zip = NULL; page_zip_des_t* page_zip = NULL;
ibool tablespace_being_deleted = FALSE; ibool tablespace_being_deleted = FALSE;
ibool corruption_noticed = FALSE; ibool corruption_noticed = FALSE;
...@@ -3149,10 +3149,10 @@ ibuf_merge_or_delete_for_page( ...@@ -3149,10 +3149,10 @@ ibuf_merge_or_delete_for_page(
return; return;
} }
zip_size = fil_space_get_zip_size(space); /* The following assumes that the uncompressed page size
is a power-of-2 multiple of zip_size. */
if (ibuf_fixed_addr_page(space, zip_size, page_no) if (ibuf_fixed_addr_page(space, 0, page_no)
|| fsp_descr_page(zip_size, page_no)) { || fsp_descr_page(0, page_no)) {
return; return;
} }
...@@ -3173,6 +3173,16 @@ ibuf_merge_or_delete_for_page( ...@@ -3173,6 +3173,16 @@ ibuf_merge_or_delete_for_page(
} }
} }
if (update_ibuf_bitmap || page) {
zip_size = fil_space_get_zip_size(space);
ut_a(ut_is_2pow(zip_size));
if (ibuf_fixed_addr_page(space, zip_size, page_no)
|| fsp_descr_page(zip_size, page_no)) {
return;
}
}
if (update_ibuf_bitmap) { if (update_ibuf_bitmap) {
mtr_start(&mtr); mtr_start(&mtr);
bitmap_page = ibuf_bitmap_get_map_page(space, page_no, bitmap_page = ibuf_bitmap_get_map_page(space, page_no,
...@@ -3368,9 +3378,11 @@ reset_bit: ...@@ -3368,9 +3378,11 @@ reset_bit:
IBUF_BITMAP_FREE, &mtr); IBUF_BITMAP_FREE, &mtr);
ulint new_bits = ibuf_index_page_calc_free(page); ulint new_bits = ibuf_index_page_calc_free(page);
#if 0 /* defined UNIV_IBUF_DEBUG */ #if 0 /* defined UNIV_IBUF_DEBUG */
fprintf(stderr, "Old bits %lu new bits %lu max size %lu\n", fprintf(stderr, "Old bits %lu new bits %lu"
" max size %lu\n",
old_bits, new_bits, old_bits, new_bits,
page_get_max_insert_size_after_reorganize(page, 1)); page_get_max_insert_size_after_reorganize(
page, 1));
#endif #endif
if (old_bits != new_bits) { if (old_bits != new_bits) {
ibuf_bitmap_page_set_bits(bitmap_page, page_no, ibuf_bitmap_page_set_bits(bitmap_page, page_no,
......
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