Blame SOURCES/gcc48-rh1278872.patch

25c7f1
2013-07-25  Sterling Augustine  <saugustine@google.com>
25c7f1
25c7f1
	* dwarf2out.c (size_of_pubnames): Move code to...
25c7f1
	(include_pubname_in_output): ...here.  New.
25c7f1
	(output_pubnames): Call include_pubname_in_output.  Move assertion.
25c7f1
25c7f1
--- gcc/dwarf2out.c	(revision 201254)
25c7f1
+++ gcc/dwarf2out.c	(revision 201255)
25c7f1
@@ -7806,6 +7806,30 @@ unmark_all_dies (dw_die_ref die)
25c7f1
       unmark_all_dies (AT_ref (a));
25c7f1
 }
25c7f1
 
25c7f1
+/* Calculate if the entry should appear in the final output file.  It may be
25c7f1
+   from a pruned a type.  */
25c7f1
+
25c7f1
+static bool
25c7f1
+include_pubname_in_output (vec<pubname_entry, va_gc> *table, pubname_entry *p)
25c7f1
+{
25c7f1
+  if (table == pubname_table)
25c7f1
+    {
25c7f1
+      /* Enumerator names are part of the pubname table, but the parent
25c7f1
+	 DW_TAG_enumeration_type die may have been pruned.  Don't output
25c7f1
+	 them if that is the case.  */
25c7f1
+      if (p->die->die_tag == DW_TAG_enumerator && !p->die->die_mark)
25c7f1
+	return false;
25c7f1
+
25c7f1
+      /* Everything else in the pubname table is included.  */
25c7f1
+      return true;
25c7f1
+    }
25c7f1
+
25c7f1
+  /* The pubtypes table shouldn't include types that have been
25c7f1
+     pruned.  */
25c7f1
+  return (p->die->die_offset != 0
25c7f1
+	  || !flag_eliminate_unused_debug_types);
25c7f1
+}
25c7f1
+
25c7f1
 /* Return the size of the .debug_pubnames or .debug_pubtypes table
25c7f1
    generated for the compilation unit.  */
25c7f1
 
25c7f1
@@ -7818,9 +7842,7 @@ size_of_pubnames (vec
25c7f1
 
25c7f1
   size = DWARF_PUBNAMES_HEADER_SIZE;
25c7f1
   FOR_EACH_VEC_ELT (*names, i, p)
25c7f1
-    if (names != pubtype_table
25c7f1
-	|| p->die->die_offset != 0
25c7f1
-	|| !flag_eliminate_unused_debug_types)
25c7f1
+    if (include_pubname_in_output (names, p))
25c7f1
       size += strlen (p->name) + DWARF_OFFSET_SIZE + 1;
25c7f1
 
25c7f1
   size += DWARF_OFFSET_SIZE;
25c7f1
@@ -8999,22 +9021,14 @@ output_pubnames (vec
25c7f1
 
25c7f1
   FOR_EACH_VEC_ELT (*names, i, pub)
25c7f1
     {
25c7f1
-      /* Enumerator names are part of the pubname table, but the parent
25c7f1
-         DW_TAG_enumeration_type die may have been pruned.  Don't output
25c7f1
-         them if that is the case.  */
25c7f1
-      if (pub->die->die_tag == DW_TAG_enumerator && !pub->die->die_mark)
25c7f1
-        continue;
25c7f1
-
25c7f1
-      /* We shouldn't see pubnames for DIEs outside of the main CU.  */
25c7f1
-      if (names == pubname_table)
25c7f1
-	gcc_assert (pub->die->die_mark);
25c7f1
-
25c7f1
-      if (names != pubtype_table
25c7f1
-	  || pub->die->die_offset != 0
25c7f1
-	  || !flag_eliminate_unused_debug_types)
25c7f1
+      if (include_pubname_in_output (names, pub))
25c7f1
 	{
25c7f1
 	  dw_offset die_offset = pub->die->die_offset;
25c7f1
 
25c7f1
+	  /* We shouldn't see pubnames for DIEs outside of the main CU.  */
25c7f1
+	  if (names == pubname_table)
25c7f1
+	    gcc_assert (pub->die->die_mark);
25c7f1
+
25c7f1
 	  /* If we're putting types in their own .debug_types sections,
25c7f1
 	     the .debug_pubtypes table will still point to the compile
25c7f1
 	     unit (not the type unit), so we want to use the offset of