diff options
author | Marko Mäkelä <marko.makela@mariadb.com> | 2020-06-02 10:25:11 +0300 |
---|---|---|
committer | Marko Mäkelä <marko.makela@mariadb.com> | 2020-06-02 10:25:11 +0300 |
commit | 8300f639a14afeb379c224e10dab9d99d31cecbd (patch) | |
tree | c67c0a5afc6062b99ec21194a99b81d3633f8c38 /storage/innobase/buf | |
parent | 804761a844906c7f7bd11139a366a5dfc1d8bcd6 (diff) | |
parent | 50641db2d11ad8a2228f7938d851e52decb71a9b (diff) | |
download | mariadb-git-8300f639a14afeb379c224e10dab9d99d31cecbd.tar.gz |
Merge 10.2 into 10.3
Diffstat (limited to 'storage/innobase/buf')
-rw-r--r-- | storage/innobase/buf/buf0buf.cc | 2 | ||||
-rw-r--r-- | storage/innobase/buf/buf0flu.cc | 6 | ||||
-rw-r--r-- | storage/innobase/buf/buf0lru.cc | 21 |
3 files changed, 3 insertions, 26 deletions
diff --git a/storage/innobase/buf/buf0buf.cc b/storage/innobase/buf/buf0buf.cc index 9a32f4cbd14..750e9da181f 100644 --- a/storage/innobase/buf/buf0buf.cc +++ b/storage/innobase/buf/buf0buf.cc @@ -4677,7 +4677,7 @@ evict_from_pool: buf_pool->mutex or block->mutex. */ { - bool success = buf_zip_decompress(block, TRUE); + bool success = buf_zip_decompress(block, false); if (!success) { buf_pool_mutex_enter(buf_pool); diff --git a/storage/innobase/buf/buf0flu.cc b/storage/innobase/buf/buf0flu.cc index b116ca919fd..243f3a18019 100644 --- a/storage/innobase/buf/buf0flu.cc +++ b/storage/innobase/buf/buf0flu.cc @@ -1071,10 +1071,8 @@ buf_flush_write_block_low( case BUF_BLOCK_ZIP_DIRTY: frame = bpage->zip.data; - mach_write_to_8(frame + FIL_PAGE_LSN, - bpage->newest_modification); - - ut_a(page_zip_verify_checksum(frame, bpage->size.physical())); + buf_flush_update_zip_checksum(frame, bpage->size.physical(), + bpage->newest_modification); break; case BUF_BLOCK_FILE_PAGE: frame = bpage->zip.data; diff --git a/storage/innobase/buf/buf0lru.cc b/storage/innobase/buf/buf0lru.cc index 40fed0617e7..2baa7ab0780 100644 --- a/storage/innobase/buf/buf0lru.cc +++ b/storage/innobase/buf/buf0lru.cc @@ -1616,27 +1616,6 @@ func_exit: UNIV_MEM_INVALID(((buf_block_t*) bpage)->frame, srv_page_size); - if (b != NULL) { - - /* Compute and stamp the compressed page - checksum while not holding any mutex. The - block is already half-freed - (BUF_BLOCK_REMOVE_HASH) and removed from - buf_pool->page_hash, thus inaccessible by any - other thread. */ - - ut_ad(b->size.is_compressed()); - - const uint32_t checksum = page_zip_calc_checksum( - b->zip.data, - b->size.physical(), - static_cast<srv_checksum_algorithm_t>( - srv_checksum_algorithm)); - - mach_write_to_4(b->zip.data + FIL_PAGE_SPACE_OR_CHKSUM, - checksum); - } - buf_pool_mutex_enter(buf_pool); if (b != NULL) { |