OSDN Git Service

2009-01-30 Julian Brown <julian@codesourcery.com>
authorJoseph Myers <joseph@codesourcery.com>
Fri, 30 Jan 2009 01:32:25 +0000 (01:32 +0000)
committerJoseph Myers <joseph@codesourcery.com>
Fri, 30 Jan 2009 01:32:25 +0000 (01:32 +0000)
* elf32-arm.c (bfd_elf32_arm_vfp11_erratum_scan): Skip BFDs with
EXEC_P or DYNAMIC flags, and skip sections which are being linked
with --just-symbols (-R).

bfd/ChangeLog
bfd/elf32-arm.c

index 16f061d..d47fbe2 100644 (file)
@@ -1,3 +1,9 @@
+2009-01-30  Julian Brown  <julian@codesourcery.com>
+
+       * elf32-arm.c (bfd_elf32_arm_vfp11_erratum_scan): Skip BFDs with
+       EXEC_P or DYNAMIC flags, and skip sections which are being linked
+       with --just-symbols (-R).
+
 2009-01-29  Adam Nemet  <anemet@caviumnetworks.com>
 
        * dwarf2.c (read_rangelist): Use read_address to read low_pc and
index 4842179..de063e6 100644 (file)
@@ -4998,6 +4998,10 @@ bfd_elf32_arm_vfp11_erratum_scan (bfd *abfd, struct bfd_link_info *link_info)
   if (globals->vfp11_fix == BFD_ARM_VFP11_FIX_NONE)
     return TRUE;
 
+  /* Skip this BFD if it corresponds to an executable or dynamic object.  */
+  if ((abfd->flags & (EXEC_P | DYNAMIC)) != 0)
+    return TRUE;
+
   for (sec = abfd->sections; sec != NULL; sec = sec->next)
     {
       unsigned int i, span, first_fmac = 0, veneer_of_insn = 0;
@@ -5008,6 +5012,8 @@ bfd_elf32_arm_vfp11_erratum_scan (bfd *abfd, struct bfd_link_info *link_info)
       if (elf_section_type (sec) != SHT_PROGBITS
           || (elf_section_flags (sec) & SHF_EXECINSTR) == 0
           || (sec->flags & SEC_EXCLUDE) != 0
+         || sec->sec_info_type == ELF_INFO_TYPE_JUST_SYMS
+         || sec->output_section == bfd_abs_section_ptr
           || strcmp (sec->name, VFP11_ERRATUM_VENEER_SECTION_NAME) == 0)
         continue;