From: Joseph Myers Date: Fri, 30 Jan 2009 01:32:25 +0000 (+0000) Subject: 2009-01-30 Julian Brown X-Git-Tag: sid-snapshot-20090201~5 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=b383affdb9d1cd9518fdf8daf28d991382ba363d;p=pf3gnuchains%2Fpf3gnuchains4x.git 2009-01-30 Julian Brown * 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). --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 16f061d77e..d47fbe25b0 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2009-01-30 Julian Brown + + * 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 * dwarf2.c (read_rangelist): Use read_address to read low_pc and diff --git a/bfd/elf32-arm.c b/bfd/elf32-arm.c index 48421795f1..de063e6126 100644 --- a/bfd/elf32-arm.c +++ b/bfd/elf32-arm.c @@ -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;