Commit db1cb106 authored by marko's avatar marko

branches/innodb+: ibuf_rec_get_size(): Correct some bugs. rb://17

This function was created when the delete buffering code was merged from
branches/fts in r2324.

ibuf_rec_get_size(): Rename the parameter new_format to pre_4_1.  Use
the correct offsets and accessors for both values of pre_4_1.

ibuf_rec_get_info(): Note that the record must be in 4.1 or later format.
parent 1141a8e0
...@@ -1116,7 +1116,7 @@ ibuf_rec_get_space( ...@@ -1116,7 +1116,7 @@ ibuf_rec_get_space(
} }
/******************************************************************** /********************************************************************
Get various information about an ibuf record. */ Get various information about an ibuf record in >= 4.1.x format. */
static static
void void
ibuf_rec_get_info( ibuf_rec_get_info(
...@@ -1509,32 +1509,41 @@ ibuf_rec_get_size( ...@@ -1509,32 +1509,41 @@ ibuf_rec_get_size(
const rec_t* rec, /* in: ibuf record */ const rec_t* rec, /* in: ibuf record */
const byte* types, /* in: fields */ const byte* types, /* in: fields */
ulint n_fields, /* in: number of fields */ ulint n_fields, /* in: number of fields */
ibool new_format) /* in: TRUE or FALSE */ ibool pre_4_1) /* in: TRUE=pre-4.1 format,
FALSE=newer */
{ {
ulint i; ulint i;
ulint offset; ulint field_offset;
ulint types_offset;
ulint size = 0; ulint size = 0;
/* 4 for compact record and 2 for old style. */ if (pre_4_1) {
offset = new_format ? 4 : 2; field_offset = 2;
types_offset = DATA_ORDER_NULL_TYPE_BUF_SIZE;
} else {
field_offset = 4;
types_offset = DATA_NEW_ORDER_NULL_TYPE_BUF_SIZE;
}
for (i = 0; i < n_fields; i++) { for (i = 0; i < n_fields; i++) {
ulint len; ulint len;
const byte* field;
field = rec_get_nth_field_old(rec, i + offset, &len);
if (len == UNIV_SQL_NULL) {
dtype_t dtype; dtype_t dtype;
dtype_read_for_order_and_null_size( rec_get_nth_field_offs_old(rec, i + field_offset, &len);
&dtype, types + i
* DATA_ORDER_NULL_TYPE_BUF_SIZE); if (len != UNIV_SQL_NULL) {
size += len;
} else if (pre_4_1) {
dtype_read_for_order_and_null_size(&dtype, types);
size += dtype_get_sql_null_size(&dtype); size += dtype_get_sql_null_size(&dtype);
} else { } else {
size += len; dtype_new_read_for_order_and_null_size(&dtype, types);
size += dtype_get_sql_null_size(&dtype);
} }
types += types_offset;
} }
return(size); return(size);
...@@ -1556,8 +1565,8 @@ ibuf_rec_get_volume( ...@@ -1556,8 +1565,8 @@ ibuf_rec_get_volume(
const byte* data; const byte* data;
const byte* types; const byte* types;
ulint n_fields; ulint n_fields;
ulint data_size = 0; ulint data_size;
ibool new_format = FALSE; ibool pre_4_1;
ut_ad(ibuf_inside()); ut_ad(ibuf_inside());
ut_ad(rec_get_n_fields_old(ibuf_rec) > 2); ut_ad(rec_get_n_fields_old(ibuf_rec) > 2);
...@@ -1570,6 +1579,8 @@ ibuf_rec_get_volume( ...@@ -1570,6 +1579,8 @@ ibuf_rec_get_volume(
ut_a(trx_doublewrite_must_reset_space_ids); ut_a(trx_doublewrite_must_reset_space_ids);
ut_a(!trx_sys_multiple_tablespace_format); ut_a(!trx_sys_multiple_tablespace_format);
pre_4_1 = TRUE;
n_fields = rec_get_n_fields_old(ibuf_rec) - 2; n_fields = rec_get_n_fields_old(ibuf_rec) - 2;
types = rec_get_nth_field_old(ibuf_rec, 1, &len); types = rec_get_nth_field_old(ibuf_rec, 1, &len);
...@@ -1584,6 +1595,8 @@ ibuf_rec_get_volume( ...@@ -1584,6 +1595,8 @@ ibuf_rec_get_volume(
ut_a(trx_sys_multiple_tablespace_format); ut_a(trx_sys_multiple_tablespace_format);
ut_a(*data == 0); ut_a(*data == 0);
pre_4_1 = FALSE;
types = rec_get_nth_field_old(ibuf_rec, 3, &len); types = rec_get_nth_field_old(ibuf_rec, 3, &len);
ibuf_rec_get_info(ibuf_rec, &op, &comp, &info_len, NULL); ibuf_rec_get_info(ibuf_rec, &op, &comp, &info_len, NULL);
...@@ -1615,11 +1628,9 @@ ibuf_rec_get_volume( ...@@ -1615,11 +1628,9 @@ ibuf_rec_get_volume(
types += info_len; types += info_len;
n_fields = rec_get_n_fields_old(ibuf_rec) - 4; n_fields = rec_get_n_fields_old(ibuf_rec) - 4;
new_format = TRUE;
} }
data_size = ibuf_rec_get_size(ibuf_rec, types, n_fields, new_format); data_size = ibuf_rec_get_size(ibuf_rec, types, n_fields, pre_4_1);
return(data_size + rec_get_converted_extra_size(data_size, n_fields, 0) return(data_size + rec_get_converted_extra_size(data_size, n_fields, 0)
+ page_dir_calc_reserved_space(1)); + page_dir_calc_reserved_space(1));
......
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