http://gcc.gnu.org/bugzilla/show_bug.cgi?id=51950
Jakub Jelinek <jakub at gcc dot gnu.org> changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|UNCONFIRMED |ASSIGNED
Last reconfirmed| |2012-01-25
AssignedTo|unassigned at gcc dot |jakub at gcc dot gnu.org
|gnu.org |
Ever Confirmed|0 |1
--- Comment #2 from Jakub Jelinek <jakub at gcc dot gnu.org> 2012-01-25
17:41:58 UTC ---
Created attachment 26465
--> http://gcc.gnu.org/bugzilla/attachment.cgi?id=26465
gcc47-pr51950.patch
Untested fix.
This "regressed" with http://gcc.gnu.org/viewcvs?root=gcc&view=rev&rev=162691
which just made a cloning bug no longer latent, because DW_AT_object_pointer
the patch added is a reference to one of its children. The problem is that we
were using clone_tree to clone all the children (in this case of
DW_TAG_subroutine_type), but clone_tree didn't enter all the children
(DW_TAG_formal_parameter in particular) into the hash table. So we ended up
with a clone DW_TAG_subroutine_type with a single cloned
DW_TAG_formal_parameter. Next clone_decls_walk attempted to adjust the
references in the attributes (DW_AT_object_pointer), but nothing was in the
hash table, so it created another DW_TAG_formal_parameter clone, and when
adding also its ancestor tree the DW_TAG_subroutine_type has been found in the
hash table and so this second DW_TAG_formal_parameter has been added as another
child.