Blame SOURCES/gdb-rhbz1878810-bfd-suppress-loadable-section-outside-ELF-sections.patch

6543d1
From FEDORA_PATCHES Mon Sep 17 00:00:00 2001
6543d1
From: Keith Seitz <keiths@redhat.com>
6543d1
Date: Fri, 23 Oct 2020 17:12:26 -0400
6543d1
Subject: 
6543d1
 gdb-rhbz1878810-bfd-suppress-loadable-section-outside-ELF-sections.patch
6543d1
6543d1
;; Backport "Stop the BFD library from issuing a warning message when
6543d1
;; processing allocated sections in debuginfo files that lie outside of
6543d1
;; Nick Clifton and Keith Seitz, RH BZ 1878810
6543d1
6543d1
   Stop the BFD library from issuing a warning message when processing allocated sections in debuginfo files that lie outside of any loadable segment.
6543d1
6543d1
   bfd/ChangeLog
6543d1
   PR 24717
6543d1
   * elf.c (is_debuginfo_file): New function.
6543d1
   (assign_file_positions_for_non_load_sections): Do not warn about
6543d1
   allocated sections outside of loadable segments if they are found
6543d1
   in a debuginfo file.
6543d1
   * elf-bfd.h (is_debuginfo_file): Prototype.
6543d1
6543d1
   gdb/ChangeLog
6543d1
   https://bugzilla.redhat.com/show_bug.cgi?id=1553086
6543d1
   * elfread.c (elf_symfile_segments): Omit "Loadable section ...
6543d1
     outside of ELF segments" warning for debugin
6543d1
6543d1
diff --git a/bfd/elf-bfd.h b/bfd/elf-bfd.h
6543d1
--- a/bfd/elf-bfd.h
6543d1
+++ b/bfd/elf-bfd.h
6543d1
@@ -2740,6 +2740,8 @@ extern bfd_vma elf64_r_sym (bfd_vma);
6543d1
 extern bfd_vma elf32_r_info (bfd_vma, bfd_vma);
6543d1
 extern bfd_vma elf32_r_sym (bfd_vma);
6543d1
 
6543d1
+extern bfd_boolean is_debuginfo_file (bfd *);
6543d1
+
6543d1
 /* Large common section.  */
6543d1
 extern asection _bfd_elf_large_com_section;
6543d1
 
6543d1
diff --git a/bfd/elf.c b/bfd/elf.c
6543d1
--- a/bfd/elf.c
6543d1
+++ b/bfd/elf.c
6543d1
@@ -5725,6 +5725,35 @@ assign_file_positions_for_load_sections (bfd *abfd,
6543d1
   return TRUE;
6543d1
 }
6543d1
 
6543d1
+/* Determine if a bfd is a debuginfo file.  Unfortunately there
6543d1
+   is no defined method for detecting such files, so we have to
6543d1
+   use heuristics instead.  */
6543d1
+
6543d1
+bfd_boolean
6543d1
+is_debuginfo_file (bfd *abfd)
6543d1
+{
6543d1
+  if (abfd == NULL || bfd_get_flavour (abfd) != bfd_target_elf_flavour)
6543d1
+    return FALSE;
6543d1
+
6543d1
+  Elf_Internal_Shdr **start_headers = elf_elfsections (abfd);
6543d1
+  Elf_Internal_Shdr **end_headers = start_headers + elf_numsections (abfd);
6543d1
+  Elf_Internal_Shdr **headerp;
6543d1
+
6543d1
+  for (headerp = start_headers; headerp < end_headers; headerp ++)
6543d1
+    {
6543d1
+      Elf_Internal_Shdr *header = * headerp;
6543d1
+
6543d1
+      /* Debuginfo files do not have any allocated SHT_PROGBITS sections.
6543d1
+	 The only allocated sections are SHT_NOBITS or SHT_NOTES.  */
6543d1
+      if ((header->sh_flags & SHF_ALLOC) == SHF_ALLOC
6543d1
+	  && header->sh_type != SHT_NOBITS
6543d1
+	  && header->sh_type != SHT_NOTE)
6543d1
+	return FALSE;
6543d1
+    }
6543d1
+
6543d1
+  return TRUE;
6543d1
+}
6543d1
+
6543d1
 /* Assign file positions for the other sections.  */
6543d1
 
6543d1
 static bfd_boolean
6543d1
@@ -5758,7 +5787,13 @@ assign_file_positions_for_non_load_sections (bfd *abfd,
6543d1
 	BFD_ASSERT (hdr->sh_offset == hdr->bfd_section->filepos);
6543d1
       else if ((hdr->sh_flags & SHF_ALLOC) != 0)
6543d1
 	{
6543d1
-	  if (hdr->sh_size != 0)
6543d1
+	  if (hdr->sh_size != 0
6543d1
+	      /* PR 24717 - debuginfo files are known to be not strictly
6543d1
+		 compliant with the ELF standard.  In particular they often
6543d1
+		 have .note.gnu.property sections that are outside of any
6543d1
+		 loadable segment.  This is not a problem for such files,
6543d1
+		 so do not warn about them.  */
6543d1
+	      && ! is_debuginfo_file (abfd))
6543d1
 	    _bfd_error_handler
6543d1
 	      /* xgettext:c-format */
6543d1
 	      (_("%pB: warning: allocated section `%s' not in segment"),
6543d1
diff --git a/gdb/elfread.c b/gdb/elfread.c
6543d1
--- a/gdb/elfread.c
6543d1
+++ b/gdb/elfread.c
6543d1
@@ -143,7 +143,12 @@ elf_symfile_segments (bfd *abfd)
6543d1
 	 RealView) use SHT_NOBITS for uninitialized data.  Since it is
6543d1
 	 uninitialized, it doesn't need a program header.  Such
6543d1
 	 binaries are not relocatable.  */
6543d1
-      if (bfd_get_section_size (sect) > 0 && j == num_segments
6543d1
+
6543d1
+      /* Exclude debuginfo files from this warning, too, since those
6543d1
+	 are often not strictly compliant with the standard. See, e.g.,
6543d1
+	 ld/24717 for more discussion.  */
6543d1
+      if (!is_debuginfo_file (abfd)
6543d1
+	  && bfd_get_section_size (sect) > 0 && j == num_segments
6543d1
 	  && (bfd_get_section_flags (abfd, sect) & SEC_LOAD) != 0)
6543d1
 	warning (_("Loadable section \"%s\" outside of ELF segments"),
6543d1
 		 bfd_section_name (abfd, sect));