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

2c2fa1
warning: Skipping deprecated .gdb_index section
2c2fa1
https://bugzilla.redhat.com/show_bug.cgi?id=953585
2c2fa1
2c2fa1
--- gdb-7.5.91.20130407-orig/gdb/dwarf2read.c	2013-04-22 15:47:18.837806752 +0200
2c2fa1
+++ gdb-7.5.91.20130407/gdb/dwarf2read.c	2013-04-22 16:12:55.043171881 +0200
2c2fa1
@@ -2700,6 +2700,14 @@ read_index_from_section (struct objfile
2c2fa1
      "set use-deprecated-index-sections on".  */
2c2fa1
   if (version < 6 && !deprecated_ok)
2c2fa1
     {
2c2fa1
+      extern int rpm_verify_vendor (const char *filename);
2c2fa1
+
2c2fa1
+      /* Red Hat Developer Toolset exception.  */
2c2fa1
+      if (rpm_verify_vendor (filename))
2c2fa1
+	{}
2c2fa1
+      else
2c2fa1
+      {
2c2fa1
+
2c2fa1
       static int warning_printed = 0;
2c2fa1
       if (!warning_printed)
2c2fa1
 	{
2c2fa1
@@ -2711,6 +2719,8 @@ to use the section anyway."),
2c2fa1
 	  warning_printed = 1;
2c2fa1
 	}
2c2fa1
       return 0;
2c2fa1
+
2c2fa1
+      }
2c2fa1
     }
2c2fa1
   /* Version 7 indices generated by gold refer to the CU for a symbol instead
2c2fa1
      of the TU (for symbols coming from TUs).  It's just a performance bug, and
2c2fa1
--- gdb-7.5.91.20130407-orig/gdb/elfread.c	2013-04-22 15:47:18.637807200 +0200
2c2fa1
+++ gdb-7.5.91.20130407/gdb/elfread.c	2013-04-22 16:04:09.259429034 +0200
2c2fa1
@@ -1674,7 +1674,7 @@ static int missing_rpm_list_entries;
2c2fa1
 /* Returns the count of newly added rpms.  */
2c2fa1
 
2c2fa1
 static int
2c2fa1
-missing_rpm_enlist (const char *filename)
2c2fa1
+missing_rpm_enlist_1 (const char *filename, int verify_vendor)
2c2fa1
 {
2c2fa1
   static int rpm_init_done = 0;
2c2fa1
   rpmts ts;
2c2fa1
@@ -1778,7 +1778,7 @@ missing_rpm_enlist (const char *filename
2c2fa1
   mi = rpmtsInitIterator_p (ts, RPMTAG_BASENAMES, filename, 0);
2c2fa1
   if (mi != NULL)
2c2fa1
     {
2c2fa1
-      for (;;)
2c2fa1
+      if (!verify_vendor) for (;;)
2c2fa1
 	{
2c2fa1
 	  Header h;
2c2fa1
 	  char *debuginfo, **slot, *s, *s2;
2c2fa1
@@ -1897,6 +1897,35 @@ missing_rpm_enlist (const char *filename
2c2fa1
 	    xfree (debuginfo);
2c2fa1
 	  count++;
2c2fa1
 	}
2c2fa1
+      else /* verify_vendor */
2c2fa1
+	{
2c2fa1
+	  int vendor_pass = 0, vendor_fail = 0;
2c2fa1
+
2c2fa1
+	  for (;;)
2c2fa1
+	    {
2c2fa1
+	      Header h;
2c2fa1
+	      errmsg_t err;
2c2fa1
+	      char *vendor;
2c2fa1
+
2c2fa1
+	      h = rpmdbNextIterator_p (mi);
2c2fa1
+	      if (h == NULL)
2c2fa1
+		break;
2c2fa1
+
2c2fa1
+	      vendor = headerFormat_p (h, "%{vendor}", &err;;
2c2fa1
+	      if (!vendor)
2c2fa1
+		{
2c2fa1
+		  warning (_("Error querying the rpm file `%s': %s"), filename,
2c2fa1
+			   err);
2c2fa1
+		  continue;
2c2fa1
+		}
2c2fa1
+	      if (strcmp (vendor, "Red Hat, Inc.") == 0)
2c2fa1
+		vendor_pass = 1;
2c2fa1
+	      else
2c2fa1
+		vendor_fail = 1;
2c2fa1
+	      xfree (vendor);
2c2fa1
+	    }
2c2fa1
+	  count = vendor_pass != 0 && vendor_fail == 0;
2c2fa1
+	}
2c2fa1
 
2c2fa1
       rpmdbFreeIterator_p (mi);
2c2fa1
     }
2c2fa1
@@ -1907,6 +1936,19 @@ missing_rpm_enlist (const char *filename
2c2fa1
 }
2c2fa1
 
2c2fa1
 static int
2c2fa1
+missing_rpm_enlist (const char *filename)
2c2fa1
+{
2c2fa1
+  return missing_rpm_enlist_1 (filename, 0);
2c2fa1
+}
2c2fa1
+
2c2fa1
+extern int rpm_verify_vendor (const char *filename);
2c2fa1
+int
2c2fa1
+rpm_verify_vendor (const char *filename)
2c2fa1
+{
2c2fa1
+  return missing_rpm_enlist_1 (filename, 1);
2c2fa1
+}
2c2fa1
+
2c2fa1
+static int
2c2fa1
 missing_rpm_list_compar (const char *const *ap, const char *const *bp)
2c2fa1
 {
2c2fa1
   return strcoll (*ap, *bp);