On Mon, 2 Jan 2012, Jason Merrill wrote:

> On 01/02/2012 10:49 AM, Richard Guenther wrote:
> > For the idea creating the DIE at the point we process the limbo DIE
> > yes.  But would you consider doing that unconditional or only for LTO?
> 
> Unconditional.  Anything that already passed the assert should be unaffected
> by the change.

There is a change in case the context is a FUNCTION_DECL or a
NAMESPACE_DECL and the DIE for it is not already present.  Previously
we'd add the DIE to comp_unit_die (), now we are going to create
a DIE for the function/namespace (which sounds better anyway,
or if that was not supposed to happen we should have asserted that).

> > I can certainly give it a shot.  Just to check, do you mean the
> > following?
> 
> Yes.

Ok, I committed the following.

[LTO] Bootstrapped and tested on x86_64-unknown-linux-gnu, SPEC 2k6
LTO build tested.

Richard.

2012-01-03  Richard Guenther  <rguent...@suse.de>

        PR debug/51650
        * dwarf2out.c (dwarf2out_finish): Always create a DIE for
        the context of a limbo DIE when it does not already exist.

        * g++.dg/lto/pr51650-3_0.C: New testcase.

Index: gcc/dwarf2out.c
===================================================================
--- gcc/dwarf2out.c     (revision 182784)
+++ gcc/dwarf2out.c     (working copy)
@@ -22501,15 +22501,8 @@ dwarf2out_finish (const char *filename)
              else if (TYPE_P (node->created_for))
                context = TYPE_CONTEXT (node->created_for);
 
-             gcc_assert (context
-                         && (TREE_CODE (context) == FUNCTION_DECL
-                             || TREE_CODE (context) == NAMESPACE_DECL));
-
-             origin = lookup_decl_die (context);
-             if (origin)
-               add_child_die (origin, die);
-             else
-               add_child_die (comp_unit_die (), die);
+             origin = get_context_die (context);
+             add_child_die (origin, die);
            }
        }
     }
Index: gcc/testsuite/g++.dg/lto/pr51650-3_0.C
===================================================================
--- gcc/testsuite/g++.dg/lto/pr51650-3_0.C      (revision 0)
+++ gcc/testsuite/g++.dg/lto/pr51650-3_0.C      (revision 0)
@@ -0,0 +1,20 @@
+// { dg-lto-do link }
+// { dg-lto-options { { -flto -g } } }
+
+struct T;
+struct C 
+{
+    typedef ::T T;
+    virtual void E();
+    static T *m ()
+      {
+       static T *d;
+       return d;
+      }
+};
+int
+fn ()
+{
+  C::m ();
+}
+int main() {}

Reply via email to