* ieee.c (struct ieee_handle): Add fields complex_float_index and

complex_double_index.
	(ieee_complex_type): Cache type index in complex_float_index and
	complex_double_index, depending upon size.  Set size on type stack
	to size * 2.

	* ieee.c (ieee_empty_type): Use builtin_unknown, not 0.
	(ieee_void_type): Use builtin_void, not 1.

	* ieee.c (parse_ieee_ty): Handle 'V' type code.
	(parse_ieee_atn): Don't require two numbers for type 10.

	* ieee.c (parse_ieee_be): Add one to offset at end of function or
	block.

	* ieee.c (struct ieee_block): Add field skip.
	(parse_ieee_bb): Don't call debug_record_function for __XRYCPP
	function, and set skip field.
	(parse_ieee_be): Don't call debug_end_function if skip is set.
This commit is contained in:
Ian Lance Taylor 1996-03-20 21:49:31 +00:00
parent d2309db18c
commit e820a5b09e

View file

@ -41,6 +41,8 @@ struct ieee_block
const char *filename; const char *filename;
/* The index of the function type, for a BB4 or BB6 block. */ /* The index of the function type, for a BB4 or BB6 block. */
unsigned int fnindx; unsigned int fnindx;
/* True if this function is being skipped. */
boolean skip;
}; };
/* This structure is the block stack. */ /* This structure is the block stack. */
@ -974,6 +976,7 @@ parse_ieee_bb (info, pp)
unsigned long namlen; unsigned long namlen;
char *namcopy; char *namcopy;
unsigned int fnindx; unsigned int fnindx;
boolean skip;
block_start = *pp; block_start = *pp;
@ -985,6 +988,7 @@ parse_ieee_bb (info, pp)
return false; return false;
fnindx = (unsigned int) -1; fnindx = (unsigned int) -1;
skip = false;
switch (b) switch (b)
{ {
@ -1098,33 +1102,44 @@ parse_ieee_bb (info, pp)
} }
else else
{ {
debug_type return_type; /* The MRI C++ compiler will output a fake function named
__XRYCPP to hold C++ debugging information. We skip
if (typindx < 256) that function. This is not crucial, but it makes
{ converting from IEEE to other debug formats work
return_type = ieee_builtin_type (info, block_start, typindx); better. */
if (return_type == NULL) if (strncmp (name, "__XRYCPP", namlen) == 0)
return false; skip = true;
}
else else
{ {
typindx -= 256; debug_type return_type;
if (! ieee_alloc_type (info, typindx, true))
return false;
fnindx = typindx;
return_type = info->types.types[typindx].type;
if (debug_get_type_kind (info->dhandle, return_type)
== DEBUG_KIND_FUNCTION)
return_type = debug_get_return_type (info->dhandle,
return_type);
}
namcopy = savestring (name, namlen); if (typindx < 256)
if (namcopy == NULL) {
return false; return_type = ieee_builtin_type (info, block_start,
if (! debug_record_function (info->dhandle, namcopy, return_type, typindx);
false, offset)) if (return_type == NULL)
return false; return false;
}
else
{
typindx -= 256;
if (! ieee_alloc_type (info, typindx, true))
return false;
fnindx = typindx;
return_type = info->types.types[typindx].type;
if (debug_get_type_kind (info->dhandle, return_type)
== DEBUG_KIND_FUNCTION)
return_type = debug_get_return_type (info->dhandle,
return_type);
}
namcopy = savestring (name, namlen);
if (namcopy == NULL)
return false;
if (! debug_record_function (info->dhandle, namcopy,
return_type, false, offset))
return false;
}
} }
} }
break; break;
@ -1188,6 +1203,7 @@ parse_ieee_bb (info, pp)
if (b == 5) if (b == 5)
info->blockstack.bsp->filename = namcopy; info->blockstack.bsp->filename = namcopy;
info->blockstack.bsp->fnindx = fnindx; info->blockstack.bsp->fnindx = fnindx;
info->blockstack.bsp->skip = skip;
++info->blockstack.bsp; ++info->blockstack.bsp;
return true; return true;
@ -1215,8 +1231,11 @@ parse_ieee_be (info, pp)
case 6: case 6:
if (! ieee_read_expression (info, pp, &offset)) if (! ieee_read_expression (info, pp, &offset))
return false; return false;
if (! debug_end_function (info->dhandle, offset)) if (! info->blockstack.bsp->skip)
return false; {
if (! debug_end_function (info->dhandle, offset + 1))
return false;
}
break; break;
case 0x86: case 0x86:
@ -1224,7 +1243,7 @@ parse_ieee_be (info, pp)
function. */ function. */
if (! ieee_read_expression (info, pp, &offset)) if (! ieee_read_expression (info, pp, &offset))
return false; return false;
if (! debug_end_block (info->dhandle, offset)) if (! debug_end_block (info->dhandle, offset + 1))
return false; return false;
break; break;
@ -1734,6 +1753,11 @@ parse_ieee_ty (info, pp)
} }
break; break;
case 'V':
/* Void. This is not documented, but the MRI compiler emits it. */
type = debug_make_void_type (dhandle);
break;
case 'Z': case 'Z':
/* Array with 0 lower bound. */ /* Array with 0 lower bound. */
{ {
@ -2185,9 +2209,11 @@ parse_ieee_atn (info, pp)
return true; return true;
case 10: case 10:
/* Locked register. */ /* Locked register. The spec says that there are two required
fields, but at least on occasion the MRI compiler only emits
one. */
if (! ieee_read_number (info, pp, &v) if (! ieee_read_number (info, pp, &v)
|| ! ieee_read_number (info, pp, &v2)) || ! ieee_read_optional_number (info, pp, &v2, &present))
return false; return false;
/* I think this means a variable that is both in a register and /* I think this means a variable that is both in a register and
@ -3741,6 +3767,10 @@ struct ieee_handle
struct ieee_modified_type *modified; struct ieee_modified_type *modified;
/* Number of entries allocated in modified. */ /* Number of entries allocated in modified. */
unsigned int modified_alloc; unsigned int modified_alloc;
/* 4 byte complex type. */
unsigned int complex_float_index;
/* 8 byte complex type. */
unsigned int complex_double_index;
/* The depth of block nesting. This is 0 outside a function, and 1 /* The depth of block nesting. This is 0 outside a function, and 1
just after start_function is called. */ just after start_function is called. */
unsigned int block_depth; unsigned int block_depth;
@ -5086,7 +5116,7 @@ ieee_empty_type (p)
{ {
struct ieee_handle *info = (struct ieee_handle *) p; struct ieee_handle *info = (struct ieee_handle *) p;
return ieee_push_type (info, 0, 0, false, false); return ieee_push_type (info, (int) builtin_unknown, 0, false, false);
} }
/* Make a void type. */ /* Make a void type. */
@ -5097,7 +5127,7 @@ ieee_void_type (p)
{ {
struct ieee_handle *info = (struct ieee_handle *) p; struct ieee_handle *info = (struct ieee_handle *) p;
return ieee_push_type (info, 1, 0, false, false); return ieee_push_type (info, (int) builtin_void, 0, false, false);
} }
/* Make an integer type. */ /* Make an integer type. */
@ -5182,6 +5212,9 @@ ieee_complex_type (p, size)
switch (size) switch (size)
{ {
case 4: case 4:
if (info->complex_float_index != 0)
return ieee_push_type (info, info->complex_float_index, size * 2,
false, false);
code = 'c'; code = 'c';
break; break;
case 12: case 12:
@ -5189,6 +5222,9 @@ ieee_complex_type (p, size)
/* These cases can be output by gcc -gstabs. Outputting the /* These cases can be output by gcc -gstabs. Outputting the
wrong type is better than crashing. */ wrong type is better than crashing. */
case 8: case 8:
if (info->complex_double_index != 0)
return ieee_push_type (info, info->complex_double_index, size * 2,
false, false);
code = 'd'; code = 'd';
break; break;
default: default:
@ -5197,9 +5233,17 @@ ieee_complex_type (p, size)
} }
/* FIXME: I don't know what the string is for. */ /* FIXME: I don't know what the string is for. */
return (ieee_define_type (info, size, false, false) if (! ieee_define_type (info, size * 2, false, false)
&& ieee_write_number (info, code) || ! ieee_write_number (info, code)
&& ieee_write_id (info, "")); || ! ieee_write_id (info, ""))
return false;
if (size == 4)
info->complex_float_index = info->type_stack->type.indx;
else
info->complex_double_index = info->type_stack->type.indx;
return true;
} }
/* Make a boolean type. IEEE doesn't support these, so we just make /* Make a boolean type. IEEE doesn't support these, so we just make
@ -7327,7 +7371,7 @@ ieee_lineno (p, filename, lineno, addr)
return false; return false;
if (strcmp (info->filename, info->pending_lineno_filename) == 0) if (strcmp (info->filename, info->pending_lineno_filename) == 0)
{ {
/* We need a new NN record, and we aren't output to /* We need a new NN record, and we aren't about to
output one. */ output one. */
info->lineno_name_indx = info->name_indx; info->lineno_name_indx = info->name_indx;
++info->name_indx; ++info->name_indx;