re PR debug/46796 (debug info missing builtin type names with lto)
authorRichard Guenther <rguenther@suse.de>
Tue, 20 Dec 2011 09:49:17 +0000 (09:49 +0000)
committerRichard Biener <rguenth@gcc.gnu.org>
Tue, 20 Dec 2011 09:49:17 +0000 (09:49 +0000)
2011-12-20  Richard Guenther  <rguenther@suse.de>

PR lto/46796
* dwarf2out.c (modified_type_die): When the type variant
chain is corrupt use the types name, if available, instead
of __unknown__.

From-SVN: r182524

gcc/ChangeLog
gcc/dwarf2out.c

index 32c1d2429ff2b1f6c386d60259e67c649068843a..2dd1cc00b259debaf7f7684cccac6e0a561b7816 100644 (file)
@@ -1,3 +1,10 @@
+2011-12-20  Richard Guenther  <rguenther@suse.de>
+
+       PR lto/46796
+       * dwarf2out.c (modified_type_die): When the type variant
+       chain is corrupt use the types name, if available, instead
+       of __unknown__.
+
 2011-12-20  Tristan Gingold  <gingold@adacore.com>
 
        * config/alpha/alpha.c (alpha_start_function): Adjust condition to
index d5f469c095cea447d8a4910087da4258a0c43705..8de36137e3358b2cd8e968c75425068c975358c9 100644 (file)
@@ -9873,7 +9873,14 @@ modified_type_die (tree type, int is_const_type, int is_volatile_type,
     }
   /* This probably indicates a bug.  */
   else if (mod_type_die && mod_type_die->die_tag == DW_TAG_base_type)
-    add_name_attribute (mod_type_die, "__unknown__");
+    {
+      name = TYPE_NAME (type);
+      if (name
+         && TREE_CODE (name) == TYPE_DECL)
+       name = DECL_NAME (name);
+      add_name_attribute (mod_type_die,
+                         name ? IDENTIFIER_POINTER (name) : "__unknown__");
+    }
 
   if (qualified_type)
     equate_type_number_to_die (qualified_type, mod_type_die);