The problem here is that the cached DIE does not have a parent because we purposely removed it, hoping that decls_for_scope will fill it in:

/* If we're a nested function, initially use a parent of NULL; if we're
         a plain function, this will be fixed up in decls_for_scope.  If
         we're a method, it will be ignored, since we already have a DIE.  */

However, for the failing Ada testcase it _is_ decls_for_scope that we're being called from while we're doing the abstract instance dance while generating the containing type:

gen_typedef_die():
  ...
  origin = decl_ultimate_origin (decl);
  if (origin != NULL)
    add_abstract_origin_attribute (type_die, origin);

So...we haven't yet filled in the parent. It doesn't really matter. We'll get it right, and besides, we shouldn't be dereferencing a parent's die field without checking the existence of said parent.

Long story short... committing as obvious.

Aldy
commit ee39c82907a029fe1403cf1d3a364b89e9dee998
Author: Aldy Hernandez <al...@redhat.com>
Date:   Mon Jun 15 09:19:45 2015 -0700

        PR debug/66535
        * dwarf2out.c (gen_subprogram_die): Do not check a parent's tag if
        there is no parent.

diff --git a/gcc/dwarf2out.c b/gcc/dwarf2out.c
index d2c516a..4fe33f8 100644
--- a/gcc/dwarf2out.c
+++ b/gcc/dwarf2out.c
@@ -18790,7 +18790,8 @@ gen_subprogram_die (tree decl, dw_die_ref context_die)
                   end function
                 end module
           */
-          || old_die->die_parent->die_tag == DW_TAG_module
+          || (old_die->die_parent
+              && old_die->die_parent->die_tag == DW_TAG_module)
           || context_die == NULL)
           && (DECL_ARTIFICIAL (decl)
               || (get_AT_file (old_die, DW_AT_decl_file) == file_index
diff --git a/gcc/testsuite/gnat.dg/debug4.adb b/gcc/testsuite/gnat.dg/debug4.adb
new file mode 100644
index 0000000..1ec37c2
--- /dev/null
+++ b/gcc/testsuite/gnat.dg/debug4.adb
@@ -0,0 +1,10 @@
+-- { dg-compile }
+-- { dg-options "-g" }
+
+with Debug4_Pkg;
+
+procedure Debug4 is
+   package P is new Debug4_Pkg (Natural);
+begin
+   null;
+end;
diff --git a/gcc/testsuite/gnat.dg/debug4_pkg.adb 
b/gcc/testsuite/gnat.dg/debug4_pkg.adb
new file mode 100644
index 0000000..18ba0c0
--- /dev/null
+++ b/gcc/testsuite/gnat.dg/debug4_pkg.adb
@@ -0,0 +1,23 @@
+package body Debug4_Pkg is
+
+   type Vertex_To_Vertex_T is array (Vertex_Id range <>) of Vertex_Id;
+
+   function Dominator_Tree_Internal (G : T'Class) return Vertex_To_Vertex_T is
+      subtype V_To_V is Vertex_To_Vertex_T (0 .. G.Vertices.Last_Index);
+      type V_To_VIL is array
+        (Valid_Vertex_Id range 1 .. G.Vertices.Last_Index)
+        of Vertex_Index_List;
+      Bucket : V_To_VIL := (others => VIL.Empty_Vector);
+      Dom    : V_To_V   := (others => 0);
+   begin
+      return Dom;
+   end;
+
+   function Dominator_Tree (G : T'Class) return T is
+      Dom : constant Vertex_To_Vertex_T := Dominator_Tree_Internal (G);
+      DT  : T := (Vertices => VL.Empty_Vector);
+   begin
+      return DT;
+   end;
+
+end Debug4_Pkg;
diff --git a/gcc/testsuite/gnat.dg/debug4_pkg.ads 
b/gcc/testsuite/gnat.dg/debug4_pkg.ads
new file mode 100644
index 0000000..bac4953
--- /dev/null
+++ b/gcc/testsuite/gnat.dg/debug4_pkg.ads
@@ -0,0 +1,28 @@
+with Ada.Containers.Vectors;
+
+generic
+   type Vertex_Key is private;
+package Debug4_Pkg is
+
+   type Vertex_Id is new Natural;
+   subtype Valid_Vertex_Id is Vertex_Id range 1 .. Vertex_Id'Last;
+
+   package VIL is new Ada.Containers.Vectors
+     (Index_Type   => Positive,
+      Element_Type => Valid_Vertex_Id);
+   use VIL;
+   subtype Vertex_Index_List is VIL.Vector;
+
+   package VL is new Ada.Containers.Vectors
+     (Index_Type   => Valid_Vertex_Id,
+      Element_Type => Vertex_Key);
+   use VL;
+   subtype Vertex_List is VL.Vector;
+
+   type T is tagged record
+      Vertices : Vertex_List;
+   end record;
+
+   function Dominator_Tree (G : T'Class) return T;
+
+end Debug4_Pkg;

Reply via email to