Commit fbfd77b8 by Joel Brobecker

dwarf2out.c (subrange_type_die): Add context_die parameter.

        * dwarf2out.c (subrange_type_die): Add context_die parameter.
        Create the subrange_type DIE using the given context DIE.
        (modified_type_die): Update call to subrange_type_die.

From-SVN: r75537
parent 7ce27103
2004-01-07 Zack Weinberg <zack@codesourcery.com> 2004-01-08 J. Brobecker <brobecker@gnat.com>
* dwarf2out.c (subrange_type_die): Add context_die parameter.
Create the subrange_type DIE using the given context DIE.
(modified_type_die): Update call to subrange_type_die.
2004-01-08 Zack Weinberg <zack@codesourcery.com>
* dwarf2.h, unwind-dw2-fde.h, unwind-pe.h, unwind.h: * dwarf2.h, unwind-dw2-fde.h, unwind-pe.h, unwind.h:
Add multiple-include guard. Add multiple-include guard.
......
...@@ -3697,7 +3697,7 @@ static dw_die_ref base_type_die (tree); ...@@ -3697,7 +3697,7 @@ static dw_die_ref base_type_die (tree);
static tree root_type (tree); static tree root_type (tree);
static int is_base_type (tree); static int is_base_type (tree);
static bool is_ada_subrange_type (tree); static bool is_ada_subrange_type (tree);
static dw_die_ref subrange_type_die (tree); static dw_die_ref subrange_type_die (tree, dw_die_ref);
static dw_die_ref modified_type_die (tree, int, int, dw_die_ref); static dw_die_ref modified_type_die (tree, int, int, dw_die_ref);
static int type_is_enum (tree); static int type_is_enum (tree);
static unsigned int reg_number (rtx); static unsigned int reg_number (rtx);
...@@ -7819,18 +7819,21 @@ is_ada_subrange_type (tree type) ...@@ -7819,18 +7819,21 @@ is_ada_subrange_type (tree type)
to a DIE that describes the given type. */ to a DIE that describes the given type. */
static dw_die_ref static dw_die_ref
subrange_type_die (tree type) subrange_type_die (tree type, dw_die_ref context_die)
{ {
dw_die_ref subtype_die; dw_die_ref subtype_die;
dw_die_ref subrange_die; dw_die_ref subrange_die;
tree name = TYPE_NAME (type); tree name = TYPE_NAME (type);
if (context_die == NULL)
context_die = comp_unit_die;
subtype_die = base_type_die (TREE_TYPE (type)); subtype_die = base_type_die (TREE_TYPE (type));
if (TREE_CODE (name) == TYPE_DECL) if (TREE_CODE (name) == TYPE_DECL)
name = DECL_NAME (name); name = DECL_NAME (name);
subrange_die = new_die (DW_TAG_subrange_type, comp_unit_die, type); subrange_die = new_die (DW_TAG_subrange_type, context_die, type);
add_name_attribute (subrange_die, IDENTIFIER_POINTER (name)); add_name_attribute (subrange_die, IDENTIFIER_POINTER (name));
if (TYPE_MIN_VALUE (type) != NULL) if (TYPE_MIN_VALUE (type) != NULL)
add_bound_info (subrange_die, DW_AT_lower_bound, add_bound_info (subrange_die, DW_AT_lower_bound,
...@@ -7935,7 +7938,7 @@ modified_type_die (tree type, int is_const_type, int is_volatile_type, ...@@ -7935,7 +7938,7 @@ modified_type_die (tree type, int is_const_type, int is_volatile_type,
item_type = TREE_TYPE (type); item_type = TREE_TYPE (type);
} }
else if (is_ada_subrange_type (type)) else if (is_ada_subrange_type (type))
mod_type_die = subrange_type_die (type); mod_type_die = subrange_type_die (type, context_die);
else if (is_base_type (type)) else if (is_base_type (type))
mod_type_die = base_type_die (type); mod_type_die = base_type_die (type);
else else
......
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