Blame SOURCES/gdb-6.6-buildid-locate-rpm-scl.patch

f9426a
warning: Skipping deprecated .gdb_index section
f9426a
https://bugzilla.redhat.com/show_bug.cgi?id=953585
f9426a
f9426a
Index: gdb-7.6.90.20140127/gdb/dwarf2read.c
f9426a
===================================================================
f9426a
--- gdb-7.6.90.20140127.orig/gdb/dwarf2read.c	2014-02-06 18:28:23.756232026 +0100
f9426a
+++ gdb-7.6.90.20140127/gdb/dwarf2read.c	2014-02-06 18:28:48.969259122 +0100
f9426a
@@ -3035,6 +3035,14 @@ read_index_from_section (struct objfile
f9426a
      "set use-deprecated-index-sections on".  */
f9426a
   if (version < 6 && !deprecated_ok)
f9426a
     {
f9426a
+      extern int rpm_verify_vendor (const char *filename);
f9426a
+
f9426a
+      /* Red Hat Developer Toolset exception.  */
f9426a
+      if (rpm_verify_vendor (filename))
f9426a
+	{}
f9426a
+      else
f9426a
+      {
f9426a
+
f9426a
       static int warning_printed = 0;
f9426a
       if (!warning_printed)
f9426a
 	{
f9426a
@@ -3046,6 +3054,8 @@ to use the section anyway."),
f9426a
 	  warning_printed = 1;
f9426a
 	}
f9426a
       return 0;
f9426a
+
f9426a
+      }
f9426a
     }
f9426a
   /* Version 7 indices generated by gold refer to the CU for a symbol instead
f9426a
      of the TU (for symbols coming from TUs),
f9426a
Index: gdb-7.6.90.20140127/gdb/build-id.c
f9426a
===================================================================
f9426a
--- gdb-7.6.90.20140127.orig/gdb/build-id.c	2014-02-06 18:28:23.758232029 +0100
f9426a
+++ gdb-7.6.90.20140127/gdb/build-id.c	2014-02-06 18:28:26.814235312 +0100
f9426a
@@ -711,7 +711,7 @@ static int missing_rpm_list_entries;
f9426a
 /* Returns the count of newly added rpms.  */
f9426a
 
f9426a
 static int
f9426a
-missing_rpm_enlist (const char *filename)
f9426a
+missing_rpm_enlist_1 (const char *filename, int verify_vendor)
f9426a
 {
f9426a
   static int rpm_init_done = 0;
f9426a
   rpmts ts;
f9426a
@@ -815,7 +815,7 @@ missing_rpm_enlist (const char *filename
f9426a
   mi = rpmtsInitIterator_p (ts, RPMTAG_BASENAMES, filename, 0);
f9426a
   if (mi != NULL)
f9426a
     {
f9426a
-      for (;;)
f9426a
+      if (!verify_vendor) for (;;)
f9426a
 	{
f9426a
 	  Header h;
f9426a
 	  char *debuginfo, **slot, *s, *s2;
f9426a
@@ -933,6 +933,35 @@ missing_rpm_enlist (const char *filename
f9426a
 	    xfree (debuginfo);
f9426a
 	  count++;
f9426a
 	}
f9426a
+      else /* verify_vendor */
f9426a
+	{
f9426a
+	  int vendor_pass = 0, vendor_fail = 0;
f9426a
+
f9426a
+	  for (;;)
f9426a
+	    {
f9426a
+	      Header h;
f9426a
+	      errmsg_t err;
f9426a
+	      char *vendor;
f9426a
+
f9426a
+	      h = rpmdbNextIterator_p (mi);
f9426a
+	      if (h == NULL)
f9426a
+		break;
f9426a
+
f9426a
+	      vendor = headerFormat_p (h, "%{vendor}", &err;;
f9426a
+	      if (!vendor)
f9426a
+		{
f9426a
+		  warning (_("Error querying the rpm file `%s': %s"), filename,
f9426a
+			   err);
f9426a
+		  continue;
f9426a
+		}
f9426a
+	      if (strcmp (vendor, "Red Hat, Inc.") == 0)
f9426a
+		vendor_pass = 1;
f9426a
+	      else
f9426a
+		vendor_fail = 1;
f9426a
+	      xfree (vendor);
f9426a
+	    }
f9426a
+	  count = vendor_pass != 0 && vendor_fail == 0;
f9426a
+	}
f9426a
 
f9426a
       rpmdbFreeIterator_p (mi);
f9426a
     }
f9426a
@@ -943,6 +972,19 @@ missing_rpm_enlist (const char *filename
f9426a
 }
f9426a
 
f9426a
 static int
f9426a
+missing_rpm_enlist (const char *filename)
f9426a
+{
f9426a
+  return missing_rpm_enlist_1 (filename, 0);
f9426a
+}
f9426a
+
f9426a
+extern int rpm_verify_vendor (const char *filename);
f9426a
+int
f9426a
+rpm_verify_vendor (const char *filename)
f9426a
+{
f9426a
+  return missing_rpm_enlist_1 (filename, 1);
f9426a
+}
f9426a
+
f9426a
+static int
f9426a
 missing_rpm_list_compar (const char *const *ap, const char *const *bp)
f9426a
 {
f9426a
   return strcoll (*ap, *bp);