Commit 9df65876 authored by marko's avatar marko

branches/zip: Improve Valgrind instrumentation.

page_zip_decompress(): Assert that the uncompressed page is completely defined.

page_zip_validate(): Assert that the compressed and uncompressed pages are
completely defined.  Fetch the "valid" bits, so that they can be examined
when run under valgrind --db-attach=yes.
parent 83f47098
...@@ -2629,6 +2629,7 @@ err_exit: ...@@ -2629,6 +2629,7 @@ err_exit:
} }
ut_a(page_is_comp(page)); ut_a(page_is_comp(page));
UNIV_MEM_ASSERT_RW(page, UNIV_PAGE_SIZE);
page_zip_fields_free(index); page_zip_fields_free(index);
mem_heap_free(heap); mem_heap_free(heap);
...@@ -2651,7 +2652,7 @@ page_zip_validate( ...@@ -2651,7 +2652,7 @@ page_zip_validate(
const page_zip_des_t* page_zip,/* in: compressed page */ const page_zip_des_t* page_zip,/* in: compressed page */
const page_t* page) /* in: uncompressed page */ const page_t* page) /* in: uncompressed page */
{ {
page_zip_des_t temp_page_zip = *page_zip; page_zip_des_t temp_page_zip;
byte* temp_page_buf; byte* temp_page_buf;
page_t* temp_page; page_t* temp_page;
ibool valid; ibool valid;
...@@ -2676,6 +2677,15 @@ page_zip_validate( ...@@ -2676,6 +2677,15 @@ page_zip_validate(
temp_page_buf = ut_malloc(2 * UNIV_PAGE_SIZE); temp_page_buf = ut_malloc(2 * UNIV_PAGE_SIZE);
temp_page = ut_align(temp_page_buf, UNIV_PAGE_SIZE); temp_page = ut_align(temp_page_buf, UNIV_PAGE_SIZE);
#ifdef UNIV_DEBUG_VALGRIND
/* Get some more information if the UNIV_MEM_ASSERT_RW below fail. */
VALGRIND_GET_VBITS(page, temp_page, UNIV_PAGE_SIZE);
VALGRIND_GET_VBITS(page_zip, &temp_page_zip, sizeof temp_page_zip);
#endif /* UNIV_DEBUG_VALGRIND */
UNIV_MEM_ASSERT_RW(page, UNIV_PAGE_SIZE);
UNIV_MEM_ASSERT_RW(page_zip->data, page_zip_get_size(page_zip));
temp_page_zip = *page_zip;
valid = page_zip_decompress(&temp_page_zip, temp_page); valid = page_zip_decompress(&temp_page_zip, temp_page);
if (!valid) { if (!valid) {
fputs("page_zip_validate(): failed to decompress\n", stderr); fputs("page_zip_validate(): failed to decompress\n", stderr);
......
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