2016-10-05 14:22:24 +08:00
|
|
|
|
2016-10-06 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* coffcode.h (coff_slurp_symbol_table): Revert accidental commit
|
|
|
|
|
made 2015-01-08.
|
|
|
|
|
* elf32-nds32.c (nds32_elf_grok_psinfo): Add missing break.
|
|
|
|
|
* reloc.c (bfd_default_reloc_type_lookup): Add missing breaks.
|
|
|
|
|
|
2016-10-06 05:38:25 +08:00
|
|
|
|
2016-10-06 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-epiphany.c (epiphany_final_link_relocate): Use bitwise
|
|
|
|
|
OR in arithmetic expression, not boolean OR.
|
|
|
|
|
|
2016-09-30 16:57:36 +08:00
|
|
|
|
2016-09-30 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* Makefile.am (BFD_H_FILES): Add linker.c and simple.c. Sort
|
|
|
|
|
as per comment at head of bfd-in2.h.
|
|
|
|
|
* Makefile.in: Regenerate.
|
|
|
|
|
|
Remove syntactic sugar
Now that _bfd_error_handler is not a function pointer.
* aout-adobe.c: Replace (*_bfd_error_handler) (...) with
_bfd_error_handler (...) throughout.
* aout-cris.c, * aoutx.h, * archive.c, * bfd.c, * binary.c,
* cache.c, * coff-alpha.c, * coff-arm.c, * coff-h8300.c,
* coff-i860.c, * coff-mcore.c, * coff-ppc.c, * coff-rs6000.c,
* coff-sh.c, * coff-tic4x.c, * coff-tic54x.c, * coff-tic80.c,
* coff64-rs6000.c, * coffcode.h, * coffgen.c, * cofflink.c,
* coffswap.h, * cpu-arm.c, * cpu-m68k.c, * cpu-sh.c, * dwarf2.c,
* ecoff.c, * elf-eh-frame.c, * elf-m10300.c, * elf.c, * elf32-arc.c,
* elf32-arm.c, * elf32-avr.c, * elf32-bfin.c, * elf32-cr16.c,
* elf32-cris.c, * elf32-crx.c, * elf32-dlx.c, * elf32-frv.c,
* elf32-hppa.c, * elf32-i370.c, * elf32-i386.c, * elf32-lm32.c,
* elf32-m32c.c, * elf32-m32r.c, * elf32-m68hc1x.c, * elf32-m68k.c,
* elf32-mcore.c, * elf32-mep.c, * elf32-metag.c, * elf32-microblaze.c,
* elf32-mips.c, * elf32-nds32.c, * elf32-nios2.c, * elf32-or1k.c,
* elf32-pj.c, * elf32-ppc.c, * elf32-rl78.c, * elf32-s390.c,
* elf32-score.c, * elf32-score7.c, * elf32-sh.c, * elf32-sh64.c,
* elf32-sparc.c, * elf32-spu.c, * elf32-tic6x.c, * elf32-tilepro.c,
* elf32-v850.c, * elf32-vax.c, * elf32-xtensa.c, * elf64-alpha.c,
* elf64-hppa.c, * elf64-ia64-vms.c, * elf64-mips.c, * elf64-mmix.c,
* elf64-ppc.c, * elf64-s390.c, * elf64-sh64.c, * elf64-sparc.c,
* elf64-x86-64.c, * elfcode.h, * elfcore.h, * elflink.c,
* elfn32-mips.c, * elfnn-aarch64.c, * elfnn-ia64.c, * elfxx-mips.c,
* elfxx-sparc.c, * elfxx-tilegx.c, * hpux-core.c, * i386linux.c,
* ieee.c, * ihex.c, * libbfd.c, * linker.c, * m68klinux.c,
* mach-o.c, * merge.c, * mmo.c, * oasys.c, * osf-core.c, * pdp11.c,
* pe-mips.c, * peXXigen.c, * pef.c, * plugin.c, * reloc.c,
* rs6000-core.c, * sco5-core.c, * som.c, * sparclinux.c, * srec.c,
* stabs.c, * syms.c, * vms-alpha.c, * vms-lib.c, * vms-misc.c,
* xcofflink.c: Likewise.
2016-09-30 11:30:18 +08:00
|
|
|
|
2016-09-30 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* aout-adobe.c: Replace (*_bfd_error_handler) (...) with
|
|
|
|
|
_bfd_error_handler (...) throughout.
|
|
|
|
|
* aout-cris.c, * aoutx.h, * archive.c, * bfd.c, * binary.c,
|
|
|
|
|
* cache.c, * coff-alpha.c, * coff-arm.c, * coff-h8300.c,
|
|
|
|
|
* coff-i860.c, * coff-mcore.c, * coff-ppc.c, * coff-rs6000.c,
|
|
|
|
|
* coff-sh.c, * coff-tic4x.c, * coff-tic54x.c, * coff-tic80.c,
|
|
|
|
|
* coff64-rs6000.c, * coffcode.h, * coffgen.c, * cofflink.c,
|
|
|
|
|
* coffswap.h, * cpu-arm.c, * cpu-m68k.c, * cpu-sh.c, * dwarf2.c,
|
|
|
|
|
* ecoff.c, * elf-eh-frame.c, * elf-m10300.c, * elf.c, * elf32-arc.c,
|
|
|
|
|
* elf32-arm.c, * elf32-avr.c, * elf32-bfin.c, * elf32-cr16.c,
|
|
|
|
|
* elf32-cris.c, * elf32-crx.c, * elf32-dlx.c, * elf32-frv.c,
|
|
|
|
|
* elf32-hppa.c, * elf32-i370.c, * elf32-i386.c, * elf32-lm32.c,
|
|
|
|
|
* elf32-m32c.c, * elf32-m32r.c, * elf32-m68hc1x.c, * elf32-m68k.c,
|
|
|
|
|
* elf32-mcore.c, * elf32-mep.c, * elf32-metag.c, * elf32-microblaze.c,
|
|
|
|
|
* elf32-mips.c, * elf32-nds32.c, * elf32-nios2.c, * elf32-or1k.c,
|
|
|
|
|
* elf32-pj.c, * elf32-ppc.c, * elf32-rl78.c, * elf32-s390.c,
|
|
|
|
|
* elf32-score.c, * elf32-score7.c, * elf32-sh.c, * elf32-sh64.c,
|
|
|
|
|
* elf32-sparc.c, * elf32-spu.c, * elf32-tic6x.c, * elf32-tilepro.c,
|
|
|
|
|
* elf32-v850.c, * elf32-vax.c, * elf32-xtensa.c, * elf64-alpha.c,
|
|
|
|
|
* elf64-hppa.c, * elf64-ia64-vms.c, * elf64-mips.c, * elf64-mmix.c,
|
|
|
|
|
* elf64-ppc.c, * elf64-s390.c, * elf64-sh64.c, * elf64-sparc.c,
|
|
|
|
|
* elf64-x86-64.c, * elfcode.h, * elfcore.h, * elflink.c,
|
|
|
|
|
* elfn32-mips.c, * elfnn-aarch64.c, * elfnn-ia64.c, * elfxx-mips.c,
|
|
|
|
|
* elfxx-sparc.c, * elfxx-tilegx.c, * hpux-core.c, * i386linux.c,
|
|
|
|
|
* ieee.c, * ihex.c, * libbfd.c, * linker.c, * m68klinux.c,
|
|
|
|
|
* mach-o.c, * merge.c, * mmo.c, * oasys.c, * osf-core.c, * pdp11.c,
|
|
|
|
|
* pe-mips.c, * peXXigen.c, * pef.c, * plugin.c, * reloc.c,
|
|
|
|
|
* rs6000-core.c, * sco5-core.c, * som.c, * sparclinux.c, * srec.c,
|
|
|
|
|
* stabs.c, * syms.c, * vms-alpha.c, * vms-lib.c, * vms-misc.c,
|
|
|
|
|
* xcofflink.c: Likewise.
|
|
|
|
|
|
2016-09-30 09:33:52 +08:00
|
|
|
|
2016-09-30 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* bfd-in.h: Include stdarg.h.
|
|
|
|
|
* bfd.c (bfd_error_handler_type): Make like vprintf.
|
|
|
|
|
(_bfd_error_internal): Rename from _bfd_error_handler. Make static.
|
|
|
|
|
(error_handler_internal): New function, split out from..
|
|
|
|
|
(_bfd_default_error_handler): ..here. Rename to _bfd_error_handler.
|
|
|
|
|
(bfd_set_error_handler): Update.
|
|
|
|
|
(bfd_get_error_handler, bfd_get_assert_handler): Delete.
|
|
|
|
|
(_bfd_assert_handler): Make static.
|
|
|
|
|
* coffgen.c (null_error_handler): Update params.
|
|
|
|
|
* elf-bfd.h (struct elf_backend_data <link_order_error_handler>):
|
|
|
|
|
Don't use bfd_error_handler_type.
|
|
|
|
|
* elf64-mmix.c (mmix_dump_bpo_gregs): Likewise.
|
|
|
|
|
* elfxx-target.h (elf_backend_link_order_error_handler): Default
|
|
|
|
|
to _bfd_error_handler.
|
|
|
|
|
* libbfd-in.h (_bfd_default_error_handler): Don't declare.
|
|
|
|
|
(bfd_assert_handler_type): Likewise.
|
|
|
|
|
(_bfd_error_handler): Update.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* libbfd.h: Regenerate.
|
|
|
|
|
|
2016-09-28 18:50:41 +08:00
|
|
|
|
2016-09-28 Akihiko Odaki <akihiko.odaki.4i@stu.hosei.ac.jp>
|
|
|
|
|
|
|
|
|
|
PR ld/20636
|
|
|
|
|
* elf-bfd.h (struct elf_backend_data): Delete
|
|
|
|
|
elf_backend_count_output_relocs callback and add
|
|
|
|
|
elf_backend_update_relocs.
|
|
|
|
|
* elf32-arm.c (elf32_arm_count_output_relocs): Deleted.
|
|
|
|
|
(emit_relocs): Deleted.
|
|
|
|
|
(elf32_arm_emit_relocs): Deleted.
|
|
|
|
|
(elf_backend_emit_relocs): Updated not to use the old functions.
|
|
|
|
|
(elf32_arm_update_relocs): New function.
|
|
|
|
|
(elf_backend_update_relocs): New define.
|
|
|
|
|
* elflink.c (bfd_elf_final_link): Add additional_reloc_count to the
|
|
|
|
|
relocation count. Call elf_backend_emit_relocs.
|
|
|
|
|
(_bfd_elf_size_reloc_section): Do not call
|
|
|
|
|
elf_backend_count_output_relocs.
|
|
|
|
|
* elfxx-target.h (elf_backend_count_output_relocs): Deleted.
|
|
|
|
|
(elf_backend_update_relocs): New define.
|
|
|
|
|
|
2016-09-28 07:37:52 +08:00
|
|
|
|
2016-09-28 Christophe Lyon <christophe.lyon@linaro.org>
|
|
|
|
|
|
|
|
|
|
PR ld/20608
|
|
|
|
|
* elf32-arm.c (arm_type_of_stub): Handle the case when the pre-PLT
|
|
|
|
|
Thumb-ARM stub is too far.
|
|
|
|
|
|
2016-09-27 19:08:19 +08:00
|
|
|
|
2016-09-27 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20634
|
|
|
|
|
* peXXigen.c (_bfd_XXi_only_swap_filehdr_out): Put 0 in the
|
|
|
|
|
timestamp field if real time values are not being stored.
|
|
|
|
|
|
2016-09-26 23:36:08 +08:00
|
|
|
|
2016-09-26 Vlad Zakharov <vzakhar@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* warning.m4 (AC_EGREP_CPP_FOR_BUILD): Introduce macro
|
|
|
|
|
to verify CC_FOR_BUILD compiler.
|
|
|
|
|
(AM_BINUTILS_WARNINGS): Introduce ac_cpp_for_build variable
|
|
|
|
|
and add CC_FOR_BUILD compiler checks.
|
|
|
|
|
* Makefile.in: Regenerate.
|
|
|
|
|
* configure: Likewise.
|
|
|
|
|
* doc/Makefile.in: Likewise.
|
|
|
|
|
|
2016-09-26 23:16:25 +08:00
|
|
|
|
2016-09-26 Awson <kyrab@mail.ru>
|
|
|
|
|
|
|
|
|
|
PR ld/17955
|
|
|
|
|
* coff-x86_64.c (coff_amd64_rtype_to_howto): Use an 8 byte offset
|
|
|
|
|
for R_AMD64_PCRQUAD relocations.
|
|
|
|
|
|
2016-09-26 16:34:57 +08:00
|
|
|
|
2016-09-26 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h (_bfd_elf_ppc_merge_fp_attributes): Declare.
|
|
|
|
|
* elf32-ppc.c (_bfd_elf_ppc_merge_fp_attributes): New function.
|
|
|
|
|
(ppc_elf_merge_obj_attributes): Use it. Don't copy first file
|
|
|
|
|
attributes, merge them. Don't warn about undefined tag bits,
|
|
|
|
|
or copy unknown values to output.
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_merge_private_bfd_data): Call
|
|
|
|
|
_bfd_elf_ppc_merge_fp_attributes.
|
|
|
|
|
|
2016-09-23 23:32:04 +08:00
|
|
|
|
2016-09-23 Akihiko Odaki <akihiko.odaki.4i@stu.hosei.ac.jp>
|
|
|
|
|
|
|
|
|
|
PR ld/20595
|
|
|
|
|
* elf-bfd.h (struct elf_backend_data): Add
|
|
|
|
|
elf_backend_count_output_relocs callback to count relocations in
|
|
|
|
|
the final output.
|
|
|
|
|
* elf-arm.c (elf32_arm_add_relocation): Deleted.
|
|
|
|
|
(elf32_arm_write_section): Move additional relocation to emit_relocs.
|
|
|
|
|
(elf32_arm_count_output_relocs): New function.
|
|
|
|
|
(emit_relocs): New function.
|
|
|
|
|
(elf32_arm_emit_relocs): New function.
|
|
|
|
|
(elf32_arm_vxworks_emit_relocs): New function.
|
|
|
|
|
(elf_backend_emit_relocs): Updated to use the new functions.
|
|
|
|
|
(elf_backend_count_output_relocs): New define.
|
|
|
|
|
* bfd/elflink.c (bfd_elf_final_link): Do not add additional_reloc_count
|
|
|
|
|
to the relocation count.
|
|
|
|
|
(_bfd_elf_link_size_reloc_section): Use callback to count the
|
|
|
|
|
relocations which will be in output.
|
|
|
|
|
(_bfd_elf_default_count_output_relocs): New function.
|
|
|
|
|
* bfd/elfxx-target.h (elf_backend_count_output_relocs): New define.
|
|
|
|
|
|
2016-09-19 20:19:14 +08:00
|
|
|
|
2016-09-19 Jose E. Marchesi <jose.marchesi@oracle.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-sparc.c (_bfd_sparc_elf_size_dynamic_sections): Allow
|
|
|
|
|
negative offsets to _GLOBAL_OFFSET_TABLE_ if the .got section is
|
|
|
|
|
bigger than 0x1000 bytes.
|
|
|
|
|
|
2016-09-14 23:02:17 +08:00
|
|
|
|
2016-09-14 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (elf32_arm_gc_mark_extra_sections): Only mark section
|
|
|
|
|
not already marked.
|
|
|
|
|
|
2016-09-14 22:32:01 +08:00
|
|
|
|
2016-09-14 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/20605
|
|
|
|
|
* peicode.h (pe_bfd_read_buildid): Check that the Data Directory
|
|
|
|
|
contains a valid size for the Debug directory.
|
|
|
|
|
|
2016-09-14 20:49:16 +08:00
|
|
|
|
2016-09-14 Bhushan Attarde <bhushan.attarde@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* format.c (struct bfd_preserve): New "build_id" field.
|
|
|
|
|
(bfd_preserve_save): Save "build_id".
|
|
|
|
|
(bfd_preserve_restore): Restore "build_id".
|
|
|
|
|
|
2016-09-07 04:34:30 +08:00
|
|
|
|
2016-09-06 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20550
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_relocate_section): Resolve size
|
|
|
|
|
relocation with copy relocation when building executable.
|
|
|
|
|
|
Fix PR ld/20545 - relaxation bugs in avr backend
Prior to the patch, addends for relocs were being adjusted even if
they went beyond an alignment boundary. This is wrong - to
preserve alignment constraints, the relaxation logic adds as many padding
bytes at the alignment boundary as was deleted, so addends beyond the
boundary should not be adjusted. avr-prop-7.s reproduces this
scenario.
Also, prior to this patch, the relaxation logic assumed that the addr
parameter pointed to the middle of the instruction to be deleted, and
that addr - count would therefore be the shrinked instruction's
address. This is true when actually shrinking instructions.
The alignment constraints handling logic also invokes the same logic
though, with addr as the starting offset of padding bytes and
with count as the number of bytes to be deleted. Calculating the
shrinked insn's address as addr - count is obviously wrong in this
case - that offset would point to count bytes before the last
non-padded byte. avr-prop-8.s reproduces this scenario.
To fix scenario 1, the patch adds an additional check to ensure reloc addends
aren't adjusted if they cross a shrink boundary. The shrink boundary
is either the section size or an alignment boundary. Addends pointing
at an alignment boundary don't need to be adjusted, as padding would
occur and keep the boundary the same. Addends pointing at section size
need to be adjusted though, as no padding occurs and the section size
itself would get decremented. The patch records whether padding
occured (did_pad) and uses that to detect and handle this condition.
To fix scenario 2, the patch adds an additional parameter
(delete_shrinks_insn) to elf32_avr_relax_delete_bytes to distinguish
instruction bytes deletion from padding bytes deletion. It then uses that to
correctly set shrinked_insn_address.
bfd/ChangeLog:
2016-09-02 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
PR ld/20545
* elf32-avr.c (elf32_avr_relax_delete_bytes): Add parameter
delete_shrinks_insn. Modify computation of shrinked_insn_address.
Compute shrink_boundary and adjust addend only if
addend_within_shrink_boundary.
(elf32_avr_relax_section): Modify calls to
elf32_avr_relax_delete_bytes to pass extra parameter.
ld/ChangeLog:
2016-09-02 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
PR ld/20545
* testsuite/ld-avr/avr-prop-7.d: New test.
* testsuite/ld-avr/avr-prop-7.s: New test.
* testsuite/ld-avr/avr-prop-8.d: New test.
* testsuite/ld-avr/avr-prop-8.s: New test.
2016-09-06 14:58:37 +08:00
|
|
|
|
2016-09-02 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20545
|
|
|
|
|
* elf32-avr.c (elf32_avr_relax_delete_bytes): Add parameter
|
|
|
|
|
delete_shrinks_insn. Modify computation of shrinked_insn_address.
|
|
|
|
|
Compute shrink_boundary and adjust addend only if
|
|
|
|
|
addend_within_shrink_boundary.
|
|
|
|
|
(elf32_avr_relax_section): Modify calls to
|
|
|
|
|
elf32_avr_relax_delete_bytes to pass extra parameter.
|
|
|
|
|
|
2016-09-01 16:35:57 +08:00
|
|
|
|
2016-09-01 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (cmse_entry_fct_p): Store instruction encoding in an
|
|
|
|
|
array of bytes and use bfd_get_16 to interpret its encoding according
|
|
|
|
|
to endianness of target.
|
|
|
|
|
|
2016-09-01 13:26:52 +08:00
|
|
|
|
2016-09-01 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (synthetic_opd): New static var.
|
|
|
|
|
(compare_symbols): Don't treat symbols in .opd specially for ELFv2.
|
|
|
|
|
(ppc64_elf_get_synthetic_symtab): Likewise. Comment.
|
|
|
|
|
|
2016-08-30 19:32:58 +08:00
|
|
|
|
2016-08-31 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (group_sections): Delete stub14_group_size. Instead,
|
|
|
|
|
track max group size with a new "group_size" var that is reduced
|
|
|
|
|
by a factor of 1024 from the 24-bit branch size whenever a 14-bit
|
|
|
|
|
branch is seen.
|
|
|
|
|
|
2016-08-31 11:48:34 +08:00
|
|
|
|
2016-08-31 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-ppc.c (ppc_elf_section_processing): Delete.
|
|
|
|
|
(elf_backend_section_processing): Don't define.
|
|
|
|
|
(ppc_elf_modify_segment_map): Set p_flags and mark valid. Don't
|
|
|
|
|
split on non-exec sections differing in SHF_PPC_VLE. When
|
|
|
|
|
splitting segments, mark size invalid.
|
|
|
|
|
|
2016-08-30 19:27:32 +08:00
|
|
|
|
2016-08-30 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 20531
|
|
|
|
|
* elf32-ppc.c (_bfd_elf_ppc_set_arch): Add missing "break".
|
|
|
|
|
|
2016-08-29 23:12:59 +08:00
|
|
|
|
2016-08-29 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/14961
|
|
|
|
|
PR ld/20515
|
|
|
|
|
* elf32-i386.c (elf_i386_check_relocs): Issue an error when
|
|
|
|
|
R_386_PC32 relocation is used to call IFUNC function in PIC
|
|
|
|
|
object.
|
|
|
|
|
|
2016-08-27 08:13:42 +08:00
|
|
|
|
2016-08-27 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 20520
|
|
|
|
|
* elf.c (_bfd_elf_setup_sections): Check that SHT_GROUP sections
|
|
|
|
|
have corresponding SHF_GROUP sections.
|
|
|
|
|
(bfd_elf_set_group_contents): Comment.
|
|
|
|
|
|
2016-08-27 07:29:29 +08:00
|
|
|
|
2016-08-27 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 20519
|
|
|
|
|
* elf64-ppc.c (pc_dynrelocs): New function.
|
|
|
|
|
(ppc64_elf_relocate_section): Use it and must_be_dyn_reloc to
|
|
|
|
|
handle pic dynamic relocs.
|
|
|
|
|
|
Reduce parameter list in bfd_elf32_arm_target_relocs
2016-08-26 Thomas Preud'homme <thomas.preudhomme@arm.com>
bfd/
* bfd-in.h (struct elf32_arm_params): Define.
(bfd_elf32_arm_set_target_relocs): Rename into ...
(bfd_elf32_arm_set_target_params): This. Use a struct
elf32_arm_params to pass all parameters but the bfd and bfd_link_info.
* bfd-in2.h: Regenerate.
* elf32-arm.c (bfd_elf32_arm_set_target_relocs): Rename into ...
(bfd_elf32_arm_set_target_params): This. Pass all values via a struct
elf32_arm_params rather than as individual parameters.
ld/
* emultempl/armelf.em (params): New static variable.
(thumb_entry_symbol, byteswap_code, target1_is_rel, target2_type,
fix_v4bx, use_blx, vfp11_denorm_fix, stm32l4xx_fix, fix_cortex_a8,
no_enum_size_warning, no_wchar_size_warning, pic_veneer,
merge_exidx_entries, fix_arm1176, cmse_implib): move as part of the
above new structure.
(arm_elf_before_allocation): Access static variable from the params
structure.
(gld${EMULATION_NAME}_finish): Likewise.
(arm_elf_create_output_section_statements): Likewise and pass the
address of that structure to bfd_elf32_arm_set_target_relocs instead
of the static variables.
(PARSE_AND_LIST_ARGS_CASES): Access static variable from the params
structure.
2016-08-26 21:00:39 +08:00
|
|
|
|
2016-08-26 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* bfd-in.h (struct elf32_arm_params): Define.
|
|
|
|
|
(bfd_elf32_arm_set_target_relocs): Rename into ...
|
|
|
|
|
(bfd_elf32_arm_set_target_params): This. Use a struct
|
|
|
|
|
elf32_arm_params to pass all parameters but the bfd and bfd_link_info.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* elf32-arm.c (bfd_elf32_arm_set_target_relocs): Rename into ...
|
|
|
|
|
(bfd_elf32_arm_set_target_params): This. Pass all values via a struct
|
|
|
|
|
elf32_arm_params rather than as individual parameters.
|
|
|
|
|
|
2016-08-26 19:01:47 +08:00
|
|
|
|
2016-08-26 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (elf32_arm_get_stub_entry): Assert that we don't access
|
|
|
|
|
passed the end of htab->stub_group array.
|
|
|
|
|
(elf32_arm_create_or_find_stub_sec): Likewise.
|
|
|
|
|
(elf32_arm_create_stub): Likewise.
|
|
|
|
|
|
2016-07-21 21:32:35 +08:00
|
|
|
|
2016-08-26 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf_arc_relocate_section): Changed. Set should_relocate
|
|
|
|
|
to TRUE for GOT and TLS relocs.
|
|
|
|
|
|
2016-07-19 20:33:34 +08:00
|
|
|
|
2016-08-26 Cupertino Miranda <cmiranda@synospsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf_arc_finish_dynamic_sections): Changed.
|
|
|
|
|
|
2016-07-14 00:04:20 +08:00
|
|
|
|
2016-08-26 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h: Added ARC_ELF_DATA to enum elf_target_id.
|
|
|
|
|
* elf32-arc.c (struct elf_arc_link_hash_entry): Added.
|
|
|
|
|
(struct elf_arc_link_hash_table): Likewise.
|
|
|
|
|
(elf_arc_link_hash_newfunc): Likewise.
|
|
|
|
|
(elf_arc_link_hash_table_free): Likewise.
|
|
|
|
|
(arc_elf_link_hash_table_create): Likewise.
|
|
|
|
|
(elf_arc_relocate_section): Fixed conditions related to dynamic
|
|
|
|
|
(elf_arc_check_relocs): Likewise.
|
|
|
|
|
(arc_elf_create_dynamic_sections): Added
|
|
|
|
|
(elf_arc_adjust_dynamic_symbol): Changed access to .rela.bss to be done
|
|
|
|
|
through the hash table.
|
|
|
|
|
|
2016-07-12 22:31:40 +08:00
|
|
|
|
2016-08-26 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* arc-got.h (relocate_fix_got_relocs_for_got_info): Fixed addresses in
|
|
|
|
|
debug comments. Fixed address in .got related to TLS_IE_GOT dynamic
|
|
|
|
|
relocation.
|
|
|
|
|
|
2016-06-07 16:24:37 +08:00
|
|
|
|
2016-08-26 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* reloc.c: Fixed type in ARC_SECTOFF relocations. Added ARC_SDA_12
|
|
|
|
|
relocation.
|
|
|
|
|
* bfd-in2.h: Regenerated from the previous changes.
|
|
|
|
|
* libbfd.h: Regenerated from the previous changes.
|
|
|
|
|
|
2016-08-26 17:59:26 +08:00
|
|
|
|
2016-08-26 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* bfd-in.h (bfd_elf32_arm_set_target_relocs): Add a new parameter for
|
|
|
|
|
the input import library bfd.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* elf32-arm.c (struct elf32_arm_link_hash_table): New in_implib_bfd
|
|
|
|
|
and new_cmse_stub_offset fields.
|
|
|
|
|
(stub_hash_newfunc): Initialize stub_offset and stub_template_size to
|
|
|
|
|
-1.
|
|
|
|
|
(elf32_arm_add_stub): Likewise for stub_offset.
|
|
|
|
|
(arm_new_stubs_start_offset_ptr): New function.
|
|
|
|
|
(arm_build_one_stub): Only allocate a stub_offset if it is -1. Allow
|
|
|
|
|
empty SG veneers to have zero relocations.
|
|
|
|
|
(arm_size_one_stub): Only initialize stub size and template
|
|
|
|
|
information for non empty veneers. Do not update veneer section size
|
|
|
|
|
if veneer already has an offset.
|
|
|
|
|
(elf32_arm_create_stub): Return the stub entry pointer or NULL instead
|
|
|
|
|
of a boolean indicating success or failure.
|
|
|
|
|
(cmse_scan): Change stub_changed parameter into an integer pointer
|
|
|
|
|
parameter cmse_stub_created to count the number of stub created and
|
|
|
|
|
adapt to change of return value in elf32_arm_create_stub.
|
|
|
|
|
(cmse_entry_fct_p): New function.
|
|
|
|
|
(arm_list_new_cmse_stub): Likewise.
|
|
|
|
|
(set_cmse_veneer_addr_from_implib): Likewise.
|
|
|
|
|
(elf32_arm_size_stubs): Define cmse_stub_created, pass its address to
|
|
|
|
|
cmse_scan instead of that of cmse_stub_changed to compute the number
|
|
|
|
|
of stub created and use it to initialize stub_changed. Call
|
|
|
|
|
set_cmse_veneer_addr_from_implib after all cmse_scan. Adapt to change
|
|
|
|
|
of return value in elf32_arm_create_stub. Use
|
|
|
|
|
arm_stub_section_start_offset () if not NULL to initialize size of
|
|
|
|
|
secure gateway veneers section. Initialize stub_offset of Cortex-A8
|
|
|
|
|
erratum fix to -1. Use ret to hold return value.
|
|
|
|
|
(elf32_arm_build_stubs): Use arm_stub_section_start_offset () if not
|
|
|
|
|
NULL to initialize size of secure gateway veneers section. Adapt
|
|
|
|
|
comment to stress the importance of zeroing veneer section content.
|
|
|
|
|
(bfd_elf32_arm_set_target_relocs): Add new in_implib_bfd parameter to
|
|
|
|
|
initialize eponymous field in struct elf32_arm_link_hash_table.
|
|
|
|
|
|
2016-08-26 01:13:57 +08:00
|
|
|
|
2016-08-25 Andreas Arnez <arnez@linux.vnet.ibm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-s390.c (stdarg.h): New include.
|
|
|
|
|
(elf_s390_grok_psinfo): New function.
|
|
|
|
|
(elf_s390_write_core_note): New function.
|
|
|
|
|
(elf_backend_grok_psinfo): Declare backend hook.
|
|
|
|
|
(elf_backend_write_core_note): Likewise.
|
|
|
|
|
* elf64-s390.c (stdarg.h): New include.
|
|
|
|
|
(elf_s390_grok_prstatus): New function.
|
|
|
|
|
(elf_s390_grok_psinfo): New function.
|
|
|
|
|
(elf_s390_write_core_note): New function.
|
|
|
|
|
(elf_backend_grok_prstatus): Declare backend hook.
|
|
|
|
|
(elf_backend_grok_psinfo): Likewise.
|
|
|
|
|
(elf_backend_write_core_note): Likewise.
|
|
|
|
|
|
2016-08-26 01:13:57 +08:00
|
|
|
|
2016-08-25 Andreas Arnez <arnez@linux.vnet.ibm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-s390.c (allocate_dynrelocs): Fix indentation.
|
|
|
|
|
(elf_s390_finish_ifunc_symbol): Likewise.
|
|
|
|
|
(elf_s390_finish_dynamic_symbol): Likewise.
|
|
|
|
|
(elf_s390_finish_dynamic_sections): Likewise.
|
|
|
|
|
(elf_s390_grok_prstatus): Likewise.
|
|
|
|
|
* elf64-s390.c (elf_s390_hash_table): Fix indentation.
|
|
|
|
|
(elf_s390_finish_dynamic_symbol): Likewise.
|
|
|
|
|
|
2013-09-12 19:56:45 +08:00
|
|
|
|
2016-08-24 Anton Kolesov <Anton.Kolesov@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf32_arc_grok_prstatus): New function.
|
|
|
|
|
|
2016-08-23 16:45:11 +08:00
|
|
|
|
2016-08-23 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (elf32_arm_count_additional_relocs): Return zero if
|
|
|
|
|
there is no arm data associated with the section.
|
|
|
|
|
|
2016-08-23 10:50:59 +08:00
|
|
|
|
2016-08-23 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 20475
|
|
|
|
|
* elf32-or1k.c (or1k_elf_relocate_section): Offset from
|
|
|
|
|
_GLOBAL_OFFSET_TABLE_, not start of .got section.
|
|
|
|
|
|
2016-08-22 21:23:19 +08:00
|
|
|
|
2016-08-22 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* doc/chew.c (main): Free the string buffer used to files as they
|
|
|
|
|
are parsed.
|
|
|
|
|
|
2016-08-22 09:12:26 +08:00
|
|
|
|
2016-08-22 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-ppc.c (ppc_elf_check_relocs): Move error for @local ifunc..
|
|
|
|
|
(ppc_elf_relocate_section): ..to here. Comment. Error on
|
|
|
|
|
detecting -mbss-plt -fPIC local ifuncs too.
|
|
|
|
|
(ppc_elf_size_dynamic_sections): Comment on unnecessary glink
|
|
|
|
|
branch table entries.
|
|
|
|
|
|
2016-08-19 16:16:30 +08:00
|
|
|
|
2016-08-19 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* elf.c (assign_section_numbers): Assign number for the .shstrtab
|
|
|
|
|
section after the symbol table and string table sections.
|
|
|
|
|
|
2016-08-19 09:36:53 +08:00
|
|
|
|
2016-08-19 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (struct ppc_link_hash_entry): Add weakref.
|
|
|
|
|
(ppc64_elf_copy_indirect_symbol): Set weakref. Don't merge
|
|
|
|
|
dyn_relocs for weakdefs.
|
|
|
|
|
(alias_readonly_dynrelocs): New function.
|
|
|
|
|
(ppc64_elf_adjust_dynamic_symbol): Use alias_readonly_dynrelocs.
|
|
|
|
|
(ppc64_elf_relocate_section): Simplify condition under which
|
|
|
|
|
dyn_relocs are emitted.
|
|
|
|
|
|
2016-08-19 09:36:41 +08:00
|
|
|
|
2016-08-19 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 20472
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_before_check_relocs): Tweak abiversion test.
|
|
|
|
|
(readonly_dynrelocs): Comment fix.
|
|
|
|
|
(global_entry_stub): New function.
|
|
|
|
|
(ppc64_elf_adjust_dynamic_symbol): Tweak abiversion test. Match
|
|
|
|
|
ELFv2 code deciding on dynamic relocs vs. global entry stubs to
|
|
|
|
|
that in size_global_entry_stubs, handling ifunc too. Delete dead
|
|
|
|
|
weak sym code.
|
|
|
|
|
(allocate_dynrelocs): Ensure dyn_relocs field is cleared when no
|
|
|
|
|
dyn_relocs are needed. Correct handling of ifunc dyn_relocs.
|
|
|
|
|
Tidy ELIMINATE_COPY_RELOCS code, only setting dynindx for
|
|
|
|
|
undefweak syms. Expand and correct comments.
|
|
|
|
|
(size_global_entry_stubs): Ensure symbol is defined.
|
|
|
|
|
(ppc64_elf_relocate_section): Match condition under which
|
|
|
|
|
dyn_relocs are emitted to that in allocate_dynrelocs.
|
|
|
|
|
|
2016-08-12 22:33:43 +08:00
|
|
|
|
2016-08-12 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h (struct elf_link_hash_table): Add local_dynsymcount.
|
|
|
|
|
* elflink.c (_bfd_elf_link_renumber_dynsyms): Set local_dynsymcount.
|
|
|
|
|
(bfd_elf_final_link): Set .dynsym sh_info from local_dynsymcount.
|
|
|
|
|
|
2016-08-11 11:00:52 +08:00
|
|
|
|
2016-08-11 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_adjust_dynamic_symbol): Don't exit with
|
|
|
|
|
non_got_ref true in any case where we could have generated dynbss
|
|
|
|
|
copies but decide not to do so.
|
|
|
|
|
|
MIPS/BFD: Actually produce short microMIPS LA25 stubs
For the case where a function which requires an LA25 stub is at the
beginning of a section we use a short sequence comprised of a LUI/ADDIU
instruction pair only and prepended to the associated function rather
than using a trailing jump to reach the function. This works by
checking for the offset into section of the function symbol being 0.
This is however never the case for microMIPS function symbols, which
have the ISA bit set. Consequently the short LA25 sequence is never
produced for microMIPS functions, like with the following example:
$ cat la25a.s
.abicalls
.global f1
.ent f1
f1:
.set noreorder
.cpload $25
.set reorder
.option pic0
jal f2
.option pic2
jr $31
.end f1
.global f2
.ent f2
f2:
jr $31
.end f2
$ cat la25b.s
.abicalls
.option pic0
.global __start
.ent __start
__start:
jal f1
jal f2
.end __start
$ as -mmicromips -32 -EB -o la25a.o la25a.s
$ as -mmicromips -32 -EB -o la25b.o la25b.s
$ ld -melf32btsmip -o la25 la25a.o la25b.o
$ objdump -d la25
la25: file format elf32-tradbigmips
Disassembly of section .text:
004000d0 <.pic.f2>:
4000d0: 41b9 0040 lui t9,0x40
4000d4: d420 0083 j 400106 <f2>
4000d8: 3339 0107 addiu t9,t9,263
4000dc: 0000 0000 nop
004000e0 <.pic.f1>:
4000e0: 41b9 0040 lui t9,0x40
4000e4: d420 0078 j 4000f0 <f1>
4000e8: 3339 00f1 addiu t9,t9,241
4000ec: 0000 0000 nop
004000f0 <f1>:
4000f0: 41bc 0002 lui gp,0x2
4000f4: 339c 801f addiu gp,gp,-32737
4000f8: 033c e150 addu gp,gp,t9
4000fc: f420 0083 jal 400106 <f2>
400100: 0000 0000 nop
400104: 45bf jrc ra
00400106 <f2>:
400106: 45bf jrc ra
...
00400110 <__start>:
400110: f420 0070 jal 4000e0 <.pic.f1>
400114: 0000 0000 nop
400118: f420 0068 jal 4000d0 <.pic.f2>
40011c: 0000 0000 nop
$
where `.pic.f1' could omit the trailing jump and the filler NOP and just
fall through to `f1'.
Correct the problem by masking out the ISA bit from microMIPS functions,
which fixes the earlier example:
$ objdump -d la25
la25: file format elf32-tradbigmips
Disassembly of section .text:
004000d0 <.pic.f2>:
4000d0: 41b9 0040 lui t9,0x40
4000d4: d420 0083 j 400106 <f2>
4000d8: 3339 0107 addiu t9,t9,263
...
004000e8 <.pic.f1>:
4000e8: 41b9 0040 lui t9,0x40
4000ec: 3339 00f1 addiu t9,t9,241
004000f0 <f1>:
4000f0: 41bc 0002 lui gp,0x2
4000f4: 339c 801f addiu gp,gp,-32737
4000f8: 033c e150 addu gp,gp,t9
4000fc: f420 0083 jal 400106 <f2>
400100: 0000 0000 nop
400104: 45bf jrc ra
00400106 <f2>:
400106: 45bf jrc ra
...
00400110 <__start>:
400110: f420 0074 jal 4000e8 <.pic.f1>
400114: 0000 0000 nop
400118: f420 0068 jal 4000d0 <.pic.f2>
40011c: 0000 0000 nop
$
There is no need to do anything for MIPS16 functions, because if any
LA25 stub has been generated for such a function, then it is only
required for an associated call thunk only, which is regular MIPS code
and the address of which, with the ISA bit clear, is returned by
`mips_elf_get_la25_target'.
This problem has been there since the beginning of microMIPS support:
commit df58fc944dbc6d5efd8d3826241b64b6af22f447
Author: Richard Sandiford <rdsandiford@googlemail.com>
Date: Sun Jul 24 14:20:15 2011 +0000
<https://sourceware.org/ml/binutils/2011-07/msg00198.html>, ("MIPS:
microMIPS ASE support").
bfd/
* elfxx-mips.c (mips_elf_add_la25_stub): Clear the ISA bit of
the stub address retrieved if associated with a microMIPS
function.
2016-08-11 03:44:03 +08:00
|
|
|
|
2016-08-10 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_add_la25_stub): Clear the ISA bit of
|
|
|
|
|
the stub address retrieved if associated with a microMIPS
|
|
|
|
|
function.
|
|
|
|
|
|
2016-08-11 03:03:02 +08:00
|
|
|
|
2016-08-10 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_create_stub_symbol): For a microMIPS
|
|
|
|
|
stub also add STO_MICROMIPS annotation.
|
|
|
|
|
|
2016-08-10 19:43:18 +08:00
|
|
|
|
2016-08-10 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_calculate_relocation): Set the ISA bit
|
|
|
|
|
in microMIPS LA25 stub references.
|
|
|
|
|
|
2016-08-09 23:18:42 +08:00
|
|
|
|
2016-08-09 Jiaming Wei <jmwei@hxgpt.com>
|
|
|
|
|
|
|
|
|
|
* elf64-alpha.c (elf64_alpha_copy_indirect_symbol): Fix thinko
|
|
|
|
|
adjusting the use_count of merged .got entries.
|
|
|
|
|
|
2016-08-08 19:19:29 +08:00
|
|
|
|
2016-08-08 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* doc/chew.c (delete_string): Only free the string buffer if it is
|
|
|
|
|
there. Mark the buffer as NULL after freeing.
|
|
|
|
|
(drop): Free the dropped string.
|
|
|
|
|
(free_words): New function: Frees the memory allocated to the
|
|
|
|
|
dictionary.
|
|
|
|
|
(add_instrinsic): Duplicate the name string, so that it can be
|
|
|
|
|
freed later on.
|
|
|
|
|
(compile): Free unused words.
|
|
|
|
|
(main): Free the dictionary and top level string buffers at the
|
|
|
|
|
end.
|
|
|
|
|
|
2016-08-04 22:54:57 +08:00
|
|
|
|
2016-08-04 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* bfd-in.h (bfd_elf32_arm_set_target_relocs): Add one parameter.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* elf32-arm.c (struct elf32_arm_link_hash_table): Declare new
|
|
|
|
|
cmse_implib field.
|
|
|
|
|
(bfd_elf32_arm_set_target_relocs): Add new parameter to initialize
|
|
|
|
|
cmse_implib field in struct elf32_arm_link_hash_table.
|
|
|
|
|
(elf32_arm_filter_cmse_symbols): New function.
|
|
|
|
|
(elf32_arm_filter_implib_symbols): Likewise.
|
|
|
|
|
(elf_backend_filter_implib_symbols): Define to
|
|
|
|
|
elf32_arm_filter_implib_symbols.
|
|
|
|
|
|
2016-08-04 22:36:52 +08:00
|
|
|
|
2016-08-04 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (CMSE_PREFIX): Define macro.
|
|
|
|
|
(elf32_arm_stub_cmse_branch_thumb_only): Define stub sequence.
|
|
|
|
|
(cmse_branch_thumb_only): Declare stub.
|
|
|
|
|
(struct elf32_arm_link_hash_table): Define cmse_stub_sec field.
|
|
|
|
|
(elf32_arm_get_plt_info): Add globals parameter. Use it to return
|
|
|
|
|
FALSE if there is no PLT.
|
|
|
|
|
(arm_type_of_stub): Adapt to new elf32_arm_get_plt_info signature.
|
|
|
|
|
(elf32_arm_final_link_relocate): Likewise.
|
|
|
|
|
(elf32_arm_gc_sweep_hook): Likewise.
|
|
|
|
|
(elf32_arm_gc_mark_extra_sections): Mark sections holding ARMv8-M
|
|
|
|
|
secure entry functions.
|
|
|
|
|
(arm_stub_is_thumb): Add case for arm_stub_cmse_branch_thumb_only.
|
|
|
|
|
(arm_dedicated_stub_output_section_required): Change to a switch case
|
|
|
|
|
and add a case for arm_stub_cmse_branch_thumb_only.
|
|
|
|
|
(arm_dedicated_stub_output_section_required_alignment): Likewise.
|
|
|
|
|
(arm_stub_dedicated_output_section_name): Likewise.
|
|
|
|
|
(arm_stub_dedicated_input_section_ptr): Likewise and remove
|
|
|
|
|
ATTRIBUTE_UNUSED for htab parameter.
|
|
|
|
|
(arm_stub_required_alignment): Likewise.
|
|
|
|
|
(arm_stub_sym_claimed): Likewise.
|
|
|
|
|
(arm_dedicated_stub_section_padding): Likewise.
|
|
|
|
|
(cmse_scan): New function.
|
|
|
|
|
(elf32_arm_size_stubs): Call cmse_scan for ARM M profile targets.
|
|
|
|
|
Set stub_changed to TRUE if such veneers were created.
|
|
|
|
|
(elf32_arm_swap_symbol_in): Add detection code for CMSE special
|
|
|
|
|
symbols.
|
|
|
|
|
|
2016-08-02 21:58:47 +08:00
|
|
|
|
2016-08-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20428
|
|
|
|
|
* elf64-ppc.c (ppc_get_stub_entry): Don't segfault on NULL group.
|
|
|
|
|
|
2016-08-02 18:56:55 +08:00
|
|
|
|
2016-08-02 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR ld/17739
|
|
|
|
|
* elf32-sh.c (sh_elf_gc_sweep_hook): Delete.
|
|
|
|
|
(elf_backend_sweep_hook): Delete.
|
|
|
|
|
|
2016-08-02 00:42:31 +08:00
|
|
|
|
2016-08-01 Andrew Jenner <andrew@codesourcery.com>
|
|
|
|
|
Kwok Cheung Yeung <kcy@codesourcery.com>
|
|
|
|
|
|
|
|
|
|
* elf32-ppc.c (is_branch_reloc): Recognise VLE branch relocations.
|
|
|
|
|
(ppc_elf_howto_raw): Fix dst_mask of R_PPC_VLE_REL15.
|
|
|
|
|
(ppc_elf_vle_split16): Clear field before inserting.
|
|
|
|
|
|
2016-08-01 16:59:04 +08:00
|
|
|
|
2016-08-01 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* po/sv.po: Updated Swedish translation.
|
|
|
|
|
|
2016-07-27 17:49:32 +08:00
|
|
|
|
2016-07-27 Ozkan Sezer <sezeroz@gmail.com>
|
|
|
|
|
Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20401
|
|
|
|
|
* coffgen.c (fini_reloc_cookie_rels): Check for the extistence
|
|
|
|
|
of the coff_section_data before using it.
|
|
|
|
|
|
2016-07-27 00:45:00 +08:00
|
|
|
|
2016-07-26 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_calculate_relocation): Handle branches
|
|
|
|
|
in PLT compression selection.
|
|
|
|
|
(_bfd_mips_elf_check_relocs): Likewise.
|
|
|
|
|
|
2016-07-22 22:10:31 +08:00
|
|
|
|
2016-07-22 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* arc-got.h (relocate_fix_got_relocs_for_got_info): Handle the
|
|
|
|
|
case where there's no elf_link_hash_entry while processing
|
|
|
|
|
GOT_NORMAL got entries.
|
|
|
|
|
|
2016-07-22 06:22:13 +08:00
|
|
|
|
2016-07-21 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* version.m4 (BFD_VERSION): Set to 2.27.51.
|
|
|
|
|
* configure: Regenerated.
|
|
|
|
|
|
2016-07-20 13:36:49 +08:00
|
|
|
|
2016-07-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* elf.c (_bfd_elf_filter_global_symbols): Skip local symbols.
|
|
|
|
|
(swap_out_syms): Return an error when not finding ELF output
|
|
|
|
|
section rather than asserting.
|
|
|
|
|
|
|
|
|
|
2016-07-21 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (elf_output_implib): Call bfd_set_error on no symbols.
|
|
|
|
|
|
2016-07-05 10:19:48 +08:00
|
|
|
|
2016-07-20 John Baldwin <jhb@FreeBSD.org>
|
|
|
|
|
|
|
|
|
|
* elf.c (elfcore_grok_freebsd_psinfo): Check for minimum note size
|
|
|
|
|
and handle pr_pid if present.
|
|
|
|
|
|
2016-07-22 06:17:37 +08:00
|
|
|
|
2016-07-20 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20376
|
|
|
|
|
* elf.c (assign_file_positions_for_load_sections): Also check
|
|
|
|
|
p_paddr for program header space.
|
|
|
|
|
|
2016-07-20 09:03:14 +08:00
|
|
|
|
2016-07-20 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_howto_raw <R_PPC64_PLTREL32>): Put
|
|
|
|
|
ppc64_elf_unhandled_reloc for special_function.
|
|
|
|
|
* elf32-ppc.c (ppc_elf_howto_raw): Similarly for lots of relocs.
|
|
|
|
|
|
2016-07-19 23:19:19 +08:00
|
|
|
|
2016-07-19 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_perform_relocation): Convert cross-mode
|
|
|
|
|
BAL to JALX.
|
|
|
|
|
(_bfd_mips_elf_relocate_section) <bfd_reloc_outofrange>: Add a
|
|
|
|
|
corresponding error message.
|
|
|
|
|
|
MIPS: Verify the ISA mode and alignment of branch and jump targets
Verify that the ISA mode of branch targets is the same as the referring
relocation, so that an attempt to produce a branch between instructions
encoded in different ISA modes each causes an error rather than silently
producing non-functional code. Make sure that no symbol or addend bits
are silently truncated: terminate with an error if the relocation value
calculated cannot be encoded in the relocatable field of a branch; for
REL targets also applying to any intermediate addend.
Also make jump target's alignment verification consistent with that for
branches.
This change will require an update to some obscure handcoded assembly
sources which make branches to labels placed at data objects, however
for microMIPS code only. These labels will have to be updated with the
`.insn' directive for containing code to assemble and link successfully.
Such code is broken as any such labels have always been required by the
microMIPS architecture specification[1][2] to be annotated this way for
correct interpretation, and with our old code missing `.insn' directives
caused labels to present different semantics depending on whether they
were referred with branch (ISA bit ignored) or other relocations (ISA
bit respected).
Enforcing these checks however will ensure errors in building software,
like mixed regular MIPS and microMIPS code links with branches between,
will be diagnosed at the build time rather than causing odd run-time
errors such as intermittent crashes. It will also let cross-mode BAL
instructions be converted to JALX instructions, with a separate change.
References:
[1] "MIPS Architecture for Programmers, Volume II-B: The microMIPS32
Instruction Set", MIPS Technologies, Inc., Document Number: MD00582,
Revision 5.04, January 15, 2014, Section 7.1 "Assembly-Level
Compatibility", p. 533
[2] "MIPS Architecture for Programmers, Volume II-B: The microMIPS64
Instruction Set", MIPS Technologies, Inc., Document Number: MD00594,
Revision 5.04, January 15, 2014, Section 8.1 "Assembly-Level
Compatibility", p. 623
bfd/
* elfxx-mips.c (b_reloc_p): Add R_MICROMIPS_PC16_S1,
R_MICROMIPS_PC10_S1 and R_MICROMIPS_PC7_S1.
(branch_reloc_p): New function.
(mips_elf_calculate_relocation): Handle ISA mode determination
for relocations against section symbols, against absolute
symbols and absolute relocations. Also set `*cross_mode_jump_p'
for branches.
<R_MIPS16_26, R_MIPS_26, R_MICROMIPS_26_S1>: Suppress alignment
checks for weak undefined symbols. Also check target alignment
within the same ISA mode.
<R_MIPS_PC16, R_MIPS_GNU_REL16_S2>: Handle cross-mode branches
in the alignment check.
<R_MICROMIPS_PC7_S1>: Add an alignment check.
<R_MICROMIPS_PC10_S1>: Likewise.
<R_MICROMIPS_PC16_S1>: Likewise.
(mips_elf_perform_relocation): Report a failure for unsupported
same-mode JALX instructions and cross-mode branches.
(_bfd_mips_elf_relocate_section) <bfd_reloc_outofrange>: Add
error messages for jumps to misaligned addresses.
gas/
* config/tc-mips.c (mips_force_relocation): Also retain branch
relocations against MIPS16 and microMIPS symbols.
(fix_bad_cross_mode_jump_p): New function.
(fix_bad_same_mode_jalx_p): Likewise.
(fix_bad_misaligned_jump_p): Likewise.
(fix_bad_cross_mode_branch_p): Likewise.
(fix_bad_misaligned_branch_p): Likewise.
(fix_validate_branch): Likewise.
(md_apply_fix) <BFD_RELOC_MIPS_JMP, BFD_RELOC_MIPS16_JMP>
<BFD_RELOC_MICROMIPS_JMP>: Separate from BFD_RELOC_MIPS_SHIFT5,
etc. Verify the ISA mode and alignment of the jump target.
<BFD_RELOC_MIPS_21_PCREL_S2>: Replace the inline alignment check
with a call to `fix_validate_branch'.
<BFD_RELOC_MIPS_26_PCREL_S2>: Likewise.
<BFD_RELOC_16_PCREL_S2>: Likewise.
<BFD_RELOC_MICROMIPS_7_PCREL_S1, BFD_RELOC_MICROMIPS_10_PCREL_S1>
<BFD_RELOC_MICROMIPS_16_PCREL_S1>: Retain the original addend.
Verify the ISA mode and alignment of the branch target.
(md_convert_frag): Verify the ISA mode and alignment of resolved
MIPS16 branch targets.
* testsuite/gas/mips/branch-misc-1.s: Annotate non-instruction
branch targets with `.insn'.
* testsuite/gas/mips/branch-misc-5.s: Likewise.
* testsuite/gas/mips/micromips@branch-misc-5-64.d: Update
accordingly.
* testsuite/gas/mips/micromips@branch-misc-5pic-64.d: Likewise.
* testsuite/gas/mips/micromips-branch-relax.s: Annotate
non-instruction branch target with `.insn'.
* testsuite/gas/mips/micromips.s: Replace microMIPS JALX targets
with external symbols.
* testsuite/gas/mips/micromips-insn32.d: Update accordingly.
* testsuite/gas/mips/micromips-noinsn32.d: Likewise.
* testsuite/gas/mips/micromips-trap.d: Likewise.
* testsuite/gas/mips/micromips.d: Likewise.
* testsuite/gas/mips/mips16.s: Annotate non-instruction branch
targets with `.insn'.
* testsuite/gas/mips/mips16.d: Update accordingly.
* testsuite/gas/mips/mips16-64.d: Likewise.
* testsuite/gas/mips/mips16-dwarf2.s: Annotate non-instruction
branch target with `.insn'.
* testsuite/gas/mips/relax-swap3.s: Likewise.
* testsuite/gas/mips/branch-local-2.l: New list test.
* testsuite/gas/mips/branch-local-3.l: New list test.
* testsuite/gas/mips/branch-local-n32-2.l: New list test.
* testsuite/gas/mips/branch-local-n32-3.l: New list test.
* testsuite/gas/mips/branch-local-n64-2.l: New list test.
* testsuite/gas/mips/branch-local-n64-3.l: New list test.
* testsuite/gas/mips/unaligned-jump-1.l: New list test.
* testsuite/gas/mips/unaligned-jump-2.l: New list test.
* testsuite/gas/mips/unaligned-jump-3.d: New test.
* testsuite/gas/mips/unaligned-jump-mips16-1.l: New list test.
* testsuite/gas/mips/unaligned-jump-mips16-2.l: New list test.
* testsuite/gas/mips/unaligned-jump-mips16-3.d: New test.
* testsuite/gas/mips/unaligned-jump-micromips-1.l: New list
test.
* testsuite/gas/mips/unaligned-jump-micromips-2.l: New list
test.
* testsuite/gas/mips/unaligned-jump-micromips-3.d: New test.
* testsuite/gas/mips/unaligned-branch-1.l: New list test.
* testsuite/gas/mips/unaligned-branch-2.l: New list test.
* testsuite/gas/mips/unaligned-branch-3.d: New test.
* testsuite/gas/mips/unaligned-branch-r6-1.l: New list test.
* testsuite/gas/mips/unaligned-branch-r6-2.l: New list test.
* testsuite/gas/mips/unaligned-branch-r6-3.l: New list test.
* testsuite/gas/mips/unaligned-branch-r6-4.l: New list test.
* testsuite/gas/mips/unaligned-branch-r6-5.d: New test.
* testsuite/gas/mips/unaligned-branch-r6-6.d: New test.
* testsuite/gas/mips/unaligned-branch-mips16-1.l: New list test.
* testsuite/gas/mips/unaligned-branch-mips16-2.l: New list test.
* testsuite/gas/mips/unaligned-branch-mips16-3.d: New test.
* testsuite/gas/mips/unaligned-branch-micromips-1.l: New list
test.
* testsuite/gas/mips/unaligned-branch-micromips-2.l: New list
test.
* testsuite/gas/mips/unaligned-branch-micromips-3.d: New test.
* testsuite/gas/mips/branch-local-2.s: New test source.
* testsuite/gas/mips/branch-local-3.s: New test source.
* testsuite/gas/mips/branch-local-n32-2.s: New test source.
* testsuite/gas/mips/branch-local-n32-3.s: New test source.
* testsuite/gas/mips/branch-local-n64-2.s: New test source.
* testsuite/gas/mips/branch-local-n64-3.s: New test source.
* testsuite/gas/mips/unaligned-jump-1.s: New test source.
* testsuite/gas/mips/unaligned-jump-2.s: New test source.
* testsuite/gas/mips/unaligned-jump-mips16-1.s: New test source.
* testsuite/gas/mips/unaligned-jump-mips16-2.s: New test source.
* testsuite/gas/mips/unaligned-jump-micromips-1.s: New test
source.
* testsuite/gas/mips/unaligned-jump-micromips-2.s: New test
source.
* testsuite/gas/mips/unaligned-branch-1.s: New test source.
* testsuite/gas/mips/unaligned-branch-2.s: New test source.
* testsuite/gas/mips/unaligned-branch-r6-1.s: New test source.
* testsuite/gas/mips/unaligned-branch-r6-2.s: New test source.
* testsuite/gas/mips/unaligned-branch-r6-3.s: New test source.
* testsuite/gas/mips/unaligned-branch-r6-4.s: New test source.
* testsuite/gas/mips/unaligned-branch-mips16-1.s: New test
source.
* testsuite/gas/mips/unaligned-branch-mips16-2.s: New test
source.
* testsuite/gas/mips/unaligned-branch-micromips-1.s: New test
source.
* testsuite/gas/mips/unaligned-branch-micromips-2.s: New test
source.
* testsuite/gas/mips/mips.exp: Run the new tests.
ld/
* testsuite/ld-mips-elf/unaligned-jalx-1.d: Update error message
expected.
* testsuite/ld-mips-elf/unaligned-jalx-addend-1.d: Likewise.
* testsuite/ld-mips-elf/unaligned-jalx-addend-mips16-1.d:
Likewise.
* testsuite/ld-mips-elf/unaligned-jalx-addend-micromips-1.d:
Likewise.
* testsuite/ld-mips-elf/unaligned-jalx-mips16-1.d: Likewise.
* testsuite/ld-mips-elf/unaligned-jalx-micromips-1.d: Likewise.
* testsuite/ld-mips-elf/undefweak-overflow.s: Add jumps,
microMIPS BAL and MIPS16 instructions.
* testsuite/ld-mips-elf/undefweak-overflow.d: Update
accordingly.
* testsuite/ld-mips-elf/unaligned-branch-2.d: New test.
* testsuite/ld-mips-elf/unaligned-branch-r6-1.d: New test.
* testsuite/ld-mips-elf/unaligned-branch-r6-2.d: New test.
* testsuite/ld-mips-elf/unaligned-branch-mips16.d: New test.
* testsuite/ld-mips-elf/unaligned-branch-micromips.d: New test.
* testsuite/ld-mips-elf/unaligned-jump-mips16.d: New test.
* testsuite/ld-mips-elf/unaligned-jump-micromips.d: New test.
* testsuite/ld-mips-elf/unaligned-jump.d: New test.
* testsuite/ld-mips-elf/mips-elf.exp: Run the new tests.
2016-07-19 20:59:28 +08:00
|
|
|
|
2016-07-19 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (b_reloc_p): Add R_MICROMIPS_PC16_S1,
|
|
|
|
|
R_MICROMIPS_PC10_S1 and R_MICROMIPS_PC7_S1.
|
|
|
|
|
(branch_reloc_p): New function.
|
|
|
|
|
(mips_elf_calculate_relocation): Handle ISA mode determination
|
|
|
|
|
for relocations against section symbols, against absolute
|
|
|
|
|
symbols and absolute relocations. Also set `*cross_mode_jump_p'
|
|
|
|
|
for branches.
|
|
|
|
|
<R_MIPS16_26, R_MIPS_26, R_MICROMIPS_26_S1>: Suppress alignment
|
|
|
|
|
checks for weak undefined symbols. Also check target alignment
|
|
|
|
|
within the same ISA mode.
|
|
|
|
|
<R_MIPS_PC16, R_MIPS_GNU_REL16_S2>: Handle cross-mode branches
|
|
|
|
|
in the alignment check.
|
|
|
|
|
<R_MICROMIPS_PC7_S1>: Add an alignment check.
|
|
|
|
|
<R_MICROMIPS_PC10_S1>: Likewise.
|
|
|
|
|
<R_MICROMIPS_PC16_S1>: Likewise.
|
|
|
|
|
(mips_elf_perform_relocation): Report a failure for unsupported
|
|
|
|
|
same-mode JALX instructions and cross-mode branches.
|
|
|
|
|
(_bfd_mips_elf_relocate_section) <bfd_reloc_outofrange>: Add
|
|
|
|
|
error messages for jumps to misaligned addresses.
|
|
|
|
|
|
2016-07-16 12:02:16 +08:00
|
|
|
|
2016-07-16 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c: Include plugin-api.h.
|
|
|
|
|
* plugin.c (bfd_plugin_open_input): New function, extracted from..
|
|
|
|
|
(try_claim): ..here.
|
|
|
|
|
* plugin.h: Don't include bfd.h.
|
|
|
|
|
(bfd_plugin_open_input): Declare.
|
|
|
|
|
|
2016-07-16 11:59:35 +08:00
|
|
|
|
2016-07-16 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* targets.c (bfd_seach_for_target): Rename to..
|
|
|
|
|
(bfd_iterate_over_targets): ..this. Rewrite doc.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
|
2016-07-16 11:57:30 +08:00
|
|
|
|
2016-07-16 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* archures.c (bfd_default_set_arch_mach): Make available in bfd.h.
|
|
|
|
|
* libbfd.h: Regenerate.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
|
2016-07-16 11:55:11 +08:00
|
|
|
|
2016-07-16 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* libbfd-in.h (BFD_ALIGN): Move to..
|
|
|
|
|
* bfd-in.h: ..here.
|
|
|
|
|
* elf32-ppc.h (struct ppc_elf_params): Add pagesize.
|
|
|
|
|
* elf32-ppc.c (default_params): Adjust init.
|
|
|
|
|
(ppc_elf_link_params): Set pagesize_p2.
|
|
|
|
|
* libbfd.h: Regenerate.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
|
2016-07-16 00:49:08 +08:00
|
|
|
|
2016-07-15 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h (elf_backend_filter_implib_symbols): Declare backend hook.
|
|
|
|
|
(_bfd_elf_filter_global_symbols): Declare.
|
|
|
|
|
* elf.c (_bfd_elf_filter_global_symbols): New function.
|
|
|
|
|
* elflink.c (elf_filter_global_symbols): Likewise.
|
|
|
|
|
(elf_output_implib): Likewise.
|
|
|
|
|
(bfd_elf_final_link): Call above function, failing if it does.
|
|
|
|
|
* elfxx-target.h (elf_backend_filter_implib_symbols): Define macro and
|
|
|
|
|
default it to NULL.
|
|
|
|
|
(elf_backend_copy_indirect_symbol): Fix spacing.
|
|
|
|
|
(elf_backend_hide_symbol): Likewise.
|
|
|
|
|
(elfNN_bed): Initialize elf_backend_filter_implib_symbols backend hook.
|
|
|
|
|
|
2016-07-15 19:00:03 +08:00
|
|
|
|
2016-07-15 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
|
Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (PR_DEBUG): Delete.
|
|
|
|
|
Fix printing of debug information. Fix formatting of debug
|
|
|
|
|
statements.
|
|
|
|
|
(debug_arc_reloc): Handle symbols that are not from an input file.
|
|
|
|
|
(arc_do_relocation): Remove excessive exclamation points.
|
|
|
|
|
|
|
|
|
|
* arc-got.h: Fix formatting. Fix printing of debug information.
|
|
|
|
|
(new_got_entry_to_list): Use xmalloc.
|
|
|
|
|
* config.bfd: use the big-endian arc vector as the default vector
|
|
|
|
|
for big-endian arc targets.
|
|
|
|
|
|
2016-07-15 15:32:00 +08:00
|
|
|
|
2016-07-15 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* cofflink.c (mark_relocs): Exclude relocs with -1 r_symndx
|
|
|
|
|
from marking sym_indices.
|
|
|
|
|
|
BFD: Let targets handle relocations against absolute symbols
Fix a generic BFD issue with relocations against absolute symbols, which
are installed without using any individual relocation handler provided
by the backend. This causes any absolute section's addend to be lost on
REL targets such as o32 MIPS, and also relocation-specific calculation
adjustments are not made.
As an example assembling this program:
$ cat test.s
.text
foo:
b bar
b baz
.set bar, 0x1234
$ as -EB -32 -o test-o32.o test.s
$ as -EB -n32 -o test-n32.o test.s
produces this binary code:
$ objdump -dr test-o32.o test-n32.o
test-o32.o: file format elf32-tradbigmips
Disassembly of section .text:
00000000 <foo>:
0: 10000000 b 4 <foo+0x4>
0: R_MIPS_PC16 *ABS*
4: 00000000 nop
8: 1000ffff b 8 <foo+0x8>
8: R_MIPS_PC16 baz
c: 00000000 nop
test-n32.o: file format elf32-ntradbigmips
Disassembly of section .text:
00000000 <foo>:
0: 10000000 b 4 <foo+0x4>
0: R_MIPS_PC16 *ABS*+0x1230
4: 00000000 nop
8: 10000000 b c <foo+0xc>
8: R_MIPS_PC16 baz-0x4
c: 00000000 nop
$
where it is clearly visible in `test-o32.o', which uses REL relocations,
that the absolute section's addend equivalent to the value of `bar' -- a
reference to which cannot be fully resolved at the assembly time,
because the reference is PC-relative -- has been lost, as has been the
relocation-specific adjustment of -4, required to take into account the
PC+4-relative calculation made by hardware with branches and seen in the
external symbol reference to `baz' as the `ffff' addend encoded in the
instruction word. In `test-n32.o', which uses RELA relocations, the
absolute section's addend has been correctly retained.
Give precedence then in `bfd_perform_relocation' and
`bfd_install_relocation' to any individual relocation handler the
backend selected may have provided, while still resorting to the generic
calculation otherwise. This retains the semantics which we've had since
forever or before the beginning of our repository history, and is at the
very least compatible with `bfd_elf_generic_reloc' being used as the
handler.
Retain the `bfd_is_und_section' check unchanged at the beginning of
`bfd_perform_relocation' since this does not affect the semantics of the
function. The check returns the same `bfd_reloc_undefined' code the
check for a null `howto' does, so swapping the two does not matter.
Also the check is is mutually exclusive with the `bfd_is_abs_section'
check, since a section cannot be absolute and undefined both at once, so
swapping the two does not matter either.
With this change applied the program quoted above now has the in-place
addend correctly calculated and installed in the field being relocated:
$ objdump -dr fixed-o32.o
fixed-o32.o: file format elf32-tradbigmips
Disassembly of section .text:
00000000 <foo>:
0: 1000048c b 1234 <bar>
0: R_MIPS_PC16 *ABS*
4: 00000000 nop
8: 1000ffff b 8 <foo+0x8>
8: R_MIPS_PC16 baz
c: 00000000 nop
$
Add a set of MIPS tests to cover the relevant cases, including absolute
symbols with addends, and verifying that PC-relative relocations against
symbols concerned resolve to the same value in the final link regardless
of whether the REL or the RELA relocation form is used. Exclude linker
tests though which would overflow the in-place addend on REL targets and
use them as dump patterns for RELA targets only.
bfd/
* reloc.c (bfd_perform_relocation): Try the `howto' handler
first with relocations against absolute symbols.
(bfd_install_relocation): Likewise.
gas/
* testsuite/gas/mips/mips16-branch-absolute.d: Update patterns.
* testsuite/gas/mips/branch-absolute.d: New test.
* testsuite/gas/mips/branch-absolute-n32.d: New test.
* testsuite/gas/mips/branch-absolute-n64.d: New test.
* testsuite/gas/mips/branch-absolute-addend-n32.d: New test.
* testsuite/gas/mips/branch-absolute-addend-n64.d: New test.
* testsuite/gas/mips/mips16-branch-absolute-n32.d: New test.
* testsuite/gas/mips/mips16-branch-absolute-n64.d: New test.
* testsuite/gas/mips/mips16-branch-absolute-addend-n32.d: New
test.
* testsuite/gas/mips/mips16-branch-absolute-addend-n64.d: New
test.
* testsuite/gas/mips/micromips-branch-absolute.d: New test.
* testsuite/gas/mips/micromips-branch-absolute-n32.d: New test.
* testsuite/gas/mips/micromips-branch-absolute-n64.d: New test.
* testsuite/gas/mips/micromips-branch-absolute-addend-n32.d: New
test.
* testsuite/gas/mips/micromips-branch-absolute-addend-n64.d: New
test.
* testsuite/gas/mips/branch-absolute.s: New test source.
* testsuite/gas/mips/branch-absolute-addend.s: New test source.
* testsuite/gas/mips/mips16-branch-absolute-addend.s: New test
source.
* testsuite/gas/mips/micromips-branch-absolute.s: New test
source.
* testsuite/gas/mips/micromips-branch-absolute-addend.s: New
test source.
* testsuite/gas/mips/mips.exp: Run the new tests.
ld/
* testsuite/ld-mips-elf/branch-absolute.d: New test.
* testsuite/ld-mips-elf/branch-absolute-n32.d: New test.
* testsuite/ld-mips-elf/branch-absolute-n64.d: New test.
* testsuite/ld-mips-elf/branch-absolute-addend.d: New test.
* testsuite/ld-mips-elf/branch-absolute-addend-n32.d: New test.
* testsuite/ld-mips-elf/branch-absolute-addend-n64.d: New test.
* testsuite/ld-mips-elf/micromips-branch-absolute.d: New test.
* testsuite/ld-mips-elf/micromips-branch-absolute-n32.d: New
test.
* testsuite/ld-mips-elf/micromips-branch-absolute-n64.d: New
test.
* testsuite/ld-mips-elf/micromips-branch-absolute-addend.d: New
test.
* testsuite/ld-mips-elf/micromips-branch-absolute-addend-n32.d:
New test.
* testsuite/ld-mips-elf/micromips-branch-absolute-addend-n64.d:
New test.
* testsuite/ld-mips-elf/mips-elf.exp: Run the new tests, except
from `branch-absolute-addend' and
`micromips-branch-absolute-addend', referred indirectly only.
2016-07-12 08:30:01 +08:00
|
|
|
|
2016-07-14 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* reloc.c (bfd_perform_relocation): Try the `howto' handler
|
|
|
|
|
first with relocations against absolute symbols.
|
|
|
|
|
(bfd_install_relocation): Likewise.
|
|
|
|
|
|
2016-07-13 06:33:47 +08:00
|
|
|
|
2016-07-12 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Align
|
|
|
|
|
.got/.got.plt sections to 8 bytes.
|
|
|
|
|
|
2016-07-12 22:46:02 +08:00
|
|
|
|
2016-07-12 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* binary.c (binary_set_section_contents): Second grammar fix.
|
|
|
|
|
|
2016-07-12 18:05:13 +08:00
|
|
|
|
2016-07-12 Douglas B Rupp <rupp@adacore.com>
|
|
|
|
|
|
|
|
|
|
* binary.c (binary_set_section_contents): Fix grammar in warning
|
|
|
|
|
message.
|
|
|
|
|
|
2016-06-23 17:38:30 +08:00
|
|
|
|
2016-07-11 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c: made PR_DEBUG always defined.
|
|
|
|
|
|
Fixes done to TLS.
TLS relocations did not support multiple TLS modes for the same
symbol in a single object file.
Refactored how GOT and TLS is implemented. Removed code duplications between
local and global symbols conditioning.
bfd/ChangeLog:
2016-06-14 Cupertino Miranda <cmiranda@synopsys.com>
* arc-got.h: Moved got related structures from elf32-arc.c to
this file. More precisely, tls_type_e, tls_got_entries, got_entry.
* (arc_get_local_got_ents,
got_entry_for_type,
new_got_entry_to_list,
tls_type_for_reloc,
symbol_has_entry_of_type,
get_got_entry_list_for_symbol,
arc_got_entry_type_for_reloc,
ADD_SYMBOL_REF_SEC_AND_RELOC,
arc_fill_got_info_for_reloc,
relocate_fix_got_relocs_for_got_info,
create_got_dynrelocs_for_single_entry,
create_got_dynrelocs_for_got_info): Added to file.
* elf32-arc.c: Removed GOT & TLS related structs and functions to
arc-got.h.
Signed-off-by: Claudiu Zissulescu <claziss@synopsys.com>
2016-06-15 04:55:44 +08:00
|
|
|
|
2016-07-11 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* arc-got.h: Moved got related structures from elf32-arc.c to
|
|
|
|
|
this file. More precisely, tls_type_e, tls_got_entries, got_entry.
|
|
|
|
|
* (arc_get_local_got_ents, got_entry_for_type, new_got_entry_to_list,
|
|
|
|
|
tls_type_for_reloc, symbol_has_entry_of_type,
|
|
|
|
|
get_got_entry_list_for_symbol, arc_got_entry_type_for_reloc,
|
|
|
|
|
ADD_SYMBOL_REF_SEC_AND_RELOC, rc_fill_got_info_for_reloc,
|
|
|
|
|
relocate_fix_got_relocs_for_got_info,
|
|
|
|
|
create_got_dynrelocs_for_single_entry,
|
|
|
|
|
create_got_dynrelocs_for_got_info): Added to file.
|
|
|
|
|
* elf32-arc.c: Removed GOT & TLS related structs and functions to
|
|
|
|
|
arc-got.h.
|
|
|
|
|
|
2016-07-09 02:53:31 +08:00
|
|
|
|
2016-07-08 James Bowman <james.bowman@ftdichip.com>
|
|
|
|
|
|
|
|
|
|
* elf32-ft32.c (ft32_reloc_map): Use R_FT32_32 for BFD_RELOC_32.
|
|
|
|
|
|
2016-07-05 18:39:06 +08:00
|
|
|
|
2016-07-05 Andre Vieria <andre.simoesdiasvieira@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (THUMB32_MOVT): New veneer macro.
|
|
|
|
|
(THUMB32_MOVW): Likewise.
|
|
|
|
|
(elf32_arm_stub_long_branch_thumb2_only_pure): New.
|
|
|
|
|
(DEF_STUBS): Define long_branch_thumb2_only_pure.
|
|
|
|
|
(arm_stub_is_thumb): Add new veneer stub.
|
|
|
|
|
(arm_type_of_stub): Use new veneer.
|
|
|
|
|
(arm_stub_required_alignment): Add new veneer.
|
|
|
|
|
|
2016-07-05 18:28:46 +08:00
|
|
|
|
2016-07-05 Andre Vieria <andre.simoesdiasvieira@arm.com>
|
|
|
|
|
|
|
|
|
|
* bfd-in2.h (SEC_ELF_NOREAD): Rename to ...
|
|
|
|
|
(SEC_ELF_PURECODE): ... this.
|
|
|
|
|
* elf32-arm.c (elf32_arm_post_process_headers): Rename SEC_ELF_NOREAD
|
|
|
|
|
to SEC_ELF_NOREAD.
|
|
|
|
|
(elf32_arm_fake_sections): Likewise.
|
|
|
|
|
(elf_32_arm_section_flags): Likewise.
|
|
|
|
|
(elf_32_arm_lookup_section_flags): Likewise.
|
|
|
|
|
* section.c (SEC_ELF_NOREAD): Rename to ...
|
|
|
|
|
(SEC_ELF_PURECODE): ... this.
|
|
|
|
|
|
2016-07-01 23:13:25 +08:00
|
|
|
|
2016-07-01 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (using_thumb2_bl): New function.
|
|
|
|
|
(arm_type_of_stub): Declare thumb2 variable together and change type
|
|
|
|
|
to bfd_boolean. Use using_thumb2_bl () to determine whether
|
|
|
|
|
THM_MAX_FWD_BRANCH_OFFSET or THM2_MAX_FWD_BRANCH_OFFSET should be
|
|
|
|
|
checked for BL range.
|
|
|
|
|
(elf32_arm_final_link_relocate): Use using_thumb2_bl () to determine
|
|
|
|
|
the bit size of BL offset.
|
|
|
|
|
|
2016-06-29 18:17:40 +08:00
|
|
|
|
2016-06-29 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-aarch64.c (is_aarch64_mapping_symbol): New function.
|
|
|
|
|
Returns TRUE for AArch64 mapping symbols.
|
|
|
|
|
(elfNN_aarch64_backend_symbol_processing): New function. Marks
|
|
|
|
|
mapping symbols as precious in object files so that they will not
|
|
|
|
|
be stripped.
|
|
|
|
|
(elf_backend_symbol_processing): Define.
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (is_arm_mapping_symbol): New function. Returns TRUE
|
|
|
|
|
for ARM mapping symbols.
|
|
|
|
|
(elf32_arm_backend_symbol_processing): Make use of the new function.
|
|
|
|
|
|
2016-06-28 23:08:04 +08:00
|
|
|
|
2016-06-28 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20306
|
|
|
|
|
* elflink.c (elf_link_check_versioned_symbol): Return false
|
|
|
|
|
for unreferenced undefined symbol.
|
|
|
|
|
|
2016-06-28 20:22:49 +08:00
|
|
|
|
2016-06-28 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
2016-06-28 22:55:22 +08:00
|
|
|
|
* elf32-bfin.c (bfin_adjust_dynamic_symbol): Fail if a COPY reloc
|
|
|
|
|
is needed.
|
|
|
|
|
|
2016-06-28 20:22:49 +08:00
|
|
|
|
* elf32-arm.c (elf32_arm_backend_symbol_processing): New
|
|
|
|
|
function. Marks mapping symbols in object files as precious, so
|
|
|
|
|
that strip will not remove them.
|
|
|
|
|
(elf_backend_symbol_processing): Define.
|
|
|
|
|
|
2016-06-28 19:00:56 +08:00
|
|
|
|
2016-06-28 James Clarke <jrtc27@jrtc27.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-sparc.c (_bfd_sparc_elf_relocate_section): Don't convert
|
|
|
|
|
R_SPARC_32 to R_SPARC_RELATIVE if class is ELFCLASS64.
|
|
|
|
|
|
MIPS16: Add R_MIPS16_PC16_S1 branch relocation support
For R_MIPS16_PC16_S1 the calculation is `(sign_extend(A) + S - P) >> 1'
and the usual MIPS16 bit shuffling applies to relocated field handling,
as per the encoding of the branch target in the extended form of the
MIPS16 B, BEQZ, BNEZ, BTEQZ and BTNEZ instructions.
include/
* elf/mips.h (R_MIPS16_PC16_S1): New relocation.
bfd/
* elf32-mips.c (elf_mips16_howto_table_rel): Add
R_MIPS16_PC16_S1.
(mips16_reloc_map): Likewise.
* elf64-mips.c (mips16_elf64_howto_table_rel): Likewise.
(mips16_elf64_howto_table_rela): Likewise.
(mips16_reloc_map): Likewise.
* elfn32-mips.c (elf_mips16_howto_table_rel): Likewise.
(elf_mips16_howto_table_rela): Likewise.
(mips16_reloc_map): Likewise.
* elfxx-mips.c (mips16_branch_reloc_p): New function.
(mips16_reloc_p): Handle R_MIPS16_PC16_S1.
(b_reloc_p): Likewise.
(mips_elf_calculate_relocation): Likewise.
(_bfd_mips_elf_check_relocs): Likewise.
* reloc.c (BFD_RELOC_MIPS16_16_PCREL_S1): New relocation.
* bfd-in2.h: Regenerate.
* libbfd.h: Regenerate.
gas/
* config/tc-mips.c (mips16_reloc_p): Handle
BFD_RELOC_MIPS16_16_PCREL_S1.
(b_reloc_p): Likewise.
(limited_pcrel_reloc_p): Likewise.
(md_pcrel_from): Likewise.
(md_apply_fix): Likewise.
(tc_gen_reloc): Likewise.
(md_convert_frag): Likewise.
(mips_fix_adjustable): Update comment.
* testsuite/gas/mips/mips16-branch-reloc-2.d: Remove error
output, add dump patterns.
* testsuite/gas/mips/mips16-branch-reloc-3.d: Remove error
output, add dump patterns.
* testsuite/gas/mips/mips16-branch-addend-2.d: Remove error
output, add dump patterns.
* testsuite/gas/mips/mips16-branch-addend-3.d: Remove error
output, add dump patterns.
* testsuite/gas/mips/mips16-branch-absolute.d: Remove error
output, add dump patterns.
* testsuite/gas/mips/mips16-branch-reloc-2.l: Remove file.
* testsuite/gas/mips/mips16-branch-reloc-3.l: Remove file.
* testsuite/gas/mips/mips16-branch-addend-2.l: Remove file.
* testsuite/gas/mips/mips16-branch-addend-3.l: Remove file.
* testsuite/gas/mips/mips16-branch-absolute.l: Remove file.
* testsuite/gas/mips/mips16-branch-addend-2.s: Add padding.
* testsuite/gas/mips/branch-weak.s: Adjust alignment, avoid
implicit instruction padding, avoid MIPS16 JR->JRC conversion.
* testsuite/gas/mips/branch-weak-6.d: New test.
* testsuite/gas/mips/branch-weak-7.d: New test.
* testsuite/gas/mips/mips.exp: Run the new tests.
ld/
* testsuite/ld-mips-elf/mips16-branch-2.d: New test.
* testsuite/ld-mips-elf/mips16-branch-3.d: New test.
* testsuite/ld-mips-elf/mips16-branch-addend-2.d: New test.
* testsuite/ld-mips-elf/mips16-branch-addend-3.d: New test.
* testsuite/ld-mips-elf/mips16-branch.s: New test source.
* testsuite/ld-mips-elf/mips-elf.exp: Run the new tests.
2016-06-28 08:23:36 +08:00
|
|
|
|
2016-06-28 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elf32-mips.c (elf_mips16_howto_table_rel): Add
|
|
|
|
|
R_MIPS16_PC16_S1.
|
|
|
|
|
(mips16_reloc_map): Likewise.
|
|
|
|
|
* elf64-mips.c (mips16_elf64_howto_table_rel): Likewise.
|
|
|
|
|
(mips16_elf64_howto_table_rela): Likewise.
|
|
|
|
|
(mips16_reloc_map): Likewise.
|
|
|
|
|
* elfn32-mips.c (elf_mips16_howto_table_rel): Likewise.
|
|
|
|
|
(elf_mips16_howto_table_rela): Likewise.
|
|
|
|
|
(mips16_reloc_map): Likewise.
|
|
|
|
|
* elfxx-mips.c (mips16_branch_reloc_p): New function.
|
|
|
|
|
(mips16_reloc_p): Handle R_MIPS16_PC16_S1.
|
|
|
|
|
(b_reloc_p): Likewise.
|
|
|
|
|
(mips_elf_calculate_relocation): Likewise.
|
|
|
|
|
(_bfd_mips_elf_check_relocs): Likewise.
|
|
|
|
|
* reloc.c (BFD_RELOC_MIPS16_16_PCREL_S1): New relocation.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* libbfd.h: Regenerate.
|
|
|
|
|
|
2016-06-27 18:30:09 +08:00
|
|
|
|
2016-06-27 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19264
|
|
|
|
|
* elf64-ppc.c (STUB_SHRINK_ITER): Define.
|
|
|
|
|
(ppc64_elf_size_stubs): Exit stub sizing loop past STUB_SHRINK_ITER
|
|
|
|
|
if shrinking stubs.
|
|
|
|
|
(ppc64_elf_size_stubs): Adjust to suit.
|
|
|
|
|
|
2016-06-27 18:01:34 +08:00
|
|
|
|
2016-06-27 Trevor Saunders <tbsaunde+binutils@tbsaunde.org>
|
|
|
|
|
|
|
|
|
|
* elf32-dlx.h: New file.
|
|
|
|
|
* elf32-dlx.c: Adjust.
|
|
|
|
|
|
2016-06-05 04:46:58 +08:00
|
|
|
|
2016-06-25 Trevor Saunders <tbsaunde+binutils@tbsaunde.org>
|
|
|
|
|
|
|
|
|
|
* elf32-xtensa.c (xtensa_make_property_section): Remove prototype.
|
|
|
|
|
|
2016-06-13 03:34:51 +08:00
|
|
|
|
2016-06-24 John Baldwin <jhb@FreeBSD.org>
|
|
|
|
|
|
|
|
|
|
* elf.c (elfcore_grok_freebsd_note): Handle NT_FREEBSD_PROCSTAT_AUXV
|
|
|
|
|
notes.
|
|
|
|
|
|
2016-06-12 23:56:31 +08:00
|
|
|
|
2016-06-24 John Baldwin <jhb@FreeBSD.org>
|
|
|
|
|
|
|
|
|
|
* elf.c (elfcore_grok_note): Remove handling of NT_X86_XSTATE for
|
|
|
|
|
FreeBSD. Remove case for NT_FREEBSD_THRMISC.
|
|
|
|
|
(elfcore_grok_freebsd_psinfo): New function.
|
|
|
|
|
(elfcore_grok_freebsd_prstatus): New function.
|
|
|
|
|
(elfcore_grok_freebsd_note): New function.
|
|
|
|
|
(elf_parse_notes): Use "elfcore_grok_freebsd_note" for "FreeBSD"
|
|
|
|
|
notes.
|
|
|
|
|
|
2016-06-25 01:04:56 +08:00
|
|
|
|
2016-06-24 Joel Brobecker <brobecker@adacore.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c: Check the value of BFD_SUPPORTS_PLUGINS rather
|
|
|
|
|
than its existance.
|
|
|
|
|
|
2016-06-23 20:41:57 +08:00
|
|
|
|
2016-06-24 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* config.bfd: Delete mips vxworks patterns matched earlier.
|
|
|
|
|
Combine mips*-*-none with mips*-*-elf*.
|
|
|
|
|
|
2016-06-21 21:06:27 +08:00
|
|
|
|
2016-06-21 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_perform_relocation): Call
|
|
|
|
|
`info->callbacks->einfo' rather than `*_bfd_error_handler' and
|
|
|
|
|
use the `%X%H' format for the cross-mode jump conversion error
|
|
|
|
|
message. Remove the full stop from the end of the message.
|
|
|
|
|
Continue processing rather than returning failure.
|
|
|
|
|
|
2016-06-21 21:03:08 +08:00
|
|
|
|
2016-06-21 Graham Markall <graham.markall@embecosm.com>
|
|
|
|
|
|
|
|
|
|
* archures.c: Remove bfd_mach_arc_nps400.
|
|
|
|
|
* bfd-in2.h: Likewise.
|
|
|
|
|
* cpu-arc.c (arch_info_struct): Likewise.
|
|
|
|
|
* elf32-arc.c (arc_elf_object_p, arc_elf_final_write_processing):
|
|
|
|
|
Likewise.
|
|
|
|
|
|
2016-06-20 20:10:29 +08:00
|
|
|
|
2016-06-20 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/18250
|
|
|
|
|
PR ld/20267
|
|
|
|
|
* elflink.c: Include plugin.h if BFD_SUPPORTS_PLUGINS is
|
|
|
|
|
defined.
|
|
|
|
|
(elf_link_is_defined_archive_symbol): Call
|
|
|
|
|
bfd_link_plugin_object_p on unknown plugin object and use the
|
|
|
|
|
IR symbol table if the input is an IR object.
|
|
|
|
|
* plugin.c (bfd_link_plugin_object_p): New function.
|
|
|
|
|
* plugin.h (bfd_link_plugin_object_p): New prototype.
|
|
|
|
|
|
2016-06-20 08:23:50 +08:00
|
|
|
|
2016-06-20 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20276
|
|
|
|
|
* elflink.c (elf_link_add_object_symbols): Don't check alignment
|
|
|
|
|
on symbol from plugin dummy input.
|
|
|
|
|
|
2016-06-19 05:15:31 +08:00
|
|
|
|
2016-06-18 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* bfd.c (bfd_plugin_format): Rename bfd_plugin_uknown to
|
|
|
|
|
bfd_plugin_unknown.
|
|
|
|
|
* bfd-in2.h: Regenerated.
|
|
|
|
|
* plugin.c (bfd_plugin_object_p): Replace bfd_plugin_uknown
|
|
|
|
|
with bfd_plugin_unknown.
|
|
|
|
|
|
2016-06-19 00:16:52 +08:00
|
|
|
|
2016-06-18 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20253
|
|
|
|
|
* elf-bfd.h (_bfd_elf_allocate_ifunc_dyn_relocs): Add an
|
|
|
|
|
bfd_boolean argument.
|
|
|
|
|
* elf-ifunc.c (_bfd_elf_create_ifunc_sections): Replace
|
|
|
|
|
"shared object" with "PIC object" in comments.
|
|
|
|
|
(_bfd_elf_allocate_ifunc_dyn_relocs): Updated. Replace
|
|
|
|
|
"shared object" with "PIC object" in comments. Avoid PLT if
|
|
|
|
|
requested. Generate dynamic relocations for non-GOT references.
|
|
|
|
|
Make room for the special first entry in PLT and allocate PLT
|
|
|
|
|
entry only for PLT and PC-relative references. Store dynamic
|
|
|
|
|
GOT relocations in .rel[a].iplt section for static executables.
|
|
|
|
|
If PLT isn't used, always use GOT for symbol value. Don't
|
|
|
|
|
allocate GOT entry if it isn't used.
|
|
|
|
|
* elf32-i386.c (elf_i386_check_relocs): Increment PLT reference
|
|
|
|
|
count only in the code section. Allocate dynamic pointer
|
|
|
|
|
relocation against STT_GNU_IFUNC symbol in the non-code section.
|
|
|
|
|
(elf_i386_adjust_dynamic_symbol): Increment PLT reference count
|
|
|
|
|
only for PC-relative references.
|
|
|
|
|
(elf_i386_allocate_dynrelocs): Pass TRUE to
|
|
|
|
|
_bfd_elf_allocate_ifunc_dyn_relocs.
|
|
|
|
|
(elf_i386_relocate_section): Allow R_386_GOT32/R_386_GOT32X
|
|
|
|
|
relocations against STT_GNU_IFUNC symbols without PLT. Generate
|
|
|
|
|
dynamic pointer relocation against STT_GNU_IFUNC symbol in
|
|
|
|
|
the non-code section and store it in the proper REL section.
|
|
|
|
|
Don't allow non-pointer relocation against STT_GNU_IFUNC symbol
|
|
|
|
|
without PLT.
|
|
|
|
|
(elf_i386_finish_dynamic_symbol): Generate dynamic
|
|
|
|
|
R_386_IRELATIVE and R_386_GLOB_DAT GOT relocations against
|
|
|
|
|
STT_GNU_IFUNC symbols without PLT.
|
|
|
|
|
(elf_i386_finish_dynamic_sections): Don't handle local
|
|
|
|
|
STT_GNU_IFUNC symbols here.
|
|
|
|
|
(elf_i386_output_arch_local_syms): Handle local STT_GNU_IFUNC
|
|
|
|
|
symbols here.
|
|
|
|
|
(elf_backend_output_arch_local_syms): New.
|
|
|
|
|
* elf32-x86-64.c (elf_i386_check_relocs): Increment PLT reference
|
|
|
|
|
count only in the code section. Allocate dynamic pointer
|
|
|
|
|
relocation against STT_GNU_IFUNC symbol in the non-code section.
|
|
|
|
|
(elf_x86_64_adjust_dynamic_symbol): Increment PLT reference
|
|
|
|
|
count only for PC-relative references.
|
|
|
|
|
(elf_x86_64_allocate_dynrelocs): Pass TRUE to
|
|
|
|
|
_bfd_elf_allocate_ifunc_dyn_relocs.
|
|
|
|
|
(elf_x86_64_relocate_section): Allow R_X86_64_GOTPCREL,
|
|
|
|
|
R_X86_64_GOTPCRELX, R_X86_64_REX_GOTPCRELX and
|
|
|
|
|
R_X86_64_GOTPCREL64 relocations against STT_GNU_IFUNC symbols
|
|
|
|
|
without PLT. Generate dynamic pointer relocation against
|
|
|
|
|
STT_GNU_IFUNC symbol in the non-code section and store it in
|
|
|
|
|
the proper RELA section. Don't allow non-pointer relocation
|
|
|
|
|
against STT_GNU_IFUNC symbol without PLT.
|
|
|
|
|
(elf_x86_64_finish_dynamic_symbol): Generate dynamic
|
|
|
|
|
R_X86_64_IRELATIVE and R_X86_64_GLOB_DAT GOT relocations against
|
|
|
|
|
STT_GNU_IFUNC symbols without PLT.
|
|
|
|
|
(elf_x86_64_finish_dynamic_sections): Don't handle local
|
|
|
|
|
STT_GNU_IFUNC symbols here.
|
|
|
|
|
(elf_x86_64_output_arch_local_syms): Handle local STT_GNU_IFUNC
|
|
|
|
|
symbols here.
|
|
|
|
|
(elf_backend_output_arch_local_syms): New.
|
|
|
|
|
* elfnn-aarch64.c (elfNN_aarch64_allocate_ifunc_dynrelocs):
|
|
|
|
|
Pass FALSE to _bfd_elf_allocate_ifunc_dyn_relocs.
|
|
|
|
|
|
2016-06-18 01:26:08 +08:00
|
|
|
|
2016-06-17 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
Tony Wang <tony.wang@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (elf32_arm_stub_long_branch_thumb2_only): Define stub
|
|
|
|
|
sequence.
|
|
|
|
|
(stub_long_branch_thumb2_only): Define stub.
|
|
|
|
|
(arm_stub_is_thumb): Add case for arm_stub_long_branch_thumb2_only.
|
|
|
|
|
(arm_stub_long_branch_thumb2_only): Likewise.
|
|
|
|
|
(arm_type_of_stub): Use arm_stub_long_branch_thumb2_only for Thumb-2
|
|
|
|
|
capable targets.
|
|
|
|
|
|
bfd,opcodes: sparc: new opcode v9{c,d,e,v,m} architectures and bfd machine numbers.
This patch adds support for the opcode architectures
SPARC_OPCODE_ARCH_V9{C,D,E,V,M} and its associated BFD machine numbers
bfd_mach_sparc_v9{c,d,e,v,m} and bfd_mach_sparc_v8plus{c,d,e,v,m}.
Note that for arches up to v9b (UltraSPARC III), the detection of the
BFD machine type was based on the bits in the e_machine field of the ELF
header. However, there are no more available bits in that field, so
this patch takes the approach of using the hardware capabilities stored
in the object attributes HWCAPS/HWCAPS2 in order to characterize the
machine the object was built for.
bfd/ChangeLog:
2016-06-17 Jose E. Marchesi <jose.marchesi@oracle.com>
* archures.c (bfd_mach_sparc_v8plusc): Define.
(bfd_mach_sparc_v9c): Likewise.
(bfd_mach_sparc_v8plusd): Likewise.
(bfd_mach_sparc_v9d): Likewise.
(bfd_mach_sparc_v8pluse): Likewise.
(bfd_mach_sparc_v9e): Likewise.
(bfd_mach_sparc_v8plusv): Likewise
(bfd_mach_sparc_v9v): Likewise.
(bfd_mach_sparc_v8plusm): Likewise.
(bfd_mach_sparc_v9m): Likewise.
(bfd_mach_sparc_v9_p): Adapt to v8plusm and v9m.
(bfd_mach_sparc_64bit_p): Likewise.
* bfd-in2.h: Regenerate.
* cpu-sparc.c (arch_info_struct): Add entries for
bfd_mach_sparc_v8plus{c,d,e,v,m} and bfd_mach_sparc_v9{c,d,e,v,m}.
* aoutx.h (machine_type): Handle bfd_mach_sparc_v8plus{c,d,e,v,m}
and bfd_mach_sparc_v9{c,d,e,v,m}.
* elf32-sparc.c (elf32_sparc_final_write_processing): Likewise.
* elfxx-sparc.c (_bfd_sparc_elf_object_p): Likewise.
include/ChangeLog:
2016-06-17 Jose E. Marchesi <jose.marchesi@oracle.com>
* opcode/sparc.h (enum sparc_opcode_arch_val): Add
SPARC_OPCODE_ARCH_V9C, SPARC_OPCODE_ARCH_V9D,
SPARC_OPCODE_ARCH_V9E, SPARC_OPCODE_ARCH_V9V and
SPARC_OPCODE_ARCH_V9M.
opcodes/ChangeLog:
2016-06-17 Jose E. Marchesi <jose.marchesi@oracle.com>
* sparc-dis.c (MASK_V9): Add SPARC_OPCODE_ARCH_V9{C,D,E,V,M}.
(compute_arch_mask): Handle bfd_mach_sparc_v8plus{c,d,e,v,m} and
bfd_mach_sparc_v9{c,d,e,v,m}.
* sparc-opc.c (MASK_V9C): Define.
(MASK_V9D): Likewise.
(MASK_V9E): Likewise.
(MASK_V9V): Likewise.
(MASK_V9M): Likewise.
(v6): Add MASK_V9{C,D,E,V,M}.
(v6notlet): Likewise.
(v7): Likewise.
(v8): Likewise.
(v9): Likewise.
(v9andleon): Likewise.
(v9a): Likewise.
(v9b): Likewise.
(v9c): Define.
(v9d): Likewise.
(v9e): Likewise.
(v9v): Likewise.
(v9m): Likewise.
(sparc_opcode_archs): Add entry for v9{c,d,e,v,m}.
2016-06-17 17:12:48 +08:00
|
|
|
|
2016-06-17 Jose E. Marchesi <jose.marchesi@oracle.com>
|
|
|
|
|
|
|
|
|
|
* archures.c (bfd_mach_sparc_v8plusc): Define.
|
|
|
|
|
(bfd_mach_sparc_v9c): Likewise.
|
|
|
|
|
(bfd_mach_sparc_v8plusd): Likewise.
|
|
|
|
|
(bfd_mach_sparc_v9d): Likewise.
|
|
|
|
|
(bfd_mach_sparc_v8pluse): Likewise.
|
|
|
|
|
(bfd_mach_sparc_v9e): Likewise.
|
|
|
|
|
(bfd_mach_sparc_v8plusv): Likewise
|
|
|
|
|
(bfd_mach_sparc_v9v): Likewise.
|
|
|
|
|
(bfd_mach_sparc_v8plusm): Likewise.
|
|
|
|
|
(bfd_mach_sparc_v9m): Likewise.
|
|
|
|
|
(bfd_mach_sparc_v9_p): Adapt to v8plusm and v9m.
|
|
|
|
|
(bfd_mach_sparc_64bit_p): Likewise.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* cpu-sparc.c (arch_info_struct): Add entries for
|
|
|
|
|
bfd_mach_sparc_v8plus{c,d,e,v,m} and bfd_mach_sparc_v9{c,d,e,v,m}.
|
|
|
|
|
* aoutx.h (machine_type): Handle bfd_mach_sparc_v8plus{c,d,e,v,m}
|
|
|
|
|
and bfd_mach_sparc_v9{c,d,e,v,m}.
|
|
|
|
|
* elf32-sparc.c (elf32_sparc_final_write_processing): Likewise.
|
|
|
|
|
* elfxx-sparc.c (_bfd_sparc_elf_object_p): Likewise.
|
|
|
|
|
|
2016-06-17 03:38:34 +08:00
|
|
|
|
2016-06-16 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_check_relocs): Don't check undefined
|
|
|
|
|
symbols for relocations against IFUNC symbols.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_check_relocs): Likewise.
|
|
|
|
|
|
2016-06-08 20:01:31 +08:00
|
|
|
|
2016-06-16 Marcin Kościelnicki <koriakin@0x04.net>
|
|
|
|
|
|
|
|
|
|
* elf32-s390.c (elf_s390_finish_dynamic_sections): Include
|
|
|
|
|
.rela.iplt in DT_PLTRELSZ.
|
|
|
|
|
* elf64-s390.c (elf_s390_finish_dynamic_sections): Likewise,
|
|
|
|
|
for DT_PLTRELSZ and DT_RELASZ as well.
|
|
|
|
|
|
2016-06-16 20:52:34 +08:00
|
|
|
|
2016-06-16 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_check_relocs): Skip relocations in
|
|
|
|
|
non-loaded, non-alloced sections.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_check_relocs): Likewise.
|
|
|
|
|
|
2016-06-16 09:42:56 +08:00
|
|
|
|
2016-06-15 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_check_relocs): Check SEC_ALLOC before
|
|
|
|
|
allocating dynamic relocation.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_check_relocs): Likewise.
|
|
|
|
|
|
2016-06-15 14:55:30 +08:00
|
|
|
|
2016-06-14 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20254
|
|
|
|
|
* elf32-avr.c (elf32_avr_relax_delete_bytes): Adjust reloc
|
|
|
|
|
offsets until reloc_toaddr.
|
|
|
|
|
|
2016-06-15 01:18:26 +08:00
|
|
|
|
2016-06-14 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_reloc_type_class): Check R_386_IRELATIVE.
|
|
|
|
|
Don't check symbol type for STN_UNDEF symbol index.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_reloc_type_class): Check
|
|
|
|
|
R_X86_64_IRELATIVE. Don't check symbol type for STN_UNDEF symbol
|
|
|
|
|
index.
|
|
|
|
|
|
2016-06-14 19:02:53 +08:00
|
|
|
|
2016-06-14 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (using_thumb_only): Force review of arch check logic for
|
|
|
|
|
new architecture.
|
|
|
|
|
(using_thumb2): Try Tag_THUMB_ISA_use first and check
|
|
|
|
|
for exact arch value then. Force review of arch check logic for new
|
|
|
|
|
architecture.
|
|
|
|
|
(arch_has_arm_nop): Update and fix arch check logic. Force review of
|
|
|
|
|
that logic for new architecture.
|
|
|
|
|
(arch_has_thumb2_nop): Remove.
|
|
|
|
|
(elf32_arm_tls_relax): Use using_thumb2 instead of above function.
|
|
|
|
|
(elf32_arm_final_link_relocate): Likewise but using thumb2.
|
|
|
|
|
|
2016-06-14 11:54:37 +08:00
|
|
|
|
2016-06-14 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* bfd-in.h (bfd_my_archive): Delete.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
|
2016-06-14 11:42:00 +08:00
|
|
|
|
2016-06-14 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20241
|
|
|
|
|
* archive.c (open_nested_file): Set my_archive.
|
|
|
|
|
* bfd.c (_bfd_default_error_handler <%B>): Exclude archive file name
|
|
|
|
|
for thin archives.
|
|
|
|
|
* bfdio.c (bfd_tell): Don't adjust origin for thin archives.
|
|
|
|
|
(bfd_seek): Likewise.
|
|
|
|
|
* bfdwin.c (bfd_get_file_window): Likewise.
|
|
|
|
|
* cache.c (cache_bmmap): Likewise.
|
|
|
|
|
(bfd_cache_lookup_worker): Don't look in my_archive for thin archives.
|
|
|
|
|
* mach-o.c (bfd_mach_o_follow_dsym): Don't open my_archive for
|
|
|
|
|
thin archives.
|
|
|
|
|
* plugin.c (try_claim): Likewise.
|
|
|
|
|
* xcofflink.c (xcoff_link_add_dynamic_symbols): Use import path of
|
|
|
|
|
file within thin archive, not the archive.
|
|
|
|
|
|
2016-06-14 02:06:10 +08:00
|
|
|
|
2016-06-13 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20244
|
|
|
|
|
* elf32-i386.c (elf_i386_relocate_section): Add the .got.plt
|
|
|
|
|
section address for R_386_GOT32/R_386_GOT32X relocations against
|
|
|
|
|
IFUNC symbols if there is no base register and return error for
|
|
|
|
|
PIC.
|
|
|
|
|
|
2016-06-14 00:27:12 +08:00
|
|
|
|
2016-06-13 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_relocate_section): Simplify IFUNC
|
|
|
|
|
GOT32 adjustment for static executables.
|
|
|
|
|
|
2016-06-13 23:29:00 +08:00
|
|
|
|
2016-06-13 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elf32-mips.c (elf_mips_gnu_pcrel32): Update comment.
|
|
|
|
|
|
2016-06-13 23:44:48 +08:00
|
|
|
|
2016-06-13 Cupertino Miranda <cmiranda@synospsy.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf_arc_relocate_section): Fixed condition.
|
|
|
|
|
|
2016-05-26 22:00:08 +08:00
|
|
|
|
2016-06-13 Cupertino Miranda <cmiranda@synospsy.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf_arc_finish_dynamic_sections): Changed.
|
|
|
|
|
|
2016-05-20 18:06:17 +08:00
|
|
|
|
2016-06-13 Cupertino Miranda <cmiranda@synospsy.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (arc_local_data, arc_local_data): Removed.
|
|
|
|
|
(SECTSTART): Changed.
|
|
|
|
|
(elf_arc_relocate_section): Fixed mistake in PIE related
|
|
|
|
|
condition.
|
|
|
|
|
(elf_arc_size_dynamic_sections): Changed DT_RELENT to DT_RELAENT.
|
|
|
|
|
|
2016-05-17 18:15:41 +08:00
|
|
|
|
2016-06-13 Cupertino Miranda <cmiranda@synospsy.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf32_arc_reloc_type_class): Defined function to
|
|
|
|
|
enable support for "-z combreloc" and DT_RELACOUNT.
|
|
|
|
|
(elf_backend_reloc_type_class): Likewise
|
|
|
|
|
|
2016-06-12 11:44:24 +08:00
|
|
|
|
2016-06-11 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20244
|
|
|
|
|
* elf32-i386.c (elf_i386_relocate_section): When relocating
|
|
|
|
|
R_386_GOT32, return error without a base register for PIC and
|
|
|
|
|
subtract the .got.plt section address only with a base register.
|
|
|
|
|
|
2016-06-11 15:52:55 +08:00
|
|
|
|
2016-06-10 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf-strtab.c (struct strtab_save): Use size_t for "size".
|
|
|
|
|
(struct elf_strtab_hash): Likewise for "size" and "alloced".
|
|
|
|
|
(_bfd_elf_strtab_init): Formatting.
|
|
|
|
|
(_bfd_elf_strtab_add): Return size_t rather than bfd_size_type.
|
|
|
|
|
(_bfd_elf_strtab_addref): Take size_t idx param.
|
|
|
|
|
(_bfd_elf_strtab_delref, _bfd_elf_strtab_refcount): Likewise.
|
|
|
|
|
(_bfd_elf_strtab_offset): Likewise.
|
|
|
|
|
(_bfd_elf_strtab_clear_all_refs): Use size_t idx.
|
|
|
|
|
(_bfd_elf_strtab_save): Use size_t "idx" and "size" vars.
|
|
|
|
|
(_bfd_elf_strtab_restore, _bfd_elf_strtab_emit): Similarly.
|
|
|
|
|
(_bfd_elf_strtab_finalize): Similarly.
|
|
|
|
|
* elf-bfd.h (_bfd_elf_strtab_add): Update prototypes.
|
|
|
|
|
(_bfd_elf_strtab_addref, _bfd_elf_strtab_delref): Likewise.
|
|
|
|
|
(_bfd_elf_strtab_refcount, _bfd_elf_strtab_offset): Likewise.
|
|
|
|
|
* elf.c (bfd_elf_get_elf_syms): Calculate symbol buffer size
|
|
|
|
|
using bfd_size_type.
|
|
|
|
|
(bfd_section_from_shdr): Delete amt.
|
|
|
|
|
(_bfd_elf_init_reloc_shdr): Likewise.
|
|
|
|
|
(_bfd_elf_link_assign_sym_version): Likewise.
|
|
|
|
|
(assign_section_numbers): Use size_t reloc_count.
|
|
|
|
|
* elflink.c (struct elf_symbuf_head): Use size_t "count".
|
|
|
|
|
(bfd_elf_link_record_dynamic_symbol): Use size_t for some vars.
|
|
|
|
|
(elf_link_is_defined_archive_symbol): Likewise.
|
|
|
|
|
(elf_add_dt_needed_tag): Likewise.
|
|
|
|
|
(elf_finalize_dynstr): Likewise.
|
|
|
|
|
(elf_link_add_object_symbols): Likewise.
|
|
|
|
|
(bfd_elf_size_dynamic_sections): Likewise.
|
|
|
|
|
(elf_create_symbuf): Similarly.
|
|
|
|
|
(bfd_elf_match_symbols_in_sections): Likewise.
|
|
|
|
|
(elf_link_swap_symbols_out): Likewise.
|
|
|
|
|
(elf_link_check_versioned_symbol): Likewise.
|
|
|
|
|
(bfd_elf_gc_record_vtinherit): Likewise.
|
|
|
|
|
(bfd_elf_gc_common_finalize_got_offsets): Likewise.
|
|
|
|
|
|
2016-06-10 00:17:43 +08:00
|
|
|
|
2016-06-08 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20221
|
|
|
|
|
* elf32-avr.c (elf32_avr_relax_delete_bytes): Adjust syms
|
|
|
|
|
and relocs only if shrinking occurred.
|
|
|
|
|
|
Support i386 TLS code sequences without PLT
We can generate i386 TLS code sequences for general and local dynamic
models without PLT, which uses indirect call via GOT:
call *___tls_get_addr@GOT(%reg)
where EBX register isn't required as GOT base, instead of direct call:
call ___tls_get_addr[@PLT]
which requires EBX register as GOT base.
Since direct call is 4-byte long and indirect call, is 5-byte long, the
extra one byte must be handled properly.
For general dynamic model, 7-byte lea instruction before call instruction
is replaced by 6-byte one to make room for indirect call. For local
dynamic model, we simply use 5-byte indirect call.
TLS linker optimization is updated to recognize new instruction patterns.
For local dynamic model to local exec model transition, we generate
a 6-byte lea instruction as nop, instead of a 1-byte nop plus a 4-byte
lea instruction. Since linker may convert
call ___tls_get_addr[@PLT]
to
addr32 call ____tls_get_addr
when producing static executable, both patterns are recognized.
bfd/
* elf64-i386.c (elf_i386_link_hash_entry): Add tls_get_addr.
(elf_i386_link_hash_newfunc): Initialize tls_get_addr to 2.
(elf_i386_check_tls_transition): Check indirect call and direct
call with the addr32 prefix for general and local dynamic models.
Set the tls_get_addr feild.
(elf_i386_convert_load_reloc): Always use addr32 prefix for
indirect ___tls_get_addr call via GOT.
(elf_i386_relocate_section): Handle GD->LE, GD->IE and LD->LE
transitions with indirect call and direct call with the addr32
prefix.
ld/
* testsuite/ld-i386/i386.exp: Run libtlspic2.so, tlsbin2,
tlsgd3, tlsld2, tlsgd4, tlspie3a, tlspie3b and tlspie3c.
* testsuite/ld-i386/pass.out: New file.
* testsuite/ld-i386/tls-def1.c: Likewise.
* testsuite/ld-i386/tls-gd1.S: Likewise.
* testsuite/ld-i386/tls-ld1.S: Likewise.
* testsuite/ld-i386/tls-main1.c: Likewise.
* testsuite/ld-i386/tls.exp: Likewise.
* testsuite/ld-i386/tlsbin2-nacl.rd: Likewise.
* testsuite/ld-i386/tlsbin2.dd: Likewise.
* testsuite/ld-i386/tlsbin2.rd: Likewise.
* testsuite/ld-i386/tlsbin2.sd: Likewise.
* testsuite/ld-i386/tlsbin2.td: Likewise.
* testsuite/ld-i386/tlsbinpic2.s: Likewise.
* testsuite/ld-i386/tlsgd3.dd: Likewise.
* testsuite/ld-i386/tlsgd3.s: Likewise.
* testsuite/ld-i386/tlsgd4.d: Likewise.
* testsuite/ld-i386/tlsgd4.s: Likewise.
* testsuite/ld-i386/tlsld2.s: Likewise.
* testsuite/ld-i386/tlspic2-nacl.rd: Likewise.
* testsuite/ld-i386/tlspic2.dd: Likewise.
* testsuite/ld-i386/tlspic2.rd: Likewise.
* testsuite/ld-i386/tlspic2.sd: Likewise.
* testsuite/ld-i386/tlspic2.td: Likewise.
* testsuite/ld-i386/tlspic3.s: Likewise.
* testsuite/ld-i386/tlspie3.s: Likewise.
* testsuite/ld-i386/tlspie3a.d: Likewise.
* testsuite/ld-i386/tlspie3b.d: Likewise.
* testsuite/ld-i386/tlspie3c.d: Likewise.
2016-06-09 02:59:47 +08:00
|
|
|
|
2016-06-08 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf64-i386.c (elf_i386_link_hash_entry): Add tls_get_addr.
|
|
|
|
|
(elf_i386_link_hash_newfunc): Initialize tls_get_addr to 2.
|
|
|
|
|
(elf_i386_check_tls_transition): Check indirect call and direct
|
|
|
|
|
call with the addr32 prefix for general and local dynamic models.
|
|
|
|
|
Set the tls_get_addr feild.
|
|
|
|
|
(elf_i386_convert_load_reloc): Always use addr32 prefix for
|
|
|
|
|
indirect ___tls_get_addr call via GOT.
|
|
|
|
|
(elf_i386_relocate_section): Handle GD->LE, GD->IE and LD->LE
|
|
|
|
|
transitions with indirect call and direct call with the addr32
|
|
|
|
|
prefix.
|
|
|
|
|
|
2016-06-03 22:39:15 +08:00
|
|
|
|
2016-06-07 Marcin Kościelnicki <koriakin@0x04.net>
|
|
|
|
|
|
|
|
|
|
* elf32-s390.c (elf_s390_finish_dynamic_symbol): Fix comment.
|
|
|
|
|
* elf64-s390.c (elf_s390x_plt_entry): Fix comment.
|
|
|
|
|
(elf_s390_relocate_section): Fix comment.
|
|
|
|
|
(elf_s390_finish_dynamic_sections): Fix initialization of fixed
|
|
|
|
|
.got.plt entries.
|
|
|
|
|
|
2016-06-07 22:45:15 +08:00
|
|
|
|
2016-06-07 Ulrich Weigand <ulrich.weigand@de.ibm.com>
|
|
|
|
|
|
|
|
|
|
* elf64-s390.c (elf_s390_finish_dynamic_sections): Subtract plt
|
|
|
|
|
section offset when calculation the larl operand in the first PLT
|
|
|
|
|
entry.
|
|
|
|
|
|
PowerPC VLE
VLE is an encoding, not a particular processor architecture, so it
isn't really proper to select insns based on PPC_OPCODE_VLE. For
example
{"evaddw", VX (4, 512), VX_MASK, PPCSPE|PPCVLE, PPCNONE, {RS, RA, RB}},
{"vaddubs", VX (4, 512), VX_MASK, PPCVEC|PPCVLE, PPCNONE, {VD, VA, VB}},
shows two insns that have the same encoding, both available with VLE.
Enabling both with VLE means we can't disassemble the second variant
even if -Maltivec is given rather than -Mspe. Also, we don't check
user assembly against the processor type as well as we could.
Another problem is that when using the VLE encoding, insns from the
main ppc opcode table are not available, except those using opcode 4
and 31. Correcting this revealed two errors in the ld testsuite,
use of "nop" and "rfmci" when -mvle.
This patch fixes those problems in the opcode table, and removes
PPCNONE. I find a plain 0 distracts less from other values.
In addition, I've implemented code to recognize some machine values
from the apuinfo note present in ppc32 objects. It's not a complete
disambiguation since we're lacking info to detect newer chips, but
what we have should help with disassembly.
include/
* elf/ppc.h (APUINFO_SECTION_NAME, APUINFO_LABEL, PPC_APUINFO_ISEL,
PPC_APUINFO_PMR, PPC_APUINFO_RFMCI, PPC_APUINFO_CACHELCK,
PPC_APUINFO_SPE, PPC_APUINFO_EFS, PPC_APUINFO_BRLOCK,
PPC_APUINFO_VLE: Define.
opcodes/
* ppc-dis.c (ppc_opts): Delete extraneous parentheses. Default
cpu for "vle" to e500.
* ppc-opc.c (ALLOW8_SPRG): Remove PPC_OPCODE_VLE.
(NO371, PPCSPE, PPCISEL, PPCEFS, MULHW, DCBT_EO): Likewise.
(PPCNONE): Delete, substitute throughout.
(powerpc_opcodes): Remove PPCVLE from "flags". Add to "deprecated"
except for major opcode 4 and 31.
(vle_opcodes <se_rfmci>): Add PPCRFMCI to flags.
bfd/
* cpu-powerpc.c (powerpc_compatible): Allow bfd_mach_ppc_vle entry
to match other 32-bit archs.
* elf32-ppc.c (_bfd_elf_ppc_set_arch): New function.
(ppc_elf_object_p): Call it.
(ppc_elf_special_sections): Use APUINFO_SECTION_NAME. Fix
overlong line.
(APUINFO_SECTION_NAME, APUINFO_LABEL): Don't define here.
* elf64-ppc.c (ppc64_elf_object_p): Call _bfd_elf_ppc_set_arch.
* bfd-in.h (_bfd_elf_ppc_at_tls_transform,
_bfd_elf_ppc_at_tprel_transform): Move to..
* elf-bfd.h: ..here.
(_bfd_elf_ppc_set_arch): Declare.
* bfd-in2.h: Regenerate.
gas/
* config/tc-ppc.c (PPC_APUINFO_ISEL, PPC_APUINFO_PMR,
PPC_APUINFO_RFMCI, PPC_APUINFO_CACHELCK, PPC_APUINFO_SPE,
PPC_APUINFO_EFS, PPC_APUINFO_BRLOCK, PPC_APUINFO_VLE): Don't define.
(ppc_setup_opcodes): Check vle disables powerpc_opcodes overridden
by vle_opcodes, and that vle flag doesn't enable opcodes. Don't
add vle_opcodes twice.
(ppc_cleanup): Use APUINFO_SECTION_NAME and APUINFO_LABEL.
ld/
* testsuite/ld-powerpc/apuinfo1.s: Delete nop.
* testsuite/ld-powerpc/apuinfo-vle2.s: New.
* testsuite/ld-powerpc/powerpc.exp: Use apuinfo-vle2.s.
2016-06-07 20:34:38 +08:00
|
|
|
|
2016-06-07 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* cpu-powerpc.c (powerpc_compatible): Allow bfd_mach_ppc_vle entry
|
|
|
|
|
to match other 32-bit archs.
|
|
|
|
|
* elf32-ppc.c (_bfd_elf_ppc_set_arch): New function.
|
|
|
|
|
(ppc_elf_object_p): Call it.
|
|
|
|
|
(ppc_elf_special_sections): Use APUINFO_SECTION_NAME. Fix
|
|
|
|
|
overlong line.
|
|
|
|
|
(APUINFO_SECTION_NAME, APUINFO_LABEL): Don't define here.
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_object_p): Call _bfd_elf_ppc_set_arch.
|
|
|
|
|
* bfd-in.h (_bfd_elf_ppc_at_tls_transform,
|
|
|
|
|
_bfd_elf_ppc_at_tprel_transform): Move to..
|
|
|
|
|
* elf-bfd.h: ..here.
|
|
|
|
|
(_bfd_elf_ppc_set_arch): Declare.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
|
Support x86-64 TLS code sequences without PLT
We can generate x86-64 TLS code sequences for general and local dynamic
models without PLT, which uses indirect call via GOT:
call *__tls_get_addr@GOTPCREL(%rip)
instead of direct call:
call __tls_get_addr[@PLT]
Since direct call is 4-byte long and indirect call, is 5-byte long, the
extra one byte must be handled properly.
For general dynamic model, one 0x66 prefix before call instruction is
removed to make room for indirect call. For local dynamic model, we
simply use 5-byte indirect call.
TLS linker optimization is updated to recognize new instruction patterns.
For local dynamic model to local exec model transition, we generate
4 0x66 prefixes, instead of 3, before mov instruction in 64-bit and
generate a 5-byte nop, instead of 4-byte, before mov instruction in
32-bit. Since linker may convert
call *__tls_get_addr@GOTPCREL(%rip)
to
addr32 call __tls_get_addr
when producing static executable, both patterns are recognized.
bfd/
* elf64-x86-64.c (elf_x86_64_link_hash_entry): Add tls_get_addr.
(elf_x86_64_link_hash_newfunc): Initialize tls_get_addr to 2.
(elf_x86_64_check_tls_transition): Check indirect call and
direct call with the addr32 prefix for general and local dynamic
models. Set the tls_get_addr feild.
(elf_x86_64_convert_load_reloc): Always use addr32 prefix for
indirect __tls_get_addr call via GOT.
(elf_x86_64_relocate_section): Handle GD->LE, GD->IE and LD->LE
transitions with indirect call and direct call with the addr32
prefix.
ld/
* testsuite/ld-x86-64/pass.out: New file.
* testsuite/ld-x86-64/tls-def1.c: Likewise.
* testsuite/ld-x86-64/tls-gd1.S: Likewise.
* testsuite/ld-x86-64/tls-ld1.S: Likewise.
* testsuite/ld-x86-64/tls-main1.c: Likewise.
* testsuite/ld-x86-64/tls.exp: Likewise.
* testsuite/ld-x86-64/tlsbin2-nacl.rd: Likewise.
* testsuite/ld-x86-64/tlsbin2.dd: Likewise.
* testsuite/ld-x86-64/tlsbin2.rd: Likewise.
* testsuite/ld-x86-64/tlsbin2.sd: Likewise.
* testsuite/ld-x86-64/tlsbin2.td: Likewise.
* testsuite/ld-x86-64/tlsbinpic2.s: Likewise.
* testsuite/ld-x86-64/tlsgd10.dd: Likewise.
* testsuite/ld-x86-64/tlsgd10.s: Likewise.
* testsuite/ld-x86-64/tlsgd11.dd: Likewise.
* testsuite/ld-x86-64/tlsgd11.s: Likewise.
* testsuite/ld-x86-64/tlsgd12.d: Likewise.
* testsuite/ld-x86-64/tlsgd12.s: Likewise.
* testsuite/ld-x86-64/tlsgd13.d: Likewise.
* testsuite/ld-x86-64/tlsgd13.s: Likewise.
* testsuite/ld-x86-64/tlsgd14.dd: Likewise.
* testsuite/ld-x86-64/tlsgd14.s: Likewise.
* testsuite/ld-x86-64/tlsgd5c.s: Likewise.
* testsuite/ld-x86-64/tlsgd6c.s: Likewise.
* testsuite/ld-x86-64/tlsgd9.dd: Likewise.
* testsuite/ld-x86-64/tlsgd9.s: Likewise.
* testsuite/ld-x86-64/tlsld4.dd: Likewise.
* testsuite/ld-x86-64/tlsld4.s: Likewise.
* testsuite/ld-x86-64/tlsld5.dd: Likewise.
* testsuite/ld-x86-64/tlsld5.s: Likewise.
* testsuite/ld-x86-64/tlsld6.dd: Likewise.
* testsuite/ld-x86-64/tlsld6.s: Likewise.
* testsuite/ld-x86-64/tlspic2-nacl.rd: Likewise.
* testsuite/ld-x86-64/tlspic2.dd: Likewise.
* testsuite/ld-x86-64/tlspic2.rd: Likewise.
* testsuite/ld-x86-64/tlspic2.sd: Likewise.
* testsuite/ld-x86-64/tlspic2.td: Likewise.
* testsuite/ld-x86-64/tlspic3.s: Likewise.
* testsuite/ld-x86-64/tlspie2.s: Likewise.
* testsuite/ld-x86-64/tlspie2a.d: Likewise.
* testsuite/ld-x86-64/tlspie2b.d: Likewise.
* testsuite/ld-x86-64/tlspie2c.d: Likewise.
* testsuite/ld-x86-64/tlsgd5.dd: Updated.
* testsuite/ld-x86-64/tlsgd6.dd: Likewise.
* testsuite/ld-x86-64/x86-64.exp: Run libtlspic2.so, tlsbin2,
tlsgd5b, tlsgd6b, tlsld4, tlsld5, tlsld6, tlsgd9, tlsgd10,
tlsgd11, tlsgd14, tlsgd12, tlsgd13, tlspie2a, tlspie2b and
tlspie2c.
2016-06-07 02:06:55 +08:00
|
|
|
|
2016-06-06 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_link_hash_entry): Add tls_get_addr.
|
|
|
|
|
(elf_x86_64_link_hash_newfunc): Initialize tls_get_addr to 2.
|
|
|
|
|
(elf_x86_64_check_tls_transition): Check indirect call and
|
|
|
|
|
direct call with the addr32 prefix for general and local dynamic
|
|
|
|
|
models. Set the tls_get_addr feild.
|
|
|
|
|
(elf_x86_64_convert_load_reloc): Always use addr32 prefix for
|
|
|
|
|
indirect __tls_get_addr call via GOT.
|
|
|
|
|
(elf_x86_64_relocate_section): Handle GD->LE, GD->IE and LD->LE
|
|
|
|
|
transitions with indirect call and direct call with the addr32
|
|
|
|
|
prefix.
|
|
|
|
|
|
2016-06-05 04:15:52 +08:00
|
|
|
|
2016-06-04 Christian Groessler <chris@groessler.org>
|
|
|
|
|
|
|
|
|
|
* coff-z8k.c (extra_case): Fix range check for R_JR relocation.
|
|
|
|
|
|
2016-06-03 00:17:03 +08:00
|
|
|
|
2016-06-02 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR target/20088
|
|
|
|
|
* cpu-arm.c (processors): Add "arm_any" type to match any ARM
|
|
|
|
|
architecture.
|
|
|
|
|
(arch_info_struct): Likewise.
|
|
|
|
|
(architectures): Likewise.
|
|
|
|
|
|
2016-06-02 22:03:47 +08:00
|
|
|
|
2016-06-02 Vineet Gupta <Vineet.Gupta1@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* config.bfd: Replace -uclibc with *.
|
|
|
|
|
|
2016-06-02 21:50:45 +08:00
|
|
|
|
2016-06-02 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf64-x86-64.c: Replace data32 with data16 in comments.
|
|
|
|
|
|
2016-05-30 08:13:44 +08:00
|
|
|
|
2016-05-31 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20159
|
|
|
|
|
PR ld/16467
|
|
|
|
|
* elflink.c (_bfd_elf_merge_symbol): Revert PR16467 change.
|
|
|
|
|
(_bfd_elf_add_default_symbol): Don't indirect to/from defined
|
|
|
|
|
symbol given a version by a script different to the version
|
|
|
|
|
of the symbol being added.
|
|
|
|
|
(elf_link_add_object_symbols): Use _bfd_elf_strtab_save and
|
|
|
|
|
_bfd_elf_strtab_restore. Don't fudge dynstr references.
|
|
|
|
|
* elf-strtab.c (_bfd_elf_strtab_restore_size): Delete.
|
|
|
|
|
(struct strtab_save): New.
|
|
|
|
|
(_bfd_elf_strtab_save, _bfd_elf_strtab_restore): New functions.
|
|
|
|
|
* elf-bfd.h (_bfd_elf_strtab_restore_size): Delete.
|
|
|
|
|
(_bfd_elf_strtab_save, _bfd_elf_strtab_restore): Declare.
|
|
|
|
|
|
2016-05-29 16:29:22 +08:00
|
|
|
|
2016-06-01 Trevor Saunders <tbsaunde+binutils@tbsaunde.org>
|
|
|
|
|
|
|
|
|
|
* elf32-hppa.h: Add extern "C".
|
|
|
|
|
* elf32-nds32.h: Likewise.
|
|
|
|
|
* elf32-tic6x.h: Likewise.
|
|
|
|
|
|
2016-06-01 23:51:55 +08:00
|
|
|
|
2016-06-01 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* po/sr.po: New Serbian translation.
|
|
|
|
|
* configure.ac (ALL_LINGUAS): Add sr.
|
|
|
|
|
* configure: Regenerate.
|
|
|
|
|
|
2016-05-28 17:57:58 +08:00
|
|
|
|
2016-05-28 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (b_reloc_p): New function.
|
|
|
|
|
(_bfd_mips_elf_relocate_section) <bfd_reloc_outofrange>: Handle
|
|
|
|
|
branch relocations.
|
|
|
|
|
|
MIPS/BFD: Enable local R_MIPS_26 overflow detection
The original MIPS SVR4 psABI defines the calculation for the R_MIPS_26
relocation in a complex way, as follows[1]:
Name Value Field Symbol Calculation
R_MIPS_26 4 T-targ26 local (((A << 2) | \
(P & 0xf0000000)) + S) >> 2
4 T-targ26 external (sign-extend(A << 2) + S) >> 2
This is further clarified, by correcting typos (already applied in the
excerpt above) in the 64-bit psABI extension[2]. A note is included in
both documents to specify that for the purpose of relocation processing
a local symbol is one with binding STB_LOCAL and type STT_SECTION, and
otherwise, a symbol is external.
We have both calculations implemented for the R_MIPS_26 relocation, and
by extension also for the R_MIPS16_26 and R_MICROMIPS_26_S1 relocations,
from now on collectively called jump relocations. However our code uses
a different condition to tell local and external symbols apart, that is
it only checks for the STB_LOCAL binding and ignores the symbol type,
however for REL relocations only. The external calculation is used for
all RELA jump relocations.
In reality the difference matters for jump relocations referring local
MIPS16 and, as from recent commit 44d3da233815 ("MIPS/GAS: Treat local
jump relocs the same no matter if REL or RELA"), also local microMIPS
symbols. Such relocations are not converted to refer to corresponding
section symbols instead and retain the original local symbol reference.
It can be inferred from the relocation calculation definitions that the
addend is effectively unsigned for the local case and explicitly signed
for the external case. With the REL relocation format it makes sense
given the limited range provided for by the field being relocated: the
use of an unsigned addend expands the range by one bit for the local
case, because a negative offset from a section symbol makes no sense,
and any usable negative offset from the original local symbol will have
worked out positive if converted to a section-relative reference. In
the external case a signed addend gives more flexibility as offsets both
negative and positive can be used with a symbol. Any such offsets will
typically have a small value.
The inclusion of the (P & 0xf0000000) component, ORed in the calculation
in the local case, seems questionable as bits 31:28 are not included in
the relocatable field and are masked out as the relocation is applied.
Their value is therefore irrelevant for output processing, the relocated
field ends up the same regardless of their value. They could be used
for overflow detection, however this is precluded by adding them to bits
31:28 of the symbol referred, as the sum will not correspond to the
value calculated by the processor at run time whenever bits 31:28 of the
symbol referred are not all zeros, even though it is valid as long they
are the same as bits 31:28 of P.
We deal with this problem by ignoring any overflow resulting from the
local calculation. This however makes us miss genuine overflow cases,
where 31:28 of the symbol referred are different from bits 31:28 of P,
and non-functional code is produced.
Given the situation, for the purpose of overflow detection we can change
our code to follow the original psABI and only treat the in-place addend
as unsigned in the section symbol case, permitting jumps to offsets
128MiB and above into section. Sections so large may be uncommon, but
still a reasonable use case. On the other hand such large offsets from
regular local symbols are not expected and it makes sense to support
(possibly small) negative offsets instead, also in consistency with what
we do for global symbols.
Drop the (P & 0xf0000000) component then, treat the addend as signed
with local non-section symbols and also detect an overflow in the result
of such calculation with local symbols. NB it does not affect the value
computed for the relocatable field, it only affects overflow detection.
References:
[1] "SYSTEM V APPLICATION BINARY INTERFACE, MIPS RISC Processor
Supplement, 3rd Edition", Figure 4-11: "Relocation Types", p. 4-19
<http://www.linux-mips.org/pub/linux/mips/doc/ABI/mipsabi.pdf>
[2] "64-bit ELF Object File Specification, Draft Version 2.5", Table 32
"Relocation Types", p. 45
<http://techpubs.sgi.com/library/manuals/4000/007-4658-001/pdf/007-4658-001.pdf>
bfd/
* elfxx-mips.c (mips_elf_calculate_relocation): <R_MIPS16_26>
<R_MIPS_26, R_MICROMIPS_26_S1>: Drop the region bits of the
reloc location from calculation, treat the addend as signed with
local non-section symbols and enable overflow detection.
ld/
* testsuite/ld-mips-elf/jal-global-overflow-0.d: New test.
* testsuite/ld-mips-elf/jal-global-overflow-1.d: New test.
* testsuite/ld-mips-elf/jal-local-overflow-0.d: New test.
* testsuite/ld-mips-elf/jal-local-overflow-1.d: New test.
* testsuite/ld-mips-elf/jal-global-overflow.s: New test source.
* testsuite/ld-mips-elf/jal-local-overflow.s: New test source.
* testsuite/ld-mips-elf/mips-elf.exp: Run the new tests.
2016-05-28 17:30:22 +08:00
|
|
|
|
2016-05-28 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_calculate_relocation): <R_MIPS16_26>
|
|
|
|
|
<R_MIPS_26, R_MICROMIPS_26_S1>: Drop the region bits of the
|
|
|
|
|
reloc location from calculation, treat the addend as signed with
|
|
|
|
|
local non-section symbols and enable overflow detection.
|
|
|
|
|
|
Return void from linker callbacks
The ldmain.c implementation of these linker callback functions always
return true, so any code handling a false return is dead. What's
more, some of the bfd backends abort if ever a false return is seen,
and there seems to be some confusion in gdb's compile-object-load.c.
The return value was never meant to be "oh yes, a multiple_definition
error occurred", but rather "out of memory or other catastrophic
failure".
This patch removes the status return on the callbacks that always
return true. I kept the return status for "notice" because that one
does happen to need to return "out of memory".
include/
* bfdlink.h (struct bfd_link_callbacks): Update comments.
Return void from multiple_definition, multiple_common,
add_to_set, constructor, warning, undefined_symbol,
reloc_overflow, reloc_dangerous and unattached_reloc.
bfd/
* aoutx.h: Adjust linker callback calls throughout file,
removing dead code.
* bout.c: Likewise.
* coff-alpha.c: Likewise.
* coff-arm.c: Likewise.
* coff-h8300.c: Likewise.
* coff-h8500.c: Likewise.
* coff-i960.c: Likewise.
* coff-mcore.c: Likewise.
* coff-mips.c: Likewise.
* coff-ppc.c: Likewise.
* coff-rs6000.c: Likewise.
* coff-sh.c: Likewise.
* coff-tic80.c: Likewise.
* coff-w65.c: Likewise.
* coff-z80.c: Likewise.
* coff-z8k.c: Likewise.
* coff64-rs6000.c: Likewise.
* cofflink.c: Likewise.
* ecoff.c: Likewise.
* elf-bfd.h: Likewise.
* elf-m10200.c: Likewise.
* elf-m10300.c: Likewise.
* elf32-arc.c: Likewise.
* elf32-arm.c: Likewise.
* elf32-avr.c: Likewise.
* elf32-bfin.c: Likewise.
* elf32-cr16.c: Likewise.
* elf32-cr16c.c: Likewise.
* elf32-cris.c: Likewise.
* elf32-crx.c: Likewise.
* elf32-d10v.c: Likewise.
* elf32-epiphany.c: Likewise.
* elf32-fr30.c: Likewise.
* elf32-frv.c: Likewise.
* elf32-ft32.c: Likewise.
* elf32-h8300.c: Likewise.
* elf32-hppa.c: Likewise.
* elf32-i370.c: Likewise.
* elf32-i386.c: Likewise.
* elf32-i860.c: Likewise.
* elf32-ip2k.c: Likewise.
* elf32-iq2000.c: Likewise.
* elf32-lm32.c: Likewise.
* elf32-m32c.c: Likewise.
* elf32-m32r.c: Likewise.
* elf32-m68hc1x.c: Likewise.
* elf32-m68k.c: Likewise.
* elf32-mep.c: Likewise.
* elf32-metag.c: Likewise.
* elf32-microblaze.c: Likewise.
* elf32-moxie.c: Likewise.
* elf32-msp430.c: Likewise.
* elf32-mt.c: Likewise.
* elf32-nds32.c: Likewise.
* elf32-nios2.c: Likewise.
* elf32-or1k.c: Likewise.
* elf32-ppc.c: Likewise.
* elf32-s390.c: Likewise.
* elf32-score.c: Likewise.
* elf32-score7.c: Likewise.
* elf32-sh.c: Likewise.
* elf32-sh64.c: Likewise.
* elf32-spu.c: Likewise.
* elf32-tic6x.c: Likewise.
* elf32-tilepro.c: Likewise.
* elf32-v850.c: Likewise.
* elf32-vax.c: Likewise.
* elf32-visium.c: Likewise.
* elf32-xstormy16.c: Likewise.
* elf32-xtensa.c: Likewise.
* elf64-alpha.c: Likewise.
* elf64-hppa.c: Likewise.
* elf64-ia64-vms.c: Likewise.
* elf64-mmix.c: Likewise.
* elf64-ppc.c: Likewise.
* elf64-s390.c: Likewise.
* elf64-sh64.c: Likewise.
* elf64-x86-64.c: Likewise.
* elflink.c: Likewise.
* elfnn-aarch64.c: Likewise.
* elfnn-ia64.c: Likewise.
* elfxx-mips.c: Likewise.
* elfxx-sparc.c: Likewise.
* elfxx-tilegx.c: Likewise.
* linker.c: Likewise.
* pdp11.c: Likewise.
* pe-mips.c: Likewise.
* reloc.c: Likewise.
* reloc16.c: Likewise.
* simple.c: Likewise.
* vms-alpha.c: Likewise.
* xcofflink.c: Likewise.
* elf32-rl78.c (get_symbol_value, get_romstart, get_ramstart): Delete
status param. Adjust calls to these and linker callbacks throughout.
* elf32-rx.c: (get_symbol_value, get_gp, get_romstart,
get_ramstart): Delete status param. Adjust calls to these and
linker callbacks throughout.
ld/
* ldmain.c (multiple_definition, multiple_common, add_to_set,
constructor_callback, warning_callback, undefined_symbol,
reloc_overflow, reloc_dangerous, unattached_reloc): Return void.
* emultempl/elf32.em: Adjust callback calls.
gdb/
* compile/compile-object-load.c (link_callbacks_multiple_definition,
link_callbacks_warning, link_callbacks_undefined_symbol,
link_callbacks_undefined_symbol, link_callbacks_reloc_overflow,
link_callbacks_reloc_dangerous,
link_callbacks_unattached_reloc): Return void.
2016-05-27 15:50:55 +08:00
|
|
|
|
2016-05-28 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* aoutx.h: Adjust linker callback calls throughout file,
|
|
|
|
|
removing dead code.
|
|
|
|
|
* bout.c: Likewise.
|
|
|
|
|
* coff-alpha.c: Likewise.
|
|
|
|
|
* coff-arm.c: Likewise.
|
|
|
|
|
* coff-h8300.c: Likewise.
|
|
|
|
|
* coff-h8500.c: Likewise.
|
|
|
|
|
* coff-i960.c: Likewise.
|
|
|
|
|
* coff-mcore.c: Likewise.
|
|
|
|
|
* coff-mips.c: Likewise.
|
|
|
|
|
* coff-ppc.c: Likewise.
|
|
|
|
|
* coff-rs6000.c: Likewise.
|
|
|
|
|
* coff-sh.c: Likewise.
|
|
|
|
|
* coff-tic80.c: Likewise.
|
|
|
|
|
* coff-w65.c: Likewise.
|
|
|
|
|
* coff-z80.c: Likewise.
|
|
|
|
|
* coff-z8k.c: Likewise.
|
|
|
|
|
* coff64-rs6000.c: Likewise.
|
|
|
|
|
* cofflink.c: Likewise.
|
|
|
|
|
* ecoff.c: Likewise.
|
|
|
|
|
* elf-bfd.h: Likewise.
|
|
|
|
|
* elf-m10200.c: Likewise.
|
|
|
|
|
* elf-m10300.c: Likewise.
|
|
|
|
|
* elf32-arc.c: Likewise.
|
|
|
|
|
* elf32-arm.c: Likewise.
|
|
|
|
|
* elf32-avr.c: Likewise.
|
|
|
|
|
* elf32-bfin.c: Likewise.
|
|
|
|
|
* elf32-cr16.c: Likewise.
|
|
|
|
|
* elf32-cr16c.c: Likewise.
|
|
|
|
|
* elf32-cris.c: Likewise.
|
|
|
|
|
* elf32-crx.c: Likewise.
|
|
|
|
|
* elf32-d10v.c: Likewise.
|
|
|
|
|
* elf32-epiphany.c: Likewise.
|
|
|
|
|
* elf32-fr30.c: Likewise.
|
|
|
|
|
* elf32-frv.c: Likewise.
|
|
|
|
|
* elf32-ft32.c: Likewise.
|
|
|
|
|
* elf32-h8300.c: Likewise.
|
|
|
|
|
* elf32-hppa.c: Likewise.
|
|
|
|
|
* elf32-i370.c: Likewise.
|
|
|
|
|
* elf32-i386.c: Likewise.
|
|
|
|
|
* elf32-i860.c: Likewise.
|
|
|
|
|
* elf32-ip2k.c: Likewise.
|
|
|
|
|
* elf32-iq2000.c: Likewise.
|
|
|
|
|
* elf32-lm32.c: Likewise.
|
|
|
|
|
* elf32-m32c.c: Likewise.
|
|
|
|
|
* elf32-m32r.c: Likewise.
|
|
|
|
|
* elf32-m68hc1x.c: Likewise.
|
|
|
|
|
* elf32-m68k.c: Likewise.
|
|
|
|
|
* elf32-mep.c: Likewise.
|
|
|
|
|
* elf32-metag.c: Likewise.
|
|
|
|
|
* elf32-microblaze.c: Likewise.
|
|
|
|
|
* elf32-moxie.c: Likewise.
|
|
|
|
|
* elf32-msp430.c: Likewise.
|
|
|
|
|
* elf32-mt.c: Likewise.
|
|
|
|
|
* elf32-nds32.c: Likewise.
|
|
|
|
|
* elf32-nios2.c: Likewise.
|
|
|
|
|
* elf32-or1k.c: Likewise.
|
|
|
|
|
* elf32-ppc.c: Likewise.
|
|
|
|
|
* elf32-s390.c: Likewise.
|
|
|
|
|
* elf32-score.c: Likewise.
|
|
|
|
|
* elf32-score7.c: Likewise.
|
|
|
|
|
* elf32-sh.c: Likewise.
|
|
|
|
|
* elf32-sh64.c: Likewise.
|
|
|
|
|
* elf32-spu.c: Likewise.
|
|
|
|
|
* elf32-tic6x.c: Likewise.
|
|
|
|
|
* elf32-tilepro.c: Likewise.
|
|
|
|
|
* elf32-v850.c: Likewise.
|
|
|
|
|
* elf32-vax.c: Likewise.
|
|
|
|
|
* elf32-visium.c: Likewise.
|
|
|
|
|
* elf32-xstormy16.c: Likewise.
|
|
|
|
|
* elf32-xtensa.c: Likewise.
|
|
|
|
|
* elf64-alpha.c: Likewise.
|
|
|
|
|
* elf64-hppa.c: Likewise.
|
|
|
|
|
* elf64-ia64-vms.c: Likewise.
|
|
|
|
|
* elf64-mmix.c: Likewise.
|
|
|
|
|
* elf64-ppc.c: Likewise.
|
|
|
|
|
* elf64-s390.c: Likewise.
|
|
|
|
|
* elf64-sh64.c: Likewise.
|
|
|
|
|
* elf64-x86-64.c: Likewise.
|
|
|
|
|
* elflink.c: Likewise.
|
|
|
|
|
* elfnn-aarch64.c: Likewise.
|
|
|
|
|
* elfnn-ia64.c: Likewise.
|
|
|
|
|
* elfxx-mips.c: Likewise.
|
|
|
|
|
* elfxx-sparc.c: Likewise.
|
|
|
|
|
* elfxx-tilegx.c: Likewise.
|
|
|
|
|
* linker.c: Likewise.
|
|
|
|
|
* pdp11.c: Likewise.
|
|
|
|
|
* pe-mips.c: Likewise.
|
|
|
|
|
* reloc.c: Likewise.
|
|
|
|
|
* reloc16.c: Likewise.
|
|
|
|
|
* simple.c: Likewise.
|
|
|
|
|
* vms-alpha.c: Likewise.
|
|
|
|
|
* xcofflink.c: Likewise.
|
|
|
|
|
* elf32-rl78.c (get_symbol_value, get_romstart, get_ramstart): Delete
|
|
|
|
|
status param. Adjust calls to these and linker callbacks throughout.
|
|
|
|
|
* elf32-rx.c: (get_symbol_value, get_gp, get_romstart,
|
|
|
|
|
get_ramstart): Delete status param. Adjust calls to these and
|
|
|
|
|
linker callbacks throughout.
|
|
|
|
|
|
2016-05-28 03:43:05 +08:00
|
|
|
|
2016-05-27 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_calculate_relocation) <R_MIPS16_26>
|
|
|
|
|
<R_MIPS_26, R_MICROMIPS_26_S1>: Include the addend in JALX's
|
|
|
|
|
target alignment verification.
|
|
|
|
|
|
2016-05-28 03:41:40 +08:00
|
|
|
|
2016-05-27 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_calculate_relocation): Also use the
|
|
|
|
|
section name if `bfd_elf_string_from_elf_section' returns an
|
|
|
|
|
empty string.
|
|
|
|
|
|
2016-05-26 19:24:45 +08:00
|
|
|
|
2016-05-26 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_relocate_section)
|
|
|
|
|
<bfd_reloc_outofrange>: Use the `%X%H' rather than `%C' format
|
|
|
|
|
for message. Continue processing rather than returning failure.
|
|
|
|
|
|
2016-05-26 03:59:37 +08:00
|
|
|
|
2016-05-25 Maciej W. Rozycki <macro@imgtec.com>
|
2016-05-26 19:24:45 +08:00
|
|
|
|
|
2016-05-26 03:59:37 +08:00
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_relocate_section)
|
|
|
|
|
<bfd_reloc_outofrange>: Call `->einfo' rather than `->warning'.
|
|
|
|
|
Call `bfd_set_error'.
|
|
|
|
|
|
2016-05-26 00:46:47 +08:00
|
|
|
|
2016-05-25 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/14625
|
|
|
|
|
* archive.c (bfd_slurp_armap): Replace
|
|
|
|
|
bfd_elf64_archive_slurp_armap with
|
|
|
|
|
_bfd_archive_64_bit_slurp_armap.
|
|
|
|
|
(bsd_write_armap): Call _bfd_archive_64_bit_write_armap if
|
|
|
|
|
BFD64 is defined and the archive is too big.
|
|
|
|
|
(coff_write_armap): Likewise.
|
|
|
|
|
* archive64.c (bfd_elf64_archive_slurp_armap): Renamed to ...
|
|
|
|
|
(_bfd_archive_64_bit_slurp_armap): This.
|
|
|
|
|
(bfd_elf64_archive_write_armap): Renamed to ...
|
|
|
|
|
(_bfd_archive_64_bit_write_armap): This.
|
|
|
|
|
* configure.ac: Add --enable-64-bit-archive.
|
|
|
|
|
(want_64_bit_archive): New. Set to true by default for 64-bit
|
|
|
|
|
MIPS and s390 ELF targets.
|
|
|
|
|
(USE_64_BIT_ARCHIVE): New AC_DEFINE.
|
|
|
|
|
* config.in: Regenerated.
|
|
|
|
|
* configure: Likewise.
|
|
|
|
|
* elf64-mips.c (bfd_elf64_archive_functions): Removed.
|
|
|
|
|
(bfd_elf64_archive_slurp_armap): Likewise.
|
|
|
|
|
(bfd_elf64_archive_write_armap): Likewise.
|
|
|
|
|
(bfd_elf64_archive_slurp_extended_name_table): Likewise.
|
|
|
|
|
(bfd_elf64_archive_construct_extended_name_table): Likewise.
|
|
|
|
|
(bfd_elf64_archive_truncate_arname): Likewise.
|
|
|
|
|
(bfd_elf64_archive_read_ar_hdr): Likewise.
|
|
|
|
|
(bfd_elf64_archive_write_ar_hdr): Likewise.
|
|
|
|
|
(bfd_elf64_archive_openr_next_archived_file): Likewise.
|
|
|
|
|
(bfd_elf64_archive_get_elt_at_index): Likewise.
|
|
|
|
|
(bfd_elf64_archive_generic_stat_arch_elt): Likewise.
|
|
|
|
|
(bfd_elf64_archive_update_armap_timestamp): Likewise.
|
|
|
|
|
* elf64-s390.c (bfd_elf64_archive_functions): Removed.
|
|
|
|
|
(bfd_elf64_archive_slurp_armap): Likewise.
|
|
|
|
|
(bfd_elf64_archive_write_armap): Likewise.
|
|
|
|
|
(bfd_elf64_archive_slurp_extended_name_table): Likewise.
|
|
|
|
|
(bfd_elf64_archive_construct_extended_name_table): Likewise.
|
|
|
|
|
(bfd_elf64_archive_truncate_arname): Likewise.
|
|
|
|
|
(bfd_elf64_archive_read_ar_hdr): Likewise.
|
|
|
|
|
(bfd_elf64_archive_write_ar_hdr): Likewise.
|
|
|
|
|
(bfd_elf64_archive_openr_next_archived_file): Likewise.
|
|
|
|
|
(bfd_elf64_archive_get_elt_at_index): Likewise.
|
|
|
|
|
(bfd_elf64_archive_generic_stat_arch_elt): Likewise.
|
|
|
|
|
(bfd_elf64_archive_update_armap_timestamp): Likewise.
|
|
|
|
|
* elfxx-target.h (TARGET_BIG_SYM): Use _bfd_archive_64_bit on
|
|
|
|
|
BFD_JUMP_TABLE_ARCHIVE if USE_64_BIT_ARCHIVE is defined and
|
|
|
|
|
bfd_elfNN_archive_functions isn't defined.
|
|
|
|
|
(TARGET_LITTLE_SYM): Likewise.
|
|
|
|
|
* libbfd-in.h (_bfd_archive_64_bit_slurp_armap): New prototype.
|
|
|
|
|
(_bfd_archive_64_bit_write_armap): Likewise.
|
|
|
|
|
(_bfd_archive_64_bit_slurp_extended_name_table): New macro.
|
|
|
|
|
(_bfd_archive_64_bit_construct_extended_name_table): Likewise.
|
|
|
|
|
(_bfd_archive_64_bit_truncate_arname): Likewise.
|
|
|
|
|
(_bfd_archive_64_bit_read_ar_hdr): Likewise.
|
|
|
|
|
(_bfd_archive_64_bit_write_ar_hdr): Likewise.
|
|
|
|
|
(_bfd_archive_64_bit_openr_next_archived_file): Likewise.
|
|
|
|
|
(_bfd_archive_64_bit_get_elt_at_index): Likewise.
|
|
|
|
|
(_bfd_archive_64_bit_generic_stat_arch_elt): Likewise.
|
|
|
|
|
(_bfd_archive_64_bit_update_armap_timestamp): Likewise.
|
|
|
|
|
* libbfd.h: Regenerated.
|
|
|
|
|
* plugin.c (plugin_vec): Use _bfd_archive_64_bit on
|
|
|
|
|
BFD_JUMP_TABLE_ARCHIVE if USE_64_BIT_ARCHIVE is defined.
|
|
|
|
|
|
2016-05-25 23:40:52 +08:00
|
|
|
|
2016-05-25 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20103
|
|
|
|
|
* cofflink.c (coff_link_check_archive_element): Return TRUE if
|
|
|
|
|
linker add_archive_element callback returns FALSE.
|
|
|
|
|
* ecoff.c (ecoff_link_check_archive_element): Likewise.
|
|
|
|
|
* elf64-ia64-vms.c (elf64_vms_link_add_archive_symbols): Skip
|
|
|
|
|
archive element if linker add_archive_element callback returns
|
|
|
|
|
FALSE.
|
|
|
|
|
* elflink.c (elf_link_add_archive_symbols): Likewise.
|
|
|
|
|
* pdp11.c (aout_link_check_ar_symbols): Likewise.
|
|
|
|
|
* vms-alpha.c (alpha_vms_link_add_archive_symbols): Likewise.
|
|
|
|
|
* xcofflink.c (xcoff_link_check_dynamic_ar_symbols): Likewise.
|
|
|
|
|
(xcoff_link_check_ar_symbols): Likewise.
|
|
|
|
|
|
2016-05-25 03:45:30 +08:00
|
|
|
|
2016-05-24 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_relocate_section)
|
|
|
|
|
<bfd_reloc_outofrange>: Unify error reporting code.
|
|
|
|
|
|
2016-05-24 07:38:21 +08:00
|
|
|
|
2016-05-23 Jim Wilson <jim.wilson@linaro.org>
|
|
|
|
|
|
|
|
|
|
* elfnn-aarch64.c: Unconditionally enable R_AARCH64_NULL and
|
|
|
|
|
R_AARCH64_NONE. Use HOWTO64 for R_AARCH64_NULL.
|
|
|
|
|
* relocs.c: Add BFD_RELOC_AARCH64_NULL.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* libbfd.h: Likewise.
|
|
|
|
|
|
2016-05-23 20:53:07 +08:00
|
|
|
|
2016-05-23 Kuba Sejdak <jakub.sejdak@phoesys.com>
|
|
|
|
|
|
|
|
|
|
* config.bfd: Add entry for arm-phoenix.
|
|
|
|
|
|
2016-05-23 16:41:36 +08:00
|
|
|
|
2016-05-23 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (arm_dedicated_stub_section_padding): New function.
|
|
|
|
|
(elf32_arm_size_stubs): Declare stub_type in a more outer scope and
|
|
|
|
|
account for padding for stub section requiring one.
|
|
|
|
|
(elf32_arm_build_stubs): Add comment to stress the importance of
|
|
|
|
|
zeroing veneer section content.
|
|
|
|
|
|
2016-05-23 16:38:32 +08:00
|
|
|
|
2016-05-23 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* bfd-in.h (bfd_elf32_arm_keep_private_stub_output_sections): Declare
|
|
|
|
|
bfd hook.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* elf32-arm.c (arm_dedicated_stub_output_section_required): New
|
|
|
|
|
function.
|
|
|
|
|
(arm_dedicated_stub_output_section_required_alignment): Likewise.
|
|
|
|
|
(arm_dedicated_stub_output_section_name): Likewise.
|
|
|
|
|
(arm_dedicated_stub_input_section_ptr): Likewise.
|
|
|
|
|
(elf32_arm_create_or_find_stub_sec): Add stub type parameter and
|
|
|
|
|
function description comment. Add support for dedicated output stub
|
|
|
|
|
section to given stub types.
|
|
|
|
|
(elf32_arm_add_stub): Add a stub type parameter and pass it down to
|
|
|
|
|
elf32_arm_create_or_find_stub_sec.
|
|
|
|
|
(elf32_arm_create_stub): Pass stub type down to elf32_arm_add_stub.
|
|
|
|
|
(elf32_arm_size_stubs): Pass stub type when calling
|
|
|
|
|
elf32_arm_create_or_find_stub_sec for Cortex-A8 erratum veneers.
|
|
|
|
|
(bfd_elf32_arm_keep_private_stub_output_sections): New function.
|
|
|
|
|
|
2016-05-21 00:36:48 +08:00
|
|
|
|
2016-05-20 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_check_relocs): Don't check R_386_GOT32
|
|
|
|
|
when setting need_convert_load.
|
|
|
|
|
|
2016-05-20 20:32:19 +08:00
|
|
|
|
2016-05-20 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_read_rel_addend): Adjust the addend for
|
|
|
|
|
microMIPS JALX.
|
|
|
|
|
|
2016-05-20 03:56:55 +08:00
|
|
|
|
2016-05-19 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20117
|
|
|
|
|
* elf32-i386.c (elf_i386_convert_load_reloc): Don't check
|
|
|
|
|
R_386_GOT32X.
|
|
|
|
|
(elf_i386_convert_load): Don't convert R_386_GOT32.
|
|
|
|
|
|
2016-05-19 23:03:42 +08:00
|
|
|
|
2016-05-20 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR gas/20118
|
|
|
|
|
* elf.c (elf_fake_sections): Set sh_entsize for SHT_INIT_ARRAY,
|
|
|
|
|
SHT_FINI_ARRAY, and SHT_PREINIT_ARRAY.
|
|
|
|
|
|
2016-05-19 20:39:36 +08:00
|
|
|
|
2016-05-19 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (arc_elf_final_write_processing): Changed.
|
|
|
|
|
(debug_arc_reloc): Likewise.
|
|
|
|
|
(elf_arc_relocate_section): Likewise.
|
|
|
|
|
(elf_arc_check_relocs): Likewise.
|
|
|
|
|
(elf_arc_adjust_dynamic_symbol): Likewise.
|
|
|
|
|
(elf_arc_add_symbol_hook): Likewise.
|
|
|
|
|
|
2016-05-18 11:19:02 +08:00
|
|
|
|
2016-05-19 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* config.bfd: Remove `am34-*-linux*' support.
|
|
|
|
|
|
2016-05-18 22:29:04 +08:00
|
|
|
|
2016-05-19 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (allocate_dynrelocs): Allocate got and other dynamic
|
|
|
|
|
relocs before plt relocs.
|
|
|
|
|
|
2016-05-19 11:02:40 +08:00
|
|
|
|
2016-05-19 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_branch_reloc): Check for NULL owner
|
|
|
|
|
before dereferencing.
|
|
|
|
|
|
2016-05-18 19:44:43 +08:00
|
|
|
|
2016-05-18 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* po/sv.po: Updated Swedish translation.
|
|
|
|
|
|
2016-05-18 14:14:46 +08:00
|
|
|
|
2016-05-18 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (elf32_arm_size_stubs): Free or cache local syms
|
|
|
|
|
for each BFD. Don't goto error_ret_free_local from outside loop.
|
|
|
|
|
|
2016-05-16 15:51:26 +08:00
|
|
|
|
2016-05-17 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elf-s390-common.c (elf_s390_add_symbol_hook): Remove
|
|
|
|
|
STB_GNU_UNIQUE handling.
|
|
|
|
|
* elf32-arc.c (elf_arc_add_symbol_hook): Likewise.
|
|
|
|
|
* elf32-arm.c (elf32_arm_add_symbol_hook): Likewise.
|
|
|
|
|
* elf32-m68k.c (elf_m68k_add_symbol_hook): Likewise.
|
|
|
|
|
* elf32-ppc.c (ppc_elf_add_symbol_hook): Likewise.
|
|
|
|
|
* elf32-sparc.c (elf32_sparc_add_symbol_hook): Likewise.
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_add_symbol_hook): Likewise.
|
|
|
|
|
* elf64-sparc.c (elf64_sparc_add_symbol_hook): Likewise.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_add_symbol_hook): Likewise.
|
|
|
|
|
* elfxx-aarch64.c (_bfd_aarch64_elf_add_symbol_hook): Likewise.
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_add_symbol_hook): Likewise.
|
|
|
|
|
* elf32-i386.c (elf_i386_add_symbol_hook): Remove function.
|
|
|
|
|
(elf_backend_add_symbol_hook): Remove macro.
|
|
|
|
|
* elflink.c (elf_link_add_object_symbols): Set `has_gnu_symbols'
|
|
|
|
|
for STB_GNU_UNIQUE symbols.
|
|
|
|
|
|
2016-05-16 15:22:59 +08:00
|
|
|
|
2016-05-16 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elf32-v850.c (v850_elf_copy_notes): New function, factored out
|
|
|
|
|
from...
|
|
|
|
|
(v850_elf_copy_private_bfd_data): ... here. Call the new
|
|
|
|
|
function and `_bfd_elf_copy_private_bfd_data'.
|
|
|
|
|
|
2016-05-14 01:59:32 +08:00
|
|
|
|
2016-05-13 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20093
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_convert_load_reloc): Don't convert
|
|
|
|
|
GOTPCREL relocation against large section.
|
|
|
|
|
|
2016-05-13 10:18:56 +08:00
|
|
|
|
2016-05-13 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf-m10300.c (_bfd_mn10300_elf_finish_dynamic_sections): Use
|
|
|
|
|
linker dynamic sections in calculating size and address of
|
2016-05-14 01:59:32 +08:00
|
|
|
|
dynamic tags rather than using output sections. Remove asserts.
|
2016-05-13 10:18:56 +08:00
|
|
|
|
* elf32-arm.c (elf32_arm_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-cr16.c (_bfd_cr16_elf_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-cris.c (elf_cris_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-i370.c (i370_elf_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-lm32.c (lm32_elf_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-m32r.c (m32r_elf_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-m68k.c (elf_m68k_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-metag.c (elf_metag_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-microblaze.c (microblaze_elf_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-nds32.c (nds32_elf_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-nios2.c (nios2_elf32_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-or1k.c (or1k_elf_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-s390.c (elf_s390_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-score.c (s3_bfd_score_elf_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-score7.c (s7_bfd_score_elf_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-vax.c (elf_vax_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf32-xtensa.c (elf_xtensa_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf64-alpha.c (elf64_alpha_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf64-s390.c (elf_s390_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elf64-sh64.c (sh64_elf64_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elflink.c (bfd_elf_final_link): Likewise.
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_finish_dynamic_sections): Likewise.
|
|
|
|
|
* elfxx-sparc.c (sparc_finish_dyn): Likewise. Adjust error message.
|
|
|
|
|
* elf32-arc.c (GET_SYMBOL_OR_SECTION): Remove ASSERT arg and
|
|
|
|
|
don't set doit. Look up dynobj section.
|
|
|
|
|
(elf_arc_finish_dynamic_sections): Adjust GET_SYMBOL_OR_SECTION
|
|
|
|
|
invocation and dynamic tag vma calculation. Don't test
|
|
|
|
|
boolean var == TRUE.
|
|
|
|
|
* elfnn-aarch64.c (elfNN_aarch64_finish_dynamic_sections): Fix
|
|
|
|
|
DT_JMPREL calc.
|
|
|
|
|
|
2016-05-13 10:04:56 +08:00
|
|
|
|
2016-05-13 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (elf_link_sort_relocs): Wrap overlong lines. Fix
|
|
|
|
|
octets_per_byte. Put dynamic .rela.plt last in link orders.
|
|
|
|
|
Assign output_offset for reloc sections rather than writing
|
|
|
|
|
sorted relocs from block corresponding to output_offset.
|
|
|
|
|
|
2016-05-12 22:29:26 +08:00
|
|
|
|
2016-05-12 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h (elf_reloc_type_class): Put reloc_class_plt last.
|
|
|
|
|
|
2014-11-26 19:15:01 +08:00
|
|
|
|
2016-05-11 Andrew Bennett <andrew.bennett@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (print_mips_ases): Add DSPR3.
|
|
|
|
|
|
2016-05-11 21:21:14 +08:00
|
|
|
|
2016-05-11 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-hppa.c (elf32_hppa_init_stub_bfd): New function.
|
|
|
|
|
(elf32_hppa_check_relocs): Don't set dynobj.
|
|
|
|
|
(elf32_hppa_size_stubs): Test !SEC_LINKER_CREATED for stub sections.
|
|
|
|
|
(elf32_hppa_build_stubs): Likewise.
|
|
|
|
|
* elf32-hppa.h (elf32_hppa_init_stub_bfd): Declare.
|
|
|
|
|
|
2016-05-11 20:24:05 +08:00
|
|
|
|
2016-05-11 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 20060
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_tls_setup): Clear forced_local.
|
|
|
|
|
* elf32-ppc.c (ppc_elf_tls_setup): Likewise.
|
|
|
|
|
|
2016-05-11 18:55:02 +08:00
|
|
|
|
2016-05-10 Jiong Wang <jiong.wang@arm.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-aarch64.c (elfNN_aarch64_final_link_relocate): Remove redundant
|
|
|
|
|
aarch64_tls_transition check.
|
|
|
|
|
|
2016-05-10 23:20:19 +08:00
|
|
|
|
2016-05-10 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (enum elf32_arm_stub_type): New max_stub_type
|
|
|
|
|
enumerator.
|
|
|
|
|
(arm_stub_sym_claimed): New function.
|
|
|
|
|
(elf32_arm_create_stub): Use veneered symbol name and section if
|
|
|
|
|
veneer needs to claim its symbol, and keep logic unchanged otherwise.
|
|
|
|
|
(arm_stub_claim_sym): New function.
|
|
|
|
|
(arm_map_one_stub): Call arm_stub_claim_sym if veneer needs to claim
|
|
|
|
|
veneered symbol, otherwise create local symbol as before.
|
|
|
|
|
|
2016-05-10 23:14:23 +08:00
|
|
|
|
2016-05-10 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (elf32_arm_size_stubs): Use new macros
|
|
|
|
|
ARM_GET_SYM_BRANCH_TYPE and ARM_SET_SYM_BRANCH_TYPE to respectively get
|
|
|
|
|
and set branch type of a symbol.
|
|
|
|
|
(bfd_elf32_arm_process_before_allocation): Likewise.
|
|
|
|
|
(elf32_arm_relocate_section): Likewise and fix identation along the
|
|
|
|
|
way.
|
|
|
|
|
(allocate_dynrelocs_for_symbol): Likewise.
|
|
|
|
|
(elf32_arm_finish_dynamic_symbol): Likewise.
|
|
|
|
|
(elf32_arm_swap_symbol_in): Likewise.
|
|
|
|
|
(elf32_arm_swap_symbol_out): Likewise.
|
|
|
|
|
|
2016-05-10 22:45:01 +08:00
|
|
|
|
2016-05-10 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* bfd-in.h (elf32_arm_size_stubs): Add an output section parameter.
|
|
|
|
|
* bfd-in2.h: Regenerated.
|
|
|
|
|
* elf32-arm.c (struct elf32_arm_link_hash_table): Add an output section
|
|
|
|
|
parameter to add_stub_section callback.
|
|
|
|
|
(elf32_arm_create_or_find_stub_sec): Get output section from link_sec
|
|
|
|
|
and pass it down to add_stub_section.
|
|
|
|
|
(elf32_arm_add_stub): Set section to stub_sec if NULL before using it
|
|
|
|
|
for error message.
|
|
|
|
|
(elf32_arm_size_stubs): Add output section parameter to
|
|
|
|
|
add_stub_section function pointer parameter.
|
|
|
|
|
|
2016-05-10 22:42:20 +08:00
|
|
|
|
2016-05-10 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (elf32_arm_create_stub): New function.
|
|
|
|
|
(elf32_arm_size_stubs): Use elf32_arm_create_stub for stub creation.
|
|
|
|
|
|
2016-05-10 22:28:10 +08:00
|
|
|
|
2016-05-10 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (enum elf32_arm_stub_type): Delete
|
|
|
|
|
arm_stub_a8_veneer_lwm enumerator.
|
|
|
|
|
(arm_stub_a8_veneer_lwm): New unsigned constant to replace
|
|
|
|
|
aforementioned enumerator.
|
|
|
|
|
(struct elf32_arm_stub_hash_entry): Delete target_addend
|
|
|
|
|
field and add source_value.
|
|
|
|
|
(struct a8_erratum_fix): Delete addend field and add target_offset.
|
|
|
|
|
(stub_hash_newfunc): Initialize source_value field amd remove
|
|
|
|
|
initialization for target_addend.
|
|
|
|
|
(arm_build_one_stub): Stop special casing Thumb relocations: promote
|
|
|
|
|
the else to being always executed, moving the
|
|
|
|
|
arm_stub_a8_veneer_b_cond specific code in it. Remove
|
|
|
|
|
stub_entry->target_addend from points_to computation.
|
|
|
|
|
(cortex_a8_erratum_scan): Store in a8_erratum_fix structure the offset
|
|
|
|
|
to target symbol from start of section rather than the offset from the
|
|
|
|
|
stub address.
|
|
|
|
|
(elf32_arm_size_stubs): Set stub_entry's source_value and target_value
|
|
|
|
|
fields from struct a8_erratum_fix's offset and target_offset
|
|
|
|
|
respectively.
|
|
|
|
|
(make_branch_to_a8_stub): Rename target variable to loc. Compute
|
|
|
|
|
veneered_insn_loc and loc using stub_entry's source_value.
|
|
|
|
|
|
2016-05-10 22:15:15 +08:00
|
|
|
|
2016-05-10 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
(elf32_arm_merge_eabi_attributes): Add merging logic for
|
|
|
|
|
Tag_DSP_extension.
|
|
|
|
|
|
2016-05-10 09:31:47 +08:00
|
|
|
|
2016-05-10 Pip Cet <pipcet@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20059
|
|
|
|
|
* elfxx-target.h (bfd_elfNN_bfd_copy_link_hash_symbol_type):
|
|
|
|
|
Define as _bfd_generic_copy_link_hash_symbol_type when using
|
|
|
|
|
generic hash table.
|
|
|
|
|
|
2016-05-10 00:31:07 +08:00
|
|
|
|
2016-05-09 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/20063
|
|
|
|
|
* elf.c (bfd_elf_get_elf_syms): Check for out of range sh_link
|
|
|
|
|
field before accessing sections array.
|
|
|
|
|
|
2016-05-09 21:10:37 +08:00
|
|
|
|
2016-05-09 Christophe Monat <christophe.monat@st.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20030
|
|
|
|
|
* elf32-arm.c (is_thumb2_vldm): Account for T1 (DP) encoding.
|
|
|
|
|
(stm32l4xx_need_create_replacing_stub): Rename ambiguous nb_regs
|
|
|
|
|
to nb_words.
|
|
|
|
|
(create_instruction_vldmia): Add is_dp to disambiguate SP/DP
|
|
|
|
|
encoding.
|
|
|
|
|
(create_instruction_vldmdb): Likewise.
|
|
|
|
|
(stm32l4xx_create_replacing_stub_vldm): is_dp detects DP encoding,
|
|
|
|
|
uses it to re-encode.
|
|
|
|
|
|
2016-05-09 19:07:32 +08:00
|
|
|
|
2016-05-09 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 19938
|
|
|
|
|
* elf32-arm.c (elf32_arm_adjust_dynamic_symbol): Revert accidental
|
|
|
|
|
commit.
|
|
|
|
|
|
2016-05-09 15:38:35 +08:00
|
|
|
|
2016-05-09 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_init_stub_bfd): Remove redundant NULL check.
|
|
|
|
|
|
2016-05-07 00:46:34 +08:00
|
|
|
|
2016-05-06 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/17550
|
|
|
|
|
* elf-bfd.h (elf_link_hash_entry): Update comments for indx,
|
|
|
|
|
documenting that indx == -3 if symbol is defined in a discarded
|
|
|
|
|
section.
|
|
|
|
|
* elflink.c (elf_link_add_object_symbols): Set indx to -3 if
|
|
|
|
|
symbol is defined in a discarded section.
|
|
|
|
|
(elf_link_output_extsym): Strip a global symbol defined in a
|
|
|
|
|
discarded section.
|
|
|
|
|
|
2016-05-06 23:28:27 +08:00
|
|
|
|
2016-05-06 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_backend_add_symbol_hook): Defined for Intel
|
|
|
|
|
MCU.
|
|
|
|
|
|
2016-05-05 19:13:47 +08:00
|
|
|
|
2016-05-05 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_convert_load): Extract the GOT load
|
|
|
|
|
conversion to ...
|
|
|
|
|
(elf_i386_convert_load_reloc): This. New function.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_convert_load): Extract the GOT load
|
|
|
|
|
conversion to ...
|
|
|
|
|
(elf_x86_64_convert_load_reloc): This. New function.
|
|
|
|
|
|
2016-05-05 19:11:57 +08:00
|
|
|
|
2016-05-05 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_check_tls_transition): Remove abfd.
|
|
|
|
|
Don't check if contents == NULL.
|
|
|
|
|
(elf_i386_tls_transition): Add from_relocate_section. Check
|
|
|
|
|
from_relocate_section instead of contents != NULL. Update
|
|
|
|
|
elf_i386_check_tls_transition call.
|
|
|
|
|
(elf_i386_check_relocs): Cache the section contents if
|
|
|
|
|
keep_memory is FALSE. Pass FALSE as from_relocate_section to
|
|
|
|
|
elf_i386_tls_transition.
|
|
|
|
|
(elf_i386_relocate_section): Pass TRUE as from_relocate_section
|
|
|
|
|
to elf_i386_tls_transition.
|
|
|
|
|
(elf_backend_caches_rawsize): New.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_check_tls_transition): Don't check
|
|
|
|
|
if contents == NULL.
|
|
|
|
|
(elf_x86_64_tls_transition): Add from_relocate_section. Check
|
|
|
|
|
from_relocate_section instead of contents != NULL.
|
|
|
|
|
(elf_x86_64_check_relocs): Cache the section contents if
|
|
|
|
|
keep_memory is FALSE. Pass FALSE as from_relocate_section to
|
|
|
|
|
elf_x86_64_tls_transition.
|
|
|
|
|
(elf_x86_64_relocate_section): Pass TRUE as from_relocate_section
|
|
|
|
|
to elf_x86_64_tls_transition.
|
|
|
|
|
(elf_backend_caches_rawsize): New.
|
|
|
|
|
|
2016-05-04 06:47:55 +08:00
|
|
|
|
2016-05-03 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
PR 10549
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_add_symbol_hook): Handle
|
|
|
|
|
STB_GNU_UNIQUE.
|
|
|
|
|
|
2016-05-03 18:59:37 +08:00
|
|
|
|
2016-05-03 Jiong Wang <jiong.wang@arm.com>
|
|
|
|
|
|
|
|
|
|
* bfd-in.h (bfd_elf64_aarch64_set_options): Update prototype.
|
|
|
|
|
* bfd-in2.h (bfd_elf64_aarch64_set_options): Likewise.
|
|
|
|
|
* elfnn-aarch64.c (bfd_elfNN_aarch64_set_options): Initialize
|
|
|
|
|
no_apply_dynamic_relocs.
|
|
|
|
|
(elfNN_aarch64_final_link_relocate): Apply absolute relocations even though
|
|
|
|
|
dynamic relocations generated.
|
|
|
|
|
|
2016-04-29 23:27:13 +08:00
|
|
|
|
2016-04-29 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_size_dynamic_sections): Move interp
|
|
|
|
|
setting to ...
|
|
|
|
|
(elf_i386_create_dynamic_sections): Here.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_size_dynamic_sections): Move
|
|
|
|
|
interp setting to ...
|
|
|
|
|
(elf_x86_64_create_dynamic_sections): Here.
|
|
|
|
|
|
2016-04-29 23:17:12 +08:00
|
|
|
|
2016-04-29 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (UNDEFINED_WEAK_RESOLVED_TO_ZERO): Take GOT_RELOC
|
|
|
|
|
and replace (EH)->has_got_reloc with GOT_RELOC.
|
|
|
|
|
(elf_i386_fixup_symbol): Pass has_got_reloc to
|
|
|
|
|
UNDEFINED_WEAK_RESOLVED_TO_ZERO.
|
|
|
|
|
(elf_i386_allocate_dynrelocs): Likewise.
|
|
|
|
|
(elf_i386_relocate_section): Likewise.
|
|
|
|
|
(elf_i386_finish_dynamic_symbol): Likewise.
|
|
|
|
|
(elf_i386_convert_load): Pass TRUE to
|
|
|
|
|
UNDEFINED_WEAK_RESOLVED_TO_ZERO.
|
|
|
|
|
* elf64-x86-64.c (UNDEFINED_WEAK_RESOLVED_TO_ZERO): Take
|
|
|
|
|
GOT_RELOC and replace (EH)->has_got_reloc with GOT_RELOC.
|
|
|
|
|
(elf_x86_64_fixup_symbol): Pass has_got_reloc to
|
|
|
|
|
UNDEFINED_WEAK_RESOLVED_TO_ZERO.
|
|
|
|
|
(elf_x86_64_allocate_dynrelocs): Likewise.
|
|
|
|
|
(elf_x86_64_relocate_section): Likewise.
|
|
|
|
|
(elf_x86_64_finish_dynamic_symbol): Likewise.
|
|
|
|
|
(elf_x86_64_convert_load): Pass TRUE to
|
|
|
|
|
UNDEFINED_WEAK_RESOLVED_TO_ZERO.
|
|
|
|
|
|
2016-04-29 19:31:54 +08:00
|
|
|
|
2016-04-29 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (check_relocs_failed): New.
|
|
|
|
|
(elf_i386_check_relocs): Set check_relocs_failed on error.
|
|
|
|
|
(elf_i386_relocate_section): Skip if check_relocs failed.
|
|
|
|
|
|
2016-04-29 19:29:38 +08:00
|
|
|
|
2016-04-29 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_check_relocs): Set
|
|
|
|
|
check_relocs_failed on error.
|
|
|
|
|
|
2016-04-29 16:24:42 +08:00
|
|
|
|
2016-04-29 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 19938
|
|
|
|
|
* elf-bfd.h (struct elf_backend_data): Rename
|
|
|
|
|
elf_backend_set_special_section_info_and_link to
|
|
|
|
|
elf_backend_copy_special_section_fields.
|
|
|
|
|
* elfxx-target.h: Likewise.
|
|
|
|
|
* elf.c (section_match): Ignore the SHF_INFO_LINK flag when
|
|
|
|
|
comparing section flags.
|
|
|
|
|
(copy_special_section_fields): New function.
|
|
|
|
|
(_bfd_elf_copy_private_bfd_data): Copy the EI_ABIVERSION field.
|
|
|
|
|
Perform two scans over special sections. The first one looks for
|
|
|
|
|
a direct mapping between the output section and an input section.
|
|
|
|
|
The second scan looks for a possible match based upon section
|
|
|
|
|
characteristics.
|
|
|
|
|
* elf32-arm.c (elf32_arm_copy_special_section_fields): New
|
|
|
|
|
function. Handle setting the sh_link field of SHT_ARM_EXIDX
|
|
|
|
|
sections.
|
|
|
|
|
* elf32-i386.c (elf32_i386_set_special_info_link): Rename to
|
|
|
|
|
elf32_i386_copy_solaris_special_section_fields.
|
|
|
|
|
* elf32-sparc.c (elf32_sparc_set_special_section_info_link):
|
|
|
|
|
Rename to elf32_sparc_copy_solaris_special_section_fields.
|
|
|
|
|
* elf64-x86-64.c (elf64_x86_64_set_special_info_link): Rename to
|
|
|
|
|
elf64_x86_64_copy_solaris_special_section_fields.
|
|
|
|
|
|
2016-04-28 21:09:49 +08:00
|
|
|
|
2016-04-28 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* po/zh_CN.po: Updated Chinese (simplified) translation.
|
|
|
|
|
|
2016-04-28 00:13:10 +08:00
|
|
|
|
2016-04-27 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20006
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_convert_load): Skip debug sections
|
|
|
|
|
when estimating distances between output sections.
|
|
|
|
|
|
2016-04-27 11:23:05 +08:00
|
|
|
|
2016-04-27 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (_bfd_elf_is_start_stop): New function.
|
|
|
|
|
(_bfd_elf_gc_mark_rsec): Use it.
|
|
|
|
|
* elf-bfd.h (_bfd_elf_is_start_stop): Declare.
|
|
|
|
|
|
2016-04-13 17:17:31 +08:00
|
|
|
|
2016-04-26 Trevor Saunders <tbsaunde+binutils@tbsaunde.org>
|
|
|
|
|
|
|
|
|
|
* elf32-rx.c (rx_set_section_contents): Avoid arithmetic on void *.
|
|
|
|
|
* mmo.c (mmo_get_section_contents): Likewise.
|
|
|
|
|
(mmo_set_section_contents): Likewise.
|
|
|
|
|
|
2016-04-26 18:53:07 +08:00
|
|
|
|
2016-04-26 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h (elf_link_hash_table): Update comments for
|
|
|
|
|
dynsymcount.
|
|
|
|
|
* elflink.c (_bfd_elf_link_renumber_dynsyms): Always count for
|
|
|
|
|
the unused NULL entry at the head of dynamic symbol table.
|
|
|
|
|
(bfd_elf_size_dynsym_hash_dynstr): Remove dynsymcount != 0
|
|
|
|
|
checks.
|
|
|
|
|
|
2016-04-22 12:45:57 +08:00
|
|
|
|
2016-04-21 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (_bfd_elf_link_create_dynstrtab): Exclude linker
|
|
|
|
|
created file from dynobj.
|
|
|
|
|
|
2016-04-22 10:14:10 +08:00
|
|
|
|
2016-04-21 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (_bfd_elf_link_create_dynstrtab): Set dynobj to a
|
|
|
|
|
normal input file if possible.
|
|
|
|
|
|
2016-04-21 22:43:00 +08:00
|
|
|
|
2016-04-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* aout-adobe.c: Use _bfd_generic_link_check_relocs.
|
|
|
|
|
* aout-target.h: Likewise.
|
|
|
|
|
* aout-tic30.c: Likewise.
|
|
|
|
|
* binary.c: Likewise.
|
|
|
|
|
* bout.c: Likewise.
|
|
|
|
|
* coff-alpha.c: Likewise.
|
|
|
|
|
* coff-rs6000.c: Likewise.
|
|
|
|
|
* coff64-rs6000.c: Likewise.
|
|
|
|
|
* coffcode.h: Likewise.
|
|
|
|
|
* i386msdos.c: Likewise.
|
|
|
|
|
* i386os9k.c: Likewise.
|
|
|
|
|
* ieee.c: Likewise.
|
|
|
|
|
* ihex.c: Likewise.
|
|
|
|
|
* libbfd-in.h: Likewise.
|
|
|
|
|
* libecoff.h: Likewise.
|
|
|
|
|
* mach-o-target.c: Likewise.
|
|
|
|
|
* mmo.c: Likewise.
|
|
|
|
|
* nlm-target.h: Likewise.
|
|
|
|
|
* oasys.c: Likewise.
|
|
|
|
|
* pef.c: Likewise.
|
|
|
|
|
* plugin.c: Likewise.
|
|
|
|
|
* ppcboot.c: Likewise.
|
|
|
|
|
* som.c: Likewise.
|
|
|
|
|
* srec.c: Likewise.
|
|
|
|
|
* tekhex.c: Likewise.
|
|
|
|
|
* versados.c: Likewise.
|
|
|
|
|
* vms-alpha.c: Likewise.
|
|
|
|
|
* xsym.c: Likewise.
|
|
|
|
|
* elfxx-target.h: Use _bfd_elf_link_check_relocs.
|
|
|
|
|
* linker.c (bfd_link_check_relocs): New function.
|
|
|
|
|
(_bfd_generic_link_check_relocs): New function.
|
|
|
|
|
* targets.c (BFD_JUMP_TABLE_LINK): Add initialization of
|
|
|
|
|
_bfd_link_check_relocs field.
|
|
|
|
|
(struct bfd_target)L Add _bfd_link_check_relocs field.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* libbfd.h: Regenerate.
|
|
|
|
|
|
2016-04-21 08:12:46 +08:00
|
|
|
|
2016-04-20 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_gc_sweep_hook): Removed.
|
|
|
|
|
(elf_backend_gc_sweep_hook): Likewise.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_gc_sweep_hook): Likewise.
|
|
|
|
|
(elf_backend_gc_sweep_hook): Likewise.
|
|
|
|
|
|
2016-04-21 08:10:55 +08:00
|
|
|
|
2016-04-20 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (_bfd_elf_link_check_relocs): Don't check relocations
|
|
|
|
|
in excluded sections
|
|
|
|
|
|
2016-04-21 02:10:21 +08:00
|
|
|
|
2016-04-20 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19969
|
|
|
|
|
* elf64-x86-64.c (check_relocs_failed): New.
|
|
|
|
|
(elf_x86_64_need_pic): Moved before elf_x86_64_check_relocs.
|
|
|
|
|
Support relocation agaist local symbol. Set check_relocs_failed.
|
|
|
|
|
(elf_x86_64_check_relocs): Use elf_x86_64_need_pic. Check
|
|
|
|
|
R_X86_64_32 relocation overflow.
|
|
|
|
|
(elf_x86_64_relocate_section): Skip if check_relocs failed.
|
|
|
|
|
Update one elf_x86_64_need_pic and remove one elf_x86_64_need_pic.
|
|
|
|
|
|
2016-04-20 20:34:02 +08:00
|
|
|
|
2016-04-20 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_check_relocs): Call
|
|
|
|
|
_bfd_elf_create_ifunc_sections only for STT_GNU_IFUNC symbol.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_check_relocs): Likewise.
|
|
|
|
|
|
2016-04-20 20:26:37 +08:00
|
|
|
|
2016-04-20 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h (_bfd_elf_link_check_relocs): New.
|
|
|
|
|
* elflink.c (_bfd_elf_link_check_relocs): New function.
|
|
|
|
|
(elf_link_add_object_symbols): Call _bfd_elf_link_check_relocs
|
|
|
|
|
if check_relocs_after_open_input is FALSE.
|
|
|
|
|
|
2016-04-14 06:30:46 +08:00
|
|
|
|
2016-04-20 Trevor Saunders <tbsaunde+binutils@tbsaunde.org>
|
|
|
|
|
|
|
|
|
|
* cache.c: Update old style function definitions.
|
|
|
|
|
* elf32-m68k.c: Likewise.
|
|
|
|
|
* elf64-mmix.c: Likewise.
|
|
|
|
|
* stab-syms.c: Likewise.
|
|
|
|
|
|
2016-04-13 16:41:23 +08:00
|
|
|
|
2016-04-20 Trevor Saunders <tbsaunde+binutils@tbsaunde.org>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (put_thumb2_insn): Change argument type to bfd_byte *.
|
|
|
|
|
|
2016-04-16 07:20:02 +08:00
|
|
|
|
2016-04-15 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* Makefile.in: Regenerated with automake 1.11.6.
|
|
|
|
|
* aclocal.m4: Likewise.
|
|
|
|
|
* doc/Makefile.in: Likewise.
|
|
|
|
|
|
arc/nps400 : New cmem instructions and associated relocation
Add support for arc/nps400 cmem instructions, these load and store
instructions are hard-wired to access "0x57f00000 + 16-bit-offset".
Supporting this relocation required some additions to the arc relocation
handling in the bfd library, as well as the standard changes required to
add a new relocation type.
There's a test of the new instructions in the assembler, and a test of
the relocation in the linker.
bfd/ChangeLog:
* reloc.c: Add BFD_RELOC_ARC_NPS_CMEM16 entry.
* bfd-in2.h: Regenerate.
* libbfd.h: Regenerate.
* elf32-arc.c: Add 'opcode/arc.h' include.
(struct arc_relocation_data): Add symbol_name.
(arc_special_overflow_checks): New function.
(arc_do_relocation): Use arc_special_overflow_checks, reindent as
required, add an extra comment.
(elf_arc_relocate_section): Setup symbol_name in reloc_data.
gas/ChangeLog:
* testsuite/gas/arc/nps400-3.d: New file.
* testsuite/gas/arc/nps400-3.s: New file.
include/ChangeLog:
* elf/arc-reloc.def: Add ARC_NPS_CMEM16 reloc.
* opcode/arc.h (NPS_CMEM_HIGH_VALUE): Define.
ld/ChangeLog:
* testsuite/ld-arc/arc.exp: New file.
* testsuite/ld-arc/nps-1.s: New file.
* testsuite/ld-arc/nps-1a.d: New file.
* testsuite/ld-arc/nps-1b.d: New file.
* testsuite/ld-arc/nps-1b.err: New file.
opcodes/ChangeLog:
* arc-nps400-tbl.h: Add xldb, xldw, xld, xstb, xstw, and xst
instructions.
* arc-opc.c (insert_nps_cmem_uimm16): New function.
(extract_nps_cmem_uimm16): New function.
(arc_operands): Add NPS_XLDST_UIMM16 operand.
2016-03-30 07:02:19 +08:00
|
|
|
|
2016-04-14 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
|
|
|
|
|
|
* reloc.c: Add BFD_RELOC_ARC_NPS_CMEM16 entry.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* libbfd.h: Regenerate.
|
|
|
|
|
* elf32-arc.c: Add 'opcode/arc.h' include.
|
|
|
|
|
(struct arc_relocation_data): Add symbol_name.
|
|
|
|
|
(arc_special_overflow_checks): New function.
|
|
|
|
|
(arc_do_relocation): Use arc_special_overflow_checks, reindent as
|
|
|
|
|
required, add an extra comment.
|
|
|
|
|
(elf_arc_relocate_section): Setup symbol_name in reloc_data.
|
|
|
|
|
|
2016-04-07 01:55:23 +08:00
|
|
|
|
2016-04-14 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (tls_got_entries): Add 'TLS_GOT_' prefix to all
|
|
|
|
|
entries.
|
|
|
|
|
(elf_arc_relocate_section): Update enum uses.
|
|
|
|
|
(elf_arc_check_relocs): Likewise.
|
|
|
|
|
(elf_arc_finish_dynamic_symbol): Likewise.
|
|
|
|
|
|
2016-04-14 23:36:32 +08:00
|
|
|
|
2016-04-14 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf.c (_bfd_elf_copy_private_bfd_data): Replace "link" with
|
|
|
|
|
"sh_link".
|
|
|
|
|
|
2016-04-14 19:04:09 +08:00
|
|
|
|
2016-04-14 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR target/19938
|
|
|
|
|
* elf-bbfd.h (struct elf_backend_data): New field:
|
|
|
|
|
elf_strtab_flags.
|
|
|
|
|
New field: elf_backend_set_special_section_info_and_link
|
|
|
|
|
* elfxx-target.h (elf_backend_strtab_flags): Define if not already
|
|
|
|
|
defined.
|
|
|
|
|
(elf_backend_set_special_section_info_and_link): Define if not
|
|
|
|
|
already defined.
|
|
|
|
|
(elfNN_bed): Use elf_backend_set_special_section_info_and_link and
|
|
|
|
|
elf_backend_strtab_flags macros to initialise fields in structure.
|
|
|
|
|
* elf.c (_bfd_elf_make_section_from_shdr): Check for SHF_STRINGS
|
|
|
|
|
being set even if SHF_MERGE is not set.
|
|
|
|
|
(elf_fake_sections): Likewise.
|
|
|
|
|
(section_match): New function. Matches two ELF sections based
|
|
|
|
|
upon fixed characteristics.
|
|
|
|
|
(find_link): New function. Locates a section in a BFD that
|
|
|
|
|
matches a section in a different BFD.
|
|
|
|
|
(_bfd_elf_copy_private_bfd_data): Copy the sh_info and sh_link
|
|
|
|
|
fields of reserved sections.
|
|
|
|
|
(bfd_elf_compute_section_file_positions): Set the flags for the
|
|
|
|
|
.shstrtab section based upon the elf_strtab_flags field in the
|
|
|
|
|
elf_backend_data structure.
|
|
|
|
|
(swap_out_syms): Likewise for the .strtab section.
|
|
|
|
|
* elflink.c (bfd_elf_final_link): Set the flags for the
|
|
|
|
|
.strtab section based upon the elf_strtab_flags field in the
|
|
|
|
|
elf_backend_data structure.
|
|
|
|
|
* elf32-i386.c (elf32_i386_set_special_info_link): New function.
|
|
|
|
|
(elf_backend_strtab_flags): Set to SHF_STRINGS for Solaris
|
|
|
|
|
targets.
|
|
|
|
|
(elf_backend_set_special_section_info_and_link): Define for
|
|
|
|
|
Solaris targets.
|
|
|
|
|
* elf32-sparc.c: Likewise.
|
|
|
|
|
* elf64-x86-64.c: Likewise.
|
|
|
|
|
|
2016-04-12 10:41:37 +08:00
|
|
|
|
2016-04-11 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19939
|
|
|
|
|
* elf-bfd.h (_bfd_elf_allocate_ifunc_dyn_relocs): Add a pointer
|
|
|
|
|
to bfd_boolean.
|
|
|
|
|
* elf-ifunc.c (_bfd_elf_allocate_ifunc_dyn_relocs): Updated.
|
|
|
|
|
Set *readonly_dynrelocs_against_ifunc_p to TRUE if dynamic reloc
|
|
|
|
|
applies to read-only section.
|
|
|
|
|
* elf32-i386.c (elf_i386_link_hash_table): Add
|
|
|
|
|
readonly_dynrelocs_against_ifunc.
|
|
|
|
|
(elf_i386_allocate_dynrelocs): Updated.
|
|
|
|
|
(elf_i386_size_dynamic_sections): Issue an error for read-only
|
|
|
|
|
segment with dynamic IFUNC relocations only if
|
|
|
|
|
readonly_dynrelocs_against_ifunc is TRUE.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_link_hash_table): Add
|
|
|
|
|
readonly_dynrelocs_against_ifunc.
|
|
|
|
|
(elf_x86_64_allocate_dynrelocs): Updated.
|
|
|
|
|
(elf_x86_64_size_dynamic_sections): Issue an error for read-only
|
|
|
|
|
segment with dynamic IFUNC relocations only if
|
|
|
|
|
readonly_dynrelocs_against_ifunc is TRUE.
|
|
|
|
|
* elfnn-aarch64.c (elfNN_aarch64_allocate_ifunc_dynrelocs):
|
|
|
|
|
Updated.
|
|
|
|
|
|
2016-04-06 16:26:42 +08:00
|
|
|
|
2016-04-06 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (elf32_arm_size_stubs): Move error_ret_free_local to be
|
|
|
|
|
a fall through from error_ret_free_internal. Free local_syms in
|
|
|
|
|
error_ret_free_local if allocated from bfd_elf_get_elf_syms ().
|
|
|
|
|
|
2016-04-05 23:23:24 +08:00
|
|
|
|
2016-04-05 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (plt_do_relocs_for_symbol): Changed.
|
|
|
|
|
(relocate_plt_for_entry): Likewise.
|
|
|
|
|
|
2016-04-05 23:14:03 +08:00
|
|
|
|
2016-04-05 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf_arc_check_relocs): Changed
|
|
|
|
|
|
2016-04-05 23:05:09 +08:00
|
|
|
|
2016-04-05 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (name_for_global_symbol): Changed assert.
|
|
|
|
|
(get_replace_function): Created.:
|
|
|
|
|
(struct arc_relocation_data): Changed to signed types.
|
|
|
|
|
(defines S, L, P, PDATA): Casted to signed type.
|
|
|
|
|
(defines SECTSTART, _SDA_BASE_, TLS_REL): Likewise.
|
|
|
|
|
(PRINT_DEBUG_RELOC_INFO_BEFORE): Changed.
|
|
|
|
|
(arc_do_relocation): Changed.
|
|
|
|
|
|
2016-04-05 22:34:12 +08:00
|
|
|
|
2016-04-05 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (name_for_global_symbol): Added assert to check for
|
|
|
|
|
symbol index.
|
|
|
|
|
(elf_arc_relocate_section): Added and changed asserts, validating
|
|
|
|
|
the synamic symbol index.
|
|
|
|
|
(elf_arc_finish_dynamic_symbol): Do not fill the dynamic
|
|
|
|
|
relocation if symbol has dynindx set to -1.
|
|
|
|
|
|
ELF/LD: Avoid producing hidden and internal dynamic symbols
Always turn hidden and internal symbols which have a dynamic index into
local ones. This is required by the the ELF gABI[1]:
"A hidden symbol contained in a relocatable object must be either
removed or converted to STB_LOCAL binding by the link-editor when the
relocatable object is included in an executable file or shared object."
"An internal symbol contained in a relocatable object must be either
removed or converted to STB_LOCAL binding by the link-editor when the
relocatable object is included in an executable file or shared object."
The ELF linker usually respects this requirement, however in the case
where a dynamic symbol has been preallocated due to a reference of the
default export class aka visibility from the object being linked, and
then merged with a hidden or internal symbol definition from within the
same object, then the original export class is carried over to the
output dynamic symbol table, because while merging the generic ELF
linker only converts affected dynamic symbols to local when they are
defined or referenced by the object being linked and a dynamic object
involved in the link both at a time.
The dynamic symbol produced confuses then the dynamic loader at the run
time -- the hidden or internal export class is ignored and the symbol
follows preemption rules as with the default export class.
In the MIPS target it happens when `mips_elf_record_global_got_symbol'
creates a dynamic symbol when a call relocation is encountered.
Additionally if the undefined symbol referred by such a relocation does
specify the intended export class, then a local dynamic symbol is
created instead, which is harmless and allowed, but useless. Normally
no local dynamic symbols are created, except for a single dummy one at
the beginning.
Correct the problem by removing the extra check for a dynamic symbol
being defined or referenced by the object being linked and a dynamic
object involved in the link both at a time. The test cases included
cover the internal and hidden symbol cases, as well as a protected
symbol for a reference, the handling of which is unchanged by this fix.
Both cases described above are covered, that is where an internal or
hidden dynamic symbol is produced and where a local one is.
NB this change affects CRIS results where some symbols in the static
table produced in a final link are now converted from STV_HIDDEN to
STB_LOCAL. This happens whenever the `elf_backend_hide_symbol' handler
is called, so the affected symbols must have been chosen for entering
into the dynamic symbol table, except in these test cases no such symbol
table is produced. In fully linked binaries the static symbol table is
only used for debugging though, so such a change is fine.
References:
[1] "System V Application Binary Interface - DRAFT - 24 April 2001",
The Santa Cruz Operation, Inc., "Symbol Table",
<http://www.sco.com/developers/gabi/2001-04-24/ch4.symtab.html>
bfd/
PR ld/19908
* elflink.c (elf_link_add_object_symbols): Always turn hidden
and internal symbols which have a dynamic index into local
ones.
ld/
PR ld/19908
* testsuite/ld-cris/tls-e-20.d: Adjust for hidden symbol
handling fix.
* testsuite/ld-cris/tls-e-20a.d: Likewise.
* testsuite/ld-cris/tls-e-21.d: Likewise.
* testsuite/ld-cris/tls-e-23.d: Likewise.
* testsuite/ld-cris/tls-e-80.d: Likewise.
* testsuite/ld-cris/tls-gd-3h.d: Likewise.
* testsuite/ld-cris/tls-leie-19.d: Likewise.
* testsuite/ld-mips-elf/export-class-ref-lib.sd: New test.
* testsuite/ld-mips-elf/export-hidden-ref.sd: New test.
* testsuite/ld-mips-elf/export-internal-ref.sd: New test.
* testsuite/ld-mips-elf/export-protected-ref.sd: New test.
* testsuite/ld-mips-elf/export-class-ref-f0.s: New test source.
* testsuite/ld-mips-elf/export-class-ref-f1.s: New test source.
* testsuite/ld-mips-elf/export-class-ref-f2.s: New test source.
* testsuite/ld-mips-elf/mips-elf.exp: Run the new tests.
2016-04-05 22:10:05 +08:00
|
|
|
|
2016-04-05 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (elf_link_add_object_symbols): Always turn hidden
|
|
|
|
|
and internal symbols which have a dynamic index into local
|
|
|
|
|
ones.
|
|
|
|
|
|
2016-04-04 19:53:33 +08:00
|
|
|
|
2016-04-04 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 19872
|
|
|
|
|
* dwarf2.c (parse_comp_unit): Skip warning about unrecognised
|
|
|
|
|
version number if the version is zero.
|
|
|
|
|
|
2016-04-01 14:38:45 +08:00
|
|
|
|
2016-04-01 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 19886
|
|
|
|
|
* elflink.c (on_needed_list): Recursively check needed status.
|
|
|
|
|
(elf_link_add_object_symbols): Adjust.
|
|
|
|
|
|
2016-03-30 21:52:26 +08:00
|
|
|
|
2016-03-30 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-avr.c (avr_elf32_load_records_from_section): Free
|
|
|
|
|
internal_relocs only if they aren't cached.
|
|
|
|
|
|
2016-03-29 17:24:16 +08:00
|
|
|
|
2016-03-29 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 17334
|
|
|
|
|
* elf32-bfin.c (elf32_bfinfdpic_finish_dynamic_sections): Relax
|
|
|
|
|
assertion on the size of the got section to allow it to be bigger
|
|
|
|
|
than the number of relocs.
|
|
|
|
|
|
2016-03-29 11:55:23 +08:00
|
|
|
|
2016-03-29 Toni Spets <toni.spets@iki.fi>
|
|
|
|
|
|
|
|
|
|
PR 19878
|
|
|
|
|
* coffcode.h (coff_write_object_contents): Revert accidental
|
|
|
|
|
2014-11-10 change.
|
|
|
|
|
|
2016-03-22 20:20:18 +08:00
|
|
|
|
2016-03-22 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 19850
|
|
|
|
|
* dwarf2.c (read_attribute_value): Skip info_ptr check for
|
|
|
|
|
DW_FORM_flag_present.
|
|
|
|
|
|
2016-03-22 17:41:16 +08:00
|
|
|
|
2016-03-22 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
2016-03-22 19:34:26 +08:00
|
|
|
|
* cpu-v850_rh850.c (arch_info_struct): Restore v850-rh850 as an
|
|
|
|
|
architecture name for backwards compatibility.
|
|
|
|
|
|
2016-03-22 18:37:42 +08:00
|
|
|
|
* peXXigen.c (_bfd_XXi_write_codeview_record): Fix possible
|
|
|
|
|
unbounded stack use.
|
|
|
|
|
|
2016-03-22 17:41:16 +08:00
|
|
|
|
* warning.m4 (GCC_WARN_CFLAGS): Only add -Wstack-usage if using a
|
|
|
|
|
sufficiently recent version of GCC.
|
|
|
|
|
* configure: Regenerate.
|
|
|
|
|
|
2016-03-22 11:50:18 +08:00
|
|
|
|
2016-03-22 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 19851
|
|
|
|
|
* plugin.c (try_load_plugin): Avoid -Wstack-usage warning.
|
|
|
|
|
|
2016-03-16 05:51:50 +08:00
|
|
|
|
2016-03-21 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
|
|
|
|
|
|
* archures.c (bfd_mach_arc_nps400): Define.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* cpu-arc.c (arch_info_struct): New entry for nps400, renumber
|
|
|
|
|
some existing entries to make space.
|
|
|
|
|
* elf32-arc.c (arc_elf_object_p): Add nps400 case.
|
|
|
|
|
(arc_elf_final_write_processing): Likewise.
|
|
|
|
|
|
arc: Remove EF_ARC_CPU_GENERIC constant.
The constant EF_ARC_CPU_GENERIC is defined in the include/elf/arc.h
file, and is used in a few places in binutils, however, this constant
should never make it into the elf header flags; we always set a valid
cpu type in the assembler, which should then be copied over during
linking.
There are some non-gnu arc compilers that don't write an architecture
type into the e_flags field, instead leaving the field as 0, which is
the EF_ARC_CPU_GENERIC value. This non-gnu compiler uses the machine
type to distinguish between the old and newer arc architectures, setting
the machine type to EM_ARC_COMPACT for old arc600, arc601, and arc700
architectures, while using EM_ARC_COMPACT2 for newer arcem and archs
architectures.
Previously when displaying the machine flags for an older EM_ARC_COMPACT
machine, if the e_flags had not been filled in, then we relied on the
default case statement to display the message "Generic ARCompact", while
in the EM_ARC_COMPACT2 case we specifically handled EF_ARC_CPU_GENERIC
to print "ARC Generic", leaving the default case to print a message
about unrecognised cpu flag.
After this commit EF_ARC_CPU_GENERIC has been removed, for both machine
types EM_ARC_COMPACT and EM_ARC_COMPACT2 we now rely on the default case
statement to handle the situation where the e_flags has not been filled
in. The message displayed is now "Unknown ARCompact" (for older arc
architectures) and "Unknown ARC" (for the newer architectures). The
switch from "Generic" to "Unknown" in the message string is for clarity,
calling the file "Generic" can give the impression that the file is
compiled for a common sub-set of the architectures, and would therefore
run on any type of machine (or at least any type of new or old machine
depending on if the machine type is ARC or ARCv2). However, this was
not what "Generic" meant, it really meant "Unknown", so that's what we
now say.
As part of the merging of the readelf flag reading code, I have unified
the strings used in displaying the ELF ABI. This means that for older
arc machines (arc600, arc601, and arc700) the string used for the
original ABI, and ABIv2 have changed, the current ABIv3 remains the
same. For the newer architectures (arcem and archs) the abi strings
remain unchanged in all cases.
bfd/ChangeLog:
* elf32-arc.c (arc_elf_print_private_bfd_data): Remove use of
EF_ARC_CPU_GENERIC.
(arc_elf_final_write_processing): Don't bother setting cpu field
in e_flags, this will have been set elsewhere.
binutils/ChangeLog:
* readelf.c (get_machine_flags): Move arc processing into...
(decode_ARC_machine_flags): ... new function. Remove use of
EF_ARC_CPU_GENERIC, change default case from "generic arc" to
"unknown arc". Merged ABI printing between two machine types.
gas/ChangeLog:
* config/tc-arc.c (arc_select_cpu): Remove use of
EF_ARC_CPU_GENERIC.
include/ChangeLog:
* elf/arc.h (EF_ARC_CPU_GENERIC): Delete. Update related comment.
2016-03-16 05:38:30 +08:00
|
|
|
|
2016-03-21 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (arc_elf_print_private_bfd_data): Remove use of
|
|
|
|
|
EF_ARC_CPU_GENERIC.
|
|
|
|
|
(arc_elf_final_write_processing): Don't bother setting cpu field
|
|
|
|
|
in e_flags, this will have been set elsewhere.
|
|
|
|
|
|
2016-03-16 03:09:23 +08:00
|
|
|
|
2016-03-21 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (arc_elf_final_write_processing): Switch to using
|
|
|
|
|
EF_ARC_MACH_MSK.
|
|
|
|
|
|
2016-03-22 00:31:46 +08:00
|
|
|
|
2016-03-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* warning.m4 (GCC_WARN_CFLAGS): Add -Wstack-usage=262144
|
|
|
|
|
* configure: Regenerate.
|
|
|
|
|
* elf32-m68hc1x.c (elf32_m68hc11_relocate_section): Replace use of
|
|
|
|
|
alloca with call to xmalloc.
|
|
|
|
|
* elf32-nds32.c: Likewise.
|
|
|
|
|
* elf64-hppa.c: Likewise.
|
|
|
|
|
* elfxx-mips.c: Likewise.
|
|
|
|
|
* pef.c: Likewise.
|
|
|
|
|
* pei-x86_64.c: Likewise.
|
|
|
|
|
* som.c: Likewise.
|
|
|
|
|
* xsym.c: Likewise.
|
|
|
|
|
|
2016-03-16 02:46:51 +08:00
|
|
|
|
2016-03-15 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19827
|
|
|
|
|
* elf32-i386.c (elf_i386_check_relocs): Bind defined symbol
|
|
|
|
|
locally in PIE.
|
|
|
|
|
(elf_i386_relocate_section): Likewise.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_check_relocs): Likewise.
|
|
|
|
|
(elf_x86_64_relocate_section): Likewise.
|
|
|
|
|
|
2016-03-16 02:07:06 +08:00
|
|
|
|
2016-03-15 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19807
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_relocate_section): Check
|
|
|
|
|
no_reloc_overflow_check to diable R_X86_64_32/R_X86_64_32S
|
|
|
|
|
relocation overflow check.
|
|
|
|
|
|
2016-03-15 04:17:22 +08:00
|
|
|
|
2016-03-14 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* bfd-in2.h: Regenerated.
|
|
|
|
|
|
2016-03-11 17:17:28 +08:00
|
|
|
|
2016-03-11 Dan Gissel <dgisselq@ieee.org>
|
|
|
|
|
|
|
|
|
|
PR 19713
|
|
|
|
|
* elf.c (_bfd_elf_section_offset): Ensure that the returned offset
|
|
|
|
|
uses bytes not octets.
|
|
|
|
|
* elflink.c (resolve_section): Likewise.
|
|
|
|
|
Add a bfd parameter.
|
|
|
|
|
(eval_section): Pass the input_bfd to resolve_section.
|
|
|
|
|
(bfd_elf_perform_complex_relocation): Convert byte offset to
|
|
|
|
|
octets before read and writing values.
|
|
|
|
|
(elf_link_input_bfd): Add byte to octet conversions.
|
|
|
|
|
(elf_reloc_link_order): Likewise.
|
|
|
|
|
(elf_fixup_link_order): Likewise.
|
|
|
|
|
(bfd_elf_final_link): Likewise.
|
|
|
|
|
* reloc.c (_bfd_final_link_relocate): Likewise.
|
|
|
|
|
* syms.c (_bfd_stab_section_find_nearest_line): Likewise.
|
|
|
|
|
|
2016-03-10 23:29:42 +08:00
|
|
|
|
2016-03-10 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* config.bfd: Mark the i370 target as obsolete.
|
|
|
|
|
|
Fix v850 bfd arch info printable names
Currently, it's not possible to manually set some of the v850 archs in
gdb:
(gdb) set architecture v850<TAB>
v850 (using old gcc ABI)
v850-rh850
v850e
v850e (using old gcc ABI)
v850e1
[...]
(gdb) set architecture v850 (using old gcc ABI)
Ambiguous item "v850 (using old gcc ABI)".
The problem is that "set architecture" is a GDB "enum command", and
GDB only considers an enum value to be the string up until the first
space. So writing "v850 (using old gcc ABI)" is the same as writing
"v850", and then that's not an unambiguous arch printable name prefix.
v850 is actually the only arch that has spaces in its printable name.
One can conveniently see that with e.g.:
(gdb) set max-completions unlimited
(gdb) complete set architecture
...
Rather than hack GDB into accepting this somehow, make v850 arch
printable names more like the printable names of the other archs, and
put the abi variant in the "machine" part, after a ':'.
We now get:
(gdb) set architecture v850<TAB>
v850:old-gcc-abi
v850:rh850
v850e
v850e1
v850e1:old-gcc-abi
v850e2
v850e2:old-gcc-abi
[...]
And now "set architecture v850:old-gcc-abi" works as expected.
I ran the binutils/gas/ld testsuites, and found no regressions. I
don't have a cross compiler handy, but I ran the gdb tests anyway,
which covers at least some snoke testing.
I think that the OUTPUT_ARCH in ld/scripttempl/v850.sc may have got
broken with the previous 2012 change, since I hacked v850_rh850.sc to
output "v850" and ld failed to grok it. I think it only works if the
old GCC ABI is the configured v850 default ABI. That's now fixed by
changing to use explicit v850:old-gcc-abi.
Also, this actually "fixes" an existing GDB test, which isn't likewise
expecting spaces in arch names, when GDB is configured for
--target=v850:
(gdb) FAIL: gdb.xml/tdesc-arch.exp: read valid architectures
bfd/ChangeLog:
2016-03-09 Pedro Alves <palves@redhat.com>
* cpu-v850.c (N): Append ":old-gcc-abi" instead of " (using old
gcc ABI)" to printable name.
* cpu-v850_rh850.c (bfd_v850_rh850_arch): Use "v850:rh850" instead
of "v850-rh850" as printable name.
ld/ChangeLog:
2016-03-09 Pedro Alves <palves@redhat.com>
* scripttempl/v850.sc: Use "v850:old-gcc-abi" as OUTPUT_ARCH.
* scripttempl/v850_rh850.sc: Use "v850:rh850" as OUTPUT_ARCH.
2016-03-09 23:43:13 +08:00
|
|
|
|
2016-03-09 Pedro Alves <palves@redhat.com>
|
|
|
|
|
|
|
|
|
|
* cpu-v850.c (N): Append ":old-gcc-abi" instead of " (using old
|
|
|
|
|
gcc ABI)" to printable name.
|
|
|
|
|
* cpu-v850_rh850.c (bfd_v850_rh850_arch): Use "v850:rh850" instead
|
|
|
|
|
of "v850-rh850" as printable name.
|
|
|
|
|
|
2016-03-09 23:26:45 +08:00
|
|
|
|
2016-03-09 Leon Winter <winter-gcc@bfw-online.de>
|
|
|
|
|
|
|
|
|
|
PR ld/19623
|
|
|
|
|
* cofflink.c (_bfd_coff_generic_relocate_section): Do not apply
|
|
|
|
|
relocations against absolute symbols.
|
|
|
|
|
|
2016-03-09 13:40:53 +08:00
|
|
|
|
2016-03-09 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/19775
|
|
|
|
|
* coff-alpha.c (alpha_ecoff_openr_next_archived_file): Allow zero
|
|
|
|
|
length elements in the archive.
|
|
|
|
|
|
2016-03-09 12:41:41 +08:00
|
|
|
|
2016-03-08 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19789
|
|
|
|
|
* elflink.c (elf_link_add_object_symbols): Create dynamic sections
|
|
|
|
|
for -E/--dynamic-list only when not relocatable.
|
|
|
|
|
|
2016-03-09 01:42:01 +08:00
|
|
|
|
2016-03-08 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19784
|
|
|
|
|
* elf32-i386.c (elf_i386_check_relocs): Increment PLT reference
|
|
|
|
|
count for locally defined local IFUNC symbols in shared object.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_check_relocs): Likewise.
|
|
|
|
|
|
2016-03-08 21:28:55 +08:00
|
|
|
|
2016-03-08 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19579
|
|
|
|
|
* elflink.c (_bfd_elf_merge_symbol): Group common symbol checking
|
|
|
|
|
together.
|
|
|
|
|
|
2016-03-08 21:19:52 +08:00
|
|
|
|
2016-03-08 Cupertino Miranda <Cupertino.Miranda@synopsys.com>
|
|
|
|
|
Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (arc_bfd_get_32): Becomes an alias for bfd_get_32.
|
|
|
|
|
(arc_bfd_put_32): Becomes an alias for bfd_put_32.
|
|
|
|
|
(arc_elf_howto_init): Added assert to validate relocations.
|
|
|
|
|
(get_middle_endian_relocation): Delete.
|
|
|
|
|
(middle_endian_convert): New function.
|
|
|
|
|
(ME): Redefine, now does nothing.
|
|
|
|
|
(IS_ME): New define.
|
|
|
|
|
(arc_do_relocation): Extend the attached 'ARC_RELOC_HOWTO'
|
|
|
|
|
definition to call middle_endian_convert. Add a new local
|
|
|
|
|
variable and make use of this throughout. Added call to
|
|
|
|
|
arc_bfd_get_8 and arc_bfd_put_8 for 8 bit relocations.
|
|
|
|
|
|
2016-03-08 01:29:25 +08:00
|
|
|
|
2016-03-07 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/19775
|
|
|
|
|
* archive.c (bfd_generic_openr_next_archived_file): Allow zero
|
|
|
|
|
length elements in the archive.
|
|
|
|
|
|
2016-03-07 23:40:50 +08:00
|
|
|
|
2016-03-07 Jiong Wang <jiong.wang@arm.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-aarch64.c (elfNN_aarch64_check_relocs): Always create .got
|
|
|
|
|
section if the symbol "_GLOBAL_OFFSET_TABLE_" is referenced.
|
|
|
|
|
|
2016-03-04 22:37:34 +08:00
|
|
|
|
2016-03-04 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19579
|
|
|
|
|
* elflink.c (_bfd_elf_merge_symbol): Treat common symbol in
|
|
|
|
|
executable as definition if the new definition comes from a
|
|
|
|
|
shared library.
|
|
|
|
|
|
2016-03-02 06:32:30 +08:00
|
|
|
|
2016-03-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* Makefile.in: Regenerate.
|
|
|
|
|
* po/SRC-POTFILES.in: Regenerate.
|
|
|
|
|
|
2016-02-29 23:51:11 +08:00
|
|
|
|
2016-02-29 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf_arc_relocate_section): Added rules to fix the
|
|
|
|
|
relocation addend when sections get merged.
|
|
|
|
|
|
2016-02-29 23:07:48 +08:00
|
|
|
|
2016-02-29 Cupertino Miranda <Cupertino.Miranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (arc_elf_final_write_processing): Add condition to
|
|
|
|
|
the flag change.
|
|
|
|
|
(elf_arc_relocate_section): Fixes and conditions to support PIE.
|
|
|
|
|
Assert for code sections dynamic relocs.
|
|
|
|
|
|
2016-02-27 01:52:34 +08:00
|
|
|
|
2016-02-26 Renlin Li <renlin.li@arm.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-aarch64.c (elfNN_aarch64_howto_table): Fix signed overflow
|
|
|
|
|
check for MOVW_SABS_G0, MOVW_SABS_G1, MOVW_SABS_G2.
|
|
|
|
|
|
2016-02-27 01:38:08 +08:00
|
|
|
|
2016-02-26 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19609
|
|
|
|
|
* elf32-i386.c (elf_i386_convert_load): Convert to R_386_32 for
|
|
|
|
|
load with locally bound symbols if PIC is false or there is no
|
|
|
|
|
base register. Optimize branch to 0 if PIC is false.
|
|
|
|
|
(elf_i386_relocate_section): Don't generate dynamic relocations
|
|
|
|
|
against undefined weak symbols if PIC is false.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_convert_load): Disable optimization
|
|
|
|
|
if we can't estimate relocation overflow with --no-relax.
|
|
|
|
|
Convert to R_X86_64_32S/R_X86_64_32 for load with locally bound
|
|
|
|
|
symbols if PIC is false. Optimize branch to 0 if PIC is false.
|
|
|
|
|
(elf_x86_64_relocate_section): Don't generate dynamic relocations
|
|
|
|
|
against undefined weak symbols if PIC is false.
|
|
|
|
|
|
2016-02-26 22:44:03 +08:00
|
|
|
|
2016-02-26 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19645
|
|
|
|
|
* bfd.c (bfd): Change flags to 20 bits.
|
|
|
|
|
(BFD_CONVERT_ELF_COMMON): New.
|
|
|
|
|
(BFD_USE_ELF_STT_COMMON): Likewise.
|
|
|
|
|
(BFD_FLAGS_SAVED): Add BFD_CONVERT_ELF_COMMON and
|
|
|
|
|
BFD_USE_ELF_STT_COMMON.
|
|
|
|
|
(BFD_FLAGS_FOR_BFD_USE_MASK): Likewise.
|
|
|
|
|
* configure.ac: Remove --enable-elf-stt-common.
|
|
|
|
|
* elf.c (swap_out_syms): Choose STT_COMMON or STT_OBJECT for
|
|
|
|
|
common symbol depending on BFD_CONVERT_ELF_COMMON and
|
|
|
|
|
BFD_USE_ELF_STT_COMMON.
|
|
|
|
|
* elfcode.h (elf_slurp_symbol_table): Set BSF_ELF_COMMON for
|
|
|
|
|
STT_COMMON.
|
|
|
|
|
* elflink.c (bfd_elf_link_mark_dynamic_symbol): Also check
|
|
|
|
|
STT_COMMON.
|
|
|
|
|
(elf_link_convert_common_type): New function.
|
|
|
|
|
(elf_link_output_extsym): Choose STT_COMMON or STT_OBJECT for
|
|
|
|
|
common symbol depending on BFD_CONVERT_ELF_COMMON and
|
|
|
|
|
BFD_USE_ELF_STT_COMMON. Set sym.st_info after sym.st_shndx.
|
|
|
|
|
* elfxx-target.h (TARGET_BIG_SYM): Add BFD_CONVERT_ELF_COMMON
|
|
|
|
|
and BFD_USE_ELF_STT_COMMON to object_flags.
|
|
|
|
|
(TARGET_LITTLE_SYM): Likewise.
|
|
|
|
|
* syms.c (BSF_KEEP_G): Renamed to ...
|
|
|
|
|
(BSF_ELF_COMMON): This.
|
|
|
|
|
* bfd-in2.h: Regenerated.
|
|
|
|
|
* config.in: Likewise.
|
|
|
|
|
* configure: Likewise.
|
|
|
|
|
|
2016-02-26 20:16:15 +08:00
|
|
|
|
2016-02-26 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19636
|
|
|
|
|
PR ld/19704
|
|
|
|
|
PR ld/19719
|
|
|
|
|
* elf32-i386.c (UNDEFINED_WEAK_RESOLVED_TO_ZERO): New.
|
|
|
|
|
(elf_i386_link_hash_entry): Add has_got_reloc and
|
|
|
|
|
has_non_got_reloc.
|
|
|
|
|
(elf_i386_link_hash_table): Add interp.
|
|
|
|
|
(elf_i386_link_hash_newfunc): Initialize has_got_reloc and
|
|
|
|
|
has_non_got_reloc.
|
|
|
|
|
(elf_i386_copy_indirect_symbol): Copy has_got_reloc and
|
|
|
|
|
has_non_got_reloc.
|
|
|
|
|
(elf_i386_check_relocs): Set has_got_reloc and has_non_got_reloc.
|
|
|
|
|
(elf_i386_fixup_symbol): New function.
|
|
|
|
|
(elf_i386_pie_finish_undefweak_symbol): Likewise.
|
|
|
|
|
(elf_i386_allocate_dynrelocs): Don't allocate space for dynamic
|
|
|
|
|
relocations and discard relocations against resolved undefined
|
|
|
|
|
weak symbols in executable. Don't make resolved undefined weak
|
|
|
|
|
symbols in executable dynamic. Keep dynamic non-GOT/non-PLT
|
|
|
|
|
relocation against undefined weak symbols in PIE.
|
|
|
|
|
(elf_i386_size_dynamic_sections): Set interp to .interp section.
|
|
|
|
|
(elf_i386_relocate_section): Don't generate dynamic relocations
|
|
|
|
|
against resolved undefined weak symbols in PIE, except for
|
|
|
|
|
R_386_PC32.
|
|
|
|
|
(elf_i386_finish_dynamic_symbol): Keep PLT/GOT entries without
|
|
|
|
|
dynamic PLT/GOT relocations for resolved undefined weak symbols.
|
|
|
|
|
Don't generate dynamic relocation against resolved undefined weak
|
|
|
|
|
symbol in executable.
|
|
|
|
|
(elf_i386_finish_dynamic_sections): Call
|
|
|
|
|
elf_i386_pie_finish_undefweak_symbol on all symbols in PIE.
|
|
|
|
|
(elf_backend_fixup_symbol): New.
|
|
|
|
|
* elf64-x86-64.c (UNDEFINED_WEAK_RESOLVED_TO_ZERO): New.
|
|
|
|
|
(elf_x86_64_link_hash_entry): Add has_got_reloc and
|
|
|
|
|
has_non_got_reloc.
|
|
|
|
|
(elf_x86_64_link_hash_table): Add interp.
|
|
|
|
|
(elf_x86_64_link_hash_newfunc): Initialize has_got_reloc and
|
|
|
|
|
has_non_got_reloc.
|
|
|
|
|
(elf_x86_64_copy_indirect_symbol): Copy has_got_reloc and
|
|
|
|
|
has_non_got_reloc.
|
|
|
|
|
(elf_x86_64_check_relocs): Set has_got_reloc and
|
|
|
|
|
has_non_got_reloc.
|
|
|
|
|
(elf_x86_64_fixup_symbol): New function.
|
|
|
|
|
(elf_x86_64_pie_finish_undefweak_symbol): Likewise.
|
|
|
|
|
(elf_x86_64_allocate_dynrelocs): Don't allocate space for dynamic
|
|
|
|
|
relocations and discard relocations against resolved undefined
|
|
|
|
|
weak symbols in executable. Don't make resolved undefined weak
|
|
|
|
|
symbols in executable dynamic.
|
|
|
|
|
(elf_x86_64_size_dynamic_sections): Set interp to .interp section.
|
|
|
|
|
(elf_x86_64_relocate_section): Check relocation overflow for
|
|
|
|
|
dynamic relocations against unresolved weak undefined symbols.
|
|
|
|
|
Don't generate dynamic relocations against resolved weak
|
|
|
|
|
undefined symbols in PIE.
|
|
|
|
|
(elf_x86_64_finish_dynamic_symbol): Keep PLT/GOT entries without
|
|
|
|
|
dynamic PLT/GOT relocations for resolved undefined weak symbols.
|
|
|
|
|
Don't generate dynamic relocation against resolved undefined weak
|
|
|
|
|
symbol in executable.
|
|
|
|
|
(elf_x86_64_finish_dynamic_sections): Call
|
|
|
|
|
elf_x86_64_pie_finish_undefweak_symbol on all symbols in PIE.
|
|
|
|
|
(elf_backend_fixup_symbol): New.
|
|
|
|
|
|
2016-02-26 20:30:33 +08:00
|
|
|
|
2016-02-26 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (create_linkage_sections): Create sfpr when
|
|
|
|
|
save_restore_funcs, rest of sections when not relocatable.
|
|
|
|
|
(ppc64_elf_init_stub_bfd): Always call create_linkage_sections.
|
|
|
|
|
(sfpr_define): Define all symbols on emitted code.
|
|
|
|
|
(ppc64_elf_func_desc_adjust): Adjust for sfpr now being created
|
|
|
|
|
when relocatable. Move sfpr_define loop earlier.
|
|
|
|
|
|
2016-02-25 08:31:29 +08:00
|
|
|
|
2016-02-24 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_need_pic): New function.
|
|
|
|
|
(elf_x86_64_relocate_section): Use it. Replace
|
|
|
|
|
x86_64_elf_howto_table[r_type] with howto.
|
|
|
|
|
|
2016-02-25 07:13:35 +08:00
|
|
|
|
2016-02-24 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19698
|
|
|
|
|
* elflink.c (bfd_elf_record_link_assignment): Set versioned if
|
|
|
|
|
symbol version is unknown.
|
|
|
|
|
|
2016-02-24 21:42:27 +08:00
|
|
|
|
2016-02-24 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_allocate_dynrelocs): Set plt_got.offset
|
|
|
|
|
to (bfd_vma) -1 when setting needs_plt to 0.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_allocate_dynrelocs): Likewise.
|
|
|
|
|
|
2016-02-23 21:18:43 +08:00
|
|
|
|
2016-02-23 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (bfd_elf_record_link_assignment): Check for shared
|
|
|
|
|
library, instead of PIC, and don't check PDE when making linker
|
|
|
|
|
assigned symbol dynamic.
|
|
|
|
|
|
2016-02-23 20:58:03 +08:00
|
|
|
|
2016-02-23 Faraz Shahbazker <faraz.shahbazker@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* bfd/elfxx-mips.c (_bfd_mips_post_process_headers): Increment
|
|
|
|
|
ABIVERSION for non-executable stack.
|
|
|
|
|
|
2016-02-23 18:37:24 +08:00
|
|
|
|
2016-02-23 Rich Felker <bugdal@aerifal.cx>
|
|
|
|
|
|
|
|
|
|
PR target/19516
|
|
|
|
|
* elf32-microblaze.c (microblaze_elf_finish_dynamic_symbol):
|
|
|
|
|
Always produce a RELATIVE reloc for a local symbol.
|
|
|
|
|
|
2016-02-23 09:06:45 +08:00
|
|
|
|
2016-02-23 Hans-Peter Nilsson <hp@axis.com>
|
|
|
|
|
|
|
|
|
|
Fix test-case ld-elf/pr19617b
|
|
|
|
|
* elf32-cris.c (elf_cris_discard_excess_program_dynamics): Don't
|
|
|
|
|
discard unused non-function symbols when --dynamic-list-data.
|
|
|
|
|
|
2016-02-23 08:30:30 +08:00
|
|
|
|
2016-02-22 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (_bfd_elf_link_renumber_dynsyms): Always create the
|
|
|
|
|
dynsym section, even if it is empty, with dynamic sections.
|
|
|
|
|
|
2016-02-22 20:39:21 +08:00
|
|
|
|
2016-02-22 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* syms.c: Remove BSF_COMMON from comments.
|
|
|
|
|
* bfd-in2.h: Regenerated.
|
|
|
|
|
|
2016-02-22 20:16:06 +08:00
|
|
|
|
2016-02-22 Jiong Wang <jiong.wang@arm.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-aarch64. (aarch64_type_of_stub): Remove redundation calcuation
|
|
|
|
|
for destination. Remove useless function parameters.
|
|
|
|
|
(elfNN_aarch64_size_stubs): Update parameters for aarch64_type_of_stub.
|
|
|
|
|
|
2016-02-19 23:20:30 +08:00
|
|
|
|
2016-02-19 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
2016-02-19 23:55:06 +08:00
|
|
|
|
PR ld/19629
|
|
|
|
|
* aoutx.h (aout_link_add_symbols): Check for out of range string
|
|
|
|
|
table offsets.
|
|
|
|
|
|
2016-02-19 23:20:30 +08:00
|
|
|
|
PR ld/19628
|
|
|
|
|
* reloc.c (bfd_generic_get_relocated_section_contents): Stop
|
|
|
|
|
processing if we encounter a reloc without an associated symbol.
|
|
|
|
|
|
2016-02-18 19:13:19 +08:00
|
|
|
|
2016-02-18 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19617
|
|
|
|
|
* elflink.c (elf_link_add_object_symbols): Always create dynamic
|
|
|
|
|
sections for -E/--dynamic-list.
|
|
|
|
|
|
2016-02-18 03:18:53 +08:00
|
|
|
|
2016-02-17 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf64-x86-64.c (elf_backend_omit_section_dynsym): New. Defined
|
|
|
|
|
to bfd_true.
|
|
|
|
|
|
Fix BFD format matching for x86_64-w64-mingw32 -m32 LTO.
In <https://sourceware.org/ml/binutils/2015-12/msg00190.html> (commit
4a07dc81356ed8728e204e9aabeb256703c59aef), Kwok fixed a problem with
the template used for a dummy BFD for an IR file for LTO on MinGW,
where the input and output formats are not the same.
A problem, however, remains in the case of linking for
x86_64-w64-mingw32 -m32, where LTO linking reports an ambiguity
between the pe-i386 and pei-i386 formats. An object (pe-i386) with
plugin data is being tested by the linker to see what formats match.
The default format initially set by the linker when
bfd_check_format_matches is called is pei-i386 (as that's the output
format from the linker script), which does not match, so the function
goes on to the loop over possible BFD vectors. The pe-i386 vector
matches, as it should. One other vector matches: the plugin vector.
bfd_check_format_matches tests a vector for matching by temporarily
modifying the BFD object to use that vector then using
_bfd_check_format on it. So the BFD object is temporarily using
plugin_vec. _bfd_check_format ends up using bfd_plugin_object_p which
uses plugin_object_p from ld which uses plugin_get_ir_dummy_bfd which
succeeds, having created a BFD based on link_info.output_bfd (because
srctemplate is the BFD temporarily using plugin_vec, even after Kwok's
patch link_info.output_bfd is all that's available to base the dummy
BFD on). So we end up with a match from the plugin vector which uses
the pei-i386 vector even though the pei-i386 vector itself does not
match the input object. (In the i686-mingw32 case, as opposed to this
multilib case, pe-i386 is the default BFD target, which would
short-circuit that logic.)
There are two cases of the linker handling inputs with a plugin: they
may be inputs that are also accepted by some non-plugin BFD format, as
here, or they may be a format that would not be recognized at all, as
with some tests in the ld testsuite. In the former case, there is no
need for BFD to accept the objects using the plugin vector, as the
linker has its own logic to allow plugins to claim objects accepted by
some other BFD vector. Thus, this patch arranges for the plugin
vector to have the lowest match priority, and for the priority from
that vector to be used in the relevant case (the attempted match to
the plugin vector results in TEMP pointing to the pei-i386 vector).
Tested for GCC and Binutils testsuites for x86_64-pc-linux-gnu, as
well as verifying that it fixes the observed LTO issue for
x86_64-w64-mingw32.
* plugin.c (plugin_vec): Set match priority to 255.
* format.c (bfd_check_format_matches) [BFD_SUPPORTS_PLUGINS]: When
matching against the plugin vector, take priority from there not
from TEMP.
2016-02-16 08:27:11 +08:00
|
|
|
|
2016-02-16 Joseph Myers <joseph@codesourcery.com>
|
|
|
|
|
|
|
|
|
|
* plugin.c (plugin_vec): Set match priority to 255.
|
|
|
|
|
* format.c (bfd_check_format_matches) [BFD_SUPPORTS_PLUGINS]: When
|
|
|
|
|
matching against the plugin vector, take priority from there not
|
|
|
|
|
from TEMP.
|
|
|
|
|
|
2016-02-15 19:11:46 +08:00
|
|
|
|
2016-02-15 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h (struct bfd_elf_special_section): Use unsigned values
|
|
|
|
|
for length and type fields. Use a signed value for the
|
|
|
|
|
suffix_length field.
|
|
|
|
|
|
2016-02-11 11:33:52 +08:00
|
|
|
|
2016-02-10 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19601
|
|
|
|
|
* elf32-i386.c (elf_i386_relocate_section): Mask off the least
|
|
|
|
|
significant bit in GOT offset for R_386_GOT32X.
|
|
|
|
|
|
2016-02-10 19:25:59 +08:00
|
|
|
|
2016-02-10 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 19405
|
|
|
|
|
* elf32-nios2.c (nios2_elf32_install_imm16): Allow for signed
|
|
|
|
|
immediate values.
|
|
|
|
|
* elf-eh-frame.c (_bfd_elf_discard_section_eh_frame): Limit the
|
|
|
|
|
number of messages about FDE encoding preventing .eh_frame_hdr
|
|
|
|
|
generation.
|
|
|
|
|
|
2016-02-09 17:56:21 +08:00
|
|
|
|
2016-02-09 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
2016-02-10 00:34:24 +08:00
|
|
|
|
* oasys.c (oasys_archive_p): Fix indentation.
|
|
|
|
|
* elf32-nds32.c (nds32_elf_relax_section): Use an unsigned
|
|
|
|
|
constant for left shifting.
|
|
|
|
|
|
2016-02-09 17:56:21 +08:00
|
|
|
|
* elfnn-aarch64.c (elfNN_aarch64_relocate_section): Add a more
|
|
|
|
|
helpful warning message to explain why certain AArch64 relocs
|
|
|
|
|
might overflow.
|
|
|
|
|
|
2016-02-05 18:15:26 +08:00
|
|
|
|
2016-02-05 Simon Marchi <simon.marchi@ericsson.com>
|
|
|
|
|
|
|
|
|
|
* pe-mips.c (coff_mips_reloc): Fix formatting.
|
|
|
|
|
|
2016-02-05 17:58:01 +08:00
|
|
|
|
2016-02-05 Cupertino Miranda <Cupertino.Miranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* cpu-arc.c: Change default archure from bfd_mach_arc_arcv2
|
|
|
|
|
to bfd_mach_arc_arc600.
|
|
|
|
|
|
2016-02-03 21:55:56 +08:00
|
|
|
|
2016-02-04 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_relocate_section): Adjust last patch
|
|
|
|
|
for big-endian.
|
|
|
|
|
|
2016-02-03 00:14:43 +08:00
|
|
|
|
2016-02-02 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19542
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_convert_load): Store the estimated
|
2016-02-03 05:08:58 +08:00
|
|
|
|
distances in the compressed_size field of the output section.
|
2016-02-03 00:14:43 +08:00
|
|
|
|
|
2016-02-02 20:46:14 +08:00
|
|
|
|
2016-02-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_relocate_section): Further restrict
|
|
|
|
|
ELFv2 entry optimization.
|
|
|
|
|
|
2016-02-02 19:30:21 +08:00
|
|
|
|
2016-02-02 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/19547
|
|
|
|
|
* elf.c (assign_section_numbers): Clear HAS_RELOC if there are
|
|
|
|
|
no relocations in relocatable files.
|
|
|
|
|
|
2016-02-02 07:49:52 +08:00
|
|
|
|
2016-02-01 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19553
|
|
|
|
|
* elflink.c (elf_link_add_object_symbols): Don't add DT_NEEDED
|
|
|
|
|
if a symbol from a library loaded via DT_NEEDED doesn't match
|
|
|
|
|
the symbol referenced by regular object.
|
|
|
|
|
|
2016-02-01 21:44:15 +08:00
|
|
|
|
2016-02-01 Nathaniel Smith <njs@pobox.com>
|
|
|
|
|
|
|
|
|
|
* peicode.h (pe_ILF_build_a_bfd): Create an import symbol for both
|
|
|
|
|
CODE and DATA.
|
|
|
|
|
|
2016-02-01 18:57:02 +08:00
|
|
|
|
2016-02-01 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_get_plt_sym_val): Don't abort on
|
|
|
|
|
an out of range reloc_index.
|
|
|
|
|
* elf32-i386.c (elf_i386_get_plt_sym_val): Likewise.
|
|
|
|
|
|
2016-02-01 18:35:38 +08:00
|
|
|
|
2016-02-01 Kamil Rytarowski <n54@gmx.com>
|
|
|
|
|
|
|
|
|
|
* Makefile.am (OPTIONAL_BACKENDS): Add netbsd-core.lo.
|
|
|
|
|
(OPTIONAL_BACKENDS_CFILES): Add netbsd-core.c.
|
|
|
|
|
* Makefile.in: Regenerated.
|
|
|
|
|
|
2016-02-01 10:47:47 +08:00
|
|
|
|
2016-02-01 Jan Kratochvil <jan.kratochvil@redhat.com>
|
|
|
|
|
|
|
|
|
|
* elf64-s390.c (elf_s390_reloc_name_lookup): Fix indentation.
|
|
|
|
|
|
2016-02-01 00:52:24 +08:00
|
|
|
|
2016-01-31 John David Anglin <danglin@gcc.gnu.org>
|
|
|
|
|
|
|
|
|
|
PR ld/19526
|
|
|
|
|
* elf32-hppa.c (elf32_hppa_final_link): Don't sort non-regular output
|
|
|
|
|
files.
|
|
|
|
|
* elf64-hppa.c (elf32_hppa_final_link): Likewise. Remove retval.
|
|
|
|
|
|
2016-01-31 06:11:03 +08:00
|
|
|
|
2016-01-30 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19539
|
|
|
|
|
* elf32-i386.c (elf_i386_reloc_type_class): Check relocation
|
|
|
|
|
against STT_GNU_IFUNC symbol only with dynamic symbols.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_reloc_type_class): Likewise.
|
|
|
|
|
|
2016-01-29 05:29:53 +08:00
|
|
|
|
2016-01-28 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/19523
|
|
|
|
|
* dwarf2.c (_bfd_dwarf2_slurp_debug_info): Set BFD_DECOMPRESS to
|
|
|
|
|
decompress debug sections.
|
|
|
|
|
|
2016-01-26 00:06:46 +08:00
|
|
|
|
2016-01-25 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf_arc_finish_dynamic_symbol): Rename `index' to
|
|
|
|
|
`dynindx'.
|
|
|
|
|
|
2016-01-25 17:35:33 +08:00
|
|
|
|
2016-01-25 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR target/19435
|
|
|
|
|
* mach-o.c (bfd_mach_o_close_and_cleanup): Suppress code to free
|
|
|
|
|
dsym filename buffer.
|
|
|
|
|
|
MIPS/BFD: Simplify register index calculation in BZ16_REG_FIELD
Just mask higher bits off, which returns the same set of 3-bit register
encodings of { 0, 1, 2, 3, 4, 5, 6, 7 } for the allowed 5-bit encodings
of { 16, 17, 2, 3, 4, 5, 6, 7 }. Input has already been validated with
OP16_VALID_REG.
bfd/
* elfxx-mips.c (BZ16_REG_FIELD): Simplify calculation.
2016-01-24 08:55:13 +08:00
|
|
|
|
2016-01-24 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (BZ16_REG_FIELD): Simplify calculation.
|
|
|
|
|
|
MIPS/BFD: Correct register index calculation in BZ16_REG
For the 3-bit register encodings of { 0, 1, 2, 3, 4, 5, 6, 7 } return
the 5-bit encodings of { 16, 17, 2, 3, 4, 5, 6, 7 } respectively rather
than { 24, 25, 2, 3, 4, 5, 6, 7 }.
bfd/
* elfxx-mips.c (BZ16_REG): Correct calculation.
2016-01-24 08:49:26 +08:00
|
|
|
|
2016-01-24 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (BZ16_REG): Correct calculation.
|
|
|
|
|
|
2016-01-21 21:54:11 +08:00
|
|
|
|
2016-01-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (ADD_RELA): Fix compile time warning errors by
|
|
|
|
|
changing the type of _loc to be bfd_byte *.
|
|
|
|
|
(elf_arc_finish_dynamic_symbol): Likewise.
|
|
|
|
|
|
2016-01-21 18:51:25 +08:00
|
|
|
|
2016-01-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19455
|
|
|
|
|
* elf32-arm.c (elf32_arm_create_dynamic_sections): Set the ELF
|
|
|
|
|
class of the linker stub bfd.
|
|
|
|
|
(elf32_arm_check_relocs): Skip check for pic format after
|
|
|
|
|
processing a vxWorks R_ARM_ABS12 reloc.
|
|
|
|
|
* elflink.c (bfd_elf_final_link): Check for ELFCLASSNONE when
|
|
|
|
|
reporting a class mismatch.
|
|
|
|
|
|
2016-01-21 00:57:59 +08:00
|
|
|
|
2016-01-21 Jiong Wang <jiong.wang@arm.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-aarch64.c (aarch64_type_of_stub): Allow insert long branch
|
|
|
|
|
veneer for sym_sec != input_sec.
|
|
|
|
|
(elfNN_aarch64_size_stub): Support STT_SECTION symbol.
|
|
|
|
|
(elfNN_aarch64_final_link_relocate): Take rela addend into account when
|
|
|
|
|
calculation destination.
|
|
|
|
|
|
2016-01-21 11:03:53 +08:00
|
|
|
|
2016-01-21 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf-linux-core.h (swap_linux_prpsinfo32_out): New function.
|
|
|
|
|
(swap_linux_prpsinfo64_out): New function.
|
|
|
|
|
(LINUX_PRPSINFO32_SWAP_FIELDS): Delete.
|
|
|
|
|
(LINUX_PRPSINFO64_SWAP_FIELDS): Delete.
|
|
|
|
|
* elf.c (elfcore_write_linux_prpsinfo32): Adjust. Don't memset.
|
|
|
|
|
(elfcore_write_linux_prpsinfo64): Likewise.
|
|
|
|
|
* elf32-ppc.c (swap_ppc_linux_prpsinfo32_out): New function.
|
|
|
|
|
(PPC_LINUX_PRPSINFO32_SWAP_FIELDS): Delete.
|
|
|
|
|
(elfcore_write_ppc_linux_prpsinfo32): Adjust. Don't memset.
|
|
|
|
|
|
2016-01-21 10:45:02 +08:00
|
|
|
|
2016-01-21 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf-linux-core.h: Rename from elf-linux-psinfo.h.
|
|
|
|
|
* elf.c: Adjust #include.
|
|
|
|
|
* elf32-ppc.c: Don't #include elf-linux-psinfo.h
|
|
|
|
|
* Makefile.am (SOURCE_HFILES): Update.
|
|
|
|
|
* Makefile.in: Regenerate.
|
|
|
|
|
* po/SRC-PORFILES.in: Regenerate.
|
|
|
|
|
|
2016-01-19 09:54:09 +08:00
|
|
|
|
2016-01-21 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* configure.ac: Move corefile selection later in file. Move
|
|
|
|
|
tdefaults code immediately after other target vector code.
|
|
|
|
|
* configure: Regenerate.
|
|
|
|
|
|
2016-01-20 20:53:50 +08:00
|
|
|
|
2016-01-20 Mickael Guene <mickael.guene@st.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (elf32_arm_special_sections): Remove catch of noread
|
|
|
|
|
section using '.text.noread' pattern.
|
|
|
|
|
|
2015-12-14 14:47:25 +08:00
|
|
|
|
2016-01-19 John Baldwin <jhb@FreeBSD.org>
|
|
|
|
|
|
|
|
|
|
* elf.c (elfcore_grok_note): Recognize NT_FREEBSD_THRMISC notes.
|
|
|
|
|
|
Add PIC and TLS support to the ARC target.
bfd/ChangeLog:
* arc-plt.def: New file.
* arc-plt.h: Likewise.
* elf32-arc.c (elf_arc_abs_plt0_entry, elf_arc_abs_pltn_entry,
elf_arcV2_abs_plt0_entry, elf_arcV2_abs_pltn_entry,
elf_arc_pic_plt0_entry, elf_arc_pic_pltn_entry,
elf_arcV2_pic_plt0_entry, elf_arcV2_pic_pltn_entry): Remove.
(name_for_global_symbol): Added.
(ADD_RELA): Helper to create dynamic relocs.
(new_got_entry_to_list): Create a new got entry in linked list.
(symbol_has_entry_of_type): Search for specific type of entry in
list.
(is_reloc_for_GOT): return FALSE for any TLS related relocs.
(is_reloc_for_TLS, arc_elf_set_private_flags)
(arc_elf_print_private_bfd_data, arc_elf_copy_private_bfd_data)
(arc_elf_merge_private_bfd_data): New functions.
(debug_arc_reloc): Cleaned debug info printing.
(PDATA reloc): Changed not to perform address alignment.
(reverse_me): Added. Fix for ARC_32 relocs.
(arc_do_relocation): Return bfd_reloc_of when no relocation should
occur.
(arc_get_local_got_ents): Renamed from arc_get_local_got_offsets.
Changed function to access an array of list of GOT entries instead
of just an array of offsets.
(elf_arc_relocate_section): Added support for PIC and TLS related relocations.
(elf_arc_check_relocs): Likewise.
(elf_arc_adjust_dynamic_symbol, elf_arc_finish_dynamic_symbol,
(elf_arc_finish_dynamic_sections): Likewise
(arc_create_dynamic_sections): Modified conditions to create
dynamic sections.
(ADD_SYMBOL_REF_SEC_AND_RELOC): New macro.
(plt_do_relocs_for_symbol, relocate_plt_for_symbol)
(relocate_plt_for_entry): Changed to support new way to define PLT
related code.
(add_symbol_to_plt): Likewise.
(arc_elf_link_hash_table_create): New function.
include/ChangeLog:
* elf/arc-reloc.def (ARC_32, ARC_GOTPC, ARC_TLS_GD_GOT)
(ARC_TLS_IE_GOT, ARC_TLS_DTPOFF, ARC_TLS_DTPOFF_S9, ARC_TLS_LE_S9)
(ARC_TLS_LE_32): Fixed formula.
(ARC_TLS_GD_LD): Use new special function.
* opcode/arc-func.h: Changed all the replacement
functions to clear the patching bits before doing an or it with the value
argument.
2016-01-19 23:25:58 +08:00
|
|
|
|
2016-01-18 Miranda Cupertino <Cupertino.Miranda@synopsys.com>
|
|
|
|
|
Zissulescu Claudiu <Claudiu.Zissulescu@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* arc-plt.def: New file.
|
|
|
|
|
* arc-plt.h: Likewise.
|
|
|
|
|
* elf32-arc.c (elf_arc_abs_plt0_entry, elf_arc_abs_pltn_entry,
|
|
|
|
|
elf_arcV2_abs_plt0_entry, elf_arcV2_abs_pltn_entry,
|
|
|
|
|
elf_arc_pic_plt0_entry, elf_arc_pic_pltn_entry,
|
|
|
|
|
elf_arcV2_pic_plt0_entry, elf_arcV2_pic_pltn_entry): Remove.
|
|
|
|
|
(name_for_global_symbol): Added.
|
|
|
|
|
(ADD_RELA): Helper to create dynamic relocs.
|
|
|
|
|
(new_got_entry_to_list): Create a new got entry in linked list.
|
|
|
|
|
(symbol_has_entry_of_type): Search for specific type of entry in
|
|
|
|
|
list.
|
|
|
|
|
(is_reloc_for_GOT): return FALSE for any TLS related relocs.
|
|
|
|
|
(is_reloc_for_TLS, arc_elf_set_private_flags)
|
|
|
|
|
(arc_elf_print_private_bfd_data, arc_elf_copy_private_bfd_data)
|
|
|
|
|
(arc_elf_merge_private_bfd_data): New functions.
|
|
|
|
|
(debug_arc_reloc): Cleaned debug info printing.
|
|
|
|
|
(PDATA reloc): Changed not to perform address alignment.
|
|
|
|
|
(reverse_me): Added. Fix for ARC_32 relocs.
|
|
|
|
|
(arc_do_relocation): Return bfd_reloc_of when no relocation should
|
|
|
|
|
occur.
|
|
|
|
|
(arc_get_local_got_ents): Renamed from arc_get_local_got_offsets.
|
|
|
|
|
Changed function to access an array of list of GOT entries instead
|
|
|
|
|
of just an array of offsets.
|
|
|
|
|
(elf_arc_relocate_section): Added support for PIC and TLS related relocations.
|
|
|
|
|
(elf_arc_check_relocs): Likewise.
|
|
|
|
|
(elf_arc_adjust_dynamic_symbol, elf_arc_finish_dynamic_symbol,
|
|
|
|
|
(elf_arc_finish_dynamic_sections): Likewise
|
|
|
|
|
(arc_create_dynamic_sections): Modified conditions to create
|
|
|
|
|
dynamic sections.
|
|
|
|
|
(ADD_SYMBOL_REF_SEC_AND_RELOC): New macro.
|
|
|
|
|
(plt_do_relocs_for_symbol, relocate_plt_for_symbol)
|
|
|
|
|
(relocate_plt_for_entry): Changed to support new way to define PLT
|
|
|
|
|
related code.
|
|
|
|
|
(add_symbol_to_plt): Likewise.
|
|
|
|
|
(arc_elf_link_hash_table_create): New function.
|
|
|
|
|
|
2016-01-18 23:58:47 +08:00
|
|
|
|
2016-01-18 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19440
|
|
|
|
|
* coff-rs6000.c (_bfd_xcoff_swap_sym_in): Sign extend external
|
|
|
|
|
section number into internal section number.
|
|
|
|
|
* coff64-rs6000.c (_bfd_xcoff64_swap_sym_in): Likewise.
|
|
|
|
|
* coffswap.h (coff_swap_sym_in): Likewise.
|
|
|
|
|
* peXXigen.c (_bfd_XXi_swap_sym_in): Likewise.
|
|
|
|
|
* coffcode.h (_coff_bigobj_swap_sym_in): Make sure that internal
|
|
|
|
|
section number field is big enough to hold the external value.
|
|
|
|
|
|
2016-01-17 09:50:55 +08:00
|
|
|
|
2016-01-17 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* configure: Regenerate.
|
|
|
|
|
|
2016-01-13 00:33:20 +08:00
|
|
|
|
2016-01-12 Yury Usishchev <y.usishchev@samsung.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (elf32_arm_fix_exidx_coverage): Insert cantunwind
|
|
|
|
|
when address in first unwind entry does not match start of
|
|
|
|
|
section.
|
|
|
|
|
|
2016-01-08 17:47:24 +08:00
|
|
|
|
2016-01-08 Richard Sandiford <richard.sandiford@arm.com>
|
|
|
|
|
Jiong Wang <jiong.wang@arm.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19368
|
|
|
|
|
* elf32-arm.c (elf32_arm_reloc_type_class): Map R_ARM_IRELATIVE to
|
|
|
|
|
reloc_class_ifunc.
|
|
|
|
|
|
2016-01-05 22:46:39 +08:00
|
|
|
|
2016-01-06 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (reloc_type_to_name): Change ARC_RELOC_HOWTO to
|
|
|
|
|
place 'R_' before the reloc name returned.
|
|
|
|
|
(elf_arc_howto_table): Change ARC_RELOC_HOWTO to place 'R_' before
|
|
|
|
|
the relocation string.
|
|
|
|
|
|
2016-01-05 07:32:34 +08:00
|
|
|
|
2016-01-04 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_merge_obj_abiflags): New function,
|
|
|
|
|
factored out from...
|
|
|
|
|
(_bfd_mips_elf_merge_private_bfd_data): ... here.
|
|
|
|
|
|
2016-01-05 07:30:00 +08:00
|
|
|
|
2016-01-04 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_merge_private_bfd_data): Move
|
|
|
|
|
attribute check after ELF file header flag check.
|
|
|
|
|
|
2016-01-05 07:16:45 +08:00
|
|
|
|
2016-01-04 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_merge_obj_attributes): Propagate the
|
|
|
|
|
return status from `_bfd_elf_merge_object_attributes'.
|
|
|
|
|
|
2016-01-05 07:15:03 +08:00
|
|
|
|
2016-01-04 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_merge_obj_e_flags): New function,
|
|
|
|
|
factored out from...
|
|
|
|
|
(_bfd_mips_elf_merge_private_bfd_data): ... here.
|
|
|
|
|
|
2016-01-05 07:13:10 +08:00
|
|
|
|
2016-01-04 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_merge_private_bfd_data): Fold the
|
|
|
|
|
handling of input MIPS ABI flags together.
|
|
|
|
|
|
2016-01-05 07:00:24 +08:00
|
|
|
|
2016-01-04 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_merge_private_bfd_data): Suppress
|
|
|
|
|
attribute checks for null input.
|
|
|
|
|
|
2016-01-05 06:49:59 +08:00
|
|
|
|
2016-01-04 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_merge_private_bfd_data): Use local
|
|
|
|
|
pointers to target data.
|
|
|
|
|
|
2016-01-05 06:46:40 +08:00
|
|
|
|
2016-01-04 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_merge_private_bfd_data): Correct
|
|
|
|
|
an FP ABI warning.
|
|
|
|
|
|
2016-01-01 19:25:12 +08:00
|
|
|
|
2016-01-01 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
Update year range in copyright notice of all files.
|
|
|
|
|
|
2016-01-01 18:44:31 +08:00
|
|
|
|
For older changes see ChangeLog-2015 and doc/ChangeLog-0415
|
|
|
|
|
|
|
|
|
|
Copyright (C) 2016 Free Software Foundation, Inc.
|
|
|
|
|
|
|
|
|
|
Copying and distribution of this file, with or without modification,
|
|
|
|
|
are permitted in any medium without royalty provided the copyright
|
|
|
|
|
notice and this notice are preserved.
|
|
|
|
|
|
|
|
|
|
Local Variables:
|
|
|
|
|
mode: change-log
|
|
|
|
|
left-margin: 8
|
|
|
|
|
fill-column: 74
|
|
|
|
|
version-control: never
|
|
|
|
|
End:
|