Commit 03a6c35b authored by marko's avatar marko

branches/zip: Remove temporary hooks for testing BLOB compression.

dict_mem_table_create(): Initialize table->zip.

btr0cur.c: Distinguish compressed BLOBs based on page_zip or table->zip.
parent 9d4fa728
...@@ -38,8 +38,6 @@ Created 10/16/1994 Heikki Tuuri ...@@ -38,8 +38,6 @@ Created 10/16/1994 Heikki Tuuri
#include "lock0lock.h" #include "lock0lock.h"
#include "zlib.h" #include "zlib.h"
#define ZIP_BLOB TRUE /* testing */
#ifdef UNIV_DEBUG #ifdef UNIV_DEBUG
/* If the following is set to TRUE, this module prints a lot of /* If the following is set to TRUE, this module prints a lot of
trace information of individual record operations */ trace information of individual record operations */
...@@ -841,7 +839,7 @@ btr_cur_insert_if_possible( ...@@ -841,7 +839,7 @@ btr_cur_insert_if_possible(
dtuple_t* tuple, /* in: tuple to insert; the size info need not dtuple_t* tuple, /* in: tuple to insert; the size info need not
have been stored to tuple */ have been stored to tuple */
const ulint* ext, /* in: array of extern field numbers */ const ulint* ext, /* in: array of extern field numbers */
ulint n_ext, /* in: number of elements in vec */ ulint n_ext, /* in: number of elements in ext */
mtr_t* mtr) /* in: mtr */ mtr_t* mtr) /* in: mtr */
{ {
page_cur_t* page_cursor; page_cur_t* page_cursor;
...@@ -3517,8 +3515,9 @@ btr_store_big_rec_extern_fields( ...@@ -3517,8 +3515,9 @@ btr_store_big_rec_extern_fields(
space_id = buf_frame_get_space_id(rec); space_id = buf_frame_get_space_id(rec);
page_zip = buf_block_get_page_zip(buf_block_align(rec)); page_zip = buf_block_get_page_zip(buf_block_align(rec));
ut_ad(!page_zip == !index->table->zip);
if (ZIP_BLOB || UNIV_LIKELY_NULL(page_zip)) { if (UNIV_LIKELY_NULL(page_zip)) {
int err; int err;
c_stream.zalloc = (alloc_func) 0; c_stream.zalloc = (alloc_func) 0;
...@@ -3549,7 +3548,7 @@ btr_store_big_rec_extern_fields( ...@@ -3549,7 +3548,7 @@ btr_store_big_rec_extern_fields(
prev_page_no = FIL_NULL; prev_page_no = FIL_NULL;
if (ZIP_BLOB || UNIV_LIKELY_NULL(page_zip)) { if (UNIV_LIKELY_NULL(page_zip)) {
int err = deflateReset(&c_stream); int err = deflateReset(&c_stream);
ut_a(err == Z_OK); ut_a(err == Z_OK);
...@@ -3572,7 +3571,7 @@ btr_store_big_rec_extern_fields( ...@@ -3572,7 +3571,7 @@ btr_store_big_rec_extern_fields(
mtr_commit(&mtr); mtr_commit(&mtr);
if (ZIP_BLOB || UNIV_LIKELY_NULL(page_zip)) { if (UNIV_LIKELY_NULL(page_zip)) {
deflateEnd(&c_stream); deflateEnd(&c_stream);
} }
...@@ -3592,7 +3591,7 @@ btr_store_big_rec_extern_fields( ...@@ -3592,7 +3591,7 @@ btr_store_big_rec_extern_fields(
SYNC_EXTERN_STORAGE); SYNC_EXTERN_STORAGE);
#endif /* UNIV_SYNC_DEBUG */ #endif /* UNIV_SYNC_DEBUG */
if (ZIP_BLOB||UNIV_LIKELY_NULL(page_zip)) { if (UNIV_LIKELY_NULL(page_zip)) {
next_ptr = prev_page; next_ptr = prev_page;
} else { } else {
next_ptr = prev_page + FIL_PAGE_DATA next_ptr = prev_page + FIL_PAGE_DATA
...@@ -3603,7 +3602,7 @@ btr_store_big_rec_extern_fields( ...@@ -3603,7 +3602,7 @@ btr_store_big_rec_extern_fields(
page_no, MLOG_4BYTES, &mtr); page_no, MLOG_4BYTES, &mtr);
} }
if (UNIV_LIKELY_NULL(ZIP_BLOB||page_zip)) { if (UNIV_LIKELY_NULL(page_zip)) {
int err; int err;
c_stream.next_out = page + 4; c_stream.next_out = page + 4;
...@@ -3667,9 +3666,7 @@ btr_store_big_rec_extern_fields( ...@@ -3667,9 +3666,7 @@ btr_store_big_rec_extern_fields(
FIL_PAGE_DATA, FIL_PAGE_DATA,
MLOG_4BYTES, &mtr); MLOG_4BYTES, &mtr);
} }
#if ZIP_BLOB
if (page_zip)
#endif
page_zip_write_blob_ptr(page_zip, rec, page_zip_write_blob_ptr(page_zip, rec,
index, offsets, index, offsets,
big_rec_vec->fields[i].field_no, &mtr); big_rec_vec->fields[i].field_no, &mtr);
...@@ -3755,7 +3752,7 @@ next_zip_page: ...@@ -3755,7 +3752,7 @@ next_zip_page:
} }
} }
if (ZIP_BLOB||UNIV_LIKELY_NULL(page_zip)) { if (UNIV_LIKELY_NULL(page_zip)) {
deflateEnd(&c_stream); deflateEnd(&c_stream);
} }
...@@ -3851,7 +3848,7 @@ btr_free_externally_stored_field( ...@@ -3851,7 +3848,7 @@ btr_free_externally_stored_field(
#ifdef UNIV_SYNC_DEBUG #ifdef UNIV_SYNC_DEBUG
buf_page_dbg_add_level(page, SYNC_EXTERN_STORAGE); buf_page_dbg_add_level(page, SYNC_EXTERN_STORAGE);
#endif /* UNIV_SYNC_DEBUG */ #endif /* UNIV_SYNC_DEBUG */
if (ZIP_BLOB||UNIV_LIKELY_NULL(page_zip)) { if (UNIV_UNLIKELY(index->table->zip)) {
next_page_no = mach_read_from_4(page); next_page_no = mach_read_from_4(page);
btr_page_free_low(index->tree, page, btr_page_free_low(index->tree, page,
...@@ -4179,6 +4176,6 @@ btr_rec_copy_externally_stored_field( ...@@ -4179,6 +4176,6 @@ btr_rec_copy_externally_stored_field(
data = rec_get_nth_field(rec, offsets, no, &local_len); data = rec_get_nth_field(rec, offsets, no, &local_len);
return(btr_copy_externally_stored_field(len, data, return(btr_copy_externally_stored_field(len, data,
ZIP_BLOB, !!buf_block_get_page_zip(buf_block_align(rec)),
local_len, heap)); local_len, heap));
} }
...@@ -57,6 +57,7 @@ dict_mem_table_create( ...@@ -57,6 +57,7 @@ dict_mem_table_create(
table->ibd_file_missing = FALSE; table->ibd_file_missing = FALSE;
table->tablespace_discarded = FALSE; table->tablespace_discarded = FALSE;
table->comp = comp; table->comp = comp;
table->zip = 0;
table->n_def = 0; table->n_def = 0;
table->n_cols = n_cols + DATA_N_SYS_COLS; table->n_cols = n_cols + DATA_N_SYS_COLS;
table->mem_fix = 0; table->mem_fix = 0;
......
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