PR debug/32610
authorjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 21 Aug 2007 17:11:20 +0000 (17:11 +0000)
committerjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 21 Aug 2007 17:11:20 +0000 (17:11 +0000)
* dwarf2out.c (gen_decl_die): Don't call
gen_tagged_type_instantiation_die if decl doesn't have tagged type.

* gcc.dg/debug/pr32610.c: New test.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@127669 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/dwarf2out.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/debug/pr32610.c [new file with mode: 0644]

index 4724e16..82b7685 100644 (file)
@@ -1,3 +1,9 @@
+2007-08-21  Jakub Jelinek  <jakub@redhat.com>
+
+       PR debug/32610
+       * dwarf2out.c (gen_decl_die): Don't call
+       gen_tagged_type_instantiation_die if decl doesn't have tagged type.
+
 2007-08-21  Paul Brook  <paul@codesourcery.com>
            Nathan Sidwell  <nathan@codesourcery.com>
            Mark Mitchell  <mark@codesourcery.com>
index ec6e121..a03b81a 100644 (file)
@@ -13622,7 +13622,8 @@ gen_decl_die (tree decl, dw_die_ref context_die)
         was generated within the original definition of an inline function) we
         have to generate a special (abbreviated) DW_TAG_structure_type,
         DW_TAG_union_type, or DW_TAG_enumeration_type DIE here.  */
-      if (TYPE_DECL_IS_STUB (decl) && decl_ultimate_origin (decl) != NULL_TREE)
+      if (TYPE_DECL_IS_STUB (decl) && decl_ultimate_origin (decl) != NULL_TREE
+         && is_tagged_type (TREE_TYPE (decl)))
        {
          gen_tagged_type_instantiation_die (TREE_TYPE (decl), context_die);
          break;
index 4fc50ce..002f824 100644 (file)
@@ -1,5 +1,8 @@
 2007-08-21  Jakub Jelinek  <jakub@redhat.com>
 
+       PR debug/32610
+       * gcc.dg/debug/pr32610.c: New test.
+
        * g++.dg/init/new24.C: New test.
 
        PR middle-end/32912
diff --git a/gcc/testsuite/gcc.dg/debug/pr32610.c b/gcc/testsuite/gcc.dg/debug/pr32610.c
new file mode 100644 (file)
index 0000000..d1dae1d
--- /dev/null
@@ -0,0 +1,14 @@
+/* PR debug/32610 */
+/* { dg-do compile } */
+
+inline void
+foo (int x)
+{
+  double (*arr)[x];
+}
+
+void
+bar (void)
+{
+  foo (1);
+}