* bfd/elfxx-mips.c (_bfd_mips_elf_fake_sections): Force SHF_MIPS_NOSTRIP on
authorNick Clifton <nickc@redhat.com>
Wed, 7 Nov 2007 14:52:44 +0000 (14:52 +0000)
committerNick Clifton <nickc@redhat.com>
Wed, 7 Nov 2007 14:52:44 +0000 (14:52 +0000)
   .debug_frame for Irix.

bfd/ChangeLog
bfd/elfxx-mips.c

index b42e0c9..b05c8ee 100644 (file)
@@ -1,3 +1,8 @@
+2007-11-07  Olivier Hainque  <hainque@adacore.com>
+
+       * bfd/elfxx-mips.c (_bfd_mips_elf_fake_sections): Force
+       SHF_MIPS_NOSTRIP on .debug_frame for Irix.
+
 2007-11-06  Alan Modra  <amodra@bigpond.net.au>
 
        * elf64-ppc.c (ppc64_elf_check_relocs): Don't refcount tlsld_got here..
index b0e8a62..c571077 100644 (file)
@@ -5672,7 +5672,15 @@ _bfd_mips_elf_fake_sections (bfd *abfd, Elf_Internal_Shdr *hdr, asection *sec)
       hdr->sh_flags |= SHF_MIPS_NOSTRIP;
     }
   else if (CONST_STRNEQ (name, ".debug_"))
-    hdr->sh_type = SHT_MIPS_DWARF;
+    {
+      hdr->sh_type = SHT_MIPS_DWARF;
+
+      /* Irix facilities such as libexc expect a single .debug_frame
+        per executable, the system ones have NOSTRIP set and the linker
+        doesn't merge sections with different flags so ...  */
+      if (SGI_COMPAT (abfd) && CONST_STRNEQ (name, ".debug_frame"))
+       hdr->sh_flags |= SHF_MIPS_NOSTRIP;
+    }
   else if (strcmp (name, ".MIPS.symlib") == 0)
     {
       hdr->sh_type = SHT_MIPS_SYMBOL_LIB;