Commit 0c46bd17 authored by marko's avatar marko

branches/zip: recv_recover_page_func(): Write the log sequence number

to the compressed page, if there is one.  Previously, the function only
wrote the LSN to the uncompressed page.

It is not clear why recv_recover_page_func() is updating FIL_PAGE_LSN
in the buffer pool.  The log sequence number will be stamped on the
page when it is flushed to disk, in buf_flush_init_for_writing().
I noticed this inconsistency when analyzing Issue #313, but this patch
does not fix it.  That is no surprise, since FIL_PAGE_LSN should only
matter on disk files, not in the buffer pool.
parent b18aa573
...@@ -1327,6 +1327,7 @@ recv_recover_page_func( ...@@ -1327,6 +1327,7 @@ recv_recover_page_func(
buf_block_t* block) /*!< in/out: buffer block */ buf_block_t* block) /*!< in/out: buffer block */
{ {
page_t* page; page_t* page;
page_zip_des_t* page_zip;
recv_addr_t* recv_addr; recv_addr_t* recv_addr;
recv_t* recv; recv_t* recv;
byte* buf; byte* buf;
...@@ -1376,6 +1377,7 @@ recv_recover_page_func( ...@@ -1376,6 +1377,7 @@ recv_recover_page_func(
mtr_set_log_mode(&mtr, MTR_LOG_NONE); mtr_set_log_mode(&mtr, MTR_LOG_NONE);
page = block->frame; page = block->frame;
page_zip = buf_block_get_page_zip(block);
#ifndef UNIV_HOTBACKUP #ifndef UNIV_HOTBACKUP
if (just_read_in) { if (just_read_in) {
...@@ -1436,13 +1438,19 @@ recv_recover_page_func( ...@@ -1436,13 +1438,19 @@ recv_recover_page_func(
if (recv->type == MLOG_INIT_FILE_PAGE) { if (recv->type == MLOG_INIT_FILE_PAGE) {
page_lsn = page_newest_lsn; page_lsn = page_newest_lsn;
mach_write_ull(page + UNIV_PAGE_SIZE memset(FIL_PAGE_LSN + page, 0, 8);
- FIL_PAGE_END_LSN_OLD_CHKSUM, 0); memset(UNIV_PAGE_SIZE - FIL_PAGE_END_LSN_OLD_CHKSUM
mach_write_ull(page + FIL_PAGE_LSN, 0); + page, 0, 8);
if (page_zip) {
memset(FIL_PAGE_LSN + page_zip->data, 0, 8);
}
} }
if (recv->start_lsn >= page_lsn) { if (recv->start_lsn >= page_lsn) {
ib_uint64_t end_lsn;
if (!modification_to_page) { if (!modification_to_page) {
modification_to_page = TRUE; modification_to_page = TRUE;
...@@ -1464,11 +1472,17 @@ recv_recover_page_func( ...@@ -1464,11 +1472,17 @@ recv_recover_page_func(
recv_parse_or_apply_log_rec_body(recv->type, buf, recv_parse_or_apply_log_rec_body(recv->type, buf,
buf + recv->len, buf + recv->len,
block, &mtr); block, &mtr);
mach_write_ull(page + UNIV_PAGE_SIZE
- FIL_PAGE_END_LSN_OLD_CHKSUM, end_lsn = recv->start_lsn + recv->len;
recv->start_lsn + recv->len); mach_write_ull(FIL_PAGE_LSN + page, end_lsn);
mach_write_ull(page + FIL_PAGE_LSN, mach_write_ull(UNIV_PAGE_SIZE
recv->start_lsn + recv->len); - FIL_PAGE_END_LSN_OLD_CHKSUM
+ page, end_lsn);
if (page_zip) {
mach_write_ull(FIL_PAGE_LSN
+ page_zip->data, end_lsn);
}
} }
if (recv->len > RECV_DATA_BLOCK_SIZE) { if (recv->len > RECV_DATA_BLOCK_SIZE) {
......
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