mirror of
https://github.com/espressif/binutils-gdb.git
synced 2025-08-03 04:01:22 +08:00
Initialize the c++ specific portion of the type structure for union types
as well as struct types, since gdb attempts to reference that portion for both types. Was getting core dumps due to NULL pointer dereferencing.
This commit is contained in:
@ -901,24 +901,28 @@ DEFUN(struct_type, (dip, thisdie, enddie),
|
||||
{
|
||||
type = alloc_utype (dip -> dieref, NULL);
|
||||
}
|
||||
switch (dip -> dietag)
|
||||
if (dip -> dietag == TAG_structure_type || dip -> dietag == TAG_union_type)
|
||||
{
|
||||
TYPE_CPLUS_SPECIFIC (type) = (struct cplus_struct_type *)
|
||||
obstack_alloc (symbol_obstack, sizeof (struct cplus_struct_type));
|
||||
(void) memset (TYPE_CPLUS_SPECIFIC (type), 0,
|
||||
sizeof (struct cplus_struct_type));
|
||||
if (dip -> dietag == TAG_structure_type)
|
||||
{
|
||||
TYPE_CODE (type) = TYPE_CODE_STRUCT;
|
||||
tpart1 = "struct ";
|
||||
}
|
||||
else
|
||||
{
|
||||
TYPE_CODE (type) = TYPE_CODE_UNION;
|
||||
tpart1 = "union ";
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
case TAG_structure_type:
|
||||
TYPE_CODE (type) = TYPE_CODE_STRUCT;
|
||||
TYPE_CPLUS_SPECIFIC (type)
|
||||
= (struct cplus_struct_type *) obstack_alloc (symbol_obstack, sizeof (struct cplus_struct_type));
|
||||
bzero (TYPE_CPLUS_SPECIFIC (type), sizeof (struct cplus_struct_type));
|
||||
tpart1 = "struct ";
|
||||
break;
|
||||
case TAG_union_type:
|
||||
TYPE_CODE (type) = TYPE_CODE_UNION;
|
||||
tpart1 = "union ";
|
||||
break;
|
||||
default:
|
||||
tpart1 = "";
|
||||
SQUAWK (("missing structure or union tag"));
|
||||
TYPE_CODE (type) = TYPE_CODE_UNDEF;
|
||||
break;
|
||||
}
|
||||
/* Some compilers try to be helpful by inventing "fake" names for anonymous
|
||||
enums, structures, and unions, like "~0fake". Thanks, but no thanks. */
|
||||
|
Reference in New Issue
Block a user