Commit fcaa035f authored by marko's avatar marko

branches/zip: Eliminate some more buf_block_align() calls.

mlog_write_initial_log_record_fast(): Remove the buf_block_align() call
unless #ifdef UNIV_DEBUG.

btr_cur_update_in_place(): Replace buf_frame_get_page_zip() with
buf_block_get_page_zip().

btr_page_create(), btr_page_empty(): Replace the parameter page with block.

btr_attach_half_pages(): Use btr_block_get() instead of btr_page_get().
Remove buf_block_align() calls.

btr_cur_latch_leaves(): Remove duplicated code.  Use btr_block_get()
instead of btr_page_get().  Remove buf_block_align() calls.
parent bbcef45a
...@@ -90,16 +90,6 @@ btr_page_get_father_node_ptr( ...@@ -90,16 +90,6 @@ btr_page_get_father_node_ptr(
page_t* page, /* in: page: must contain at least one page_t* page, /* in: page: must contain at least one
user record */ user record */
mtr_t* mtr); /* in: mtr */ mtr_t* mtr); /* in: mtr */
/*****************************************************************
Empties an index page. */
static
void
btr_page_empty(
/*===========*/
page_t* page, /* in: page to be emptied */
page_zip_des_t* page_zip,/* out: compressed page, or NULL */
mtr_t* mtr, /* in: mtr */
dict_index_t* index); /* in: the index of the page */
/****************************************************************** /******************************************************************
Gets the root node of a tree and x-latches it. */ Gets the root node of a tree and x-latches it. */
...@@ -167,8 +157,8 @@ btr_get_prev_user_rec( ...@@ -167,8 +157,8 @@ btr_get_prev_user_rec(
MTR_MEMO_PAGE_S_FIX) MTR_MEMO_PAGE_S_FIX)
|| mtr_memo_contains(mtr, prev_block, || mtr_memo_contains(mtr, prev_block,
MTR_MEMO_PAGE_X_FIX)); MTR_MEMO_PAGE_X_FIX));
ut_a(page_is_comp(prev_page) == page_is_comp(page));
#ifdef UNIV_BTR_DEBUG #ifdef UNIV_BTR_DEBUG
ut_a(page_is_comp(prev_page) == page_is_comp(page));
ut_a(btr_page_get_next(prev_page, mtr) ut_a(btr_page_get_next(prev_page, mtr)
== page_get_page_no(page)); == page_get_page_no(page));
#endif /* UNIV_BTR_DEBUG */ #endif /* UNIV_BTR_DEBUG */
...@@ -221,11 +211,11 @@ btr_get_next_user_rec( ...@@ -221,11 +211,11 @@ btr_get_next_user_rec(
|| mtr_memo_contains(mtr, next_block, || mtr_memo_contains(mtr, next_block,
MTR_MEMO_PAGE_X_FIX)); MTR_MEMO_PAGE_X_FIX));
#ifdef UNIV_BTR_DEBUG #ifdef UNIV_BTR_DEBUG
ut_a(page_is_comp(next_page) == page_is_comp(page));
ut_a(btr_page_get_prev(next_page, mtr) ut_a(btr_page_get_prev(next_page, mtr)
== page_get_page_no(page)); == page_get_page_no(page));
#endif /* UNIV_BTR_DEBUG */ #endif /* UNIV_BTR_DEBUG */
ut_a(page_is_comp(next_page) == page_is_comp(page));
return(page_rec_get_next(page_get_infimum_rec(next_page))); return(page_rec_get_next(page_get_infimum_rec(next_page)));
} }
...@@ -239,13 +229,15 @@ static ...@@ -239,13 +229,15 @@ static
void void
btr_page_create( btr_page_create(
/*============*/ /*============*/
page_t* page, /* in/out: page to be created */ buf_block_t* block, /* in/out: page to be created */
page_zip_des_t* page_zip,/* in/out: compressed page, or NULL */ page_zip_des_t* page_zip,/* in/out: compressed page, or NULL */
dict_index_t* index, /* in: index */ dict_index_t* index, /* in: index */
ulint level, /* in: the B-tree level of the page */ ulint level, /* in: the B-tree level of the page */
mtr_t* mtr) /* in: mtr */ mtr_t* mtr) /* in: mtr */
{ {
ut_ad(mtr_memo_contains_page(mtr, page, MTR_MEMO_PAGE_X_FIX)); page_t* page = buf_block_get_frame(block);
ut_ad(mtr_memo_contains(mtr, block, MTR_MEMO_PAGE_X_FIX));
if (UNIV_LIKELY_NULL(page_zip)) { if (UNIV_LIKELY_NULL(page_zip)) {
page_create_zip(page, page_zip, index, level, mtr); page_create_zip(page, page_zip, index, level, mtr);
...@@ -255,7 +247,7 @@ btr_page_create( ...@@ -255,7 +247,7 @@ btr_page_create(
btr_page_set_level(page, NULL, level, mtr); btr_page_set_level(page, NULL, level, mtr);
} }
buf_block_align(page)->check_index_page_at_flush = TRUE; block->check_index_page_at_flush = TRUE;
btr_page_set_index_id(page, page_zip, index->id, mtr); btr_page_set_index_id(page, page_zip, index->id, mtr);
} }
...@@ -742,7 +734,7 @@ btr_create( ...@@ -742,7 +734,7 @@ btr_create(
btr_page_set_level(page, NULL, 0, mtr); btr_page_set_level(page, NULL, 0, mtr);
} }
buf_block_align(page)->check_index_page_at_flush = TRUE; block->check_index_page_at_flush = TRUE;
/* Set the index id of the page */ /* Set the index id of the page */
btr_page_set_index_id(page, page_zip, index_id, mtr); btr_page_set_index_id(page, page_zip, index_id, mtr);
...@@ -998,14 +990,12 @@ static ...@@ -998,14 +990,12 @@ static
void void
btr_page_empty( btr_page_empty(
/*===========*/ /*===========*/
page_t* page, /* in: page to be emptied */ buf_block_t* block, /* in: page to be emptied */
page_zip_des_t* page_zip,/* out: compressed page, or NULL */ page_zip_des_t* page_zip,/* out: compressed page, or NULL */
mtr_t* mtr, /* in: mtr */ mtr_t* mtr, /* in: mtr */
dict_index_t* index) /* in: index of the page */ dict_index_t* index) /* in: index of the page */
{ {
buf_block_t* block; page_t* page = buf_block_get_frame(block);
block = buf_block_align(page);
ut_ad(mtr_memo_contains(mtr, block, MTR_MEMO_PAGE_X_FIX)); ut_ad(mtr_memo_contains(mtr, block, MTR_MEMO_PAGE_X_FIX));
#ifdef UNIV_ZIP_DEBUG #ifdef UNIV_ZIP_DEBUG
...@@ -1088,7 +1078,7 @@ btr_root_raise_and_insert( ...@@ -1088,7 +1078,7 @@ btr_root_raise_and_insert(
ut_a(!new_page_zip == !root_page_zip); ut_a(!new_page_zip == !root_page_zip);
ut_a(!new_page_zip || new_page_zip->size == root_page_zip->size); ut_a(!new_page_zip || new_page_zip->size == root_page_zip->size);
btr_page_create(new_page, new_page_zip, index, level, mtr); btr_page_create(new_block, new_page_zip, index, level, mtr);
/* Set the next node and previous node fields of new page */ /* Set the next node and previous node fields of new page */
btr_page_set_next(new_page, new_page_zip, FIL_NULL, mtr); btr_page_set_next(new_page, new_page_zip, FIL_NULL, mtr);
...@@ -1558,8 +1548,6 @@ btr_attach_half_pages( ...@@ -1558,8 +1548,6 @@ btr_attach_half_pages(
{ {
ulint space; ulint space;
rec_t* node_ptr; rec_t* node_ptr;
page_t* prev_page;
page_t* next_page;
ulint prev_page_no; ulint prev_page_no;
ulint next_page_no; ulint next_page_no;
ulint level; ulint level;
...@@ -1637,25 +1625,30 @@ btr_attach_half_pages( ...@@ -1637,25 +1625,30 @@ btr_attach_half_pages(
/* Update page links of the level */ /* Update page links of the level */
if (prev_page_no != FIL_NULL) { if (prev_page_no != FIL_NULL) {
buf_block_t* prev_block = btr_block_get(space, prev_page_no,
prev_page = btr_page_get(space, prev_page_no, RW_X_LATCH, mtr); RW_X_LATCH, mtr);
ut_a(page_is_comp(prev_page) == page_is_comp(page));
#ifdef UNIV_BTR_DEBUG #ifdef UNIV_BTR_DEBUG
ut_a(btr_page_get_next(prev_page, mtr) ut_a(page_is_comp(prev_block->frame) == page_is_comp(page));
ut_a(btr_page_get_next(prev_block->frame, mtr)
== page_get_page_no(page)); == page_get_page_no(page));
#endif /* UNIV_BTR_DEBUG */ #endif /* UNIV_BTR_DEBUG */
btr_page_set_next(prev_page, buf_frame_get_page_zip(prev_page), btr_page_set_next(buf_block_get_frame(prev_block),
buf_block_get_page_zip(prev_block),
lower_page_no, mtr); lower_page_no, mtr);
} }
if (next_page_no != FIL_NULL) { if (next_page_no != FIL_NULL) {
buf_block_t* next_block = btr_block_get(space, next_page_no,
RW_X_LATCH, mtr);
#ifdef UNIV_BTR_DEBUG
ut_a(page_is_comp(next_block->frame) == page_is_comp(page));
ut_a(btr_page_get_prev(next_block->frame, mtr)
== page_get_page_no(page));
#endif /* UNIV_BTR_DEBUG */
next_page = btr_page_get(space, next_page_no, RW_X_LATCH, mtr); btr_page_set_prev(buf_block_get_frame(next_block),
ut_a(page_is_comp(next_page) == page_is_comp(page)); buf_block_get_page_zip(next_block),
btr_page_set_prev(next_page,
buf_frame_get_page_zip(next_page),
upper_page_no, mtr); upper_page_no, mtr);
} }
...@@ -1763,7 +1756,7 @@ func_start: ...@@ -1763,7 +1756,7 @@ func_start:
btr_page_get_level(page, mtr), mtr); btr_page_get_level(page, mtr), mtr);
new_page = buf_block_get_frame(new_block); new_page = buf_block_get_frame(new_block);
new_page_zip = buf_block_get_page_zip(new_block); new_page_zip = buf_block_get_page_zip(new_block);
btr_page_create(new_page, new_page_zip, cursor->index, btr_page_create(new_block, new_page_zip, cursor->index,
btr_page_get_level(page, mtr), mtr); btr_page_get_level(page, mtr), mtr);
/* 3. Calculate the first record on the upper half-page, and the /* 3. Calculate the first record on the upper half-page, and the
...@@ -1998,8 +1991,8 @@ btr_level_list_remove( ...@@ -1998,8 +1991,8 @@ btr_level_list_remove(
if (prev_page_no != FIL_NULL) { if (prev_page_no != FIL_NULL) {
prev_page = btr_page_get(space, prev_page_no, RW_X_LATCH, mtr); prev_page = btr_page_get(space, prev_page_no, RW_X_LATCH, mtr);
ut_a(page_is_comp(prev_page) == page_is_comp(page));
#ifdef UNIV_BTR_DEBUG #ifdef UNIV_BTR_DEBUG
ut_a(page_is_comp(prev_page) == page_is_comp(page));
ut_a(btr_page_get_next(prev_page, mtr) ut_a(btr_page_get_next(prev_page, mtr)
== page_get_page_no(page)); == page_get_page_no(page));
#endif /* UNIV_BTR_DEBUG */ #endif /* UNIV_BTR_DEBUG */
...@@ -2011,8 +2004,8 @@ btr_level_list_remove( ...@@ -2011,8 +2004,8 @@ btr_level_list_remove(
if (next_page_no != FIL_NULL) { if (next_page_no != FIL_NULL) {
next_page = btr_page_get(space, next_page_no, RW_X_LATCH, mtr); next_page = btr_page_get(space, next_page_no, RW_X_LATCH, mtr);
ut_a(page_is_comp(next_page) == page_is_comp(page));
#ifdef UNIV_BTR_DEBUG #ifdef UNIV_BTR_DEBUG
ut_a(page_is_comp(next_page) == page_is_comp(page));
ut_a(btr_page_get_prev(next_page, mtr) ut_a(btr_page_get_prev(next_page, mtr)
== page_get_page_no(page)); == page_get_page_no(page));
#endif /* UNIV_BTR_DEBUG */ #endif /* UNIV_BTR_DEBUG */
...@@ -2141,6 +2134,7 @@ btr_lift_page_up( ...@@ -2141,6 +2134,7 @@ btr_lift_page_up(
record from the page should be removed */ record from the page should be removed */
mtr_t* mtr) /* in: mtr */ mtr_t* mtr) /* in: mtr */
{ {
buf_block_t* father_block;
page_t* father_page; page_t* father_page;
ulint page_level; ulint page_level;
page_zip_des_t* father_page_zip; page_zip_des_t* father_page_zip;
...@@ -2149,9 +2143,10 @@ btr_lift_page_up( ...@@ -2149,9 +2143,10 @@ btr_lift_page_up(
ut_ad(btr_page_get_prev(page, mtr) == FIL_NULL); ut_ad(btr_page_get_prev(page, mtr) == FIL_NULL);
ut_ad(btr_page_get_next(page, mtr) == FIL_NULL); ut_ad(btr_page_get_next(page, mtr) == FIL_NULL);
ut_ad(mtr_memo_contains(mtr, block, MTR_MEMO_PAGE_X_FIX)); ut_ad(mtr_memo_contains(mtr, block, MTR_MEMO_PAGE_X_FIX));
father_page = page_align( father_block = buf_block_align(
btr_page_get_father_node_ptr(index, page, mtr)); btr_page_get_father_node_ptr(index, page, mtr));
father_page_zip = buf_frame_get_page_zip(father_page); father_page_zip = buf_block_get_page_zip(father_block);
father_page = buf_block_get_frame(father_block);
#ifdef UNIV_ZIP_DEBUG #ifdef UNIV_ZIP_DEBUG
ut_a(!father_page_zip ut_a(!father_page_zip
|| page_zip_validate(father_page_zip, father_page)); || page_zip_validate(father_page_zip, father_page));
...@@ -2162,7 +2157,7 @@ btr_lift_page_up( ...@@ -2162,7 +2157,7 @@ btr_lift_page_up(
btr_search_drop_page_hash_index(block); btr_search_drop_page_hash_index(block);
/* Make the father empty */ /* Make the father empty */
btr_page_empty(father_page, father_page_zip, mtr, index); btr_page_empty(father_block, father_page_zip, mtr, index);
/* Set the level before inserting records, because /* Set the level before inserting records, because
page_zip_compress() requires that the first user record page_zip_compress() requires that the first user record
on a non-leaf page has the min_rec_mark set. */ on a non-leaf page has the min_rec_mark set. */
...@@ -2438,6 +2433,7 @@ btr_discard_only_page_on_level( ...@@ -2438,6 +2433,7 @@ btr_discard_only_page_on_level(
page_t* page, /* in: page which is the only on its level */ page_t* page, /* in: page which is the only on its level */
mtr_t* mtr) /* in: mtr */ mtr_t* mtr) /* in: mtr */
{ {
buf_block_t* father_block;
page_t* father_page; page_t* father_page;
ulint page_level; ulint page_level;
...@@ -2446,8 +2442,9 @@ btr_discard_only_page_on_level( ...@@ -2446,8 +2442,9 @@ btr_discard_only_page_on_level(
ut_ad(mtr_memo_contains_page(mtr, page, MTR_MEMO_PAGE_X_FIX)); ut_ad(mtr_memo_contains_page(mtr, page, MTR_MEMO_PAGE_X_FIX));
btr_search_drop_page_hash_index(buf_block_align(page)); btr_search_drop_page_hash_index(buf_block_align(page));
father_page = page_align( father_block = buf_block_align(
btr_page_get_father_node_ptr(index, page, mtr)); btr_page_get_father_node_ptr(index, page, mtr));
father_page = buf_block_get_frame(father_block);
page_level = btr_page_get_level(page, mtr); page_level = btr_page_get_level(page, mtr);
...@@ -2463,8 +2460,8 @@ btr_discard_only_page_on_level( ...@@ -2463,8 +2460,8 @@ btr_discard_only_page_on_level(
== dict_index_get_page(index))) { == dict_index_get_page(index))) {
/* The father is the root page */ /* The father is the root page */
btr_page_empty(father_page, btr_page_empty(father_block,
buf_frame_get_page_zip(father_page), buf_block_get_page_zip(father_block),
mtr, index); mtr, index);
/* We play safe and reset the free bits for the father */ /* We play safe and reset the free bits for the father */
......
...@@ -176,104 +176,83 @@ btr_cur_latch_leaves( ...@@ -176,104 +176,83 @@ btr_cur_latch_leaves(
btr_cur_t* cursor, /* in: cursor */ btr_cur_t* cursor, /* in: cursor */
mtr_t* mtr) /* in: mtr */ mtr_t* mtr) /* in: mtr */
{ {
ulint mode;
ulint left_page_no; ulint left_page_no;
ulint right_page_no; ulint right_page_no;
page_t* get_page; buf_block_t* get_block;
ut_ad(page && mtr); ut_ad(page && mtr);
if (latch_mode == BTR_SEARCH_LEAF) { switch (latch_mode) {
case BTR_SEARCH_LEAF:
get_page = btr_page_get(space, page_no, RW_S_LATCH, mtr); case BTR_MODIFY_LEAF:
ut_a(page_is_comp(get_page) == page_is_comp(page)); mode = latch_mode == BTR_SEARCH_LEAF ? RW_S_LATCH : RW_X_LATCH;
buf_block_align(get_page)->check_index_page_at_flush = TRUE; get_block = btr_block_get(space, page_no, mode, mtr);
ut_a(page_is_comp(get_block->frame) == page_is_comp(page));
} else if (latch_mode == BTR_MODIFY_LEAF) { get_block->check_index_page_at_flush = TRUE;
return;
get_page = btr_page_get(space, page_no, RW_X_LATCH, mtr); case BTR_MODIFY_TREE:
ut_a(page_is_comp(get_page) == page_is_comp(page));
buf_block_align(get_page)->check_index_page_at_flush = TRUE;
} else if (latch_mode == BTR_MODIFY_TREE) {
/* x-latch also brothers from left to right */ /* x-latch also brothers from left to right */
left_page_no = btr_page_get_prev(page, mtr); left_page_no = btr_page_get_prev(page, mtr);
if (left_page_no != FIL_NULL) { if (left_page_no != FIL_NULL) {
get_page = btr_page_get(space, left_page_no, get_block = btr_block_get(space, left_page_no,
RW_X_LATCH, mtr); RW_X_LATCH, mtr);
#ifdef UNIV_BTR_DEBUG #ifdef UNIV_BTR_DEBUG
ut_a(btr_page_get_next(get_page, mtr) ut_a(page_is_comp(get_block->frame)
== page_is_comp(page));
ut_a(btr_page_get_next(get_block->frame, mtr)
== page_get_page_no(page)); == page_get_page_no(page));
#endif /* UNIV_BTR_DEBUG */ #endif /* UNIV_BTR_DEBUG */
ut_a(page_is_comp(get_page) == page_is_comp(page)); get_block->check_index_page_at_flush = TRUE;
buf_block_align(get_page)->check_index_page_at_flush
= TRUE;
} }
get_page = btr_page_get(space, page_no, RW_X_LATCH, mtr); get_block = btr_block_get(space, page_no, RW_X_LATCH, mtr);
ut_a(page_is_comp(get_page) == page_is_comp(page)); ut_a(page_is_comp(get_block->frame) == page_is_comp(page));
buf_block_align(get_page)->check_index_page_at_flush = TRUE; get_block->check_index_page_at_flush = TRUE;
right_page_no = btr_page_get_next(page, mtr); right_page_no = btr_page_get_next(page, mtr);
if (right_page_no != FIL_NULL) { if (right_page_no != FIL_NULL) {
get_page = btr_page_get(space, right_page_no, get_block = btr_block_get(space, right_page_no,
RW_X_LATCH, mtr); RW_X_LATCH, mtr);
#ifdef UNIV_BTR_DEBUG #ifdef UNIV_BTR_DEBUG
ut_a(btr_page_get_prev(get_page, mtr) ut_a(page_is_comp(get_block->frame)
== page_is_comp(page));
ut_a(btr_page_get_prev(get_block->frame, mtr)
== page_get_page_no(page)); == page_get_page_no(page));
#endif /* UNIV_BTR_DEBUG */ #endif /* UNIV_BTR_DEBUG */
buf_block_align(get_page)->check_index_page_at_flush get_block->check_index_page_at_flush = TRUE;
= TRUE;
} }
} else if (latch_mode == BTR_SEARCH_PREV) { return;
/* s-latch also left brother */ case BTR_SEARCH_PREV:
case BTR_MODIFY_PREV:
mode = latch_mode == BTR_SEARCH_PREV ? RW_S_LATCH : RW_X_LATCH;
/* latch also left brother */
left_page_no = btr_page_get_prev(page, mtr); left_page_no = btr_page_get_prev(page, mtr);
if (left_page_no != FIL_NULL) { if (left_page_no != FIL_NULL) {
cursor->left_page = btr_page_get(space, left_page_no, get_block = btr_block_get(space, left_page_no,
RW_S_LATCH, mtr); mode, mtr);
cursor->left_page = buf_block_get_frame(get_block);
#ifdef UNIV_BTR_DEBUG #ifdef UNIV_BTR_DEBUG
ut_a(btr_page_get_next(cursor->left_page, mtr)
== page_get_page_no(page));
#endif /* UNIV_BTR_DEBUG */
ut_a(page_is_comp(cursor->left_page) ut_a(page_is_comp(cursor->left_page)
== page_is_comp(page)); == page_is_comp(page));
buf_block_align(cursor->left_page)
->check_index_page_at_flush = TRUE;
}
get_page = btr_page_get(space, page_no, RW_S_LATCH, mtr);
ut_a(page_is_comp(get_page) == page_is_comp(page));
buf_block_align(get_page)->check_index_page_at_flush = TRUE;
} else if (latch_mode == BTR_MODIFY_PREV) {
/* x-latch also left brother */
left_page_no = btr_page_get_prev(page, mtr);
if (left_page_no != FIL_NULL) {
cursor->left_page = btr_page_get(space, left_page_no,
RW_X_LATCH, mtr);
#ifdef UNIV_BTR_DEBUG
ut_a(btr_page_get_next(cursor->left_page, mtr) ut_a(btr_page_get_next(cursor->left_page, mtr)
== page_get_page_no(page)); == page_get_page_no(page));
#endif /* UNIV_BTR_DEBUG */ #endif /* UNIV_BTR_DEBUG */
ut_a(page_is_comp(cursor->left_page) get_block->check_index_page_at_flush = TRUE;
== page_is_comp(page));
buf_block_align(cursor->left_page)
->check_index_page_at_flush = TRUE;
} }
get_page = btr_page_get(space, page_no, RW_X_LATCH, mtr); get_block = btr_block_get(space, page_no, mode, mtr);
ut_a(page_is_comp(get_page) == page_is_comp(page)); ut_a(page_is_comp(get_block->frame) == page_is_comp(page));
buf_block_align(get_page)->check_index_page_at_flush = TRUE; get_block->check_index_page_at_flush = TRUE;
} else { return;
ut_error;
} }
ut_error;
} }
/************************************************************************ /************************************************************************
...@@ -1650,7 +1629,7 @@ btr_cur_update_in_place( ...@@ -1650,7 +1629,7 @@ btr_cur_update_in_place(
block = buf_block_align(rec); block = buf_block_align(rec);
/* Check that enough space is available on the compressed page. */ /* Check that enough space is available on the compressed page. */
page_zip = buf_frame_get_page_zip(rec); page_zip = buf_block_get_page_zip(block);
if (UNIV_LIKELY_NULL(page_zip) if (UNIV_LIKELY_NULL(page_zip)
&& UNIV_UNLIKELY(!page_zip_alloc(page_zip, && UNIV_UNLIKELY(!page_zip_alloc(page_zip,
buf_block_get_frame(block), buf_block_get_frame(block),
......
...@@ -9,6 +9,7 @@ Created 12/7/1995 Heikki Tuuri ...@@ -9,6 +9,7 @@ Created 12/7/1995 Heikki Tuuri
#include "mach0data.h" #include "mach0data.h"
#include "ut0lst.h" #include "ut0lst.h"
#include "buf0buf.h" #include "buf0buf.h"
#include "page0page.h"
/************************************************************ /************************************************************
Opens a buffer to mlog. It must be closed with mlog_close. */ Opens a buffer to mlog. It must be closed with mlog_close. */
...@@ -160,7 +161,9 @@ mlog_write_initial_log_record_fast( ...@@ -160,7 +161,9 @@ mlog_write_initial_log_record_fast(
byte* log_ptr,/* in: pointer to mtr log which has been opened */ byte* log_ptr,/* in: pointer to mtr log which has been opened */
mtr_t* mtr) /* in: mtr */ mtr_t* mtr) /* in: mtr */
{ {
#ifdef UNIV_DEBUG
buf_block_t* block; buf_block_t* block;
#endif
ulint space; ulint space;
ulint offset; ulint offset;
...@@ -168,10 +171,8 @@ mlog_write_initial_log_record_fast( ...@@ -168,10 +171,8 @@ mlog_write_initial_log_record_fast(
ut_ad(type <= MLOG_BIGGEST_TYPE); ut_ad(type <= MLOG_BIGGEST_TYPE);
ut_ad(ptr && log_ptr); ut_ad(ptr && log_ptr);
block = buf_block_align(ptr); space = page_get_space_id(page_align(ptr));
offset = page_get_page_no(page_align(ptr));
space = buf_block_get_space(block);
offset = buf_block_get_page_no(block);
mach_write_to_1(log_ptr, type); mach_write_to_1(log_ptr, type);
log_ptr++; log_ptr++;
...@@ -188,6 +189,7 @@ mlog_write_initial_log_record_fast( ...@@ -188,6 +189,7 @@ mlog_write_initial_log_record_fast(
#ifdef UNIV_DEBUG #ifdef UNIV_DEBUG
/* We now assume that all x-latched pages have been modified! */ /* We now assume that all x-latched pages have been modified! */
block = buf_block_align(ptr);
if (!mtr_memo_contains(mtr, block, MTR_MEMO_MODIFY)) { if (!mtr_memo_contains(mtr, block, MTR_MEMO_MODIFY)) {
......
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