Commit 4df65a76 authored by marko's avatar marko

branches/zip: ibuf_set_free_bits_func(): Disable redo logging when

crash recovery is in progress.  This avoids a hang when
btr_parse_page_reorganize(), called from an I/O handler thread,
attempts to acquire log_sys->mutex while it is being held by
the main thread (the one that runs innobase_init()).  This change
was committed accidentally.  It may be unsafe to clear
mtr.modifications, because buf_page_release() at mtr_commit() may
forget to put modified pages to the flush list.

Cleanup: Remove the "type" parameter from many ibuf functions.
Let the caller check that !dict_index_is_clust().  This should avoid
function calls and register spilling.

ibuf_set_free_bits_func(), ibuf_set_free_bits(): Remove the parameter "type".

ibuf_reset_free_bits_with_type(): Rename to ibuf_reset_free_bits().
Remove the parameter "type".

ibuf_update_free_bits_if_full(), ibuf_update_free_bits_zip(),
ibuf_update_free_bits_low(), ibuf_update_free_bits_for_two_pages_low():
Remove the parameter "index".
parent d28d18ca
...@@ -787,7 +787,9 @@ btr_create( ...@@ -787,7 +787,9 @@ btr_create(
trees in the same mtr, otherwise the latch on a bitmap page would trees in the same mtr, otherwise the latch on a bitmap page would
prevent it because of the latching order */ prevent it because of the latching order */
ibuf_reset_free_bits_with_type(type, block); if (!(type & DICT_CLUSTERED)) {
ibuf_reset_free_bits(block);
}
/* In the following assertion we test that two records of maximum /* In the following assertion we test that two records of maximum
allowed size fit on the root page: this fact is needed to ensure allowed size fit on the root page: this fact is needed to ensure
...@@ -977,8 +979,7 @@ btr_page_reorganize_low( ...@@ -977,8 +979,7 @@ btr_page_reorganize_low(
if (UNIV_LIKELY_NULL(page_zip) if (UNIV_LIKELY_NULL(page_zip)
&& !dict_index_is_clust(index) && page_is_leaf(page)) { && !dict_index_is_clust(index) && page_is_leaf(page)) {
ibuf_update_free_bits_zip( ibuf_update_free_bits_zip(page_zip_get_size(page_zip), block);
index, page_zip_get_size(page_zip), block);
} }
func_exit: func_exit:
...@@ -1212,7 +1213,10 @@ btr_root_raise_and_insert( ...@@ -1212,7 +1213,10 @@ btr_root_raise_and_insert(
fprintf(stderr, "Root raise new page no %lu\n", new_page_no); fprintf(stderr, "Root raise new page no %lu\n", new_page_no);
#endif #endif
ibuf_reset_free_bits_with_type(index->type, new_block); if (!dict_index_is_clust(index)) {
ibuf_reset_free_bits(new_block);
}
/* Reposition the cursor to the child node */ /* Reposition the cursor to the child node */
page_cur_search(new_block, index, tuple, page_cur_search(new_block, index, tuple,
PAGE_CUR_LE, page_cursor); PAGE_CUR_LE, page_cursor);
...@@ -1979,7 +1983,9 @@ func_start: ...@@ -1979,7 +1983,9 @@ func_start:
start of the function for a new split */ start of the function for a new split */
insert_failed: insert_failed:
/* We play safe and reset the free bits for new_page */ /* We play safe and reset the free bits for new_page */
ibuf_reset_free_bits_with_type(cursor->index->type, new_block); if (!dict_index_is_clust(cursor->index)) {
ibuf_reset_free_bits(new_block);
}
/* fprintf(stderr, "Split second round %lu\n", /* fprintf(stderr, "Split second round %lu\n",
page_get_page_no(page)); */ page_get_page_no(page)); */
...@@ -1998,7 +2004,6 @@ func_exit: ...@@ -1998,7 +2004,6 @@ func_exit:
if (!dict_index_is_clust(cursor->index) && page_is_leaf(page)) { if (!dict_index_is_clust(cursor->index) && page_is_leaf(page)) {
ibuf_update_free_bits_for_two_pages_low( ibuf_update_free_bits_for_two_pages_low(
cursor->index,
buf_block_get_zip_size(left_block), buf_block_get_zip_size(left_block),
left_block, right_block, mtr); left_block, right_block, mtr);
} }
...@@ -2281,7 +2286,9 @@ btr_lift_page_up( ...@@ -2281,7 +2286,9 @@ btr_lift_page_up(
btr_page_free(index, block, mtr); btr_page_free(index, block, mtr);
/* We play safe and reset the free bits for the father */ /* We play safe and reset the free bits for the father */
ibuf_reset_free_bits_with_type(index->type, father_block); if (!dict_index_is_clust(index)) {
ibuf_reset_free_bits(father_block);
}
ut_ad(page_validate(father_page, index)); ut_ad(page_validate(father_page, index));
ut_ad(btr_check_node_ptr(index, father_block, mtr)); ut_ad(btr_check_node_ptr(index, father_block, mtr));
} }
...@@ -2519,10 +2526,9 @@ err_exit: ...@@ -2519,10 +2526,9 @@ err_exit:
/* We have added new records to merge_page: /* We have added new records to merge_page:
update its free bits */ update its free bits */
if (zip_size) { if (zip_size) {
ibuf_update_free_bits_zip(index, zip_size, ibuf_update_free_bits_zip(zip_size, merge_block);
merge_block);
} else { } else {
ibuf_update_free_bits_if_full(index, merge_block, ibuf_update_free_bits_if_full(merge_block,
UNIV_PAGE_SIZE, UNIV_PAGE_SIZE,
ULINT_UNDEFINED); ULINT_UNDEFINED);
} }
...@@ -2580,7 +2586,9 @@ btr_discard_only_page_on_level( ...@@ -2580,7 +2586,9 @@ btr_discard_only_page_on_level(
btr_page_empty(father_block, father_page_zip, mtr, index); btr_page_empty(father_block, father_page_zip, mtr, index);
/* We play safe and reset the free bits for the father */ /* We play safe and reset the free bits for the father */
ibuf_reset_free_bits_with_type(index->type, father_block); if (!dict_index_is_clust(index)) {
ibuf_reset_free_bits(father_block);
}
} else { } else {
ut_ad(page_get_n_recs(father_page) == 1); ut_ad(page_get_n_recs(father_page) == 1);
......
...@@ -898,8 +898,7 @@ btr_cur_insert_if_possible( ...@@ -898,8 +898,7 @@ btr_cur_insert_if_possible(
&& !dict_index_is_clust(cursor->index) && !dict_index_is_clust(cursor->index)
&& page_is_leaf(buf_block_get_frame(block))) { && page_is_leaf(buf_block_get_frame(block))) {
/* Update the free bits in the insert buffer. */ /* Update the free bits in the insert buffer. */
ibuf_update_free_bits_zip(cursor->index, ibuf_update_free_bits_zip(buf_block_get_zip_size(block),
buf_block_get_zip_size(block),
block); block);
} }
...@@ -1226,11 +1225,10 @@ fail_err: ...@@ -1226,11 +1225,10 @@ fail_err:
if (!dict_index_is_clust(index) && UNIV_LIKELY(0 == level)) { if (!dict_index_is_clust(index) && UNIV_LIKELY(0 == level)) {
/* We have added a record to page: update its free bits */ /* We have added a record to page: update its free bits */
if (zip_size) { if (zip_size) {
ibuf_update_free_bits_zip(cursor->index, ibuf_update_free_bits_zip(zip_size, block);
zip_size, block);
} else { } else {
ibuf_update_free_bits_if_full( ibuf_update_free_bits_if_full(
cursor->index, block, max_size, block, max_size,
rec_size + PAGE_DIR_SLOT_SIZE); rec_size + PAGE_DIR_SLOT_SIZE);
} }
} }
...@@ -1664,7 +1662,7 @@ btr_cur_update_alloc_zip( ...@@ -1664,7 +1662,7 @@ btr_cur_update_alloc_zip(
length, 0)) { length, 0)) {
if (!dict_index_is_clust(index)) { if (!dict_index_is_clust(index)) {
/* No space on the page: reset the free bits. */ /* No space on the page: reset the free bits. */
ibuf_reset_free_bits_with_type(index->type, block); ibuf_reset_free_bits(block);
} }
return(FALSE); return(FALSE);
} }
...@@ -1734,7 +1732,7 @@ btr_cur_update_in_place( ...@@ -1734,7 +1732,7 @@ btr_cur_update_in_place(
&& page_is_leaf(buf_block_get_frame(block))) { && page_is_leaf(buf_block_get_frame(block))) {
/* Update the free bits in the insert buffer. */ /* Update the free bits in the insert buffer. */
ibuf_update_free_bits_zip( ibuf_update_free_bits_zip(
index, page_zip_get_size(page_zip), block); page_zip_get_size(page_zip), block);
} }
if (UNIV_LIKELY_NULL(heap)) { if (UNIV_LIKELY_NULL(heap)) {
...@@ -1775,7 +1773,7 @@ btr_cur_update_in_place( ...@@ -1775,7 +1773,7 @@ btr_cur_update_in_place(
if (page_zip && !dict_index_is_clust(index) if (page_zip && !dict_index_is_clust(index)
&& page_is_leaf(buf_block_get_frame(block))) { && page_is_leaf(buf_block_get_frame(block))) {
/* Update the free bits in the insert buffer. */ /* Update the free bits in the insert buffer. */
ibuf_update_free_bits_zip(index, buf_block_get_zip_size(block), ibuf_update_free_bits_zip(buf_block_get_zip_size(block),
block); block);
} }
...@@ -1954,7 +1952,7 @@ err_exit: ...@@ -1954,7 +1952,7 @@ err_exit:
&& page_is_leaf(page)) { && page_is_leaf(page)) {
/* Update the free bits in the insert buffer. */ /* Update the free bits in the insert buffer. */
ibuf_update_free_bits_zip( ibuf_update_free_bits_zip(
index, buf_block_get_zip_size(block), block); buf_block_get_zip_size(block), block);
} }
mem_heap_free(heap); mem_heap_free(heap);
...@@ -2785,8 +2783,10 @@ btr_cur_optimistic_delete( ...@@ -2785,8 +2783,10 @@ btr_cur_optimistic_delete(
ut_a(!page_zip || page_zip_validate(page_zip, page)); ut_a(!page_zip || page_zip_validate(page_zip, page));
#endif /* UNIV_ZIP_DEBUG */ #endif /* UNIV_ZIP_DEBUG */
ibuf_update_free_bits_low(cursor->index, zip_size, if (!dict_index_is_clust(cursor->index)) {
block, max_ins_size, mtr); ibuf_update_free_bits_low(zip_size, block,
max_ins_size, mtr);
}
} }
if (UNIV_LIKELY_NULL(heap)) { if (UNIV_LIKELY_NULL(heap)) {
......
...@@ -791,7 +791,6 @@ UNIV_INLINE ...@@ -791,7 +791,6 @@ UNIV_INLINE
void void
ibuf_set_free_bits_low( ibuf_set_free_bits_low(
/*===================*/ /*===================*/
ulint type, /* in: index type */
ulint zip_size,/* in: compressed page size in bytes; ulint zip_size,/* in: compressed page size in bytes;
0 for uncompressed pages */ 0 for uncompressed pages */
buf_block_t* block, /* in: index page; free bits are set if buf_block_t* block, /* in: index page; free bits are set if
...@@ -804,11 +803,6 @@ ibuf_set_free_bits_low( ...@@ -804,11 +803,6 @@ ibuf_set_free_bits_low(
ulint space; ulint space;
ulint page_no; ulint page_no;
if (type & DICT_CLUSTERED) {
return;
}
if (!page_is_leaf(buf_block_get_frame(block))) { if (!page_is_leaf(buf_block_get_frame(block))) {
return; return;
...@@ -840,10 +834,8 @@ were kept. */ ...@@ -840,10 +834,8 @@ were kept. */
void void
ibuf_set_free_bits_func( ibuf_set_free_bits_func(
/*====================*/ /*====================*/
ulint type, /* in: index type */ buf_block_t* block, /* in: index page of a non-clustered index;
buf_block_t* block, /* in: index page; free bit is reset free bit is reset if page level is 0 */
if the index is a non-clustered
non-unique, and page level is 0 */
#ifdef UNIV_IBUF_DEBUG #ifdef UNIV_IBUF_DEBUG
ulint max_val,/* in: ULINT_UNDEFINED or a maximum ulint max_val,/* in: ULINT_UNDEFINED or a maximum
value which the bits must have before value which the bits must have before
...@@ -858,11 +850,6 @@ ibuf_set_free_bits_func( ...@@ -858,11 +850,6 @@ ibuf_set_free_bits_func(
ulint page_no; ulint page_no;
ulint zip_size; ulint zip_size;
if (type & DICT_CLUSTERED) {
return;
}
page = buf_block_get_frame(block); page = buf_block_get_frame(block);
if (!page_is_leaf(page)) { if (!page_is_leaf(page)) {
...@@ -872,6 +859,10 @@ ibuf_set_free_bits_func( ...@@ -872,6 +859,10 @@ ibuf_set_free_bits_func(
mtr_start(&mtr); mtr_start(&mtr);
if (recv_recovery_is_on()) {
mtr_set_log_mode(&mtr, MTR_LOG_NONE);
}
space = buf_block_get_space(block); space = buf_block_get_space(block);
page_no = buf_block_get_page_no(block); page_no = buf_block_get_page_no(block);
zip_size = buf_block_get_zip_size(block); zip_size = buf_block_get_zip_size(block);
...@@ -905,6 +896,14 @@ ibuf_set_free_bits_func( ...@@ -905,6 +896,14 @@ ibuf_set_free_bits_func(
#endif /* UNIV_IBUF_DEBUG */ #endif /* UNIV_IBUF_DEBUG */
ibuf_bitmap_page_set_bits(bitmap_page, page_no, zip_size, ibuf_bitmap_page_set_bits(bitmap_page, page_no, zip_size,
IBUF_BITMAP_FREE, val, &mtr); IBUF_BITMAP_FREE, val, &mtr);
if (recv_recovery_is_on()) {
/* Do not acquire log_sys->mutex or attempt to
write to the redo log, because the lock is being
held by the crash recovery thread. */
mtr.modifications = FALSE;
}
mtr_commit(&mtr); mtr_commit(&mtr);
} }
...@@ -915,14 +914,13 @@ work to only ibuf bitmap operations, which would result if the latch to the ...@@ -915,14 +914,13 @@ work to only ibuf bitmap operations, which would result if the latch to the
bitmap page were kept. */ bitmap page were kept. */
void void
ibuf_reset_free_bits_with_type( ibuf_reset_free_bits(
/*===========================*/ /*=================*/
ulint type, /* in: index type */
buf_block_t* block) /* in: index page; free bits are set to 0 buf_block_t* block) /* in: index page; free bits are set to 0
if the index is a non-clustered if the index is a non-clustered
non-unique, and page level is 0 */ non-unique, and page level is 0 */
{ {
ibuf_set_free_bits(type, block, 0, ULINT_UNDEFINED); ibuf_set_free_bits(block, 0, ULINT_UNDEFINED);
} }
/************************************************************************** /**************************************************************************
...@@ -933,7 +931,6 @@ any further operations for this OS thread until mtr is committed. */ ...@@ -933,7 +931,6 @@ any further operations for this OS thread until mtr is committed. */
void void
ibuf_update_free_bits_low( ibuf_update_free_bits_low(
/*======================*/ /*======================*/
dict_index_t* index, /* in: index */
ulint zip_size, /* in: compressed page size in bytes; ulint zip_size, /* in: compressed page size in bytes;
0 for uncompressed pages */ 0 for uncompressed pages */
buf_block_t* block, /* in: index page */ buf_block_t* block, /* in: index page */
...@@ -950,8 +947,7 @@ ibuf_update_free_bits_low( ...@@ -950,8 +947,7 @@ ibuf_update_free_bits_low(
after = ibuf_index_page_calc_free(zip_size, block); after = ibuf_index_page_calc_free(zip_size, block);
if (before != after) { if (before != after) {
ibuf_set_free_bits_low(index->type, zip_size, ibuf_set_free_bits_low(zip_size, block, after, mtr);
block, after, mtr);
} }
} }
...@@ -963,7 +959,6 @@ prevent any further operations until mtr is committed. */ ...@@ -963,7 +959,6 @@ prevent any further operations until mtr is committed. */
void void
ibuf_update_free_bits_for_two_pages_low( ibuf_update_free_bits_for_two_pages_low(
/*====================================*/ /*====================================*/
dict_index_t* index, /* in: index */
ulint zip_size,/* in: compressed page size in bytes; ulint zip_size,/* in: compressed page size in bytes;
0 for uncompressed pages */ 0 for uncompressed pages */
buf_block_t* block1, /* in: index page */ buf_block_t* block1, /* in: index page */
...@@ -980,11 +975,11 @@ ibuf_update_free_bits_for_two_pages_low( ...@@ -980,11 +975,11 @@ ibuf_update_free_bits_for_two_pages_low(
state = ibuf_index_page_calc_free(zip_size, block1); state = ibuf_index_page_calc_free(zip_size, block1);
ibuf_set_free_bits_low(index->type, zip_size, block1, state, mtr); ibuf_set_free_bits_low(zip_size, block1, state, mtr);
state = ibuf_index_page_calc_free(zip_size, block2); state = ibuf_index_page_calc_free(zip_size, block2);
ibuf_set_free_bits_low(index->type, zip_size, block2, state, mtr); ibuf_set_free_bits_low(zip_size, block2, state, mtr);
mutex_exit(&ibuf_bitmap_mutex); mutex_exit(&ibuf_bitmap_mutex);
} }
......
...@@ -61,9 +61,8 @@ work to only ibuf bitmap operations, which would result if the latch to the ...@@ -61,9 +61,8 @@ work to only ibuf bitmap operations, which would result if the latch to the
bitmap page were kept. */ bitmap page were kept. */
void void
ibuf_reset_free_bits_with_type( ibuf_reset_free_bits(
/*===========================*/ /*=================*/
ulint type, /* in: index type */
buf_block_t* block); /* in: index page; free bits are set to 0 buf_block_t* block); /* in: index page; free bits are set to 0
if the index is a non-clustered if the index is a non-clustered
non-unique, and page level is 0 */ non-unique, and page level is 0 */
...@@ -76,7 +75,6 @@ UNIV_INLINE ...@@ -76,7 +75,6 @@ UNIV_INLINE
void void
ibuf_update_free_bits_if_full( ibuf_update_free_bits_if_full(
/*==========================*/ /*==========================*/
dict_index_t* index, /* in: index */
buf_block_t* block, /* in: index page to which we have added new buf_block_t* block, /* in: index page to which we have added new
records; the free bits are updated if the records; the free bits are updated if the
index is non-clustered and non-unique and index is non-clustered and non-unique and
...@@ -97,7 +95,6 @@ UNIV_INLINE ...@@ -97,7 +95,6 @@ UNIV_INLINE
void void
ibuf_update_free_bits_zip( ibuf_update_free_bits_zip(
/*======================*/ /*======================*/
dict_index_t* index, /* in: index */
ulint zip_size,/* in: compressed page size in bytes */ ulint zip_size,/* in: compressed page size in bytes */
buf_block_t* block); /* in: B-tree leaf page of a secondary buf_block_t* block); /* in: B-tree leaf page of a secondary
index */ index */
...@@ -109,7 +106,6 @@ prevent any further operations for this OS thread until mtr is committed. */ ...@@ -109,7 +106,6 @@ prevent any further operations for this OS thread until mtr is committed. */
void void
ibuf_update_free_bits_low( ibuf_update_free_bits_low(
/*======================*/ /*======================*/
dict_index_t* index, /* in: index */
ulint zip_size, /* in: compressed page size in bytes; ulint zip_size, /* in: compressed page size in bytes;
0 for uncompressed pages */ 0 for uncompressed pages */
buf_block_t* block, /* in: index page */ buf_block_t* block, /* in: index page */
...@@ -125,7 +121,6 @@ prevent any further operations until mtr is committed. */ ...@@ -125,7 +121,6 @@ prevent any further operations until mtr is committed. */
void void
ibuf_update_free_bits_for_two_pages_low( ibuf_update_free_bits_for_two_pages_low(
/*====================================*/ /*====================================*/
dict_index_t* index, /* in: index */
ulint zip_size,/* in: compressed page size in bytes; ulint zip_size,/* in: compressed page size in bytes;
0 for uncompressed pages */ 0 for uncompressed pages */
buf_block_t* block1, /* in: index page */ buf_block_t* block1, /* in: index page */
......
...@@ -59,10 +59,8 @@ were kept. */ ...@@ -59,10 +59,8 @@ were kept. */
void void
ibuf_set_free_bits_func( ibuf_set_free_bits_func(
/*====================*/ /*====================*/
ulint type, /* in: index type */ buf_block_t* block, /* in: index page of a non-clustered index;
buf_block_t* block, /* in: index page; free bit is reset free bit is reset if page level is 0 */
if the index is a non-clustered
non-unique, and page level is 0 */
#ifdef UNIV_IBUF_DEBUG #ifdef UNIV_IBUF_DEBUG
ulint max_val,/* in: ULINT_UNDEFINED or a maximum ulint max_val,/* in: ULINT_UNDEFINED or a maximum
value which the bits must have before value which the bits must have before
...@@ -70,9 +68,9 @@ ibuf_set_free_bits_func( ...@@ -70,9 +68,9 @@ ibuf_set_free_bits_func(
#endif /* UNIV_IBUF_DEBUG */ #endif /* UNIV_IBUF_DEBUG */
ulint val); /* in: value to set: < 4 */ ulint val); /* in: value to set: < 4 */
#ifdef UNIV_IBUF_DEBUG #ifdef UNIV_IBUF_DEBUG
# define ibuf_set_free_bits(t,b,v,max) ibuf_set_free_bits_func(t,b,max,v) # define ibuf_set_free_bits(b,v,max) ibuf_set_free_bits_func(b,max,v)
#else /* UNIV_IBUF_DEBUG */ #else /* UNIV_IBUF_DEBUG */
# define ibuf_set_free_bits(t,b,v,max) ibuf_set_free_bits_func(t,b,v) # define ibuf_set_free_bits(b,v,max) ibuf_set_free_bits_func(b,v)
#endif /* UNIV_IBUF_DEBUG */ #endif /* UNIV_IBUF_DEBUG */
/************************************************************************** /**************************************************************************
...@@ -238,7 +236,6 @@ UNIV_INLINE ...@@ -238,7 +236,6 @@ UNIV_INLINE
void void
ibuf_update_free_bits_if_full( ibuf_update_free_bits_if_full(
/*==========================*/ /*==========================*/
dict_index_t* index, /* in: index */
buf_block_t* block, /* in: index page to which we have added new buf_block_t* block, /* in: index page to which we have added new
records; the free bits are updated if the records; the free bits are updated if the
index is non-clustered and non-unique and index is non-clustered and non-unique and
...@@ -279,7 +276,7 @@ ibuf_update_free_bits_if_full( ...@@ -279,7 +276,7 @@ ibuf_update_free_bits_if_full(
} }
if (before > after) { if (before > after) {
ibuf_set_free_bits(index->type, block, after, before); ibuf_set_free_bits(block, after, before);
} }
} }
...@@ -292,7 +289,6 @@ UNIV_INLINE ...@@ -292,7 +289,6 @@ UNIV_INLINE
void void
ibuf_update_free_bits_zip( ibuf_update_free_bits_zip(
/*======================*/ /*======================*/
dict_index_t* index, /* in: index */
ulint zip_size,/* in: compressed page size in bytes */ ulint zip_size,/* in: compressed page size in bytes */
buf_block_t* block) /* in: B-tree leaf page of a secondary buf_block_t* block) /* in: B-tree leaf page of a secondary
index */ index */
...@@ -308,5 +304,5 @@ ibuf_update_free_bits_zip( ...@@ -308,5 +304,5 @@ ibuf_update_free_bits_zip(
buf_page_make_young(&block->page); buf_page_make_young(&block->page);
} }
ibuf_set_free_bits(index->type, block, free_bits, ULINT_UNDEFINED); ibuf_set_free_bits(block, free_bits, ULINT_UNDEFINED);
} }
...@@ -20,7 +20,7 @@ ibool ...@@ -20,7 +20,7 @@ ibool
recv_recovery_is_on(void) recv_recovery_is_on(void)
/*=====================*/ /*=====================*/
{ {
return(recv_recovery_on); return(UNIV_UNLIKELY(recv_recovery_on));
} }
/*********************************************************************** /***********************************************************************
......
...@@ -3887,8 +3887,7 @@ page_zip_reorganize( ...@@ -3887,8 +3887,7 @@ page_zip_reorganize(
if (!dict_index_is_clust(index) && page_is_leaf(page)) { if (!dict_index_is_clust(index) && page_is_leaf(page)) {
/* Recompute the insert buffer free bits. */ /* Recompute the insert buffer free bits. */
ibuf_update_free_bits_zip(index, ibuf_update_free_bits_zip(page_zip_get_size(page_zip), block);
page_zip_get_size(page_zip), block);
} }
buf_block_free(temp_block); buf_block_free(temp_block);
......
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