55222 - Previous patch had a bug in unused code which was reactivated in

mysql-trunk-innodb in rev revno: 3367  Tue 2010-12-07 02:25:25-0800.
The crash happens only when lower_case_table_names=2, such as on MacOS,
when running the new testcase innodb-system-table-view.  Specifically,
it crashes when any query is made against the INFORMATION_SCHEMA.
INNODB_SYS_FOREIGN table.  The function dict_process_sys_foreign_rec()
is only used for displaying SYS_FOREIGN records so it does not need a
lookup version of those names to be allocated. In this patch, those new
function calls are deleted.
parent e2131e67
...@@ -441,7 +441,7 @@ dict_process_sys_fields_rec( ...@@ -441,7 +441,7 @@ dict_process_sys_fields_rec(
/********************************************************************//** /********************************************************************//**
This function parses a SYS_FOREIGN record and populate a dict_foreign_t This function parses a SYS_FOREIGN record and populate a dict_foreign_t
structure with the information from the record. For detail information structure with the information from the record. For detail information
about SYS_FOREIGN fields, please refer to dict_load_foreign() function about SYS_FOREIGN fields, please refer to dict_load_foreign() function.
@return error message, or NULL on success */ @return error message, or NULL on success */
UNIV_INTERN UNIV_INTERN
const char* const char*
...@@ -469,6 +469,11 @@ dict_process_sys_foreign_rec( ...@@ -469,6 +469,11 @@ dict_process_sys_foreign_rec(
err_len: err_len:
return("incorrect column length in SYS_FOREIGN"); return("incorrect column length in SYS_FOREIGN");
} }
/* This recieves a dict_foreign_t* that points to a stack variable.
So mem_heap_free(foreign->heap) is not used as elsewhere.
Since the heap used here is freed elsewhere, foreign->heap
is not assigned. */
foreign->id = mem_heap_strdupl(heap, (const char*) field, len); foreign->id = mem_heap_strdupl(heap, (const char*) field, len);
rec_get_nth_field_offs_old(rec, 1/*DB_TRX_ID*/, &len); rec_get_nth_field_offs_old(rec, 1/*DB_TRX_ID*/, &len);
...@@ -480,22 +485,22 @@ dict_process_sys_foreign_rec( ...@@ -480,22 +485,22 @@ dict_process_sys_foreign_rec(
goto err_len; goto err_len;
} }
/* The _lookup versions of the referenced and foreign table names
are not assigned since they are not used in this dict_foreign_t */
field = rec_get_nth_field_old(rec, 3/*FOR_NAME*/, &len); field = rec_get_nth_field_old(rec, 3/*FOR_NAME*/, &len);
if (UNIV_UNLIKELY(len < 1 || len == UNIV_SQL_NULL)) { if (UNIV_UNLIKELY(len < 1 || len == UNIV_SQL_NULL)) {
goto err_len; goto err_len;
} }
foreign->foreign_table_name = mem_heap_strdupl( foreign->foreign_table_name = mem_heap_strdupl(
heap, (const char*) field, len); heap, (const char*) field, len);
dict_mem_foreign_table_name_lookup_set(foreign, TRUE);
field = rec_get_nth_field_old(rec, 4/*REF_NAME*/, &len); field = rec_get_nth_field_old(rec, 4/*REF_NAME*/, &len);
if (UNIV_UNLIKELY(len < 1 || len == UNIV_SQL_NULL)) { if (UNIV_UNLIKELY(len < 1 || len == UNIV_SQL_NULL)) {
goto err_len; goto err_len;
} }
foreign->referenced_table_name = mem_heap_strdupl( foreign->referenced_table_name = mem_heap_strdupl(
heap, (const char*) field, len); heap, (const char*) field, len);
dict_mem_referenced_table_name_lookup_set(foreign, TRUE);
field = rec_get_nth_field_old(rec, 5/*N_COLS*/, &len); field = rec_get_nth_field_old(rec, 5/*N_COLS*/, &len);
if (UNIV_UNLIKELY(len != 4)) { if (UNIV_UNLIKELY(len != 4)) {
......
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