2017-06-22 10:57:52 -07:00
|
|
|
|
2017-06-22 Eric Christopher <echristo@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (elf32_arm_final_link_relocate): Use labs rather than
|
|
|
|
|
abs to fix a truncation warning.
|
|
|
|
|
|
2017-06-22 05:50:20 -07:00
|
|
|
|
2017-06-22 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_merge_gnu_properties): If info->shstk
|
|
|
|
|
is set, turn on GNU_PROPERTY_X86_FEATURE_1_SHSTK.
|
|
|
|
|
(elf_i386_link_setup_gnu_properties): If info->shstk is set,
|
|
|
|
|
turn on GNU_PROPERTY_X86_FEATURE_1_IBT.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_merge_gnu_properties): If
|
|
|
|
|
info->shstk is set, turn on GNU_PROPERTY_X86_FEATURE_1_SHSTK.
|
|
|
|
|
(elf_x86_64_link_setup_gnu_properties): If info->shstk is set,
|
|
|
|
|
turn on GNU_PROPERTY_X86_FEATURE_1_IBT.
|
|
|
|
|
|
x86: Support Intel IBT with IBT property and IBT-enable PLT
To support IBT in Intel Control-flow Enforcement Technology (CET)
instructions:
https://software.intel.com/sites/default/files/managed/4d/2a/control-flow-enforcement-technology-preview.pdf
#define GNU_PROPERTY_X86_FEATURE_1_AND 0xc0000002
#define GNU_PROPERTY_X86_FEATURE_1_IBT (1U << 0)
are added to GNU program properties to indicate that all executable
sections are compatible with IBT when ENDBR instruction starts each
valid target where an indirect branch instruction can land.
GNU_PROPERTY_X86_FEATURE_1_IBT is set on output only if it is set on
all relocatable inputs.
The followings changes are made to the Procedure Linkage Table (PLT):
1. For 64-bit x86-64, PLT is changed to
PLT0: push GOT[1]
bnd jmp *GOT[2]
nop
...
PLTn: endbr64
push namen_reloc_index
bnd jmp PLT0
together with the second PLT section:
PLTn: endbr64
bnd jmp *GOT[namen_index]
nop
BND prefix is also added so that IBT-enabled PLT is compatible with MPX.
2. For 32-bit x86-64 (x32) and i386, PLT is changed to
PLT0: push GOT[1]
jmp *GOT[2]
nop
...
PLTn: endbr64 # endbr32 for i386.
push namen_reloc_index
jmp PLT0
together with the second PLT section:
PLTn: endbr64 # endbr32 for i386.
jmp *GOT[namen_index]
nop
BND prefix isn't used since MPX isn't supported on x32 and BND registers
aren't used in parameter passing on i386.
GOT is an array of addresses. Initially, GOT[namen_index] is filled
with the address of the ENDBR instruction of the corresponding entry
in the first PLT section. The function, namen, is called via the
ENDBR instruction in the second PLT entry. GOT[namen_index] is updated
to the actual address of the function, namen, at run-time.
2 linker command line options are added:
1. -z ibtplt: Generate IBT-enabled PLT.
2. -z ibt: Generate GNU_PROPERTY_X86_FEATURE_1_IBT in GNU program
properties as well as IBT-enabled PLT.
bfd/
* elf32-i386.c (elf_i386_lazy_ibt_plt0_entry): New.
(elf_i386_lazy_ibt_plt_entry): Likewise.
(elf_i386_pic_lazy_ibt_plt0_entry): Likewise.
(elf_i386_non_lazy_ibt_plt_entry): Likewise.
(elf_i386_pic_non_lazy_ibt_plt_entry): Likewise.
(elf_i386_eh_frame_lazy_ibt_plt): Likewise.
(elf_i386_lazy_plt_layout): Likewise.
(elf_i386_non_lazy_plt_layout): Likewise.
(elf_i386_link_hash_entry): Add plt_second.
(elf_i386_link_hash_table): Add plt_second and
plt_second_eh_frame.
(elf_i386_allocate_dynrelocs): Use the second PLT if needed.
(elf_i386_size_dynamic_sections): Use .plt.got unwind info for
the second PLT. Check the second PLT.
(elf_i386_relocate_section): Use the second PLT to resolve
PLT reference if needed.
(elf_i386_finish_dynamic_symbol): Fill and use the second PLT if
needed.
(elf_i386_finish_dynamic_sections): Set sh_entsize on the
second PLT. Generate unwind info for the second PLT.
(elf_i386_plt_type): Add plt_second.
(elf_i386_get_synthetic_symtab): Support the second PLT.
(elf_i386_parse_gnu_properties): Support
GNU_PROPERTY_X86_FEATURE_1_AND.
(elf_i386_merge_gnu_properties): Support
GNU_PROPERTY_X86_FEATURE_1_AND. If info->ibt is set, turn
on GNU_PROPERTY_X86_FEATURE_1_IBT
(elf_i386_link_setup_gnu_properties): If info->ibt is set,
turn on GNU_PROPERTY_X86_FEATURE_1_IBT. Use IBT-enabled PLT
for info->ibtplt, info->ibt or GNU_PROPERTY_X86_FEATURE_1_IBT
is set on all relocatable inputs.
* elf64-x86-64.c (elf_x86_64_lazy_ibt_plt_entry): New.
(elf_x32_lazy_ibt_plt_entry): Likewise.
(elf_x86_64_non_lazy_ibt_plt_entry): Likewise.
(elf_x32_non_lazy_ibt_plt_entry): Likewise.
(elf_x86_64_eh_frame_lazy_ibt_plt): Likewise.
(elf_x32_eh_frame_lazy_ibt_plt): Likewise.
(elf_x86_64_lazy_ibt_plt): Likewise.
(elf_x32_lazy_ibt_plt): Likewise.
(elf_x86_64_non_lazy_ibt_plt): Likewise.
(elf_x32_non_lazy_ibt_plt): Likewise.
(elf_x86_64_get_synthetic_symtab): Support the second PLT.
(elf_x86_64_parse_gnu_properties): Support
GNU_PROPERTY_X86_FEATURE_1_AND.
(elf_x86_64_merge_gnu_properties): Support
GNU_PROPERTY_X86_FEATURE_1_AND. If info->ibt is set, turn
on GNU_PROPERTY_X86_FEATURE_1_IBT
(elf_x86_64_link_setup_gnu_properties): If info->ibt is set,
turn on GNU_PROPERTY_X86_FEATURE_1_IBT. Use IBT-enabled PLT
for info->ibtplt, info->ibt or GNU_PROPERTY_X86_FEATURE_1_IBT
is set on all relocatable inputs.
binutils/
* readelf.c (decode_x86_feature): New.
(print_gnu_property_note): Call decode_x86_feature on
GNU_PROPERTY_X86_FEATURE_1_AND.
* testsuite/binutils-all/i386/empty.d: New file.
* testsuite/binutils-all/i386/empty.s: Likewise.
* testsuite/binutils-all/i386/ibt.d: Likewise.
* testsuite/binutils-all/i386/ibt.s: Likewise.
* testsuite/binutils-all/x86-64/empty-x32.d: Likewise.
* testsuite/binutils-all/x86-64/empty.d: Likewise.
* testsuite/binutils-all/x86-64/empty.s: Likewise.
* testsuite/binutils-all/x86-64/ibt-x32.d: Likewise.
* testsuite/binutils-all/x86-64/ibt.d: Likewise.
* testsuite/binutils-all/x86-64/ibt.s: Likewise.
include/
* bfdlink.h (bfd_link_info): Add ibtplt and ibt.
* elf/common.h (GNU_PROPERTY_X86_FEATURE_1_AND): New.
(GNU_PROPERTY_X86_FEATURE_1_IBT): Likewise.
ld/
* Makefile.am (ELF_X86_DEPS): Add $(srcdir)/emulparams/cet.sh.
* Makefile.in: Regenerated.
* NEWS: Mention GNU_PROPERTY_X86_FEATURE_1_IBT, -z ibtplt
and -z ibt.
* emulparams/cet.sh: New file.
* testsuite/ld-i386/ibt-plt-1.d: Likewise.
* testsuite/ld-i386/ibt-plt-1.s: Likewise.
* testsuite/ld-i386/ibt-plt-2.s: Likewise.
* testsuite/ld-i386/ibt-plt-2a.d: Likewise.
* testsuite/ld-i386/ibt-plt-2b.d: Likewise.
* testsuite/ld-i386/ibt-plt-2c.d: Likewise.
* testsuite/ld-i386/ibt-plt-2d.d: Likewise.
* testsuite/ld-i386/ibt-plt-3.s: Likewise.
* testsuite/ld-i386/ibt-plt-3a.d: Likewise.
* testsuite/ld-i386/ibt-plt-3b.d: Likewise.
* testsuite/ld-i386/ibt-plt-3c.d: Likewise.
* testsuite/ld-i386/ibt-plt-3d.d: Likewise.
* testsuite/ld-i386/plt-main-ibt.dd: Likewise.
* testsuite/ld-i386/plt-pie-ibt.dd: Likewise.
* testsuite/ld-i386/property-x86-empty.s: Likewise.
* testsuite/ld-i386/property-x86-ibt.s: Likewise.
* testsuite/ld-i386/property-x86-ibt1a.d: Likewise.
* testsuite/ld-i386/property-x86-ibt1b.d: Likewise.
* testsuite/ld-i386/property-x86-ibt2.d: Likewise.
* testsuite/ld-i386/property-x86-ibt3a.d: Likewise.
* testsuite/ld-i386/property-x86-ibt3b.d: Likewise.
* testsuite/ld-i386/property-x86-ibt4.d: Likewise.
* testsuite/ld-i386/property-x86-ibt5.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-1-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-1.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-1.s: Likewise.
* testsuite/ld-x86-64/ibt-plt-2.s: Likewise.
* testsuite/ld-x86-64/ibt-plt-2a-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2a.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2b-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2b.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2c-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2c.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2d-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2d.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3.s: Likewise.
* testsuite/ld-x86-64/ibt-plt-3a-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3a.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3b-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3b.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3c-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3c.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3d-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3d.d: Likewise.
* testsuite/ld-x86-64/plt-main-ibt-now.rd: Likewise.
* testsuite/ld-x86-64/plt-main-ibt-x32.dd: Likewise.
* testsuite/ld-x86-64/plt-main-ibt.dd: Likewise.
* testsuite/ld-x86-64/property-x86-empty.s: Likewise.
* testsuite/ld-x86-64/property-x86-ibt.s: Likewise.
* testsuite/ld-x86-64/property-x86-ibt1a-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt1a.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt1b-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt1b.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt2-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt2.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt3a-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt3a.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt3b-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt3b.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt4-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt4.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt5-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt5.d: Likewise.
* emulparams/elf32_x86_64.sh: Source emulparams/cet.sh.
(TINY_READONLY_SECTION): Add .plt.sec.
* emulparams/elf_i386.sh: Likewise.
* emulparams/elf_x86_64.sh: Source emulparams/cet.sh.
* ld.texinfo: Document -z ibtplt and -z ibt.
* testsuite/ld-i386/i386.exp: Run IBT and IBT PLT tests.
* testsuite/ld-x86-64/x86-64.exp: Likewise.
* testsuite/ld-x86-64/pr21481b.S (check): Updated for x32.
2017-06-22 05:44:37 -07:00
|
|
|
|
2017-06-22 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_lazy_ibt_plt0_entry): New.
|
|
|
|
|
(elf_i386_lazy_ibt_plt_entry): Likewise.
|
|
|
|
|
(elf_i386_pic_lazy_ibt_plt0_entry): Likewise.
|
|
|
|
|
(elf_i386_non_lazy_ibt_plt_entry): Likewise.
|
|
|
|
|
(elf_i386_pic_non_lazy_ibt_plt_entry): Likewise.
|
|
|
|
|
(elf_i386_eh_frame_lazy_ibt_plt): Likewise.
|
|
|
|
|
(elf_i386_lazy_plt_layout): Likewise.
|
|
|
|
|
(elf_i386_non_lazy_plt_layout): Likewise.
|
|
|
|
|
(elf_i386_link_hash_entry): Add plt_second.
|
|
|
|
|
(elf_i386_link_hash_table): Add plt_second and
|
|
|
|
|
plt_second_eh_frame.
|
|
|
|
|
(elf_i386_allocate_dynrelocs): Use the second PLT if needed.
|
|
|
|
|
(elf_i386_size_dynamic_sections): Use .plt.got unwind info for
|
|
|
|
|
the second PLT. Check the second PLT.
|
|
|
|
|
(elf_i386_relocate_section): Use the second PLT to resolve
|
|
|
|
|
PLT reference if needed.
|
|
|
|
|
(elf_i386_finish_dynamic_symbol): Fill and use the second PLT if
|
|
|
|
|
needed.
|
|
|
|
|
(elf_i386_finish_dynamic_sections): Set sh_entsize on the
|
|
|
|
|
second PLT. Generate unwind info for the second PLT.
|
|
|
|
|
(elf_i386_plt_type): Add plt_second.
|
|
|
|
|
(elf_i386_get_synthetic_symtab): Support the second PLT.
|
|
|
|
|
(elf_i386_parse_gnu_properties): Support
|
|
|
|
|
GNU_PROPERTY_X86_FEATURE_1_AND.
|
|
|
|
|
(elf_i386_merge_gnu_properties): Support
|
|
|
|
|
GNU_PROPERTY_X86_FEATURE_1_AND. If info->ibt is set, turn
|
|
|
|
|
on GNU_PROPERTY_X86_FEATURE_1_IBT
|
|
|
|
|
(elf_i386_link_setup_gnu_properties): If info->ibt is set,
|
|
|
|
|
turn on GNU_PROPERTY_X86_FEATURE_1_IBT. Use IBT-enabled PLT
|
|
|
|
|
for info->ibtplt, info->ibt or GNU_PROPERTY_X86_FEATURE_1_IBT
|
|
|
|
|
is set on all relocatable inputs.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_lazy_ibt_plt_entry): New.
|
|
|
|
|
(elf_x32_lazy_ibt_plt_entry): Likewise.
|
|
|
|
|
(elf_x86_64_non_lazy_ibt_plt_entry): Likewise.
|
|
|
|
|
(elf_x32_non_lazy_ibt_plt_entry): Likewise.
|
|
|
|
|
(elf_x86_64_eh_frame_lazy_ibt_plt): Likewise.
|
|
|
|
|
(elf_x32_eh_frame_lazy_ibt_plt): Likewise.
|
|
|
|
|
(elf_x86_64_lazy_ibt_plt): Likewise.
|
|
|
|
|
(elf_x32_lazy_ibt_plt): Likewise.
|
|
|
|
|
(elf_x86_64_non_lazy_ibt_plt): Likewise.
|
|
|
|
|
(elf_x32_non_lazy_ibt_plt): Likewise.
|
|
|
|
|
(elf_x86_64_get_synthetic_symtab): Support the second PLT.
|
|
|
|
|
(elf_x86_64_parse_gnu_properties): Support
|
|
|
|
|
GNU_PROPERTY_X86_FEATURE_1_AND.
|
|
|
|
|
(elf_x86_64_merge_gnu_properties): Support
|
|
|
|
|
GNU_PROPERTY_X86_FEATURE_1_AND. If info->ibt is set, turn
|
|
|
|
|
on GNU_PROPERTY_X86_FEATURE_1_IBT
|
|
|
|
|
(elf_x86_64_link_setup_gnu_properties): If info->ibt is set,
|
|
|
|
|
turn on GNU_PROPERTY_X86_FEATURE_1_IBT. Use IBT-enabled PLT
|
|
|
|
|
for info->ibtplt, info->ibt or GNU_PROPERTY_X86_FEATURE_1_IBT
|
|
|
|
|
is set on all relocatable inputs.
|
|
|
|
|
|
2017-06-22 10:33:56 +01:00
|
|
|
|
2017-06-22 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21649
|
|
|
|
|
* som.c (setup_sections): NUL terminate the space_strings buffer.
|
|
|
|
|
Check that the space.name field does not index beyond the end of
|
|
|
|
|
the space_strings buffer.
|
|
|
|
|
|
2017-06-21 16:36:44 +01:00
|
|
|
|
2017-06-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21646
|
|
|
|
|
* coff-sh.c (sh_reloc): Check for an out of range reloc.
|
|
|
|
|
|
2017-06-21 15:21:11 +01:00
|
|
|
|
2017-06-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21639
|
|
|
|
|
* vms-misc.c (_bfd_vms_save_sized_string): Use unsigned int as
|
|
|
|
|
type of the size parameter.
|
|
|
|
|
(_bfd_vms_save_counted_string): Add second parameter - the maximum
|
|
|
|
|
length of the counted string.
|
|
|
|
|
* vms.h (_bfd_vms_save_sized_string): Update prototype.
|
|
|
|
|
(_bfd_vms_save_counted_string): Likewise.
|
|
|
|
|
* vms-alpha.c (_bfd_vms_slurp_eisd): Update calls to
|
|
|
|
|
_bfd_vms_save_counted_string.
|
|
|
|
|
(_bfd_vms_slurp_ehdr): Likewise.
|
|
|
|
|
(_bfd_vms_slurp_egsd): Likewise.
|
|
|
|
|
(Parse_module): Likewise.
|
|
|
|
|
|
2017-06-21 15:03:25 +09:30
|
|
|
|
2017-06-21 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_size_stubs): Test for localentry:0 plt
|
|
|
|
|
calls before tocsave calls.
|
|
|
|
|
(ppc64_elf_relocate_section): Allow localentry:0 plt calls without
|
|
|
|
|
following nop.
|
|
|
|
|
|
2017-06-21 13:18:46 +01:00
|
|
|
|
2017-06-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21645
|
|
|
|
|
* reloc.c (bfd_generic_get_relocated_section_contents): Fail if
|
|
|
|
|
bfd_get_full_section_contents returns no contents.
|
|
|
|
|
|
2017-06-21 12:04:07 +01:00
|
|
|
|
2017-06-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21638
|
|
|
|
|
* vms-alpha.c (_bfd_vms_slurp_egsd): Check for an undersized
|
|
|
|
|
record.
|
|
|
|
|
|
2017-06-21 11:13:49 +01:00
|
|
|
|
2017-06-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21637
|
|
|
|
|
* vms-alpha.c (_bfd_vms_slurp_egsd): Check for an empty section
|
|
|
|
|
list.
|
|
|
|
|
(image_set_ptr): Likewise.
|
|
|
|
|
(alpha_vms_fix_sec_rel): Likewise.
|
|
|
|
|
(alpha_vms_slurp_relocs): Likewise.
|
|
|
|
|
|
2017-06-21 10:54:04 +01:00
|
|
|
|
2017-06-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21633
|
|
|
|
|
* ieee.c (ieee_slurp_sections): Check for a NULL return from
|
|
|
|
|
read_id.
|
|
|
|
|
(ieee_archive_p): Likewise.
|
|
|
|
|
(ieee_object_p): Likewise.
|
|
|
|
|
|
2017-06-21 10:36:58 +01:00
|
|
|
|
2017-06-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21640
|
|
|
|
|
* elf.c (setup_group): Zero the group section pointer list after
|
|
|
|
|
allocation so that loops can be caught. Check for NULL pointers
|
|
|
|
|
when processing a group list.
|
|
|
|
|
|
2017-06-19 20:30:20 -07:00
|
|
|
|
2017-06-19 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21626
|
|
|
|
|
* elf-properties.c (_bfd_elf_link_setup_gnu_properties): Check
|
|
|
|
|
the DYNAMIC bit instead of bfd_count_sections.
|
|
|
|
|
|
2017-06-19 14:52:36 +01:00
|
|
|
|
2017-06-19 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21618
|
|
|
|
|
* vms-alpha.c (evax_bfd_print_emh): Check for insufficient record
|
|
|
|
|
length.
|
|
|
|
|
(evax_bfd_print_eeom): Likewise.
|
|
|
|
|
(evax_bfd_print_egsd): Check for an overlarge record length.
|
|
|
|
|
(evax_bfd_print_etir): Likewise.
|
|
|
|
|
|
2017-06-19 14:06:53 +01:00
|
|
|
|
2017-06-19 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21612
|
|
|
|
|
* libieee.h (struct common_header_type): Add end_p field.
|
|
|
|
|
* ieee.c (this_byte_and_next): Do not advance input_p beyond
|
|
|
|
|
end_p.
|
|
|
|
|
(read_id): Check for a length that exceeds the remaining bytes in
|
|
|
|
|
the input buffer.
|
|
|
|
|
(ieee_seek): Initialise end_p.
|
|
|
|
|
(ieee_archive_p): Likewise.
|
|
|
|
|
(ieee_object_p): Likewise.
|
|
|
|
|
|
2017-06-19 12:31:07 +01:00
|
|
|
|
2017-06-19 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
2017-06-19 13:01:57 +01:00
|
|
|
|
PR binutils/21611
|
|
|
|
|
* vms-alpha.c (_bfd_vms_slurp_eihs): Check for invalid offset
|
|
|
|
|
before reading the EIHS structure entries.
|
|
|
|
|
|
|
|
|
|
2017-06-19 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21615
|
2017-06-19 12:31:07 +01:00
|
|
|
|
* vms-alpha.c (_bfd_vms_slurp_egsd): Use unsigned int for
|
|
|
|
|
gsd_size. Check that there are enough bytes remaining to read the
|
|
|
|
|
type and size of the next egsd. Check that the size of the egsd
|
|
|
|
|
does not exceed the size of the record.
|
|
|
|
|
|
2017-06-19 16:04:16 +09:30
|
|
|
|
2017-06-19 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* config.bfd: Correct targ_underscore for cris.
|
|
|
|
|
|
2017-06-18 09:19:34 +09:30
|
|
|
|
2017-06-18 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* config.bfd: Correct targ_underscore for epiphany, ip2k,
|
|
|
|
|
m32c, mn10200, pru, rl78, rx, crisv32 and v850.
|
|
|
|
|
|
2017-06-16 15:16:19 +01:00
|
|
|
|
2017-06-16 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (bfd_elf_size_dynsym_hash_dynstr): Do not fail if the
|
|
|
|
|
bucketlist is empty because there are no symbols to add to the
|
|
|
|
|
list.
|
|
|
|
|
|
Rewrite __start and __stop symbol handling
This arranges for __start and __stop symbols to be defined before
garbage collection, for all target formats. That should allow the
COFF and PE --gc-sections to keep a singleton orphan input section,
a feature lost by 2017-06-13 commit cbd0eecf26. The fancier ELF
treatment of keeping all input sections associated with a __start or
__stop symbol, from 2015-10-23 commit 1cce69b9dc, is retained.
.startof. and .sizeof. symbols are deliberately not defined before
garbage collection, so these won't affect garbage collection of
sections.
The patch also ensures __start, __stop, .startof. and .sizeof. symbols
are defined before target size_dynamic_sections is called, albeit
with a preliminary value, so that target code doesn't need to cope
with a symbol changing from undefined at size_dynamic_sections to
defined at relocate_section.
Also, a number of problems with the testcases have been fixed.
PR ld/20022
PR ld/21557
PR ld/21562
PR ld/21571
include/
* bfdlink.h (struct bfd_link_hash_entry): Delete undef.section.
bfd/
* targets.c (struct bfd_target): Add _bfd_define_start_stop.
(BFD_JUMP_TABLE_LINK): Likewise.
* elf-bfd.h (bfd_elf_define_start_stop): Declare.
* elflink.c (_bfd_elf_gc_mark_rsec): Update comment.
(bfd_elf_define_start_stop): New function.
* linker.c (bfd_generic_define_start_stop): New function.
* coff64-rs6000.c (rs6000_xcoff64_vec, rs6000_xcoff64_aix_vec): Init
new field.
* aout-adobe.c (aout_32_bfd_define_start_stop): Define.
* aout-target.h (MY_bfd_define_start_stop): Define.
* aout-tic30.c (MY_bfd_define_start_stop): Define.
* binary.c (binary_bfd_define_start_stop): Define.
* bout.c (b_out_bfd_define_start_stop): Define.
* coff-alpha.c (_bfd_ecoff_bfd_define_start_stop): Define.
* coff-mips.c (_bfd_ecoff_bfd_define_start_stop): Define.
* coff-rs6000.c (_bfd_xcoff_bfd_define_start_stop): Define.
* coffcode.h (coff_bfd_define_start_stop): Define.
* elfxx-target.h (bfd_elfNN_bfd_define_start_stop): Define.
* i386msdos.c (msdos_bfd_define_start_stop): Define.
* i386os9k.c (os9k_bfd_define_start_stop): Define.
* ieee.c (ieee_bfd_define_start_stop): Define.
* ihex.c (ihex_bfd_define_start_stop): Define.
* libbfd-in.h (_bfd_nolink_bfd_define_start_stop): Define.
* mach-o-target.c (bfd_mach_o_bfd_define_start_stop): Define.
* mmo.c (mmo_bfd_define_start_stop): Define.
* nlm-target.h (nlm_bfd_define_start_stop): Define.
* oasys.c (oasys_bfd_define_start_stop): Define.
* pef.c (bfd_pef_bfd_define_start_stop): Define.
* plugin.c (bfd_plugin_bfd_define_start_stop): Define.
* ppcboot.c (ppcboot_bfd_define_start_stop): Define.
* som.c (som_bfd_define_start_stop): Define.
* srec.c (srec_bfd_define_start_stop): Define.
* tekhex.c (tekhex_bfd_define_start_stop): Define.
* versados.c (versados_bfd_define_start_stop): Define.
* vms-alpha.c (vms_bfd_define_start_stop): Define.
(alpha_vms_bfd_define_start_stop): Define.
* xsym.c (bfd_sym_bfd_define_start_stop): Define.
* bfd-in2.h: Regenerate.
* libbfd.h: Regenerate.
ld/
* emultempl/elf32.em (gld${EMULATION_NAME}_after_open): Don't set
__start/__stop syms here.
* ldlang.c (lang_set_startof): Delete.
(start_stop_syms, start_stop_count, start_stop_alloc): New vars.
(lang_define_start_stop, lang_init_start_stop, foreach_start_stop,
undef_start_stop, lang_undef_start_stop, lang_init_startof_sizeof,
set_start_stop, lang_finalize_start_stop): New functions.
(lang_process): Call _start_stop functions.
* testsuite/ld-elf/pr21562a.d: Use xfail rather than notarget.
Correct typos and list of xfail targets.
* testsuite/ld-elf/pr21562b.d: Likewise.
* testsuite/ld-elf/pr21562c.d: Likewise.
* testsuite/ld-elf/pr21562d.d: Likewise.
* testsuite/ld-elf/pr21562e.d: Likewise.
* testsuite/ld-elf/pr21562f.d: Likewise.
* testsuite/ld-elf/pr21562g.d: Likewise.
* testsuite/ld-elf/pr21562h.d: Likewise.
* testsuite/ld-elf/pr21562i.d: Likewise.
* testsuite/ld-elf/pr21562j.d: Likewise.
* testsuite/ld-elf/pr21562k.d: Likewise.
* testsuite/ld-elf/pr21562l.d: Likewise.
* testsuite/ld-elf/pr21562m.d: Likewise.
* testsuite/ld-elf/pr21562n.d: Likewise.
* testsuite/ld-elf/sizeofa.d: Likewise. Adjust to pass for generic ELF.
* testsuite/ld-elf/sizeofb.d: Likewise.
* testsuite/ld-elf/startofa.d: Likewise.
* testsuite/ld-elf/startofb.d: Likewise.
2017-06-16 19:41:41 +09:30
|
|
|
|
2017-06-16 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20022
|
|
|
|
|
PR ld/21557
|
|
|
|
|
PR ld/21562
|
|
|
|
|
PR ld/21571
|
|
|
|
|
* targets.c (struct bfd_target): Add _bfd_define_start_stop.
|
|
|
|
|
(BFD_JUMP_TABLE_LINK): Likewise.
|
|
|
|
|
* elf-bfd.h (bfd_elf_define_start_stop): Declare.
|
|
|
|
|
* elflink.c (_bfd_elf_gc_mark_rsec): Update comment.
|
|
|
|
|
(bfd_elf_define_start_stop): New function.
|
|
|
|
|
* linker.c (bfd_generic_define_start_stop): New function.
|
|
|
|
|
* coff64-rs6000.c (rs6000_xcoff64_vec, rs6000_xcoff64_aix_vec): Init
|
|
|
|
|
new field.
|
|
|
|
|
* aout-adobe.c (aout_32_bfd_define_start_stop): Define.
|
|
|
|
|
* aout-target.h (MY_bfd_define_start_stop): Define.
|
|
|
|
|
* aout-tic30.c (MY_bfd_define_start_stop): Define.
|
|
|
|
|
* binary.c (binary_bfd_define_start_stop): Define.
|
|
|
|
|
* bout.c (b_out_bfd_define_start_stop): Define.
|
|
|
|
|
* coff-alpha.c (_bfd_ecoff_bfd_define_start_stop): Define.
|
|
|
|
|
* coff-mips.c (_bfd_ecoff_bfd_define_start_stop): Define.
|
|
|
|
|
* coff-rs6000.c (_bfd_xcoff_bfd_define_start_stop): Define.
|
|
|
|
|
* coffcode.h (coff_bfd_define_start_stop): Define.
|
|
|
|
|
* elfxx-target.h (bfd_elfNN_bfd_define_start_stop): Define.
|
|
|
|
|
* i386msdos.c (msdos_bfd_define_start_stop): Define.
|
|
|
|
|
* i386os9k.c (os9k_bfd_define_start_stop): Define.
|
|
|
|
|
* ieee.c (ieee_bfd_define_start_stop): Define.
|
|
|
|
|
* ihex.c (ihex_bfd_define_start_stop): Define.
|
|
|
|
|
* libbfd-in.h (_bfd_nolink_bfd_define_start_stop): Define.
|
|
|
|
|
* mach-o-target.c (bfd_mach_o_bfd_define_start_stop): Define.
|
|
|
|
|
* mmo.c (mmo_bfd_define_start_stop): Define.
|
|
|
|
|
* nlm-target.h (nlm_bfd_define_start_stop): Define.
|
|
|
|
|
* oasys.c (oasys_bfd_define_start_stop): Define.
|
|
|
|
|
* pef.c (bfd_pef_bfd_define_start_stop): Define.
|
|
|
|
|
* plugin.c (bfd_plugin_bfd_define_start_stop): Define.
|
|
|
|
|
* ppcboot.c (ppcboot_bfd_define_start_stop): Define.
|
|
|
|
|
* som.c (som_bfd_define_start_stop): Define.
|
|
|
|
|
* srec.c (srec_bfd_define_start_stop): Define.
|
|
|
|
|
* tekhex.c (tekhex_bfd_define_start_stop): Define.
|
|
|
|
|
* versados.c (versados_bfd_define_start_stop): Define.
|
|
|
|
|
* vms-alpha.c (vms_bfd_define_start_stop): Define.
|
|
|
|
|
(alpha_vms_bfd_define_start_stop): Define.
|
|
|
|
|
* xsym.c (bfd_sym_bfd_define_start_stop): Define.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* libbfd.h: Regenerate.
|
|
|
|
|
|
2017-06-16 14:20:38 +01:00
|
|
|
|
2017-06-16 Jiong Wang <jiong.wang@arm.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-aarch64.c (elfNN_aarch64_final_link_relocate): Use
|
|
|
|
|
SYMBOL_REFERENCES_LOCAL.
|
|
|
|
|
|
2017-06-15 16:51:01 +01:00
|
|
|
|
2017-06-15 Jiong Wang <jiong.wang@arm.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21532
|
|
|
|
|
* elfnn-aarch64.c (ELIMINATE_COPY_RELOCS): Set to 1.
|
|
|
|
|
(elfNN_aarch64_final_link_relocate): Also propagate relocations to
|
|
|
|
|
runtime for if there needs copy relocation elimination.
|
|
|
|
|
(need_copy_relocation_p): New function. Return true for symbol with
|
|
|
|
|
pc-relative references and if it's against read-only sections.
|
|
|
|
|
(elfNN_aarch64_adjust_dynamic_symbol): Use need_copy_relocation_p.
|
|
|
|
|
(elfNN_aarch64_check_relocs): Allocate dynrelocs for relocation types
|
|
|
|
|
that are related with accessing external objects.
|
|
|
|
|
(elfNN_aarch64_gc_sweep_hook): Sync the relocation types with the change
|
|
|
|
|
in elfNN_aarch64_check_relocs.
|
|
|
|
|
|
2017-06-15 12:44:23 +01:00
|
|
|
|
2017-06-15 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21582
|
|
|
|
|
* ieee.c (ieee_object_p): Use a static buffer to avoid compiler
|
|
|
|
|
bugs.
|
2017-06-15 13:08:47 +01:00
|
|
|
|
PR binutils/21581
|
|
|
|
|
(ieee_archive_p): Likewise.
|
2017-06-15 12:44:23 +01:00
|
|
|
|
|
2017-06-15 12:08:57 +01:00
|
|
|
|
2017-06-15 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21579
|
|
|
|
|
* vms-alpha.c (_bfd_vms_slurp_etir): Extend check of cmd_length.
|
|
|
|
|
|
2017-05-17 02:09:14 -07:00
|
|
|
|
2017-06-14 Max Filippov <jcmvbkbc@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-xtensa.c (elf_xtensa_be_plt_entry,
|
|
|
|
|
elf_xtensa_le_plt_entry): Add dimension for the ABI to arrays,
|
|
|
|
|
keep both windowed and call0 ABI PLT definitions.
|
|
|
|
|
(elf_xtensa_create_plt_entry): Use selected ABI to choose upper
|
|
|
|
|
elf_xtensa_*_plt_entry endex.
|
|
|
|
|
(ELF_MAXPAGESIZE): Fix at minimal supported MMU page size.
|
|
|
|
|
|
2017-06-14 17:01:54 +01:00
|
|
|
|
2017-06-14 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21578
|
|
|
|
|
* elf32-sh.c (sh_elf_set_mach_from_flags): Fix check for invalid
|
|
|
|
|
flag value.
|
|
|
|
|
|
2017-06-14 11:27:15 +01:00
|
|
|
|
2017-06-14 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21589
|
|
|
|
|
* vms-alpha.c (_bfd_vms_get_value): Add an extra parameter - the
|
|
|
|
|
maximum value for the ascic pointer. Check that name processing
|
|
|
|
|
does not read beyond this value.
|
|
|
|
|
(_bfd_vms_slurp_etir): Add checks for attempts to read beyond the
|
|
|
|
|
end of etir record.
|
|
|
|
|
|
2017-06-14 10:35:16 +01:00
|
|
|
|
2017-06-14 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21591
|
|
|
|
|
* versados.c (versados_mkobject): Zero the allocated tdata structure.
|
|
|
|
|
(process_otr): Check for an invalid offset in the otr structure.
|
|
|
|
|
|
2017-06-13 07:48:40 +02:00
|
|
|
|
2017-06-14 Sebastian Huber <sebastian.huber@embedded-brains.de>
|
|
|
|
|
|
|
|
|
|
* config.bfd (epiphany-*-elf): Accept epiphany-*-*.
|
|
|
|
|
|
2017-06-13 08:53:22 -07:00
|
|
|
|
2017-06-13 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20022
|
|
|
|
|
PR ld/21557
|
|
|
|
|
PR ld/21562
|
|
|
|
|
PR ld/21571
|
|
|
|
|
* elf-bfd.h (elf_link_hash_entry): Add start_stop. Change the
|
|
|
|
|
vtable field to a union.
|
|
|
|
|
(_bfd_elf_is_start_stop): Removed.
|
|
|
|
|
* elf32-i386.c (elf_i386_convert_load_reloc): Also check for
|
|
|
|
|
__start_SECNAME and __stop_SECNAME symbols.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_convert_load_reloc): Likewise.
|
|
|
|
|
* elflink.c (_bfd_elf_is_start_stop): Removed.
|
|
|
|
|
(_bfd_elf_gc_mark_rsec): Check start_stop instead of calling
|
|
|
|
|
_bfd_elf_is_start_stop.
|
|
|
|
|
(elf_gc_propagate_vtable_entries_used): Skip __start_SECNAME and
|
|
|
|
|
__stop_SECNAME symbols. Updated.
|
|
|
|
|
(elf_gc_smash_unused_vtentry_relocs): Likewise.
|
|
|
|
|
(bfd_elf_gc_record_vtinherit): Likewise.
|
|
|
|
|
(bfd_elf_gc_record_vtentry): Likewise.
|
|
|
|
|
|
2017-06-13 14:03:16 +01:00
|
|
|
|
2017-06-13 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21524
|
|
|
|
|
* elflink.c (elf_link_adjust_relocs): Generate an error when
|
|
|
|
|
encountering a reloc against a symbol removed by garbage
|
|
|
|
|
collection.
|
|
|
|
|
|
2017-06-12 07:37:15 -07:00
|
|
|
|
2017-06-12 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h (elf_backend_data): Add struct bfd_link_info *
|
|
|
|
|
to merge_gnu_properties.
|
|
|
|
|
* elf-properties.c (elf_merge_gnu_properties): Add struct
|
|
|
|
|
bfd_link_info * and pass it to merge_gnu_properties.
|
|
|
|
|
(elf_merge_gnu_property_list): Add struct bfd_link_info *
|
|
|
|
|
and pass it to elf_merge_gnu_properties.
|
|
|
|
|
(_bfd_elf_link_setup_gnu_properties): Pass info to
|
|
|
|
|
elf_merge_gnu_property_list.
|
|
|
|
|
* elf32-i386.c (elf_i386_merge_gnu_properties): Add struct
|
|
|
|
|
bfd_link_info *.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_merge_gnu_properties): Likewise.
|
|
|
|
|
|
2017-06-11 13:34:13 +09:30
|
|
|
|
2017-06-11 Joe Zbiciak <joe.zbiciak@leftturnonly.info>
|
|
|
|
|
|
|
|
|
|
PR 21564
|
|
|
|
|
* binary.c (binary_set_section_contents): Scale lma by octets
|
|
|
|
|
per byte to set filepos.
|
|
|
|
|
|
2017-05-23 13:36:33 +02:00
|
|
|
|
2017-06-08 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf_arc_check_relocs): Fixed conditions to generate
|
|
|
|
|
dynamic sections.
|
|
|
|
|
|
2017-04-05 23:22:07 +02:00
|
|
|
|
2017-06-08 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf_arc_size_dynamic_sections): Changed condition to
|
|
|
|
|
require TEXTREL.
|
|
|
|
|
|
2016-12-29 17:10:01 +01:00
|
|
|
|
2017-06-08 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* arc-got.h (relocate_fix_got_relocs_for_got_info): Added TCB_SIZE to
|
|
|
|
|
patched section contents for TLS IE reloc.
|
|
|
|
|
* elf32-arc.c: Remove TCB_SIZE preprocessor macro.
|
|
|
|
|
|
2016-11-30 20:23:21 +01:00
|
|
|
|
2017-06-08 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf_arc_relocate_section): Added "call" to
|
|
|
|
|
RELOC_FOR_GLOBAL_SYMBOL macro.
|
|
|
|
|
|
2016-11-30 14:07:20 +01:00
|
|
|
|
2018-06-08 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf_arc_relocate_section): Small refactor and condition
|
|
|
|
|
changes.
|
|
|
|
|
|
2016-05-30 15:19:22 +05:30
|
|
|
|
2017-06-08 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* config/tc-arc.c (md_undefined_symbol): Changed.
|
|
|
|
|
* config/tc-arc.h (DYNAMIC_STRUCT_NAME): Removed.
|
|
|
|
|
|
2016-10-24 22:19:48 +02:00
|
|
|
|
2017-06-08 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf_arc_relocate_section): Fixed reassign of indirect
|
|
|
|
|
symbols.
|
|
|
|
|
|
2016-10-24 12:52:04 +02:00
|
|
|
|
2017-06-08 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (elf_arc_check_relocs): Added condition to disable
|
|
|
|
|
warning and "Bad value" for local symbols ARC_32 or ARC_32_ME relocs.
|
|
|
|
|
|
2016-12-07 14:22:54 +01:00
|
|
|
|
2017-06-08 Cupertino Miranda <cmiranda@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (ADD_RELA): Changed to only work when dynamic
|
|
|
|
|
object is created.
|
|
|
|
|
|
[bfd][arm] Don't assert on suspicious build attributes in input file
It's generally a bad idea to use assertions to validate our idea of
what an input file looks like. We need to be as liberal as possible
in what we accept with respect to standards and conservative with what
we produce.
Currently, if gcc is used to produce an assembler file which contains
only data, but the FPU is set to fpv4-sp-d16 and mfloat-abi=hard, then
the following attributes will be set in the output:
.cpu arm7tdmi
.eabi_attribute 27, 1 @ Tag_ABI_HardFP_use
.eabi_attribute 28, 1 @ Tag_ABI_VFP_args
.eabi_attribute 20, 1 @ Tag_ABI_FP_denormal
.eabi_attribute 21, 1 @ Tag_ABI_FP_exceptions
.eabi_attribute 23, 3 @ Tag_ABI_FP_number_model
.eabi_attribute 24, 1 @ Tag_ABI_align8_needed
.eabi_attribute 25, 1 @ Tag_ABI_align8_preserved
.eabi_attribute 26, 2 @ Tag_ABI_enum_size
.eabi_attribute 30, 6 @ Tag_ABI_optimization_goals
.eabi_attribute 34, 0 @ Tag_CPU_unaligned_access
.eabi_attribute 18, 4 @ Tag_ABI_PCS_wchar_t
There is then no .fpu directive to cause Tag_FP_arch to be set,
because there are no functions containing code in the object file. If
this object file is assembled by hand, but without -mfpu on the
invocation of the assembler, then the build attributes produced will
trigger an assertion during linking.
Thinking about the build attributes, the combination of a
single-precision only implementation of no floating-point architecture
is still no floating-point architecture. Hence the assertion on the
input BFD in the linker makes no real sense.
We should, however, be more conservative in what we generate, so I've
left the assertion on the output bfd in place; I don't think we can
trigger it with this change since we never merge the problematic tags
from a perversely generated input file.
* elf32-arm.c (elf32_arm_merge_eabi_attributes): Remove assertion
that the input bfd has Tag_FP_ARCH non-zero if Tag_ABI_HardFP_use
is non-zero. Add clarifying comments.
2017-06-08 15:11:44 +01:00
|
|
|
|
2017-06-08 Richard Earnshaw <rearnsha@arm.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (elf32_arm_merge_eabi_attributes): Remove assertion
|
|
|
|
|
that the input bfd has Tag_FP_ARCH non-zero if Tag_ABI_HardFP_use
|
|
|
|
|
is non-zero. Add clarifying comments.
|
|
|
|
|
|
2017-06-08 03:48:04 -07:00
|
|
|
|
2017-06-08 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_check_relocs): Set local IFUNC symbol
|
|
|
|
|
name. Use local IFUNC symbol name string to report unsupported
|
|
|
|
|
non-PIC call to IFUNC function.
|
|
|
|
|
(elf_i386_relocate_section): Dump local IFUNC name with minfo
|
|
|
|
|
when generating R_386_IRELATIVE relocation.
|
|
|
|
|
(elf_i386_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf_x86_64_check_relocs (elf_x86_64_check_relocs): Set local
|
|
|
|
|
IFUNC symbol name.
|
|
|
|
|
(elf_x86_64_relocate_section): Dump local IFUNC name with minfo
|
|
|
|
|
when generating R_X86_64_IRELATIVE relocation.
|
|
|
|
|
(elf_x86_64_finish_dynamic_symbol): Likewise.
|
|
|
|
|
|
2017-06-06 11:19:06 -07:00
|
|
|
|
2017-06-06 Jose E. Marchesi <jose.marchesi@oracle.com>
|
|
|
|
|
|
|
|
|
|
* elf.c (setup_group): Make sure BFD sections are created for all
|
|
|
|
|
group sections in the input file when processing SHF_GROUP
|
|
|
|
|
sections.
|
|
|
|
|
(bfd_section_from_shdr): Avoid duplicating logic already
|
|
|
|
|
implemented in `setup_group'.
|
|
|
|
|
|
2017-06-06 15:06:02 +01:00
|
|
|
|
2017-06-06 Daniel Bonniot de Ruisselet <bonniot@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21546
|
|
|
|
|
* peXXigen.c (pe_print_idata): Use the address of the first thunk
|
|
|
|
|
if the hint address is zero.
|
|
|
|
|
|
2017-06-06 14:30:47 +01:00
|
|
|
|
2017-06-06 James Clarke <jrtc27@jrtc27.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19579
|
|
|
|
|
* elfnn-aarch64.c (elfNN_aarch64_finish_dynamic_symbol): Check
|
|
|
|
|
ELF_COMMON_DEF_P for common symbols.
|
|
|
|
|
|
ld: Allow section groups to be resolved as part of a relocatable link
This commit adds a new linker feature: the ability to resolve section
groups as part of a relocatable link.
Currently section groups are automatically resolved when performing a
final link, and are carried through when performing a relocatable link.
By carried through this means that one copy of each section group (from
all the copies that might be found in all the input files) is placed
into the output file. Sections that are part of a section group will
not match input section specifiers within a linker script and are
forcibly kept as separate sections.
There is a slight resemblance between section groups and common
section. Like section groups, common sections are carried through when
performing a relocatable link, and resolved (allocated actual space)
only at final link time.
However, with common sections there is an ability to force the linker to
allocate space for the common sections when performing a relocatable
link, there's currently no such ability for section groups.
This commit adds such a mechanism. This new facility can be accessed in
two ways, first there's a command line switch --force-group-allocation,
second, there's a new linker script command FORCE_GROUP_ALLOCATION. If
one of these is used when performing a relocatable link then the linker
will resolve the section groups as though it were performing a final
link, the section group will be deleted, and the members of the group
will be placed like normal input sections. If there are multiple copies
of the group (from multiple input files) then only one copy of the group
members will be placed, the duplicate copies will be discarded.
Unlike common sections that have the --no-define-common command line
flag, and INHIBIT_COMMON_ALLOCATION linker script command there is no
way to prevent group resolution during a final link, this is because the
ELF gABI specifically prohibits the presence of SHT_GROUP sections in a
fully linked executable. However, the code as written should make
adding such a feature trivial, setting the new resolve_section_groups
flag to false during a final link should work as you'd expect.
bfd/ChangeLog:
* elf.c (_bfd_elf_make_section_from_shdr): Don't initially mark
SEC_GROUP sections as SEC_EXCLUDE.
(bfd_elf_set_group_contents): Replace use of abort with an assert.
(assign_section_numbers): Use resolve_section_groups flag instead
of relocatable link type.
(_bfd_elf_init_private_section_data): Use resolve_section_groups
flag instead of checking the final_link flag for part of the
checks in here. Fix white space as a result.
* elflink.c (elf_link_input_bfd): Use resolve_section_groups flag
instead of relocatable link type.
(bfd_elf_final_link): Likewise.
include/ChangeLog:
* bfdlink.h (struct bfd_link_info): Add new resolve_section_groups
flag.
ld/ChangeLog:
* ld.h (struct args_type): Add force_group_allocation field.
* ldgram.y: Add support for FORCE_GROUP_ALLOCATION.
* ldlex.h: Likewise.
* ldlex.l: Likewise.
* lexsup.c: Likewise.
* ldlang.c (unique_section_p): Check resolve_section_groups flag
not the relaxable link flag.
(lang_add_section): Discard section groups when we're resolving
groups. Clear the SEC_LINK_ONCE flag if we're resolving section
groups.
* ldmain.c (main): Initialise resolve_section_groups flag in
link_info based on command line flags.
* testsuite/ld-elf/group11.d: New file.
* testsuite/ld-elf/group12.d: New file.
* testsuite/ld-elf/group12.ld: New file.
* NEWS: Mention new features.
* ld.texinfo (Options): Document --force-group-allocation.
(Miscellaneous Commands): Document FORCE_GROUP_ALLOCATION.
2017-03-22 17:27:49 +00:00
|
|
|
|
2017-06-06 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
|
|
|
|
|
|
* elf.c (_bfd_elf_make_section_from_shdr): Don't initially mark
|
|
|
|
|
SEC_GROUP sections as SEC_EXCLUDE.
|
|
|
|
|
(bfd_elf_set_group_contents): Replace use of abort with an assert.
|
|
|
|
|
(assign_section_numbers): Use resolve_section_groups flag instead
|
|
|
|
|
of relocatable link type.
|
|
|
|
|
(_bfd_elf_init_private_section_data): Use resolve_section_groups
|
|
|
|
|
flag instead of checking the final_link flag for part of the
|
|
|
|
|
checks in here. Fix white space as a result.
|
|
|
|
|
* elflink.c (elf_link_input_bfd): Use resolve_section_groups flag
|
|
|
|
|
instead of relocatable link type.
|
|
|
|
|
(bfd_elf_final_link): Likewise.
|
|
|
|
|
|
2017-06-06 00:33:20 -07:00
|
|
|
|
2017-06-06 Jose E. Marchesi <jose.marchesi@oracle.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_relocate_section): Remove unused
|
|
|
|
|
variable `bed'.
|
|
|
|
|
* elf32-score.c (score_elf_final_link_relocate): Likewise.
|
|
|
|
|
(s3_bfd_score_elf_check_relocs): Likewise.
|
|
|
|
|
* elf32-score7.c (s7_bfd_score_elf_relocate_section): Likewise.
|
|
|
|
|
(score_elf_final_link_relocate): Likewise.
|
|
|
|
|
(s7_bfd_score_elf_check_relocs): Likewise.
|
|
|
|
|
|
2017-06-06 00:01:58 -07:00
|
|
|
|
2017-06-06 Jose E. Marchesi <jose.marchesi@oracle.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (init_reloc_cookie_rels): Remove unused variable
|
|
|
|
|
`bed'.
|
|
|
|
|
|
2017-06-06 01:24:06 +01:00
|
|
|
|
2017-06-06 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h (RELOC_AGAINST_DISCARDED_SECTION): Subtract `count'
|
|
|
|
|
from `reloc_count' rather than decrementing it.
|
|
|
|
|
* elf.c (bfd_section_from_shdr): Multiply the adjustment to
|
|
|
|
|
`reloc_count' by `int_rels_per_ext_rel'.
|
|
|
|
|
* elf32-score.c (score_elf_final_link_relocate): Do not multiply
|
|
|
|
|
`reloc_count' by `int_rels_per_ext_rel' for last relocation
|
|
|
|
|
entry determination.
|
|
|
|
|
(s3_bfd_score_elf_check_relocs): Likewise.
|
|
|
|
|
* elf32-score7.c (score_elf_final_link_relocate): Likewise.
|
|
|
|
|
(s7_bfd_score_elf_relocate_section): Likewise.
|
|
|
|
|
(s7_bfd_score_elf_check_relocs): Likewise.
|
|
|
|
|
* elf64-mips.c (mips_elf64_get_reloc_upper_bound): Remove
|
|
|
|
|
prototype and function.
|
|
|
|
|
(mips_elf64_slurp_one_reloc_table): Do not update `reloc_count'.
|
|
|
|
|
(mips_elf64_slurp_reloc_table): Assert that `reloc_count' is
|
|
|
|
|
triple rather than once the sum of REL and RELA relocation entry
|
|
|
|
|
counts.
|
|
|
|
|
(bfd_elf64_get_reloc_upper_bound): Remove macro.
|
|
|
|
|
* elflink.c (_bfd_elf_link_read_relocs): Do not multiply
|
|
|
|
|
`reloc_count' by `int_rels_per_ext_rel' for internal relocation
|
|
|
|
|
storage allocation size determination.
|
|
|
|
|
(elf_link_input_bfd): Multiply `.ctors' and `.dtors' section's
|
|
|
|
|
size by `int_rels_per_ext_rel'. Do not multiply `reloc_count'
|
|
|
|
|
by `int_rels_per_ext_rel' for last relocation entry
|
|
|
|
|
determination.
|
|
|
|
|
(bfd_elf_final_link): Do not multiply `reloc_count' by
|
|
|
|
|
`int_rels_per_ext_rel' for internal relocation storage
|
|
|
|
|
allocation size determination.
|
|
|
|
|
(init_reloc_cookie_rels): Do not multiply `reloc_count' by
|
|
|
|
|
`int_rels_per_ext_rel' for last relocation entry determination.
|
|
|
|
|
(elf_gc_smash_unused_vtentry_relocs): Likewise.
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_check_relocs): Likewise.
|
|
|
|
|
(_bfd_mips_elf_relocate_section): Likewise.
|
|
|
|
|
|
2017-06-05 11:02:42 +09:30
|
|
|
|
2017-06-05 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21529
|
|
|
|
|
* linker.c (_bfd_generic_link_output_symbols): Handle BSF_GNU_UNIQUE.
|
|
|
|
|
|
2017-06-01 09:47:31 -07:00
|
|
|
|
2017-06-01 John Baldwin <jhb@FreeBSD.org>
|
Use the ELF class to determine the word size for FreeBSD core notes.
FreeBSD ELF cores contain data structures with that have two different
layouts: one for ILP32 platforms and a second for LP64 platforms.
Previously, the code used 'bits_per_word' from 'arch_info', but this
field is not a reliable indicator of the format for FreeBSD MIPS cores
in particular.
I had originally posted this patch back in November because process
cores for FreeBSD MIPS contained an e_flags value of 0 in the header
which resulted in a bfd_arch which always had 'bits_per_word' set to
32. This permitted reading o32 cores, but not n64 cores. The feedback
I received then was to try to change n64 cores to use a different
default bfd_arch that had a 64-bit 'bits_per_word' when e_flags was zero.
I submitted a patch to that effect but it was never approved. Instead,
I changed FreeBSD's kernel and gcore commands to preserve the e_flags
field from an executable when generating process cores. With a proper
e_flags field in process cores, n64 cores now use a 64-bit bfd_arch and
now work fine. However, the change to include e_flags in the process
cores had the unintended side effect of breaking handling of o32
process cores. Specifically, FreeBSD MIPS builds o32 with a default
MIPS architecture of 'mips3', thus FreeBSD process cores with a non-zero
e_flags match the 'mips3' bfd_arch which has 64 'bits_per_word'.
From this, it seems that 'bits_per_word' for FreeBSD MIPS is not likely
to ever be completely correct. However, FreeBSD core dumps do
reliably set the ELF class to ELFCLASS32 for cores using ILP32 and
ELFCLASS64 for cores using LP64. As such, I think my original patch of
using the ELF class instead of 'bits_per_word' is probably the simplest
and most reliable approach for detecting the note structure layout.
bfd/ChangeLog:
* elf.c (elfcore_grok_freebsd_psinfo): Use ELF header class to
determine structure sizes.
(elfcore_grok_freebsd_prstatus): Likewise.
2017-06-01 09:40:46 -07:00
|
|
|
|
|
|
|
|
|
* elf.c (elfcore_grok_freebsd_psinfo): Use ELF header class to
|
|
|
|
|
determine structure sizes.
|
|
|
|
|
(elfcore_grok_freebsd_prstatus): Likewise.
|
|
|
|
|
|
PPC64_OPT_LOCALENTRY
ELFv2 functions with localentry:0 are those with a single entry point,
ie. global entry == local entry, and that have no requirement on r2 or
r12, and guarantee r2 is unchanged on return. Such an external
function can be called via the PLT without saving r2 or restoring it
on return, avoiding a common load-hit-store for small functions. The
optimization is attractive. The TOC pointer load-hit-store is a major
reason why calls to small functions that need no register saves, or
with shrink-wrap, no register saves on a fast path, are slow on
powerpc64le.
To be safe, this optimization needs ld.so support to check that the
run-time matches link-time function implementation. If a function
in a shared library with st_other localentry non-zero is called
without saving and restoring r2, r2 will be trashed on return, leading
to segfaults. For that reason the optimization does not happen for
weak functions since a weak definition is a fairly solid hint that the
function will likely be overridden. I'm also not enabling the
optimization by default unless glibc-2.26 is detected, which should
have the ld.so checks implemented.
bfd/
* elf64-ppc.c (struct ppc_link_hash_table): Add has_plt_localentry0.
(ppc64_elf_merge_symbol_attribute): Merge localentry bits from
dynamic objects.
(is_elfv2_localentry0): New function.
(ppc64_elf_tls_setup): Default params->plt_localentry0.
(plt_stub_size): Adjust size for tls_get_addr_opt stub.
(build_tls_get_addr_stub): Use a simpler stub when r2 is not saved.
(ppc64_elf_size_stubs): Leave stub_type as ppc_stub_plt_call for
optimized localentry:0 stubs.
(ppc64_elf_build_stubs): Save r2 in ELFv2 __glink_PLTresolve.
(ppc64_elf_relocate_section): Leave nop unchanged for optimized
localentry:0 stubs.
(ppc64_elf_finish_dynamic_sections): Set PPC64_OPT_LOCALENTRY in
DT_PPC64_OPT.
* elf64-ppc.h (struct ppc64_elf_params): Add plt_localentry0.
include/
* elf/ppc64.h (PPC64_OPT_LOCALENTRY): Define.
ld/
* emultempl/ppc64elf.em (params): Init plt_localentry0 field.
(enum ppc64_opt): New, replacing OPTION_* defines. Add
OPTION_PLT_LOCALENTRY, and OPTION_NO_PLT_LOCALENTRY.
(PARSE_AND_LIST_*): Support --plt-localentry and --no-plt-localentry.
* testsuite/ld-powerpc/elfv2so.d: Update.
* testsuite/ld-powerpc/powerpc.exp (TLS opt 5): Use --no-plt-localentry.
* testsuite/ld-powerpc/tlsopt5.d: Update.
2017-05-26 10:02:29 +09:30
|
|
|
|
2017-06-01 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (struct ppc_link_hash_table): Add has_plt_localentry0.
|
|
|
|
|
(ppc64_elf_merge_symbol_attribute): Merge localentry bits from
|
|
|
|
|
dynamic objects.
|
|
|
|
|
(is_elfv2_localentry0): New function.
|
|
|
|
|
(ppc64_elf_tls_setup): Default params->plt_localentry0.
|
|
|
|
|
(plt_stub_size): Adjust size for tls_get_addr_opt stub.
|
|
|
|
|
(build_tls_get_addr_stub): Use a simpler stub when r2 is not saved.
|
|
|
|
|
(ppc64_elf_size_stubs): Leave stub_type as ppc_stub_plt_call for
|
|
|
|
|
optimized localentry:0 stubs.
|
|
|
|
|
(ppc64_elf_build_stubs): Save r2 in ELFv2 __glink_PLTresolve.
|
|
|
|
|
(ppc64_elf_relocate_section): Leave nop unchanged for optimized
|
|
|
|
|
localentry:0 stubs.
|
|
|
|
|
(ppc64_elf_finish_dynamic_sections): Set PPC64_OPT_LOCALENTRY in
|
|
|
|
|
DT_PPC64_OPT.
|
|
|
|
|
* elf64-ppc.h (struct ppc64_elf_params): Add plt_localentry0.
|
|
|
|
|
|
2017-05-30 15:07:56 +01:00
|
|
|
|
2017-05-30 Casey Smith <clegg89@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21523
|
|
|
|
|
* elf32-arm.c (elf32_arm_final_link_relocate): Install an absolute
|
|
|
|
|
value when processing the R_ARM_THM_ALU_PREL_11_0 reloc.
|
|
|
|
|
|
[ARC] Implement compatible function for ARC BFD architectures
The general rule for bfd_arch_info_type->compatible (A, B) is that if A and B
are compatible, then this function should return architecture that is more
"feature-rich", that is, can run both A and B. ARCv2, EM and HS all has same
mach number, so bfd_default_compatible assumes they are the same, and returns
an A. That causes issues with GDB, because GDB assumes that if machines are
compatible, then "compatible ()" always returns same machine regardless of
argument order. As a result GDB gets confused because, for example,
compatible(ARCv2, EM) returns ARCv2, but compatible(EM, ARCv2) returns EM,
hence GDB is not sure if they are compatible and prints a warning.
bfd/ChangeLog:
yyyy-mm-dd Anton Kolesov Anton.Kolesov@synopsys.com
cpu-arc.c (arc_compatible): New function.
2017-03-17 18:37:42 +03:00
|
|
|
|
2017-05-30 Anton Kolesov Anton.Kolesov@synopsys.com
|
|
|
|
|
|
|
|
|
|
* cpu-arc.c (arc_compatible): New function.
|
|
|
|
|
|
2017-03-17 16:43:31 +03:00
|
|
|
|
2017-05-30 Anton Kolesov <anton.kolesov@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* cpu-arc.c (arch_info_struct): Remove duplicate ARC600 entry.
|
|
|
|
|
|
2017-05-30 06:34:05 -07:00
|
|
|
|
2017-05-30 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21519
|
|
|
|
|
* bfdio.c (bfd_get_file_size): New function.
|
|
|
|
|
* bfd-in2.h: Regenerated.
|
|
|
|
|
|
2017-05-23 12:18:10 +02:00
|
|
|
|
2017-05-23 Dilian Palauzov <git-dpa@aegee.org>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (arc_elf_merge_attributes): Add fall through
|
|
|
|
|
comments.
|
|
|
|
|
|
2017-05-22 07:41:16 -07:00
|
|
|
|
2017-05-22 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_link_setup_gnu_properties): Use
|
|
|
|
|
dynobj instead of htab->elf.dynobj.
|
|
|
|
|
|
MIPS/BFD: For n64 hold the number of internal relocs in `->reloc_count'
Revert parts of commit fee24f1c5bfe ("objdump improvements for mips
elf64"), <https://sourceware.org/ml/binutils/2003-03/msg00108.html>, and
make the `->reloc_count' member of `struct bfd_section' hold the actual
number of internal relocations stored in its `->relocation' vector. To
do so adjust `mips_elf64_slurp_one_reloc_table' to set `->reloc_count'
to the actual number of internal relocations retrieved and discard
`mips_elf64_canonicalize_reloc', `mips_elf64_canonicalize_dynamic_reloc'
and their corresponding target macros. Contrary to the description of
`mips_elf64_slurp_one_reloc_table', adjusted appropriately, this makes
generic relocation processing code happy and satisfies the "merge notes
section" binutils test case.
Add extra binutils test cases to expand the coverage of the generic
"merge notes section" test case, now passing with the n64 ABI, across
the MIPS o32, n32 and n64 ABIs regardless of the default ABI selected in
target configuration, and also to verify correctness of the relocations
produced. Conversely, do not provide any additional test cases for the
original issue addressed with the commit referred:
- objdump would display only 1/3 of the total number of relocations,
because it used the external relocation count, but each external
relocation is brought in as 3 internal relocations.
as n64 ABI relocation processing with `objdump -r' and `objdump -R' is
already widely covered across the GAS and LD test suites.
bfd/
* elf64-mips.c (mips_elf64_canonicalize_reloc): Remove prototype
and function.
(mips_elf64_canonicalize_dynamic_reloc): Likewise.
(mips_elf64_slurp_one_reloc_table): Set `reloc_count' to the
actual number of internal relocations retrieved. Adjust
function description.
(bfd_elf64_canonicalize_reloc): Remove macro.
(bfd_elf64_canonicalize_dynamic_reloc): Likewise.
binutils/
* testsuite/binutils-all/mips/mips-note-2.d: New test.
* testsuite/binutils-all/mips/mips-note-2r.d: New test.
* testsuite/binutils-all/mips/mips-note-2-n32.d: New test.
* testsuite/binutils-all/mips/mips-note-2-n64.d: New test.
* testsuite/binutils-all/mips/mips-note-2r-n32.d: New test.
* testsuite/binutils-all/mips/mips-note-2r-n64.d: New test.
* testsuite/binutils-all/mips/mips.exp: Define `has_newabi'.
Run the new tests.
2017-05-19 15:11:31 +01:00
|
|
|
|
2017-05-19 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elf64-mips.c (mips_elf64_canonicalize_reloc): Remove prototype
|
|
|
|
|
and function.
|
|
|
|
|
(mips_elf64_canonicalize_dynamic_reloc): Likewise.
|
|
|
|
|
(mips_elf64_slurp_one_reloc_table): Set `reloc_count' to the
|
|
|
|
|
actual number of internal relocations retrieved. Adjust
|
|
|
|
|
function description.
|
|
|
|
|
(bfd_elf64_canonicalize_reloc): Remove macro.
|
|
|
|
|
(bfd_elf64_canonicalize_dynamic_reloc): Likewise.
|
|
|
|
|
|
binutils: support for the SPARC M8 processor
This patch adds support for the new SPARC M8 processor (implementing OSA
2017) to binutils.
New instructions:
- Dictionary Unpack
+ dictunpack
- Partitioned Compare with shifted result
+ Signed variants: fpcmp{le,gt,eq,ne}{8,16,32}shl
+ Unsigned variants: fpcmpu{le,gt}{8,16,32}shl
- Partitioned Dual-Equal compared, with shifted result
+ fpcmpde{8,16,32}shl
- Partitioned Unsigned Range Compare, with shifted result
+ fpcmpur{8,16,32}shl
- 64-bit shifts on Floating-Point registers
+ fps{ll,ra,rl}64x
- Misaligned loads and stores
+ ldm{sh,uh,sw,uw,x,ux}
+ ldm{sh,uh,sw,uw,x,ux}a
+ ldmf{s,d}
+ ldmf{s,d}a
+ stm{h,w,x}
+ stm{h,w,x}a
+ stmf{s,d}
+ stmf{s,d}a
- Oracle Numbers
+ on{add,sub,mul,div}
- Reverse Bytes/Bits
+ revbitsb
+ revbytes{h,w,x}
- Run-Length instructions
+ rle_burst
+ rle_length
- New crypto instructions
+ sha3
- Instruction to read the new register %entropy
+ rd %entropy
New Alternate Address Identifiers:
- 0x24, #ASI_CORE_COMMIT_COUNT
- 0x24, #ASI_CORE_SELECT_COUNT
- 0x48, #ASI_ARF_ECC_REG
- 0x53, #ASI_ITLB_PROBE
- 0x58, #ASI_DSFAR
- 0x5a, #ASI_DTLB_PROBE_PRIMARY
- 0x5b, #ASI_DTLB_PROBE_REAL
- 0x64, #ASI_CORE_SELECT_COMMIT_NHT
The new assembler command-line options for selecting the M8 architecture
are:
-Av9m8 or -Asparc6 for 64-bit binaries.
-Av8plusm8 for 32-bit (v8+) binaries.
The corresponding disassembler command-line options are:
-msparc:v9m8 for 64-bit binaries.
-msparc:v8plusm8 for 32-bit (v8+) binaries.
Tested for regressions in the following targets:
sparc-aout sparc-linux sparc-vxworks sparc64-linux
bfd/ChangeLog:
2017-05-19 Jose E. Marchesi <jose.marchesi@oracle.com>
* archures.c (bfd_mach_sparc_v9m8): Define.
(bfd_mach_sparc_v8plusm8): Likewise.
(bfd_mach_sparc_v9_p): Adjust to M8.
(bfd_mach_sparc_64bit_p): Likewise.
* aoutx.h (machine_type): Handle bfd_mach_sparc_v9m8 and
bfd_mach_sparc_v8plusm8.
* bfd-in2.h: Regenerated.
* cpu-sparc.c (arch_info_struct): Entries for sparc:v9m8 and
sparc:v8plusm8.
* elfxx-sparc.c (_bfd_sparc_elf_object_p): Handle
bfd_mach_sparc_v8plusm8 and bfd_mach_sparc_v9m8 using the new hw
capabilities ONADDSUB, ONMUL, ONDIV, DICTUNP, FPCPSHL, RLE and
SHA3.
* elf32-sparc.c (elf32_sparc_final_write_processing): Handle
bfd_mach_sparc_v8plusm8.
binutils/ChangeLog:
2017-05-19 Jose E. Marchesi <jose.marchesi@oracle.com>
* NEWS: Mention the SPARC M8 support.
gas/ChangeLog:
2017-05-19 Jose E. Marchesi <jose.marchesi@oracle.com>
* config/tc-sparc.c (sparc_arch_table): Entries for `sparc6',
`v9m8' and `v8plusm8'.
(sparc_md_end): Handle SPARC_OPCODE_ARCH_M8.
(get_hwcap_name): Support the M8 hardware capabilities.
(sparc_ip): Handle new operand types.
* doc/c-sparc.texi (Sparc-Opts): Document -Av9m8, -Av8plusm8 and
-Asparc6, and the corresponding -xarch aliases.
* testsuite/gas/sparc/sparc6.s: New file.
* testsuite/gas/sparc/sparc6.d: Likewise.
* testsuite/gas/sparc/sparc6-diag.s: Likewise.
* testsuite/gas/sparc/sparc6-diag.l: Likewise.
* testsuite/gas/sparc/fpcmpshl.s: Likewise.
* testsuite/gas/sparc/fpcmpshl.d: Likewise.
* testsuite/gas/sparc/fpcmpshl-diag.s: Likewise.
* testsuite/gas/sparc/fpcmpshl-diag.l: Likewise.
* testsuite/gas/sparc/ldm-stm.s: Likewise.
* testsuite/gas/sparc/ldm-stm.d: Likewise.
* testsuite/gas/sparc/ldm-stm-diag.s: Likewise.
* testsuite/gas/sparc/ldm-stm-diag.l: Likewise.
* testsuite/gas/sparc/ldmf-stmf.s: Likewise.
* testsuite/gas/sparc/ldmf-stmf.d: Likewise.
* testsuite/gas/sparc/ldmf-stmf-diag.s: Likewise.
* testsuite/gas/sparc/ldmf-stmf-diag.l: Likewise.
* testsuite/gas/sparc/on.s: Likewise.
* testsuite/gas/sparc/on.d: Likewise.
* testsuite/gas/sparc/on-diag.s: Likewise.
* testsuite/gas/sparc/on-diag.l: Likewise.
* testsuite/gas/sparc/rle.s: Likewise.
* testsuite/gas/sparc/rle.d: Likewise.
* testsuite/gas/sparc/sparc.exp (gas_64_check): Run new tests.
* testsuite/gas/sparc/rdasr.s: Add test for RDENTROPY.
* testsuite/gas/sparc/rdasr.d: Likewise.
include/ChangeLog:
2017-05-19 Jose E. Marchesi <jose.marchesi@oracle.com>
* elf/sparc.h (ELF_SPARC_HWCAP2_SPARC6): Define.
(ELF_SPARC_HWCAP2_ONADDSUB): Likewise.
(ELF_SPARC_HWCAP2_ONMUL): Likewise.
(ELF_SPARC_HWCAP2_ONDIV): Likewise.
(ELF_SPARC_HWCAP2_DICTUNP): Likewise.
(ELF_SPARC_HWCAP2_FPCMPSHL): Likewise.
(ELF_SPARC_HWCAP2_RLE): Likewise.
(ELF_SPARC_HWCAP2_SHA3): Likewise.
* opcode/sparc.h (sparc_opcode_arch_val): Add SPARC_OPCODE_ARCH_M8
and adjust SPARC_OPCODE_ARCH_MAX.
(HWCAP2_SPARC6): Define.
(HWCAP2_ONADDSUB): Likewise.
(HWCAP2_ONMUL): Likewise.
(HWCAP2_ONDIV): Likewise.
(HWCAP2_DICTUNP): Likewise.
(HWCAP2_FPCMPSHL): Likewise.
(HWCAP2_RLE): Likewise.
(HWCAP2_SHA3): Likewise.
(OPM): Likewise.
(OPMI): Likewise.
(ONFCN): Likewise.
(REVFCN): Likewise.
(SIMM10): Likewise.
opcodes/ChangeLog:
2017-05-19 Jose E. Marchesi <jose.marchesi@oracle.com>
* sparc-dis.c (MASK_V9): Include SPARC_OPCODE_ARCH_M8.
(X_IMM2): Define.
(compute_arch_mask): Handle bfd_mach_sparc_v8plusm8 and
bfd_mach_sparc_v9m8.
(print_insn_sparc): Handle new operand types.
* sparc-opc.c (MASK_M8): Define.
(v6): Add MASK_M8.
(v6notlet): Likewise.
(v7): Likewise.
(v8): Likewise.
(v9): Likewise.
(v9a): Likewise.
(v9b): Likewise.
(v9c): Likewise.
(v9d): Likewise.
(v9e): Likewise.
(v9v): Likewise.
(v9m): Likewise.
(v9andleon): Likewise.
(m8): Define.
(HWS_VM8): Define.
(HWS2_VM8): Likewise.
(sparc_opcode_archs): Add entry for "m8".
(sparc_opcodes): Add OSA2017 and M8 instructions
dictunpack, fpcmp{ule,ugt,eq,ne,de,ur}{8,16,32}shl,
fpx{ll,ra,rl}64x,
ldm{sh,uh,sw,uw,x,ux}, ldm{sh,uh,sw,uw,x,ux}a, ldmf{s,d},
ldmf{s,d}a, on{add,sub,mul,div}, rdentropy, revbitsb,
revbytes{h,w,x}, rle_burst, rle_length, sha3, stm{h,w,x},
stm{h,w,x}a, stmf{s,d}, stmf{s,d}a.
(asi_table): New M8 ASIs ASI_CORE_COMMIT_COUNT,
ASI_CORE_SELECT_COUNT, ASI_ARF_ECC_REG, ASI_ITLB_PROBE, ASI_DSFAR,
ASI_DTLB_PROBE_PRIMARY, ASI_DTLB_PROBE_REAL,
ASI_CORE_SELECT_COMMIT_NHT.
2017-05-19 09:27:08 -07:00
|
|
|
|
2017-05-19 Jose E. Marchesi <jose.marchesi@oracle.com>
|
|
|
|
|
|
|
|
|
|
* archures.c (bfd_mach_sparc_v9m8): Define.
|
|
|
|
|
(bfd_mach_sparc_v8plusm8): Likewise.
|
|
|
|
|
(bfd_mach_sparc_v9_p): Adjust to M8.
|
|
|
|
|
(bfd_mach_sparc_64bit_p): Likewise.
|
|
|
|
|
* aoutx.h (machine_type): Handle bfd_mach_sparc_v9m8 and
|
|
|
|
|
bfd_mach_sparc_v8plusm8.
|
|
|
|
|
* bfd-in2.h: Regenerated.
|
|
|
|
|
* cpu-sparc.c (arch_info_struct): Entries for sparc:v9m8 and
|
|
|
|
|
sparc:v8plusm8.
|
|
|
|
|
* elfxx-sparc.c (_bfd_sparc_elf_object_p): Handle
|
|
|
|
|
bfd_mach_sparc_v8plusm8 and bfd_mach_sparc_v9m8 using the new hw
|
|
|
|
|
capabilities ONADDSUB, ONMUL, ONDIV, DICTUNP, FPCPSHL, RLE and
|
|
|
|
|
SHA3.
|
|
|
|
|
* elf32-sparc.c (elf32_sparc_final_write_processing): Handle
|
|
|
|
|
bfd_mach_sparc_v8plusm8.
|
|
|
|
|
|
2017-05-19 12:40:10 +09:30
|
|
|
|
2017-05-19 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (_bfd_elf_gc_mark_extra_sections): Don't keep
|
|
|
|
|
debug and special sections when no non-note alloc sections in an
|
|
|
|
|
object are kept.
|
|
|
|
|
|
2017-05-18 14:47:40 +09:30
|
|
|
|
2017-05-18 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* arc-got.h: Don't compare boolean values against TRUE or FALSE.
|
|
|
|
|
* elf-m10300.c: Likewise.
|
|
|
|
|
* elf.c: Likewise.
|
|
|
|
|
* elf32-arc.c: Likewise.
|
|
|
|
|
* elf32-bfin.c: Likewise.
|
|
|
|
|
* elf32-m68k.c: Likewise.
|
|
|
|
|
* elf32-nds32.c: Likewise.
|
|
|
|
|
* elf32-tilepro.c: Likewise.
|
|
|
|
|
* elflink.c: Likewise.
|
|
|
|
|
* elfnn-aarch64.c: Likewise.
|
|
|
|
|
* elfnn-riscv.c: Likewise.
|
|
|
|
|
* elfxx-tilegx.c: Likewise.
|
|
|
|
|
* mach-o.c: Likewise.
|
|
|
|
|
* peXXigen.c: Likewise.
|
|
|
|
|
* vms-alpha.c: Likewise.
|
|
|
|
|
* vms-lib.c: Likewise.
|
|
|
|
|
|
2017-05-17 07:57:15 -07:00
|
|
|
|
2017-05-17 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20882
|
|
|
|
|
* elflink.c (elf_gc_mark_debug_section): New function.
|
|
|
|
|
(_bfd_elf_gc_mark_extra_sections): Mark any debug sections
|
|
|
|
|
referenced by kept debug sections.
|
|
|
|
|
|
2017-05-16 07:58:14 +09:30
|
|
|
|
2017-05-16 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf-m10300.c: Rename occurrences of non_ir_ref.
|
|
|
|
|
* elf32-arm.c: Likewise.
|
|
|
|
|
* elf32-bfin.c: Likewise.
|
|
|
|
|
* elf32-cr16.c: Likewise.
|
|
|
|
|
* elf32-cris.c: Likewise.
|
|
|
|
|
* elf32-d10v.c: Likewise.
|
|
|
|
|
* elf32-dlx.c: Likewise.
|
|
|
|
|
* elf32-fr30.c: Likewise.
|
|
|
|
|
* elf32-frv.c: Likewise.
|
|
|
|
|
* elf32-hppa.c: Likewise.
|
|
|
|
|
* elf32-i370.c: Likewise.
|
|
|
|
|
* elf32-i386.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-mcore.c: Likewise.
|
|
|
|
|
* elf32-metag.c: Likewise.
|
|
|
|
|
* elf32-microblaze.c: Likewise.
|
|
|
|
|
* elf32-moxie.c: Likewise.
|
|
|
|
|
* elf32-msp430.c: Likewise.
|
|
|
|
|
* elf32-mt.c: Likewise.
|
|
|
|
|
* elf32-nios2.c: Likewise.
|
|
|
|
|
* elf32-or1k.c: Likewise.
|
|
|
|
|
* elf32-ppc.c: Likewise.
|
|
|
|
|
* elf32-rl78.c: Likewise.
|
|
|
|
|
* elf32-s390.c: Likewise.
|
|
|
|
|
* elf32-score.c: Likewise.
|
|
|
|
|
* elf32-score7.c: Likewise.
|
|
|
|
|
* elf32-sh.c: Likewise.
|
|
|
|
|
* elf32-tic6x.c: Likewise.
|
|
|
|
|
* elf32-tilepro.c: Likewise.
|
|
|
|
|
* elf32-v850.c: Likewise.
|
|
|
|
|
* elf32-vax.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.
|
|
|
|
|
* elfnn-riscv.c: Likewise.
|
|
|
|
|
* elfxx-mips.c: Likewise.
|
|
|
|
|
* elfxx-sparc.c: Likewise.
|
|
|
|
|
* elfxx-tilegx.c: Likewise.
|
|
|
|
|
* linker.c: Likewise.
|
|
|
|
|
|
2017-05-16 07:56:41 +09:30
|
|
|
|
2017-05-16 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (add_symbol_adjust): Transfer non_ir_ref_dynamic.
|
|
|
|
|
* elflink.c (elf_link_add_object_symbols): Update to use
|
|
|
|
|
non_ir_ref_dynamic.
|
|
|
|
|
(elf_link_input_bfd): Test non_ir_ref_dynamic in addition to
|
|
|
|
|
non_ir_ref.
|
|
|
|
|
* linker.c (_bfd_generic_link_add_one_symbol): Likewise.
|
|
|
|
|
|
MIPS16e2: Add MIPS16e2 ASE support
Add MIPS16e2 ASE support as per the architecture specification[1],
including in particular:
1. A new ELF ASE flag to mark MIPS16e2 binaries.
2. MIPS16e2 instruction assembly support, including a relaxation update
to use LUI rather than an LI/SLL instruction pair for loading the
high part of 32-bit addresses.
3. MIPS16e2 instruction disassembly support, including updated rules for
extended forms of instructions that are now subdecoded and therefore
do not alias to the original MIPS16 ISA revision instructions even
for encodings that are not valid in the MIPS16e2 instruction set.
Add `-mmips16e2' and `-mno-mips16e2' GAS command-line options and their
corresponding `mips16e2' and `no-mips16e2' settings for the `.set' and
`.module' pseudo-ops. Control the availability of the MT ASE subset of
the MIPS16e2 instruction set with a combination of these controls and
the preexisting MT ASE controls.
Parts of this change by Matthew Fortune and Andrew Bennett.
References:
[1] "MIPS32 Architecture for Programmers: MIPS16e2 Application-Specific
Extension Technical Reference Manual", Imagination Technologies
Ltd., Document Number: MD01172, Revision 01.00, April 26, 2016
include/
* elf/mips.h (AFL_ASE_MIPS16E2): New macro.
(AFL_ASE_MASK): Adjust accordingly.
* opcode/mips.h: Document new operand codes defined.
(mips_operand_type): Add OP_REG28 enum value.
(INSN2_SHORT_ONLY): Update description.
(ASE_MIPS16E2, ASE_MIPS16E2_MT): New macros.
bfd/
* elfxx-mips.c (print_mips_ases): Handle MIPS16e2 ASE.
opcodes/
* mips-dis.c (mips_arch_choices): Add ASE_MIPS16E2 and
ASE_MIPS16E2_MT flags to the unnamed MIPS16 entry.
(mips_convert_abiflags_ases): Handle the AFL_ASE_MIPS16E2 flag.
(print_insn_arg) <OP_REG28>: Add handler.
(validate_insn_args) <OP_REG28>: Handle.
(print_mips16_insn_arg): Handle MIPS16 instructions that require
32-bit encoding and 9-bit immediates.
(print_insn_mips16): Handle MIPS16 instructions that require
32-bit encoding and MFC0/MTC0 operand decoding.
* mips16-opc.c (decode_mips16_operand) <'>', '9', 'G', 'N', 'O'>
<'Q', 'T', 'b', 'c', 'd', 'r', 'u'>: Add handlers.
(RD_C0, WR_C0, E2, E2MT): New macros.
(mips16_opcodes): Add entries for MIPS16e2 instructions:
GP-relative "addiu" and its "addu" spelling, "andi", "cache",
"di", "ehb", "ei", "ext", "ins", GP-relative "lb", "lbu", "lh",
"lhu", and "lw" instructions, "ll", "lui", "lwl", "lwr", "mfc0",
"movn", "movtn", "movtz", "movz", "mtc0", "ori", "pause",
"pref", "rdhwr", "sc", GP-relative "sb", "sh" and "sw"
instructions, "swl", "swr", "sync" and its "sync_acquire",
"sync_mb", "sync_release", "sync_rmb" and "sync_wmb" aliases,
"xori", "dmt", "dvpe", "emt" and "evpe". Add split
regular/extended entries for original MIPS16 ISA revision
instructions whose extended forms are subdecoded in the MIPS16e2
ISA revision: "li", "sll" and "srl".
binutils/
* readelf.c (print_mips_ases): Handle MIPS16e2 ASE.
* NEWS: Mention MIPS16e2 ASE support.
gas/
* config/tc-mips.c (RELAX_MIPS16_ENCODE): Add `e2' flag.
(RELAX_MIPS16_E2): New macro.
(RELAX_MIPS16_PIC, RELAX_MIPS16_SYM32, RELAX_MIPS16_NOMACRO)
(RELAX_MIPS16_USER_SMALL, RELAX_MIPS16_USER_EXT)
(RELAX_MIPS16_DSLOT, RELAX_MIPS16_JAL_DSLOT)
(RELAX_MIPS16_EXTENDED, RELAX_MIPS16_MARK_EXTENDED)
(RELAX_MIPS16_CLEAR_EXTENDED, RELAX_MIPS16_ALWAYS_EXTENDED)
(RELAX_MIPS16_MARK_ALWAYS_EXTENDED)
(RELAX_MIPS16_CLEAR_ALWAYS_EXTENDED, RELAX_MIPS16_MACRO)
(RELAX_MIPS16_MARK_MACRO, RELAX_MIPS16_CLEAR_MACRO): Shift bits.
(mips16_immed_extend): New prototype.
(options): Add OPTION_MIPS16E2 and OPTION_NO_MIPS16E2 enum
values.
(md_longopts): Add "mmips16e2" and "mno-mips16e2" options.
(mips_ases): Add "mips16e2" entry.
(mips_set_ase): Handle MIPS16e2 ASE.
(insn_insert_operand): Explicitly handle immediates with MIPS16
instructions that require 32-bit encoding.
(is_opcode_valid_16): Pass enabled ASE bitmask on to
`opcode_is_member'.
(validate_mips_insn): Explicitly handle immediates with MIPS16
instructions that require 32-bit encoding.
(operand_reg_mask) <OP_REG28>: Add handler.
(match_reg28_operand): New function.
(match_operand) <OP_REG28>: Add handler.
(append_insn): Pass ASE_MIPS16E2 setting to RELAX_MIPS16_ENCODE.
(match_mips16_insn): Handle MIPS16 instructions that require
32-bit encoding and `V' and `u' operand codes.
(mips16_ip): Allow any characters except from `.' in opcodes.
(mips16_immed_extend): Handle 9-bit immediates. Do not shuffle
immediates whose width is not one of these listed.
(md_estimate_size_before_relax): Handle MIPS16e2 relaxation.
(mips_relax_frag): Likewise.
(md_convert_frag): Likewise.
(mips_convert_ase_flags): Handle MIPS16e2 ASE.
* doc/as.texinfo (Target MIPS options): Add `-mmips16e2' and
`-mno-mips16e2' options.
(-mmips16e2, -mno-mips16e2): New options.
* doc/c-mips.texi (MIPS Options): Add `-mmips16e2' and
`-mno-mips16e2' options.
(MIPS ASE Instruction Generation Overrides): Add `.set mips16e2'
and `.set nomips16e2'.
2017-05-15 13:26:01 +01:00
|
|
|
|
2017-05-15 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (print_mips_ases): Handle MIPS16e2 ASE.
|
|
|
|
|
|
2017-05-12 08:07:21 -07:00
|
|
|
|
2017-05-12 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_parse_gnu_properties): Merge
|
|
|
|
|
GNU_PROPERTY_X86_ISA_1_USED and GNU_PROPERTY_X86_ISA_1_NEEDED
|
|
|
|
|
properties.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_parse_gnu_properties): Likewise.
|
|
|
|
|
|
2017-05-11 11:26:26 -07:00
|
|
|
|
2017-05-11 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_link_hash_entry): Rename plt_bnd
|
|
|
|
|
to plt_second.
|
|
|
|
|
(elf_x86_64_link_hash_table): Rename plt_bnd/plt_bnd_eh_frame
|
|
|
|
|
to plt_second/plt_second_eh_frame.
|
|
|
|
|
(elf_x86_64_link_hash_newfunc): Updated.
|
|
|
|
|
(elf_x86_64_allocate_dynrelocs): Likewise.
|
|
|
|
|
(elf_x86_64_size_dynamic_sections): Likewise.
|
|
|
|
|
(elf_x86_64_relocate_section): Likewise.
|
|
|
|
|
(elf_x86_64_finish_dynamic_symbol): Likewise.
|
|
|
|
|
(elf_x86_64_finish_dynamic_sections): Likewise.
|
|
|
|
|
(elf_x86_64_plt_type): Rename plt_bnd to plt_second.
|
|
|
|
|
(elf_x86_64_get_synthetic_symtab): Updated. Also scan the
|
|
|
|
|
.plt.sec section.
|
|
|
|
|
(elf_backend_setup_gnu_properties): Updated. Create the
|
|
|
|
|
.plt.sec section instead of the .plt.sec section.
|
|
|
|
|
|
2017-05-11 07:42:30 -07:00
|
|
|
|
2017-05-11 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_allocate_dynrelocs): Partially revert
|
|
|
|
|
commit 25070364b0ce33eed46aa5d78ebebbec6accec7e.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_allocate_dynrelocs): Likewse.
|
|
|
|
|
|
2017-05-10 18:44:19 +02:00
|
|
|
|
2017-05-10 Jose E. Marchesi <jose.marchesi@oracle.com>
|
|
|
|
|
|
|
|
|
|
* elf64-sparc.c (elf64_sparc_set_reloc): New function.
|
|
|
|
|
(bfd_elf64_set_reloc): Define.
|
|
|
|
|
(elf64_sparc_write_relocs): Use `canon_reloc_count'.
|
|
|
|
|
|
2017-05-10 18:40:04 +02:00
|
|
|
|
2017-05-10 Jose E. Marchesi <jose.marchesi@oracle.com>
|
|
|
|
|
|
|
|
|
|
* targets.c (BFD_JUMP_TABLE_RELOCS): Add NAME##_set_reloc.
|
|
|
|
|
(struct bfd_target): New field _bfd_set_reloc.
|
|
|
|
|
* bfd.c (bfd_set_reloc): Call backend _set_bfd.
|
|
|
|
|
* reloc.c (_bfd_generic_set_reloc): New function.
|
|
|
|
|
* coffcode.h (coff_set_reloc): Define to _bfd_generic_set_reloc.
|
|
|
|
|
* nlm-target.h (nlm_set_reloc): Likewise.
|
|
|
|
|
* coff-rs6000.c (_bfd_xcoff_set_reloc): Likewise.
|
|
|
|
|
* aout-tic30.c (MY_set_reloc): Likewise.
|
|
|
|
|
* aout-target.h (MY_set_reloc): Likewise.
|
|
|
|
|
* elfxx-target.h (bfd_elfNN_set_reloc): Likewise.
|
|
|
|
|
* coff-alpha.c (_bfd_ecoff_set_reloc): Likewise.
|
|
|
|
|
* mach-o-target.c (bfd_mach_o_set_reloc): Likewise.
|
|
|
|
|
* vms-alpha.c (alpha_vms_set_reloc): Likewise.
|
|
|
|
|
* aout-adobe.c (aout_32_set_reloc): Likewise.
|
|
|
|
|
* bout.c (b_out_set_reloc): Likewise.
|
|
|
|
|
* coff-mips.c (_bfd_ecoff_set_reloc): Likewise.
|
|
|
|
|
* i386os9k.c (aout_32_set_reloc): Likewise.
|
|
|
|
|
* ieee.c (ieee_set_reloc): Likewise.
|
|
|
|
|
* oasys.c (oasys_set_reloc): Likewise.
|
|
|
|
|
* som.c (som_set_reloc): Likewise.
|
|
|
|
|
* versados.c (versados_set_reloc): Likewise.
|
|
|
|
|
* coff64-rs6000.c (rs6000_xcoff64_vec): Add
|
|
|
|
|
_bfd_generic_set_reloc.
|
|
|
|
|
(rs6000_xcoff64_aix_vec): LIkewise.
|
|
|
|
|
* libbfd.c (_bfd_norelocs_set_reloc): New function.
|
|
|
|
|
* libbfd-in.h: Prototype for _bfd_norelocs_set_reloc.
|
|
|
|
|
* i386msdos.c (msdos_set_reloc): Define to
|
|
|
|
|
_bfd_norelocs_set_reloc.
|
|
|
|
|
* elfcode.h (elf_set_reloc): Define.
|
|
|
|
|
* bfd-in2.h: Regenerated.
|
|
|
|
|
|
2017-05-10 09:28:00 -07:00
|
|
|
|
2017-05-10 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21481
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_finish_dynamic_symbol): Use .plt.bnd
|
|
|
|
|
for IFUNC function address.
|
|
|
|
|
|
[ARC] Object attributes.
gas/
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
* testsuite/gas/arc/attr-arc600.d: New file.
* testsuite/gas/arc/attr-arc600_mul32x16.d: Likewise.
* testsuite/gas/arc/attr-arc600_norm.d: Likewise.
* testsuite/gas/arc/attr-arc601.d: Likewise.
* testsuite/gas/arc/attr-arc601_mul32x16.d: Likewise.
* testsuite/gas/arc/attr-arc601_mul64.d: Likewise.
* testsuite/gas/arc/attr-arc601_norm.d: Likewise.
* testsuite/gas/arc/attr-arc700.d: Likewise.
* testsuite/gas/arc/attr-arcem.d: Likewise.
* testsuite/gas/arc/attr-archs.d: Likewise.
* testsuite/gas/arc/attr-autodetect-1.d: Likewise.
* testsuite/gas/arc/attr-autodetect-1.s: Likewise.
* testsuite/gas/arc/attr-cpu-a601.d: Likewise.
* testsuite/gas/arc/attr-cpu-a601.s: Likewise.
* testsuite/gas/arc/attr-cpu-a700.d: Likewise.
* testsuite/gas/arc/attr-cpu-a700.s: Likewise.
* testsuite/gas/arc/attr-cpu-em.d: Likewise.
* testsuite/gas/arc/attr-cpu-em.s: Likewise.
* testsuite/gas/arc/attr-cpu-hs.d: Likewise.
* testsuite/gas/arc/attr-cpu-hs.s: Likewise.
* testsuite/gas/arc/attr-em.d: Likewise.
* testsuite/gas/arc/attr-em4.d: Likewise.
* testsuite/gas/arc/attr-em4_dmips.d: Likewise.
* testsuite/gas/arc/attr-em4_fpuda.d: Likewise.
* testsuite/gas/arc/attr-em4_fpus.d: Likewise.
* testsuite/gas/arc/attr-hs.d: Likewise.
* testsuite/gas/arc/attr-hs34.d: Likewise.
* testsuite/gas/arc/attr-hs38.d: Likewise.
* testsuite/gas/arc/attr-hs38_linux.d: Likewise.
* testsuite/gas/arc/attr-mul64.d: Likewise.
* testsuite/gas/arc/attr-name.d: Likewise.
* testsuite/gas/arc/attr-name.s: Likewise.
* testsuite/gas/arc/attr-nps400.d: Likewise.
* testsuite/gas/arc/attr-override-mcpu.d: Likewise.
* testsuite/gas/arc/attr-override-mcpu.s
* testsuite/gas/arc/attr-quarkse_em.d: Likewise.
* testsuite/gas/arc/blank.s: Likewise.
* testsuite/gas/elf/section2.e-arc: Likewise.
* testsuite/gas/arc/cpu-pseudop-1.d: Update test.
* testsuite/gas/arc/cpu-pseudop-2.d: Likewise.
* testsuite/gas/arc/nps400-0.d: Likewise.
* testsuite/gas/elf/elf.exp: Set target_machine for ARC.
* config/tc-arc.c (opcode/arc-attrs.h): Include.
(ARC_GET_FLAG, ARC_SET_FLAG, streq): Define.
(arc_attribute): Declare new function.
(md_pseudo_table): Add arc_attribute.
(cpu_types): Rename default cpu features.
(selected_cpu): Set the default OSABI flag.
(mpy_option): New variable.
(pic_option): Likewise.
(sda_option): Likewise.
(tls_option): Likewise.
(feature_type, feature_list): Remove.
(arc_initial_eflag): Likewise.
(attributes_set_explicitly): New variable.
(arc_check_feature): Check also for the conflicting features.
(arc_select_cpu): Refactor assignment of selected_cpu.eflags.
(arc_option): Remove setting of private flags and architecture.
(check_cpu_feature): Refactor feature names.
(autodetect_attributes): New function.
(assemble_tokens): Use above function.
(md_parse_option): Refactor feature names.
(arc_attribute): New function.
(arc_set_attribute_int): Likewise.
(arc_set_attribute_string): Likewise.
(arc_stralloc): Likewise.
(arc_set_public_attributes): Likewise.
(arc_md_end): Likewise.
(arc_copy_symbol_attributes): Likewise.
(rc_convert_symbolic_attribute): Likewise.
* config/tc-arc.h (md_end): Define.
(CONVERT_SYMBOLIC_ATTRIBUTE): Likewise.
(TC_COPY_SYMBOL_ATTRIBUTES): Likewise.
* doc/c-arc.texi: Document ARC object attributes.
binutils/
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
* readelf.c (decode_ARC_machine_flags): Recognize OSABI v4.
(get_arc_section_type_name): New function.
(get_section_type_name): Use the above function.
(display_arc_attribute): New function.
(process_arc_specific): Likewise.
(process_arch_specific): Handle ARC specific information.
* testsuite/binutils-all/strip-3.d: Consider ARC.attributes
section.
include/
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
* elf/arc.h (SHT_ARC_ATTRIBUTES): Define.
(Tag_ARC_*): Define.
(E_ARC_OSABI_V4): Define.
(E_ARC_OSABI_CURRENT): Reassign it.
(TAG_CPU_*): Define.
* opcode/arc-attrs.h: New file.
* opcode/arc.h (insn_subclass_t): Assign enum values.
(insn_subclass_t): Update enum with QUARKSE1, QUARKSE2, and LL64.
(ARC_EA, ARC_CD, ARC_LLOCK, ARC_ATOMIC, ARC_MPY, ARC_MULT)
(ARC_NPS400, ARC_DPFP, ARC_SPFP, ARC_FPU, ARC_FPUDA, ARC_SWAP)
(ARC_NORM, ARC_BSCAN, ARC_UIX, ARC_TSTAMP, ARC_VBFDW)
(ARC_BARREL, ARC_DSPA, ARC_SHIFT, ARC_INTR, ARC_DIV, ARC_XMAC)
(ARC_CRC): Delete.
bfd/
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
* elf32-arc.c (FEATURE_LIST_NAME): Define.
(CONFLICT_LIST): Likewise.
(opcode/arc-attrs.h): Include.
(arc_elf_print_private_bfd_data): Print OSABI v4 flag.
(arc_extract_features): New file.
(arc_stralloc): Likewise.
(arc_elf_merge_attributes): Likewise.
(arc_elf_merge_private_bfd_data): Use object attributes.
(bfd_arc_get_mach_from_attributes): New function.
(arc_elf_object_p): Use object attributes.
(arc_elf_final_write_processing): Likewise.
(elf32_arc_obj_attrs_arg_type): New function.
(elf32_arc_obj_attrs_handle_unknown): Likewise.
(elf32_arc_section_from_shdr): Likewise.
(elf_backend_obj_attrs_vendor): Define.
(elf_backend_obj_attrs_section): Likewise.
(elf_backend_obj_attrs_arg_type): Likewise.
(elf_backend_obj_attrs_section_type): Likewise.
(elf_backend_obj_attrs_handle_unknown): Likewise.
(elf_backend_section_from_shdr): Likewise.
ld/
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
* testsuite/ld-arc/attr-merge-0.d: New file.
* testsuite/ld-arc/attr-merge-0.s: Likewise.
* testsuite/ld-arc/attr-merge-0e.s: Likewise.
* testsuite/ld-arc/attr-merge-1.d: Likewise.
* testsuite/ld-arc/attr-merge-1.s: Likewise.
* testsuite/ld-arc/attr-merge-1e.s: Likewise.
* testsuite/ld-arc/attr-merge-2.d: Likewise.
* testsuite/ld-arc/attr-merge-2.s: Likewise.
* testsuite/ld-arc/attr-merge-3.d: Likewise.
* testsuite/ld-arc/attr-merge-3.s: Likewise.
* testsuite/ld-arc/attr-merge-3e.s: Likewise.
* testsuite/ld-arc/attr-merge-4.s: Likewise.
* testsuite/ld-arc/attr-merge-5.d: Likewise.
* testsuite/ld-arc/attr-merge-5a.s: Likewise.
* testsuite/ld-arc/attr-merge-5b.s: Likewise.
* testsuite/ld-arc/attr-merge-conflict-isa.d: Likewise.
* testsuite/ld-arc/attr-merge-err-isa.d: Likewise.
* testsuite/ld-arc/attr-merge-incompatible-cpu.d: Likewise.
* testsuite/ld-arc/got-01.d: Update test.
* testsuite/ld-arc/attr-merge-err-quarkse.d: New file.
* testsuite/ld-arc/attr-quarkse.s: Likewise.
* testsuite/ld-arc/attr-quarkse2.s: Likewise.
opcodes/
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
* arc-dis.c (parse_option): Update quarkse_em option..
* arc-ext-tbl.h (dsp_fp_flt2i, dsp_fp_i2flt): Change subclass to
QUARKSE1.
(dsp_fp_div, dsp_fp_cmp): Change subclass to QUARKSE2.
2017-05-10 14:42:22 +02:00
|
|
|
|
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (FEATURE_LIST_NAME): Define.
|
|
|
|
|
(CONFLICT_LIST): Likewise.
|
|
|
|
|
(opcode/arc-attrs.h): Include.
|
|
|
|
|
(arc_elf_print_private_bfd_data): Print OSABI v4 flag.
|
|
|
|
|
(arc_extract_features): New file.
|
|
|
|
|
(arc_stralloc): Likewise.
|
|
|
|
|
(arc_elf_merge_attributes): Likewise.
|
|
|
|
|
(arc_elf_merge_private_bfd_data): Use object attributes.
|
|
|
|
|
(bfd_arc_get_mach_from_attributes): New function.
|
|
|
|
|
(arc_elf_object_p): Use object attributes.
|
|
|
|
|
(arc_elf_final_write_processing): Likewise.
|
|
|
|
|
(elf32_arc_obj_attrs_arg_type): New function.
|
|
|
|
|
(elf32_arc_obj_attrs_handle_unknown): Likewise.
|
|
|
|
|
(elf32_arc_section_from_shdr): Likewise.
|
|
|
|
|
(elf_backend_obj_attrs_vendor): Define.
|
|
|
|
|
(elf_backend_obj_attrs_section): Likewise.
|
|
|
|
|
(elf_backend_obj_attrs_arg_type): Likewise.
|
|
|
|
|
(elf_backend_obj_attrs_section_type): Likewise.
|
|
|
|
|
(elf_backend_obj_attrs_handle_unknown): Likewise.
|
|
|
|
|
(elf_backend_section_from_shdr): Likewise.
|
|
|
|
|
|
2017-05-09 12:14:48 +01:00
|
|
|
|
2017-05-09 Andrew Goedhart <Andrewgoedhart@simplepowersolutions.co.za>
|
|
|
|
|
|
|
|
|
|
PR ld/21458
|
|
|
|
|
* elf32-arm.c (elf32_arm_final_link_relocate): Set the bottom bit
|
|
|
|
|
of the value when resolving a R_ARM_THM_ALU_PREL_11_0 relocation
|
|
|
|
|
and the destination is a Thumb symbol.
|
|
|
|
|
|
2017-05-08 13:37:50 -07:00
|
|
|
|
2017-05-08 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_get_synthetic_symtab): Add missing
|
|
|
|
|
initializer to silence GCC 4.2.
|
|
|
|
|
* lf64-x86-64.c (elf_x86_64_get_synthetic_symtab): Likewise.
|
|
|
|
|
|
x86-64: Improve PLT generation and synthetic PLT symbols
On x86-64, the procedure linkage table (PLT) is used to
1. Call external function.
2. Call internal IFUNC function. The best implementation is selected
for the target processor at run-time.
3. Act as the canonical function address.
4. Support LD_AUDIT to audit external function calls.
5. Support LD_PROFILE to profile external function calls.
PLT looks like:
PLT0: push GOT[1]
jmp *GOT[2]
nop
PLT1: jmp *GOT[name1_index]
push name1_reloc_index
jmp PLT0
GOT is an array of addresses. Initially the GOT entry of name1 is
filled with the address of the "push name1_reloc_index" instruction.
The function, name1, is called via "jmp *GOT[name1]" in the PLT entry.
Even when lazy binding is disabled by "-z now", the PLT0 entry may
still be used with LD_AUDIT or LD_PROFILE if PLT entry is used for
canonical function address.
When linker is invoked with "-z bndplt", a different PLT layout in .plt
is used:
PLT0: push GOT[1]
bnd jmp *GOT[2]
nop
PLT1: push name1_reloc_index
bnd jmp PLT0
nop
together with a second PLT section, .pl.bnd:
PLT1: bnd jmp *GOT[name1_index]
nop
where the GOT entry of name1 is filled with the address of the push
instruction of the corresponding entry in .plt.
1. With lazy binding, when the external function, name1, is called the
first time, dynamic linker is called via PLT0 to update GOT[name1_index]
with the actual address of name1 and transfers control to name1
afterwards.
2. PLT is also used to call a local IFUNC function, name1, run-time
loader updates GOT[name1_index] when loading the module.
This patch
1. Remove PLT layout configurations from x86-64 backend_data.
2. Add generic, lay and non-lazy PLT layout configurations to x86-64
link_hash_table. Generic PLT layout includes the PLT entry templates,
information how to update the first instruction in PLT and PLT eh_frame
informaton, which are initialized in x86-64 setup_gnu_properties, based
on "-z bndplt" and target selection. PLT section alignment is also set
to PLT entry size for non-NaCl target.
3. Remove elf_x86_64_create_dynamic_sections. create_dynamic_sections
isn't always called, but GOT relocations need GOT relocations. Instead,
create all x86-64 specific dynamic sections with alignment to their entry
size in x86-64 setup_gnu_properties, which initializes elf.dynobj, so
that x86-64 check_relocs can be simplified.
4. Rewrite elf_x86_64_get_synthetic_symtab to check PLT sections against
all dynamic relocations to support both lazy and non-lazy PLTs.
There is no change in PLT. The only externally visible change is the
improvement of synthetic PLT symbols for .plt.got.
bfd/
* elf64-x86-64.c (PLT_ENTRY_SIZE): Renamed to ...
(LAZY_PLT_ENTRY_SIZE): This.
(NON_LAZY_PLT_ENTRY_SIZE): New.
(elf_x86_64_plt0_entry): Renamed to ...
(elf_x86_64_lazy_plt0_entry): This.
(elf_x86_64_plt_entry): Renamed to ...
(elf_x86_64_lazy_plt_entry): This.
(elf_x86_64_bnd_plt0_entry): Renamed to ...
(elf_x86_64_lazy_bnd_plt0_entry): This.
(elf_x86_64_legacy_plt_entry): Removed.
(elf_x86_64_bnd_plt_entry): Renamed to ...
(elf_x86_64_lazy_bnd_plt_entry): This.
(elf_x86_64_legacy_plt2_entry): Renamed to ...
(elf_x86_64_non_lazy_plt_entry): This.
(elf_x86_64_bnd_plt2_entry): Renamed to ...
(elf_x86_64_non_lazy_bnd_plt_entry): This.
(elf_x86_64_eh_frame_plt): Renamed to ...
(elf_x86_64_eh_frame_lazy_plt): This.
(elf_x86_64_eh_frame_bnd_plt): Renamed to ...
(elf_x86_64_eh_frame_lazy_bnd_plt): This.
(elf_x86_64_eh_frame_plt_got): Renamed to ...
(elf_x86_64_eh_frame_non_lazy_plt): This.
(elf_x86_64_lazy_plt_layout): New.
(elf_x86_64_non_lazy_plt_layout): Likewise.
(elf_x86_64_plt_layout): Likewise.
(elf_x86_64_backend_data): Remove PLT layout information. Add
os for target system.
(GET_PLT_ENTRY_SIZE): Removed.
(elf_x86_64_lazy_plt): New.
(elf_x86_64_non_lazy_plt): Likewise.
(elf_x86_64_lazy_bnd_plt): Likewise.
(elf_x86_64_non_lazy_bnd_plt): Likewise.
(elf_x86-64_arch_bed): Updated.
(elf_x86_64_link_hash_table): Add plt, lazy_plt and non_lazy_plt.
(elf_x86_64_create_dynamic_sections): Removed.
(elf_x86_64_check_relocs): Don't check elf.dynobj. Don't call
_bfd_elf_create_ifunc_sections nor _bfd_elf_create_got_section.
(elf_x86-64_adjust_dynamic_symbol): Updated.
(elf_x86_64_allocate_dynrelocs): Updated. Pass 0 as PLT header
size to _bfd_elf_allocate_ifunc_dyn_relocs and don't allocate
size for PLT0 if there is no PLT0. Get plt_entry_size from
non_lazy_plt for non-lazy PLT entries.
(elf_x86_64_size_dynamic_sections): Updated. Get plt_entry_size
from non_lazy_plt for non-lazy PLT entries.
(elf_x86-64_relocate_section): Updated. Properly get PLT index
if there is no PLT0.
(elf_x86_64_finish_dynamic_symbol): Updated. Fill the first slot
in the PLT entry with generic PLT layout. Fill the non-lazy PLT
entries with non-lazy PLT layout. Don't fill the second and third
slots in the PLT entry if there is no PLT0.
(elf_x86_64_finish_dynamic_sections): Updated. Don't fill PLT0
if there is no PLT0. Set sh_entsize on the .plt.got section.
(compare_relocs): New.
(elf_x86_64_plt_type): Likewise.
(elf_x86_64_plt): Likewise.
(elf_x86_64_nacl_plt): New. Forward declaration.
(elf_x86_64_get_plt_sym_val): Removed.
(elf_x86_64_get_synthetic_symtab): Rewrite to check PLT sections
against all dynamic relocations.
(elf_x86_64_link_setup_gnu_properties): New function.
(elf_backend_create_dynamic_sections): Updated.
(elf_backend_setup_gnu_properties): New.
(elf_x86_64_nacl_plt): New.
(elf_x86_64_nacl_arch_bed): Updated.
ld/
* testsuite/ld-ifunc/ifunc-16-x86-64-now.d: New file.
* testsuite/ld-ifunc/ifunc-2-local-x86-64-now.d: Likewise.
* testsuite/ld-ifunc/ifunc-2-x86-64-now.d: Likewise.
* testsuite/ld-ifunc/pr17154-x86-64-now.d: Likewise.
* testsuite/ld-x86-64/bnd-branch-1-now.d: Likewise.
* testsuite/ld-x86-64/bnd-ifunc-1-now.d: Likewise.
* testsuite/ld-x86-64/bnd-ifunc-2-now.d: Likewise.
* testsuite/ld-x86-64/bnd-plt-1-now.d: Likewise.
* testsuite/ld-x86-64/mpx3n.dd: Likewise.
* testsuite/ld-x86-64/mpx4n.dd: Likewise.
* testsuite/ld-x86-64/plt-main-bnd-now.rd: Likewise.
* testsuite/ld-x86-64/plt2.dd: Likewise.
* testsuite/ld-x86-64/plt2.rd: Likewise.
* testsuite/ld-x86-64/plt2.s: Likewise.
* testsuite/ld-x86-64/pr20830a-now.d: Likewise.
* testsuite/ld-x86-64/pr20830b-now.d: Likewise.
* testsuite/ld-x86-64/pr21038a-now.d: Likewise.
* testsuite/ld-x86-64/pr21038b-now.d: Likewise.
* testsuite/ld-x86-64/pr21038c-now.d: Likewise.
* testsuite/ld-x86-64/load1b-nacl.d: Updated.
* testsuite/ld-x86-64/load1b.d: Likewise.
* testsuite/ld-x86-64/plt-main-bnd.dd: Likewise.
* testsuite/ld-x86-64/pr20253-1h.d: Likewise.
* testsuite/ld-x86-64/pr20830a.d: Update the .plt.got section
with func@plt.
* testsuite/ld-x86-64/pr20830b.d: Likewise.
* testsuite/ld-x86-64/pr21038a.d: Likewise.
* testsuite/ld-x86-64/pr21038c.d: Likewise.
* testsuite/ld-x86-64/mpx.exp: Add some -z now tests.
* testsuite/ld-x86-64/x86-64.exp: Likewise.
2017-05-08 12:24:11 -07:00
|
|
|
|
2017-05-08 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf64-x86-64.c (PLT_ENTRY_SIZE): Renamed to ...
|
|
|
|
|
(LAZY_PLT_ENTRY_SIZE): This.
|
|
|
|
|
(NON_LAZY_PLT_ENTRY_SIZE): New.
|
|
|
|
|
(elf_x86_64_plt0_entry): Renamed to ...
|
|
|
|
|
(elf_x86_64_lazy_plt0_entry): This.
|
|
|
|
|
(elf_x86_64_plt_entry): Renamed to ...
|
|
|
|
|
(elf_x86_64_lazy_plt_entry): This.
|
|
|
|
|
(elf_x86_64_bnd_plt0_entry): Renamed to ...
|
|
|
|
|
(elf_x86_64_lazy_bnd_plt0_entry): This.
|
|
|
|
|
(elf_x86_64_legacy_plt_entry): Removed.
|
|
|
|
|
(elf_x86_64_bnd_plt_entry): Renamed to ...
|
|
|
|
|
(elf_x86_64_lazy_bnd_plt_entry): This.
|
|
|
|
|
(elf_x86_64_legacy_plt2_entry): Renamed to ...
|
|
|
|
|
(elf_x86_64_non_lazy_plt_entry): This.
|
|
|
|
|
(elf_x86_64_bnd_plt2_entry): Renamed to ...
|
|
|
|
|
(elf_x86_64_non_lazy_bnd_plt_entry): This.
|
|
|
|
|
(elf_x86_64_eh_frame_plt): Renamed to ...
|
|
|
|
|
(elf_x86_64_eh_frame_lazy_plt): This.
|
|
|
|
|
(elf_x86_64_eh_frame_bnd_plt): Renamed to ...
|
|
|
|
|
(elf_x86_64_eh_frame_lazy_bnd_plt): This.
|
|
|
|
|
(elf_x86_64_eh_frame_plt_got): Renamed to ...
|
|
|
|
|
(elf_x86_64_eh_frame_non_lazy_plt): This.
|
|
|
|
|
(elf_x86_64_lazy_plt_layout): New.
|
|
|
|
|
(elf_x86_64_non_lazy_plt_layout): Likewise.
|
|
|
|
|
(elf_x86_64_plt_layout): Likewise.
|
|
|
|
|
(elf_x86_64_backend_data): Remove PLT layout information. Add
|
|
|
|
|
os for target system.
|
|
|
|
|
(GET_PLT_ENTRY_SIZE): Removed.
|
|
|
|
|
(elf_x86_64_lazy_plt): New.
|
|
|
|
|
(elf_x86_64_non_lazy_plt): Likewise.
|
|
|
|
|
(elf_x86_64_lazy_bnd_plt): Likewise.
|
|
|
|
|
(elf_x86_64_non_lazy_bnd_plt): Likewise.
|
|
|
|
|
(elf_x86-64_arch_bed): Updated.
|
|
|
|
|
(elf_x86_64_link_hash_table): Add plt, lazy_plt and non_lazy_plt.
|
|
|
|
|
(elf_x86_64_create_dynamic_sections): Removed.
|
|
|
|
|
(elf_x86_64_check_relocs): Don't check elf.dynobj. Don't call
|
|
|
|
|
_bfd_elf_create_ifunc_sections nor _bfd_elf_create_got_section.
|
|
|
|
|
(elf_x86-64_adjust_dynamic_symbol): Updated.
|
|
|
|
|
(elf_x86_64_allocate_dynrelocs): Updated. Pass 0 as PLT header
|
|
|
|
|
size to _bfd_elf_allocate_ifunc_dyn_relocs and don't allocate
|
|
|
|
|
size for PLT0 if there is no PLT0. Get plt_entry_size from
|
|
|
|
|
non_lazy_plt for non-lazy PLT entries.
|
|
|
|
|
(elf_x86_64_size_dynamic_sections): Updated. Get plt_entry_size
|
|
|
|
|
from non_lazy_plt for non-lazy PLT entries.
|
|
|
|
|
(elf_x86-64_relocate_section): Updated. Properly get PLT index
|
|
|
|
|
if there is no PLT0.
|
|
|
|
|
(elf_x86_64_finish_dynamic_symbol): Updated. Fill the first slot
|
|
|
|
|
in the PLT entry with generic PLT layout. Fill the non-lazy PLT
|
|
|
|
|
entries with non-lazy PLT layout. Don't fill the second and third
|
|
|
|
|
slots in the PLT entry if there is no PLT0.
|
|
|
|
|
(elf_x86_64_finish_dynamic_sections): Updated. Don't fill PLT0
|
|
|
|
|
if there is no PLT0. Set sh_entsize on the .plt.got section.
|
|
|
|
|
(compare_relocs): New.
|
|
|
|
|
(elf_x86_64_plt_type): Likewise.
|
|
|
|
|
(elf_x86_64_plt): Likewise.
|
|
|
|
|
(elf_x86_64_nacl_plt): New. Forward declaration.
|
|
|
|
|
(elf_x86_64_get_plt_sym_val): Removed.
|
|
|
|
|
(elf_x86_64_get_synthetic_symtab): Rewrite to check PLT sections
|
|
|
|
|
against all dynamic relocations.
|
|
|
|
|
(elf_x86_64_link_setup_gnu_properties): New function.
|
|
|
|
|
(elf_backend_create_dynamic_sections): Updated.
|
|
|
|
|
(elf_backend_setup_gnu_properties): New.
|
|
|
|
|
(elf_x86_64_nacl_plt): New.
|
|
|
|
|
(elf_x86_64_nacl_arch_bed): Updated.
|
|
|
|
|
|
i386: Improve PLT generation and synthetic PLT symbols
On i386, the procedure linkage table (PLT) is used to
1. Call external function.
2. Call internal IFUNC function. The best implementation is selected
for the target processor at run-time.
3. Act as the canonical function address.
4. Support LD_AUDIT to audit external function calls.
5. Support LD_PROFILE to profile external function calls.
PLT looks like:
PLT0: push GOT[1]
jmp *GOT[2]
nop
PLT1: jmp *GOT[name1_index]
push name1_reloc_index
jmp PLT0
GOT is an array of addresses. Initially the GOT entry of name1 is
filled with the address of the "push name1_reloc_index" instruction.
The function, name1, is called via "jmp *GOT[name1]" in the PLT entry.
Even when lazy binding is disabled by "-z now", the PLT0 entry may
still be used with LD_AUDIT or LD_PROFILE if PLT entry is used for
canonical function address.
1. With lazy binding, when the external function, name1, is called the
first time, dynamic linker is called via PLT0 to update GOT[name1_index]
with the actual address of name1 and transfers control to name1
afterwards.
2. PLT is also used to call a local IFUNC function, name1, run-time
loader updates GOT[name1_index] when loading the module.
This patch
1. Remove PLT layout configurations from i386 backend_data.
2. Add generic, lay and non-lazy PLT layout configurations to i386
link_hash_table. Generic PLT layout includes the PLT entry templates,
information how to update the first instruction in PLT and PLT eh_frame
informaton, which are initialized in i386 setup_gnu_properties, based
on PIC and target selection. PLT section alignment is also set to PLT
entry size for non-NaCl/VxWorks target.
3. Remove elf_i386_create_dynamic_sections. create_dynamic_sections
isn't always called, but GOT relocations need GOT relocations. Instead,
create all i386 specific dynamic sections in i386 setup_gnu_properties,
which initializes elf.dynobj, so that i386 check_relocs can be simplified.
4. Rewrite elf_i386_get_synthetic_symtab to check PLT sections against
all dynamic relocations to support both lazy and non-lazy PLTs.
bfd/
* elf32-i386.c (PLT_ENTRY_SIZE): Renamed to ...
(LAZY_PLT_ENTRY_SIZE): This.
(NON_LAZY_PLT_ENTRY_SIZE): New.
(elf_i386_plt0_entry): Renamed to ...
(elf_i386_lazy_plt0_entry): This.
(elf_i386_plt_entry): Renamed to ...
(elf_i386_lazy_plt_entry): This.
(elf_i386_pic_plt0_entry): Renamed to ...
(elf_i386_pic_lazy_plt0_entry): This.
(elf_i386_pic_plt_entry): Renamed to ...
(elf_i386_pic_lazy_plt_entry): This.
(elf_i386_got_plt_entry): Renamed to ...
(elf_i386_non_lazy_plt_entry): This.
(elf_i386_pic_got_plt_entry): Renamed to ...
(elf_i386_pic_non_lazy_plt_entry): This.
(elf_i386_eh_frame_plt): Renamed to ...
(elf_i386_eh_frame_lazy_plt): This.
(elf_i386_eh_frame_plt_got): Renamed to ...
(elf_i386_eh_frame_non_lazy_plt): This.
(elf_i386_plt_layout): Renamed to ...
(elf_i386_lazy_plt_layout): This. Remove eh_frame_plt_got and
eh_frame_plt_got_size.
(elf_i386_non_lazy_plt_layout): New.
(elf_i386_plt_layout): Likewise.
(elf_i386_non_lazy_plt): Likewise.
(GET_PLT_ENTRY_SIZE): Removed.
(elf_i386_plt): Renamed to ...
(elf_i386_lazy_plt): This.
(elf_i386_backend_data): Remove plt. Rename is_vxworks to os.
(elf_i386_arch_bed): Updated.
(elf_i386_link_hash_table): Add plt, lazy_plt and non_lazy_plt.
(elf_i386_create_dynamic_sections): Removed.
(elf_i386_check_relocs): Don't check elf.dynobj. Don't call
_bfd_elf_create_ifunc_sections nor _bfd_elf_create_got_section.
(elf_i386_adjust_dynamic_symbol): Updated.
(elf_i386_allocate_dynrelocs): Updated. Pass 0 as PLT header
size to _bfd_elf_allocate_ifunc_dyn_relocs and don't allocate
size for PLT0 if there is no PLT0.
(elf_i386_size_dynamic_sections): Updated. Check whether GOT
output section is discarded only if GOT isn't empty.
(elf_i386_relocate_section): Updated. Properly get PLT index
if there is no PLT0.
(elf_i386_finish_dynamic_symbol): Updated. Don't fill the
second and third slots in the PLT entry if there is no PLT0.
(elf_i386_finish_dynamic_sections): Updated. Don't fill PLT0
if there is no PLT0. Set sh_entsize on the .plt.got section.
(elf_i386_nacl_plt): Forward declaration.
(elf_i386_get_plt_sym_val): Removed.
(elf_i386_get_synthetic_symtab): Rewrite to check PLT sections
against all dynamic relocations.
(elf_i386_link_setup_gnu_properties): New function.
(elf_backend_create_dynamic_sections): Updated.
(elf_backend_setup_gnu_properties): New.
(elf_i386_nacl_plt): Updated.
(elf_i386_nacl_arch_bed): Likewise.
(elf_i386_vxworks_arch_bed): Likewise.
ld/
* testsuite/ld-i386/i386.exp: Add some -z now tests.
* testsuite/ld-i386/plt-pic2.dd: New file.
* testsuite/ld-i386/plt2.dd: Likewise.
* testsuite/ld-i386/plt2.rd: Likewise.
* testsuite/ld-i386/plt2.s: Likewise.
* testsuite/ld-ifunc/ifunc-16-i386-now.d: Likewise.
* testsuite/ld-ifunc/ifunc-2-i386-now.d: Likewise.
* testsuite/ld-ifunc/ifunc-2-local-i386-now.d: Likewise.
* testsuite/ld-ifunc/pr17154-i386-now.d: Likewise.
* testsuite/ld-i386/pr20830.d: Update the .plt.got section
with func@plt.
2017-05-08 10:10:22 -07:00
|
|
|
|
2017-05-08 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (PLT_ENTRY_SIZE): Renamed to ...
|
|
|
|
|
(LAZY_PLT_ENTRY_SIZE): This.
|
|
|
|
|
(NON_LAZY_PLT_ENTRY_SIZE): New.
|
|
|
|
|
(elf_i386_plt0_entry): Renamed to ...
|
|
|
|
|
(elf_i386_lazy_plt0_entry): This.
|
|
|
|
|
(elf_i386_plt_entry): Renamed to ...
|
|
|
|
|
(elf_i386_lazy_plt_entry): This.
|
|
|
|
|
(elf_i386_pic_plt0_entry): Renamed to ...
|
|
|
|
|
(elf_i386_pic_lazy_plt0_entry): This.
|
|
|
|
|
(elf_i386_pic_plt_entry): Renamed to ...
|
|
|
|
|
(elf_i386_pic_lazy_plt_entry): This.
|
|
|
|
|
(elf_i386_got_plt_entry): Renamed to ...
|
|
|
|
|
(elf_i386_non_lazy_plt_entry): This.
|
|
|
|
|
(elf_i386_pic_got_plt_entry): Renamed to ...
|
|
|
|
|
(elf_i386_pic_non_lazy_plt_entry): This.
|
|
|
|
|
(elf_i386_eh_frame_plt): Renamed to ...
|
|
|
|
|
(elf_i386_eh_frame_lazy_plt): This.
|
|
|
|
|
(elf_i386_eh_frame_plt_got): Renamed to ...
|
|
|
|
|
(elf_i386_eh_frame_non_lazy_plt): This.
|
|
|
|
|
(elf_i386_plt_layout): Renamed to ...
|
|
|
|
|
(elf_i386_lazy_plt_layout): This. Remove eh_frame_plt_got and
|
|
|
|
|
eh_frame_plt_got_size.
|
|
|
|
|
(elf_i386_non_lazy_plt_layout): New.
|
|
|
|
|
(elf_i386_plt_layout): Likewise.
|
|
|
|
|
(elf_i386_non_lazy_plt): Likewise.
|
|
|
|
|
(GET_PLT_ENTRY_SIZE): Removed.
|
|
|
|
|
(elf_i386_plt): Renamed to ...
|
|
|
|
|
(elf_i386_lazy_plt): This.
|
|
|
|
|
(elf_i386_backend_data): Remove plt. Rename is_vxworks to os.
|
|
|
|
|
(elf_i386_arch_bed): Updated.
|
|
|
|
|
(elf_i386_link_hash_table): Add plt, lazy_plt and non_lazy_plt.
|
|
|
|
|
(elf_i386_create_dynamic_sections): Removed.
|
|
|
|
|
(elf_i386_check_relocs): Don't check elf.dynobj. Don't call
|
|
|
|
|
_bfd_elf_create_ifunc_sections nor _bfd_elf_create_got_section.
|
|
|
|
|
(elf_i386_adjust_dynamic_symbol): Updated.
|
|
|
|
|
(elf_i386_allocate_dynrelocs): Updated. Pass 0 as PLT header
|
|
|
|
|
size to _bfd_elf_allocate_ifunc_dyn_relocs and don't allocate
|
|
|
|
|
size for PLT0 if there is no PLT0.
|
|
|
|
|
(elf_i386_size_dynamic_sections): Updated. Check whether GOT
|
|
|
|
|
output section is discarded only if GOT isn't empty.
|
|
|
|
|
(elf_i386_relocate_section): Updated. Properly get PLT index
|
|
|
|
|
if there is no PLT0.
|
|
|
|
|
(elf_i386_finish_dynamic_symbol): Updated. Don't fill the
|
|
|
|
|
second and third slots in the PLT entry if there is no PLT0.
|
|
|
|
|
(elf_i386_finish_dynamic_sections): Updated. Don't fill PLT0
|
|
|
|
|
if there is no PLT0. Set sh_entsize on the .plt.got section.
|
|
|
|
|
(elf_i386_nacl_plt): Forward declaration.
|
|
|
|
|
(elf_i386_get_plt_sym_val): Removed.
|
|
|
|
|
(elf_i386_get_synthetic_symtab): Rewrite to check PLT sections
|
|
|
|
|
against all dynamic relocations.
|
|
|
|
|
(elf_i386_link_setup_gnu_properties): New function.
|
|
|
|
|
(elf_backend_create_dynamic_sections): Updated.
|
|
|
|
|
(elf_backend_setup_gnu_properties): New.
|
|
|
|
|
(elf_i386_nacl_plt): Updated.
|
|
|
|
|
(elf_i386_nacl_arch_bed): Likewise.
|
|
|
|
|
(elf_i386_vxworks_arch_bed): Likewise.
|
|
|
|
|
|
2017-05-08 15:26:51 +01:00
|
|
|
|
2017-05-08 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (elf_output_implib): Remove executable flag from import
|
|
|
|
|
library bfd.
|
|
|
|
|
* elf32-arm.c (elf32_arm_filter_implib_symbols): Assert that the import
|
|
|
|
|
library is a relocatable object file.
|
|
|
|
|
|
Fix PR21404 - assertion fail when calculating symbol size
Fix a host of problems related to adjustment of
symbol values and sizes when relaxing for avr.
1. Adjust symbol size first before adjusting symbol
value. Otherwise, a symbol whose value just got adjusted to the
relaxed address also ends up getting resized. See pr21404-1.s.
2. Reduce symbol sizes only if their span is below an
alignment boundary. Otherwise, the size gets decremented once when the
actual instruction is relaxed and padding bytes are added, and again
when the padding bytes are deleted (if padding ends up being unnecessary).
pr21404-2.s addresses that, and this bug is really the root cause of PR21404.
3. Adjust all symbol values before an alignment boundary.
Previous code did not adjust symbol values if they fell in the
would-be padded area, resulting in incorrect symbol values in some
cases (see pr21404-3.s).
4. Increase symbol sizes if alignment directives require so.
As pr21404-4.s shows
.global nonzero_sym
L1:
jmp L1
nonzero_sym:
nop
nop
.p2align 2
.size nonzero_sym, .-nonzero_sym
The two nops satisfy the 4 byte alignment at assembly time and
therefore the size of nonzero_sym is 4. Relaxation shortens
the 4 byte jmp to a 2 byte rjmp, and to satisfy 4 byte alignment
the code places 2 extra padding bytes after the nops, increasing
nonzero_sym's size by 2. This wasn't handled before.
If the assembly code does not have any align directives, then the
boundary is the section size, and symbol values and sizes == boundary
should also get adjusted. To handle that case, add a did_pad variable
and use that to determine whether it should use < boundary or <= boundary.
Also get rid of reloc_toaddr, which is now redundant. toaddr is now not
adjusted to handle the above case - the newly added
did_pad variable does the job.
pr21404-{5,6,7,8} are the same testcases written for local symbols, as
the code handles them slightly differently.
2017-04-24 15:17:14 +05:30
|
|
|
|
2017-05-01 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21404
|
|
|
|
|
* elf32-avr.c (avr_should_move_sym): New function.
|
|
|
|
|
(avr_should_reduce_sym_size): Likewise.
|
|
|
|
|
(avr_should_increase_sym_size): Likewise.
|
|
|
|
|
(elf32_avr_relax_delete_bytes): Adjust symbol values
|
|
|
|
|
and sizes by calling new functions.
|
|
|
|
|
|
2017-05-01 10:26:32 -07:00
|
|
|
|
2017-05-01 Palmer Dabbelt <palmer@dabbelt.com>
|
|
|
|
|
|
|
|
|
|
* config.bfd (riscv32-*): Enable rv64.
|
|
|
|
|
|
2017-05-02 21:56:43 +09:30
|
|
|
|
2017-05-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21384
|
|
|
|
|
* elflink.c (bfd_elf_link_mark_dynamic_symbol): Test h->non_elf
|
|
|
|
|
rather than h->root.type == bfd_link_hash_new.
|
|
|
|
|
(bfd_elf_record_link_assignment): Similarly, call
|
|
|
|
|
bfd_elf_link_mark_dynamic_symbol when h->non_elf.
|
|
|
|
|
|
2017-04-29 14:48:16 +09:30
|
|
|
|
2017-04-29 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21432
|
|
|
|
|
* reloc.c (reloc_offset_in_range): New function.
|
|
|
|
|
(bfd_perform_relocation, bfd_install_relocation): Use it.
|
|
|
|
|
(_bfd_final_link_relocate): Likewise.
|
|
|
|
|
|
2017-04-28 07:26:45 -07:00
|
|
|
|
2017-04-28 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_allocate_dynrelocs): Check plt_got
|
|
|
|
|
before using .plt.got.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_allocate_dynrelocs): Likewise.
|
|
|
|
|
|
2017-04-27 15:24:08 -07:00
|
|
|
|
2017-04-27 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_size_dynamic_sections): Use "="
|
|
|
|
|
instead of "+=" to update 0.
|
|
|
|
|
|
2017-04-27 13:55:31 -07:00
|
|
|
|
2017-04-27 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_create_dynamic_sections): Create the
|
|
|
|
|
.plt.got section here.
|
|
|
|
|
(elf_i386_check_relocs): Don't create the .plt.got section.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Create
|
|
|
|
|
the .plt.got and .plt.bnd sections here.
|
|
|
|
|
(elf_x86_64_check_relocs): Don't create the .plt.got nor
|
|
|
|
|
.plt.bnd sections.
|
|
|
|
|
|
2017-04-27 09:32:35 -07:00
|
|
|
|
2017-04-27 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_link_hash_entry): Remove
|
|
|
|
|
has_bnd_reloc.
|
|
|
|
|
(elf_x86_64_link_hash_newfunc): Don't clear has_bnd_reloc.
|
|
|
|
|
(elf_x86_64_copy_indirect_symbol): Don't copy has_bnd_reloc.
|
|
|
|
|
(elf_x86_64_check_relocs): Don't set has_bnd_reloc.
|
|
|
|
|
(elf_x86_64_finish_dynamic_symbol): Check bndplt instead of
|
|
|
|
|
has_bnd_reloc.
|
|
|
|
|
|
2017-04-27 09:07:23 -07:00
|
|
|
|
2017-04-27 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h (elf_backend_data): Change setup_gnu_properties
|
|
|
|
|
to return bfd *.
|
|
|
|
|
(_bfd_elf_link_setup_gnu_properties): Return bfd *.
|
|
|
|
|
* elf-properties.c (_bfd_elf_link_setup_gnu_properties): Return
|
|
|
|
|
the first relocatable ELF input with GNU properties.
|
|
|
|
|
|
2017-04-27 08:55:36 -07:00
|
|
|
|
2017-04-27 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_finish_dynamic_sections): Simplify
|
|
|
|
|
VxWorks for non-PIC.
|
|
|
|
|
|
2017-04-27 12:03:39 +09:30
|
|
|
|
2017-04-27 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h (struct elf_backend_data): Make asection param of
|
|
|
|
|
elf_backend_eh_frame_address_size const.
|
|
|
|
|
(_bfd_elf_eh_frame_address_size): Likewise.
|
|
|
|
|
* elf32-m32c.c (_bfd_m32c_elf_eh_frame_address_size): Likewise.
|
|
|
|
|
* elf32-msp430.c (elf32_msp430_eh_frame_address_size): Likewise.
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_eh_frame_address_size): Likewise.
|
|
|
|
|
* elfxx-mips.h (_bfd_mips_elf_eh_frame_address_size): Likewise.
|
|
|
|
|
* elf-eh-frame.c (_bfd_elf_eh_frame_address_size): Likewise.
|
|
|
|
|
(next_cie_fde_offset): Constify params.
|
|
|
|
|
(offset_adjust, adjust_eh_frame_local_symbols): Likewise.
|
|
|
|
|
|
2017-04-27 11:08:14 +09:30
|
|
|
|
2017-04-27 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h (struct eh_cie_fde): Add aug_str_len and aug_data_len.
|
|
|
|
|
(_bfd_elf_adjust_eh_frame_global_symbol): Declare.
|
|
|
|
|
* elf-eh-frame.c (_bfd_elf_parse_eh_frame): Set aug_str_len and
|
|
|
|
|
aug_data_len.
|
|
|
|
|
(offset_adjust): New function.
|
|
|
|
|
(_bfd_elf_adjust_eh_frame_global_symbol): Likewise.
|
|
|
|
|
(adjust_eh_frame_local_symbols): Likewise.
|
|
|
|
|
(_bfd_elf_discard_section_eh_frame): Call adjust_eh_frame_local_symbols
|
|
|
|
|
after changing anything. Return true if anything changed.
|
|
|
|
|
* elflink.c (bfd_elf_discard_info): If .eh_frame changed, call
|
|
|
|
|
_bfd_elf_adjust_eh_frame_global_symbol for globals.
|
|
|
|
|
|
2017-04-27 11:06:33 +09:30
|
|
|
|
2017-04-27 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (_bfd_elf_link_hash_hide_symbol): Clear dynstr_index
|
|
|
|
|
when force_local.
|
|
|
|
|
|
2017-04-27 09:19:26 +09:30
|
|
|
|
2017-04-27 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-ppc.c (UNDEFWEAK_NO_DYNAMIC_RELOC): Define.
|
|
|
|
|
(ppc_elf_select_plt_layout, ppc_elf_tls_setup): Use it.
|
|
|
|
|
(ppc_elf_adjust_dynamic_symbol, allocate_dynrelocs): Likewise.
|
|
|
|
|
(ppc_elf_relocate_section): Likewise. Delete silly optimisation
|
|
|
|
|
for undef and undefweak dyn_relocs.
|
|
|
|
|
* elf64-ppc.c (UNDEFWEAK_NO_DYNAMIC_RELOC): Define.
|
|
|
|
|
(ppc64_elf_adjust_dynamic_symbol, ppc64_elf_tls_setup): Use it.
|
|
|
|
|
(allocate_got, allocate_dynrelocs): Likewise.
|
|
|
|
|
(ppc64_elf_relocate_section): Likewise.
|
|
|
|
|
|
2017-04-26 15:34:00 -07:00
|
|
|
|
2017-04-26 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_size_dynamic_sections): Alwasys add
|
|
|
|
|
DT_PLTRELSZ, DT_PLTREL and DT_JMPREL for .rel.plt section.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_size_dynamic_sections): Alwasys
|
|
|
|
|
add DT_PLTRELSZ, DT_PLTREL and DT_JMPREL for .rela.plt section.
|
|
|
|
|
|
2017-04-26 16:30:22 +01:00
|
|
|
|
2017-04-26 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21434
|
|
|
|
|
* reloc.c (bfd_perform_relocation): Check for a negative address
|
|
|
|
|
in the reloc.
|
|
|
|
|
|
2017-04-24 20:15:31 +01:00
|
|
|
|
2017-04-26 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21334
|
|
|
|
|
* elf-bfd.h (elf_backend_data): Add `always_renumber_dynsyms'
|
|
|
|
|
member.
|
|
|
|
|
* elfxx-target.h [!elf_backend_always_renumber_dynsyms]
|
|
|
|
|
(elf_backend_always_renumber_dynsyms): Define.
|
|
|
|
|
(elfNN_bed): Initialize `always_renumber_dynsyms' member.
|
|
|
|
|
* elfxx-mips.h (elf_backend_always_renumber_dynsyms): Define.
|
|
|
|
|
* elflink.c (bfd_elf_size_dynamic_sections): Also call
|
|
|
|
|
`_bfd_elf_link_renumber_dynsyms' if the backend has requested
|
|
|
|
|
it.
|
|
|
|
|
(bfd_elf_size_dynsym_hash_dynstr): Likewise.
|
|
|
|
|
|
2017-04-24 20:13:28 +01:00
|
|
|
|
2017-04-26 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (bfd_elf_size_dynamic_sections): Only call
|
|
|
|
|
`_bfd_elf_link_renumber_dynsyms' after section GC if dynamic
|
|
|
|
|
sections have been created.
|
|
|
|
|
|
2017-04-26 13:07:49 +01:00
|
|
|
|
2017-04-26 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21431
|
|
|
|
|
* compress.c (bfd_init_section_compress_status): Check the return
|
|
|
|
|
value from bfd_malloc.
|
|
|
|
|
|
2017-04-24 14:37:12 -07:00
|
|
|
|
2017-04-24 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_link_hash_entry): Add
|
|
|
|
|
no_finish_dynamic_symbol.
|
|
|
|
|
(elf_x86_64_link_hash_newfunc): Set no_finish_dynamic_symbol to
|
|
|
|
|
0.
|
|
|
|
|
(elf_x86_64_allocate_dynrelocs): If a symbol isn't undefined
|
|
|
|
|
weak symbol, don't make it dynamic.
|
|
|
|
|
(elf_x86_64_relocate_section): If a symbol isn't dynamic in PIC,
|
|
|
|
|
set no_finish_dynamic_symbol and generate R_X86_64_RELATIVE
|
|
|
|
|
relocation for GOT reference.
|
|
|
|
|
(elf_x86_64_finish_dynamic_symbol): Abort if
|
|
|
|
|
no_finish_dynamic_symbol isn't 0.
|
|
|
|
|
|
2017-04-24 13:42:33 -07:00
|
|
|
|
2017-04-24 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21402
|
|
|
|
|
* elf32-i386.c (elf_i386_allocate_dynrelocs): If a symbol isn't
|
|
|
|
|
undefined weak symbol, don't make it dynamic.
|
|
|
|
|
(elf_i386_relocate_section): If a symbol isn't dynamic in PIC,
|
|
|
|
|
set no_finish_dynamic_symbol and generate R_386_RELATIVE
|
|
|
|
|
relocation for R_386_GOT32.
|
|
|
|
|
|
2017-04-24 09:37:10 -07:00
|
|
|
|
2017-04-24 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21425
|
|
|
|
|
* elf32-i386.c (ELF_MAXPAGESIZE): Set to 0x1000 for VxWorks.
|
|
|
|
|
|
2017-04-23 15:21:11 +09:30
|
|
|
|
2017-04-23 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21414
|
|
|
|
|
* section.c (GLOBAL_SYM_INIT): Make available in bfd.h.
|
|
|
|
|
* elf.c (lcomm_sym): New.
|
|
|
|
|
(_bfd_elf_large_com_section): Use lcomm_sym section symbol.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
|
2017-04-23 11:03:34 +09:30
|
|
|
|
2017-04-23 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21412
|
|
|
|
|
* elf-bfd.h (struct elf_backend_data <get_reloc_section>): Change
|
|
|
|
|
parameters and comment.
|
|
|
|
|
(_bfd_elf_get_reloc_section): Delete.
|
|
|
|
|
(_bfd_elf_plt_get_reloc_section): Declare.
|
|
|
|
|
* elf.c (_bfd_elf_plt_get_reloc_section, elf_get_reloc_section):
|
|
|
|
|
New functions. Don't blindly skip over assumed .rel/.rela prefix.
|
|
|
|
|
Extracted from..
|
|
|
|
|
(_bfd_elf_get_reloc_section): ..here. Delete.
|
|
|
|
|
(assign_section_numbers): Call elf_get_reloc_section.
|
|
|
|
|
* elf64-ppc.c (elf_backend_get_reloc_section): Define.
|
|
|
|
|
* elfxx-target.h (elf_backend_get_reloc_section): Update.
|
|
|
|
|
|
2017-04-23 13:55:49 +09:30
|
|
|
|
2017-04-23 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21409
|
|
|
|
|
* dwarf2.c (_bfd_dwarf2_find_nearest_line): Don't segfault when
|
|
|
|
|
no symbols.
|
|
|
|
|
|
2017-04-21 12:03:14 -07:00
|
|
|
|
2017-04-21 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21402
|
|
|
|
|
* elf32-i386.c (elf_i386_link_hash_entry): Add
|
|
|
|
|
no_finish_dynamic_symbol.
|
|
|
|
|
(elf_i386_link_hash_newfunc): Set no_finish_dynamic_symbol to 0.
|
|
|
|
|
(elf_i386_allocate_dynrelocs): If a symbol isn't undefined weak
|
|
|
|
|
symbol, don't make it dynamic in PIE.
|
|
|
|
|
(elf_i386_relocate_section): If a symbol isn't dynamic in PIE,
|
|
|
|
|
set no_finish_dynamic_symbol and generate R_386_RELATIVE
|
|
|
|
|
relocation for R_386_GOT32
|
|
|
|
|
(elf_i386_finish_dynamic_symbol): Abort if no_finish_dynamic_symbol
|
|
|
|
|
isn't 0.
|
|
|
|
|
|
2017-04-21 12:00:55 -07:00
|
|
|
|
2017-04-21 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19617
|
|
|
|
|
PR ld/21086
|
|
|
|
|
* elflink.c (elf_link_add_object_symbols): Require
|
|
|
|
|
--no-dynamic-linker with -E/--dynamic-list when creating
|
|
|
|
|
dynamic sections.
|
|
|
|
|
|
2017-04-13 10:26:05 +01:00
|
|
|
|
2017-04-20 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (_bfd_elf_symbol_refs_local_p): Always return TRUE
|
|
|
|
|
if forced local.
|
|
|
|
|
|
2017-04-19 16:51:17 +01:00
|
|
|
|
2017-04-20 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_elf_final_link): Reorder comment about
|
|
|
|
|
dynamic symbol sorting.
|
|
|
|
|
|
2017-04-20 07:48:24 -07:00
|
|
|
|
2017-04-20 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21382
|
|
|
|
|
* elflink.c (elf_link_add_object_symbols): Preserve
|
|
|
|
|
dynamic_ref_after_ir_def when restoring the symbol table for
|
|
|
|
|
unneeded dynamic object.
|
|
|
|
|
|
2017-04-19 09:59:14 -07:00
|
|
|
|
2017-04-19 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21401
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_finish_dynamic_symbol): Don't abort
|
|
|
|
|
on on undefined IFUNC symbol in the second PLT.
|
|
|
|
|
|
2017-04-19 18:02:53 +09:30
|
|
|
|
2017-04-19 Wedson Almeida Filho <wedsonaf@gmail.com>
|
|
|
|
|
|
|
|
|
|
* peXXigen.c (pe_print_reloc): Correct chunk_end.
|
|
|
|
|
|
2017-04-19 01:26:57 +09:30
|
|
|
|
2017-04-19 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (_bfd_elf_adjust_dynamic_symbol): Hide undefweak
|
|
|
|
|
or make dynamic for info->dynamic_undefined_weak 0 and 1.
|
|
|
|
|
* elf32-ppc.c:Formatting.
|
|
|
|
|
(ensure_undefweak_dynamic): Don't make dynamic when
|
|
|
|
|
info->dynamic_undefined_weak is zero.
|
|
|
|
|
(allocate_dynrelocs): Discard undefweak dyn_relocs for
|
|
|
|
|
info->dynamic_undefined_weak. Discard undef dyn_relocs when
|
|
|
|
|
not default visibility. Discard undef and undefweak
|
|
|
|
|
dyn_relocs earlier.
|
|
|
|
|
(ppc_elf_relocate_section): Adjust to suit.
|
|
|
|
|
* elf64-ppc.c: Formatting.
|
|
|
|
|
(ensure_undefweak_dynamic): Don't make dynamic when
|
|
|
|
|
info->dynamic_undefined_weak is zero.
|
|
|
|
|
(allocate_dynrelocs): Discard undefweak dyn_relocs for
|
|
|
|
|
info->dynamic_undefined_weak. Discard them earlier.
|
|
|
|
|
|
2017-04-17 07:47:17 -07:00
|
|
|
|
2017-04-17 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21389
|
|
|
|
|
* elflink.c (bfd_elf_size_dynamic_sections): Get soname index
|
|
|
|
|
before generating the version definition section.
|
|
|
|
|
|
2017-04-17 18:33:52 +09:30
|
|
|
|
2017-04-17 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (_bfd_elf_merge_symbol): Undo dynamic linking
|
|
|
|
|
state when a regular object file defines a symbol with
|
|
|
|
|
incompatible type to that defined by an earlier shared lib.
|
|
|
|
|
|
2017-04-13 13:24:18 +09:30
|
|
|
|
2017-04-13 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* coffcode.h: Wrap some overly long _bfd_error_handler args.
|
|
|
|
|
* elf.c: Likewise.
|
|
|
|
|
* elf32-arm.c: Likewise.
|
|
|
|
|
* elf32-i386.c: Likewise.
|
|
|
|
|
* elf32-mep.c: Likewise.
|
|
|
|
|
* elf64-ia64-vms.c: Likewise.
|
|
|
|
|
* elf64-x86-64.c: Likewise.
|
|
|
|
|
* elflink.c: Likewise.
|
|
|
|
|
* elfnn-ia64.c: Likewise.
|
|
|
|
|
* elfxx-mips.c: Likewise.
|
|
|
|
|
|
2017-04-13 13:20:15 +09:30
|
|
|
|
2017-04-13 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* aoutx.h: Use %B and %A in error messages throughout file.
|
|
|
|
|
* aout-cris.c: Likewise.
|
|
|
|
|
* archive.c: Likewise.
|
|
|
|
|
* binary.c: Likewise.
|
|
|
|
|
* coff-rs6000.c: Likewise.
|
|
|
|
|
* coff-tic4x.c: Likewise.
|
|
|
|
|
* coffcode.h: Likewise.
|
|
|
|
|
* coffgen.c: Likewise.
|
|
|
|
|
* cofflink.c: Likewise.
|
|
|
|
|
* coffswap.h: Likewise.
|
|
|
|
|
* cpu-arm.c: Likewise.
|
|
|
|
|
* elf-eh-frame.c: Likewise.
|
|
|
|
|
* elf-m10300.c: Likewise.
|
|
|
|
|
* elf.c: Likewise.
|
|
|
|
|
* elf32-arc.c: Likewise.
|
|
|
|
|
* elf32-arm.c: Likewise.
|
|
|
|
|
* elf32-bfin.c: Likewise.
|
|
|
|
|
* elf32-frv.c: Likewise.
|
|
|
|
|
* elf32-iq2000.c: Likewise.
|
|
|
|
|
* elf32-m32c.c: Likewise.
|
|
|
|
|
* elf32-microblaze.c: Likewise.
|
|
|
|
|
* elf32-nds32.c: Likewise.
|
|
|
|
|
* elf32-rl78.c: Likewise.
|
|
|
|
|
* elf32-rx.c: Likewise.
|
|
|
|
|
* elf32-score.c: Likewise.
|
|
|
|
|
* elf32-score7.c: Likewise.
|
|
|
|
|
* elf32-sh64.c: Likewise.
|
|
|
|
|
* elf32-v850.c: Likewise.
|
|
|
|
|
* elf32-vax.c: Likewise.
|
|
|
|
|
* elf32-visium.c: Likewise.
|
|
|
|
|
* elf64-ia64-vms.c: Likewise.
|
|
|
|
|
* elf64-mmix.c: Likewise.
|
|
|
|
|
* elf64-sh64.c: Likewise.
|
|
|
|
|
* elfcode.h: Likewise.
|
|
|
|
|
* elfnn-aarch64.c: Likewise.
|
|
|
|
|
* elfnn-ia64.c: Likewise.
|
|
|
|
|
* elfxx-mips.c: Likewise.
|
|
|
|
|
* hpux-core.c: Likewise.
|
|
|
|
|
* ieee.c: Likewise.
|
|
|
|
|
* ihex.c: Likewise.
|
|
|
|
|
* linker.c: Likewise.
|
|
|
|
|
* merge.c: Likewise.
|
|
|
|
|
* mmo.c: Likewise.
|
|
|
|
|
* oasys.c: Likewise.
|
|
|
|
|
* pdp11.c: Likewise.
|
|
|
|
|
* peXXigen.c: Likewise.
|
|
|
|
|
* rs6000-core.c: Likewise.
|
|
|
|
|
* vms-alpha.c: Likewise.
|
|
|
|
|
* xcofflink.c: Likewise.
|
|
|
|
|
|
2017-04-13 10:58:40 +09:30
|
|
|
|
2017-04-13 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* bfd.c (PRINT_TYPE): Define.
|
|
|
|
|
(_doprnt): New function.
|
|
|
|
|
(error_handler_internal): Use _doprnt.
|
|
|
|
|
* coff-arm.c: Put %A and %B arguments to _bfd_error_handler
|
|
|
|
|
calls in their natural order, throughout file.
|
|
|
|
|
* coff-mcore.c: Likewise.
|
|
|
|
|
* coff-ppc.c: Likewise.
|
|
|
|
|
* coff-tic80.c: Likewise.
|
|
|
|
|
* cofflink.c: Likewise.
|
|
|
|
|
* elf-s390-common.c: Likewise.
|
|
|
|
|
* elf.c: Likewise.
|
|
|
|
|
* elf32-arm.c: Likewise.
|
|
|
|
|
* elf32-i386.c: Likewise.
|
|
|
|
|
* elf32-m32r.c: Likewise.
|
|
|
|
|
* elf32-msp430.c: Likewise.
|
|
|
|
|
* elf32-spu.c: Likewise.
|
|
|
|
|
* elf64-ia64-vms.c: Likewise.
|
|
|
|
|
* elf64-sparc.c: Likewise.
|
|
|
|
|
* elf64-x86-64.c: Likewise.
|
|
|
|
|
* elflink.c: Likewise.
|
|
|
|
|
* elfnn-aarch64.c: Likewise.
|
|
|
|
|
* elfnn-ia64.c: Likewise.
|
|
|
|
|
* elfxx-mips.c: Likewise.
|
|
|
|
|
|
2017-04-13 10:44:20 +09:30
|
|
|
|
2017-04-13 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arm.c (arm_type_of_stub): Supply missing args to "long
|
|
|
|
|
branch veneers" error. Fix double space and format message.
|
|
|
|
|
* elf32-avr.c (avr_add_stub): Do not pass NULL as %B arg.
|
|
|
|
|
* elf64-ppc.c (tocsave_find): Supply missing %B arg.
|
|
|
|
|
|
2017-04-13 10:33:11 +09:30
|
|
|
|
2017-04-13 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
|
2017-04-11 15:41:00 -07:00
|
|
|
|
2017-04-11 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf-properties.c (_bfd_elf_parse_gnu_properties): Remove the
|
|
|
|
|
extra `\n' in warning/error messages.
|
|
|
|
|
* elf32-i386.c (elf_i386_parse_gnu_properties): Likewise.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_parse_gnu_properties): Likewise.
|
|
|
|
|
|
2017-04-11 15:07:41 -07:00
|
|
|
|
2017-04-11 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf-properties.c (_bfd_elf_parse_gnu_properties): Ignore
|
|
|
|
|
processor-specific properties with generic ELF target vector.
|
|
|
|
|
|
2017-04-10 12:46:30 +01:00
|
|
|
|
2017-04-10 Qing Zhao <qing.zhao@oracle.com>
|
|
|
|
|
|
|
|
|
|
* elf32-sparc.c (elf_backend_fixup_symbol): New.
|
|
|
|
|
* elf64-sparc.c (elf_backend_fixup_symbol): New.
|
|
|
|
|
* elfxx-sparc.c (UNDEFINED_WEAK_RESOLVED_TO_ZERO): New.
|
|
|
|
|
(_bfd_sparc_elf_link_hash_entry): Add has_got_reloc and
|
|
|
|
|
has_non_got_reloc.
|
|
|
|
|
(link_hash_newfunc): Initialize has_got_reloc and
|
|
|
|
|
has_non_got_reloc.
|
|
|
|
|
(_bfd_sparc_elf_size_dynamic_sections): Set interp to .interp
|
|
|
|
|
section.
|
|
|
|
|
(_bfd_sparc_elf_copy_indirect_symbol): Copy has_got_reloc and
|
|
|
|
|
has_non_got_reloc.
|
|
|
|
|
(_bfd_sparc_elf_check_relocs): Set has_got_reloc and
|
|
|
|
|
has_non_got_reloc.
|
|
|
|
|
(_bfd_sparc_elf_fixup_symbol): New function.
|
|
|
|
|
(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.
|
|
|
|
|
(_bfd_sparc_elf_relocate_section): Don't generate dynamic
|
|
|
|
|
relocations against resolved undefined weak symbols in PIE
|
|
|
|
|
(_bfd_sparc_elf_finish_dynamic_symbol): Keep PLT/GOT entries
|
|
|
|
|
without ynamic PLT/GOT relocations for resolved undefined weak
|
|
|
|
|
symbols.
|
|
|
|
|
Don't generate dynamic relocation against resolved undefined
|
|
|
|
|
weak symbol in executable.
|
|
|
|
|
(pie_finish_undefweak_symbol): New function.
|
|
|
|
|
(_bfd_sparc_elf_finish_dynamic_sections): Call
|
|
|
|
|
pie_finish_undefweak_symbol on all symbols in PIE.
|
|
|
|
|
* elfxx-sparc.h (_bfd_sparc_elf_link_hash_table): Add interp.
|
|
|
|
|
(_bfd_sparc_elf_fixup_symbol): New function.
|
|
|
|
|
|
2017-04-10 11:38:21 +01:00
|
|
|
|
2017-04-10 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* config.bfd: Remove ns32k from obsolete list.
|
|
|
|
|
|
2017-04-10 15:11:35 +09:30
|
|
|
|
2017-04-10 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21287
|
|
|
|
|
* elf.c (special_sections_f): Match .fini_array and .fini_array.*.
|
|
|
|
|
(special_sections_i): Likewise for .init_array.
|
|
|
|
|
(special_sections_p): Likewise for .preinit_array.
|
|
|
|
|
|
2017-04-07 07:40:14 -07:00
|
|
|
|
2017-04-07 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/19579
|
|
|
|
|
PR ld/21306
|
|
|
|
|
* elf32-s390.c (elf_s390_finish_dynamic_symbol): Check
|
|
|
|
|
ELF_COMMON_DEF_P for common symbols.
|
|
|
|
|
* elf64-s390.c (elf_s390_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_relocate_section): Likewise.
|
|
|
|
|
* elflink.c (_bfd_elf_merge_symbol): Revert commits
|
|
|
|
|
202ac193bbbecc96a4978d1ac3d17148253f9b01 and
|
|
|
|
|
07492f668d2173da7a2bda3707ff0985e0f460b6.
|
|
|
|
|
|
2017-04-07 14:51:42 +01:00
|
|
|
|
2017-04-07 Pedro Alves <palves@redhat.com>
|
|
|
|
|
|
|
|
|
|
* opncls.c (bfd_get_debug_link_info): Rename to...
|
|
|
|
|
(bfd_get_debug_link_info_1): ... this. Change type of second
|
|
|
|
|
parameter to void pointer. Adjust.
|
|
|
|
|
(bfd_get_debug_link_info): Reimplement on top of
|
|
|
|
|
bfd_get_debug_link_info_1.
|
|
|
|
|
(separate_debug_file_exists, separate_alt_debug_file_exists):
|
|
|
|
|
Change type of second parameter to void pointer. Adjust.
|
|
|
|
|
(get_func_type, check_func_type): Change type of second parameter
|
|
|
|
|
to void pointer.
|
|
|
|
|
(find_separate_debug_file): Add 'func_data' parameter. Pass it to
|
|
|
|
|
the callback functions instead of passing the address of a local.
|
|
|
|
|
(bfd_follow_gnu_debuglink): Pass address of unsigned long local to
|
|
|
|
|
find_separate_debug_file.
|
|
|
|
|
(get_alt_debug_link_info_shim): Change type of second parameter to
|
|
|
|
|
void pointer. Adjust.
|
|
|
|
|
(bfd_follow_gnu_debugaltlink): Adjust to pass NULL to
|
|
|
|
|
find_separate_debug_file.
|
|
|
|
|
(get_build_id_name, bfd_boolean check_build_id_file): Change type
|
|
|
|
|
of second parameter to void pointer. Adjust.
|
|
|
|
|
(bfd_follow_build_id_debuglink): Pass address of bfd_build_id
|
|
|
|
|
pointer local to find_separate_debug_file.
|
|
|
|
|
|
|
|
|
|
2017-04-07 Tristan Gingold <gingold@gingold-Precision-7510>
|
2017-03-31 15:25:18 +02:00
|
|
|
|
|
|
|
|
|
* coffgen.c (_bfd_coff_gc_mark_hook): Handle PE weak
|
|
|
|
|
external symbols with a definition.
|
|
|
|
|
(_bfd_coff_gc_mark_extra_sections): Fix typo.
|
|
|
|
|
|
2017-04-07 00:17:09 +09:30
|
|
|
|
2017-04-07 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* po/SRC-POTFILES.in: Regenerate.
|
|
|
|
|
|
2017-04-05 12:47:41 +09:30
|
|
|
|
2017-04-05 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_gc_sweep_hook): Support ELFv2 PLT
|
|
|
|
|
reference counting.
|
|
|
|
|
|
2016-06-02 13:46:58 +00:00
|
|
|
|
2017-04-02 Jon Turney <jon.turney@dronecode.org.uk>
|
|
|
|
|
|
|
|
|
|
(_bfd_XXi_swap_aouthdr_out): For clarity, use defines rather than
|
|
|
|
|
numbers for DataDirectory entry indicies passed to
|
|
|
|
|
add_data_entry().
|
|
|
|
|
|
Support ELF SHF_GNU_MBIND and PT_GNU_MBIND_XXX
Mark an ALLOC section, which should be placed in special memory area,
with SHF_GNU_MBIND. Its sh_info field indicates the special memory
type. GNU_MBIND section names start with ".mbind" so that they are
placed as orphan sections by linker. All input GNU_MBIND sections
with the same sh_type, sh_flags and sh_info are placed in one output
GNU_MBIND section. In executable and shared object, create a
GNU_MBIND segment for each GNU_MBIND section and its segment type is
PT_GNU_MBIND_LO plus the sh_info value. Each GNU_MBIND segment is
aligned at page boundary.
The assembler syntax:
.section .mbind.foo,"adx",%progbits
^ 0: Special memory type.
|
'd' for SHF_GNU_MBIND.
.section .mbind.foo,"adx",%progbits,0x1
^ 1: Special memory type.
|
'd' for SHF_GNU_MBIND.
.section .mbind.bar,"adG",%progbits,.foo_group,comdat,0x2
^ 2: Special memory type.
|
'd' for SHF_GNU_MBIND.
bfd/
* elf.c (get_program_header_size): Add a GNU_MBIND segment for
each GNU_MBIND section and align GNU_MBIND section to page size.
(_bfd_elf_map_sections_to_segments): Create a GNU_MBIND
segment for each GNU_MBIND section.
(_bfd_elf_init_private_section_data): Copy sh_info from input
for GNU_MBIND section.
binutils/
* NEWS: Mention support for ELF SHF_GNU_MBIND and
PT_GNU_MBIND_XXX.
* readelf.c (get_segment_type): Handle PT_GNU_MBIND_XXX.
(get_elf_section_flags): Handle SHF_GNU_MBIND.
(process_section_headers): Likewise.
* testsuite/binutils-all/mbind1.s: New file.
* testsuite/binutils-all/objcopy.exp: Run readelf test on
mbind1.s.
gas/
* NEWS: Mention support for ELF SHF_GNU_MBIND.
* config/obj-elf.c (section_match): New.
(get_section): Match both sh_info and group name.
(obj_elf_change_section): Add argument for sh_info. Pass both
sh_info and group name to get_section. Issue an error for
SHF_GNU_MBIND section without SHF_ALLOC. Set sh_info.
(obj_elf_parse_section_letters): Set SHF_GNU_MBIND for 'd'.
(obj_elf_section): Support SHF_GNU_MBIND section info.
* config/obj-elf.h (obj_elf_change_section): Add argument for
sh_info.
* config/tc-arm.c (start_unwind_section): Pass 0 as sh_info to
obj_elf_change_section.
* config/tc-ia64.c (obj_elf_vms_common): Likewise.
* config/tc-microblaze.c (microblaze_s_data): Likewise.
(microblaze_s_sdata): Likewise.
(microblaze_s_rdata): Likewise.
(microblaze_s_bss): Likewise.
* config/tc-mips.c (s_change_section): Likewise.
* config/tc-msp430.c (msp430_profiler): Likewise.
* config/tc-rx.c (parse_rx_section): Likewise.
* config/tc-tic6x.c (tic6x_start_unwind_section): Likewise.
* doc/as.texinfo: Document 'd' for SHF_GNU_MBIND.
* testsuite/gas/elf/elf.exp: Run section12a, section12b and
section13.
* testsuite/gas/elf/section10.d: Updated.
* testsuite/gas/elf/section10.s: Likewise.
* testsuite/gas/elf/section12.s: New file.
* testsuite/gas/elf/section12a.d: Likewise.
* testsuite/gas/elf/section12b.d: Likewise.
* testsuite/gas/elf/section13.l: Likewise.
* testsuite/gas/elf/section13.d: Likewise.
* testsuite/gas/elf/section13.s: Likewise.
include/
* elf/common.h (PT_GNU_MBIND_NUM): New.
(PT_GNU_MBIND_LO): Likewise.
(PT_GNU_MBIND_HI): Likewise.
(SHF_GNU_MBIND): Likewise.
ld/
* NEWS: Mention support for ELF SHF_GNU_MBIND and
PT_GNU_MBIND_XXX.
* emultempl/elf32.em (gld${EMULATION_NAME}_place_orphan): Place
input GNU_MBIND sections with the same type, attributes and
sh_info field into a single output GNU_MBIND section.
* testsuite/ld-elf/elf.exp: Run mbind2a and mbind2b.
* testsuite/ld-elf/mbind1.s: New file.
* testsuite/ld-elf/mbind1a.d: Likewise.
* testsuite/ld-elf/mbind1b.d: Likewise.
* testsuite/ld-elf/mbind1c.d: Likewise.
* testsuite/ld-elf/mbind2a.s: Likewise.
* testsuite/ld-elf/mbind2b.c: Likewise.
2017-04-04 09:05:48 -07:00
|
|
|
|
2017-04-04 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf.c (get_program_header_size): Add a GNU_MBIND segment for
|
|
|
|
|
each GNU_MBIND section and align GNU_MBIND section to page size.
|
|
|
|
|
(_bfd_elf_map_sections_to_segments): Create a GNU_MBIND
|
|
|
|
|
segment for each GNU_MBIND section.
|
|
|
|
|
(_bfd_elf_init_private_section_data): Copy sh_info from input
|
|
|
|
|
for GNU_MBIND section.
|
|
|
|
|
|
2017-04-03 10:08:29 -07:00
|
|
|
|
2017-04-03 Palmer Dabbelt <palmer@dabbelt.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-riscv.c (GP_NAME): Delete.
|
|
|
|
|
(riscv_global_pointer_value): Change GP_NAME to RISCV_GP_SYMBOL.
|
|
|
|
|
(_bfd_riscv_relax_lui): Likewise.
|
|
|
|
|
|
2017-04-04 11:23:36 +01:00
|
|
|
|
2017-04-04 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21342
|
|
|
|
|
* elflink.c (_bfd_elf_define_linkage_sym): Prevent null pointer
|
|
|
|
|
dereference.
|
|
|
|
|
(bfd_elf_final_link): Only initialize the extended symbol index
|
|
|
|
|
section if there are extended symbol tables to list.
|
|
|
|
|
|
2017-04-03 08:03:14 -07:00
|
|
|
|
2017-04-03 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* Makefile.am (BFD32_BACKENDS): Add elf-properties.lo.
|
|
|
|
|
(BFD32_BACKENDS_CFILES): Add elf-properties.c.
|
|
|
|
|
* configure.ac (elf): Add elf-properties.lo.
|
|
|
|
|
* Makefile.in: Regenerated.
|
|
|
|
|
* configure: Likewise.
|
|
|
|
|
* elf-bfd.h (elf_property_kind): New.
|
|
|
|
|
(elf_property): Likewise.
|
|
|
|
|
(elf_property_list): Likewise.
|
|
|
|
|
(elf_properties): Likewise.
|
|
|
|
|
(_bfd_elf_parse_gnu_properties): Likewise.
|
|
|
|
|
(_bfd_elf_get_property): Likewise.
|
|
|
|
|
(_bfd_elf_link_setup_gnu_properties): Likewise.
|
|
|
|
|
(elf_backend_data): Add parse_gnu_properties, merge_gnu_properties
|
|
|
|
|
and setup_gnu_properties.
|
|
|
|
|
(elf_obj_tdata): Add properties.
|
|
|
|
|
* elf-properties.c: New file.
|
|
|
|
|
* elf32-i386.c (elf_i386_parse_gnu_properties): New.
|
|
|
|
|
(elf_i386_merge_gnu_properties): Likewise.
|
|
|
|
|
(elf_backend_parse_gnu_properties): Likewise.
|
|
|
|
|
(elf_backend_merge_gnu_properties): Likewise.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_parse_gnu_properties): Likewise.
|
|
|
|
|
(elf_x86_64_merge_gnu_properties): Likewise.
|
|
|
|
|
(elf_backend_parse_gnu_properties): Likewise.
|
|
|
|
|
(elf_backend_merge_gnu_properties): Likewise.
|
|
|
|
|
* elfxx-target.h (elf_backend_merge_gnu_properties): Likewise.
|
|
|
|
|
(elf_backend_parse_gnu_properties): Likewise.
|
|
|
|
|
(elf_backend_setup_gnu_properties): Likewise.
|
|
|
|
|
(elfNN_bed): Add elf_backend_parse_gnu_properties,
|
|
|
|
|
elf_backend_merge_gnu_properties and
|
|
|
|
|
elf_backend_setup_gnu_properties.
|
|
|
|
|
|
2017-03-30 10:57:21 +01:00
|
|
|
|
2017-03-30 Pip Cet <pipcet@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-wasm32.c: Add relocation code, two relocs.
|
|
|
|
|
* reloc.c: Add wasm32 relocations.
|
|
|
|
|
* libbfd.h: Regenerate.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* bfd/po/bfd.pot: Regenerate.
|
|
|
|
|
|
2017-03-29 12:27:44 +01:00
|
|
|
|
2017-03-29 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/18025
|
|
|
|
|
* coff-bfd.h (struct coff_section_data): Add new fields:
|
|
|
|
|
saved_bias and bias.
|
|
|
|
|
* coffgen.c (coff_find_nearest_line_with_names): Cache the bias
|
|
|
|
|
computed for PE binaries.
|
|
|
|
|
* dwarf2.c (scan_unit_for_symbols): Only warn once about each
|
|
|
|
|
missing abbrev.
|
|
|
|
|
|
2017-03-28 23:43:09 +02:00
|
|
|
|
2017-03-28 Hans-Peter Nilsson <hp@axis.com>
|
|
|
|
|
|
|
|
|
|
PR ld/16044
|
|
|
|
|
* elf32-cris.c (elf_cris_adjust_gotplt_to_got): Adjust BFD_ASSERT
|
|
|
|
|
to handle a local symbol with a hash-symbol-entry; without PLT.
|
|
|
|
|
Add BFD_ASSERT for an incidental case with GOT entry present.
|
|
|
|
|
(cris_elf_check_relocs): Increment PLT refcount only if the symbol
|
|
|
|
|
isn't forced-or-set local.
|
|
|
|
|
|
2017-03-27 13:41:39 +01:00
|
|
|
|
2017-03-27 Pip Cet <pipcet@gmail.com>
|
|
|
|
|
|
|
|
|
|
* wasm-module.c: New file to support WebAssembly modules.
|
|
|
|
|
* wasm-module.h: New file to support WebAssembly modules.
|
|
|
|
|
* doc/webassembly.texi: Start documenting wasm-module.c.
|
|
|
|
|
* config.bfd: Add wasm_vec.
|
|
|
|
|
* targets.c: Likewise.
|
|
|
|
|
* configure.ac: Likewise.
|
|
|
|
|
* Makefile.am: Add entries for wasm-module.c.
|
|
|
|
|
* Makefile.in: Regenerate.
|
|
|
|
|
* configure: Regenerate.
|
|
|
|
|
* po/SRC-POTFILES.in: Regenerate.
|
|
|
|
|
|
2017-03-27 11:45:24 +01:00
|
|
|
|
2017-03-27 Pip Cet <pipcet@gmail.com>
|
|
|
|
|
|
|
|
|
|
* cpu-wasm32.c: New file to support wasm32 architecture.
|
|
|
|
|
* elf32-wasm32.c: New file to support wasm32 architecture.
|
|
|
|
|
* Makefile.am: Add wasm32 architecture.
|
|
|
|
|
* archures.c: Likewise.
|
|
|
|
|
* config.bfd: Likewise.
|
|
|
|
|
* configure.ac: Likewise.
|
|
|
|
|
* targets.c: Likewise.
|
|
|
|
|
* Makefile.in: Regenerate.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* configure: Regenerate.
|
|
|
|
|
* po/SRC-POTFILES.in: Regenerate.
|
|
|
|
|
|
2017-03-20 08:25:50 +10:30
|
|
|
|
2017-03-20 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21266
|
|
|
|
|
* elf64-ppc.c (compare_symbols): Stabilize sort.
|
|
|
|
|
|
2017-03-17 08:37:15 +10:30
|
|
|
|
2017-03-18 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (struct ppc_link_hash_table): Add
|
|
|
|
|
local_ifunc_resolver and maybe_local_ifunc_resolver.
|
|
|
|
|
(ppc_build_one_stub): Set flags on emitting dynamic
|
|
|
|
|
relocation to ifunc.
|
|
|
|
|
(ppc64_elf_relocate_section): Likewise.
|
|
|
|
|
(ppc64_elf_finish_dynamic_symbol): Likewise.
|
|
|
|
|
(ppc64_elf_finish_dynamic_sections): Error on DT_TEXTREL with
|
|
|
|
|
local dynamic relocs to ifuncs.
|
|
|
|
|
* elf32-ppc.c (struct ppc_elf_link_hash_table): Add
|
|
|
|
|
local_ifunc_resolver and maybe_local_ifunc_resolver.
|
|
|
|
|
(ppc_elf_relocate_section): Set flag on emitting dynamic
|
|
|
|
|
relocation to ifuncs.
|
|
|
|
|
(ppc_elf_finish_dynamic_symbol): Likewise.
|
|
|
|
|
(ppc_elf_finish_dynamic_sections): Error on DT_TEXTREL with local
|
|
|
|
|
dynamic relocs to ifuncs.
|
|
|
|
|
|
2017-03-13 09:58:04 +00:00
|
|
|
|
2017-03-13 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21202
|
|
|
|
|
* reloc.c (BFD_RELOC_AARCH64_TLSDESC_LD64_LO12_NC): Rename to
|
|
|
|
|
BFD_RELOC_AARCH64_TLSDESC_LD64_LO12.
|
|
|
|
|
(BFD_RELOC_AARCH64_TLSDESC_ADD_LO12_NC): Rename to
|
|
|
|
|
BFD_RELOC_AARCH64_TLSDESC_ADD_LO12.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
* libbfd.h: Regenerate.
|
|
|
|
|
* elfnn-aarch64.c (IS_AARCH64_TLS_RELAX_RELOC): Update reloc
|
|
|
|
|
names.
|
|
|
|
|
(IS_AARCH64_TLSDESC_RELOC): Likewise.
|
|
|
|
|
(elfNN_aarch64_howto_table): Likewise.
|
|
|
|
|
(aarch64_tls_transition_without_check): Likewise.
|
|
|
|
|
(aarch64_reloc_got_type): Likewise.
|
|
|
|
|
(elfNN_aarch64_final_link_relocate): Likewise.
|
|
|
|
|
(elfNN_aarch64_tls_relax): Likewise.
|
|
|
|
|
(elfNN_aarch64_relocate_section): Likewise.
|
|
|
|
|
(elfNN_aarch64_gc_sweep_hook): Likewise.
|
|
|
|
|
(elfNN_aarch64_check_relocs): Likewise.
|
|
|
|
|
* elfxx-aarch64.c (_bfd_aarch64_elf_put_addend): Likewise.
|
|
|
|
|
(_bfd_aarch64_elf_resolve_relocation): Likewise.
|
|
|
|
|
|
2017-03-11 20:56:51 +10:30
|
|
|
|
2017-03-11 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-ppc.c: Remove ATTRIBUTE_UNUSED throughout when function
|
|
|
|
|
parameter is in fact used. Whitespace fixes.
|
|
|
|
|
* elf64-ppc.c: Likewise.
|
|
|
|
|
|
2017-03-09 15:58:39 +00:00
|
|
|
|
2017-03-09 Sam Thursfield <sam.thursfield@codethink.co.uk>
|
|
|
|
|
|
|
|
|
|
* rs6000-core.c (CORE_NEW): Simplify macro when
|
|
|
|
|
AIX_CORE_DUMPX_CORE and BFD64 are true to avoid compile warning.
|
|
|
|
|
|
2017-03-07 11:04:19 +10:30
|
|
|
|
2017-03-07 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21224
|
|
|
|
|
PR 20519
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_relocate_section): Add missing
|
|
|
|
|
dyn_relocs check.
|
|
|
|
|
|
2017-03-05 14:49:54 +10:30
|
|
|
|
2017-03-05 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf-bfd.h (struct eh_cie_fde): Add u.cie.per_encoding_aligned8.
|
|
|
|
|
* elf-eh-frame.c (size_of_output_cie_fde): Don't align here.
|
|
|
|
|
(next_cie_fde_offset): New function.
|
|
|
|
|
(_bfd_elf_parse_eh_frame): Set u.cie.per_encoding_aligned8.
|
|
|
|
|
(_bfd_elf_discard_section_eh_frame): Align zero terminator to
|
|
|
|
|
four bytes. Align CIEs to four or eight bytes depending on
|
|
|
|
|
per_encoding_aligned8. Align FDEs according to their encoding.
|
|
|
|
|
Pad last FDE to output section alignment.
|
|
|
|
|
(_bfd_elf_write_section_eh_frame): Adjust to suit. Remove
|
|
|
|
|
assertion.
|
|
|
|
|
* elf64-ppc.c (glink_eh_frame_cie): Delete padding.
|
|
|
|
|
(ppc64_elf_size_stubs): Pad glink eh_frame as per elf-eh-frame.c.
|
|
|
|
|
(ppc64_elf_finish_dynamic_sections): Adjust to suit.
|
|
|
|
|
|
2017-03-02 14:47:29 +00:00
|
|
|
|
2017-03-02 Martin Bickel <binutils@ineranves.de>
|
|
|
|
|
|
|
|
|
|
PR ld/21212
|
|
|
|
|
* elf.c (rewrite_elf_program_header): Do not issue a warning for
|
2017-03-03 10:22:16 +00:00
|
|
|
|
empty segments which have a zero filesz, but a non-zero memsz.
|
2017-03-02 14:47:29 +00:00
|
|
|
|
|
2017-03-02 10:24:14 +10:30
|
|
|
|
2017-03-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-ppc.c (ppc_elf_vle_split16): Correct insn mask typo.
|
|
|
|
|
|
2017-02-28 23:42:29 +10:30
|
|
|
|
2017-02-28 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_ha_reloc): Revert last change.
|
|
|
|
|
(ppc64_elf_relocate_section): Likewise.
|
|
|
|
|
|
2017-02-28 10:38:51 +10:30
|
|
|
|
2017-02-28 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 20995
|
|
|
|
|
* elf32-nios2.c (nios2_elf32_relocate_section): Use htab
|
|
|
|
|
rather than elf32_nios2_hash_table or elf_hash_table.
|
|
|
|
|
(create_got_section): Likewise.
|
|
|
|
|
(nios2_elf32_finish_dynamic_symbol): Likewise.
|
|
|
|
|
(nios2_elf32_adjust_dynamic_symbol): Likewise.
|
|
|
|
|
(nios2_elf32_size_dynamic_sections): Likewise.
|
|
|
|
|
(nios2_elf32_check_relocs): Delete dynobj, sgot, and srelgot
|
|
|
|
|
vars. Use htab equivalents directly instead. Don't create
|
|
|
|
|
all dynamic sections on needing just the GOT. Use a goto
|
|
|
|
|
rather than a fall-through with reloc test. Ensure
|
|
|
|
|
htab->dynobj is set when making dynamic sreloc section.
|
|
|
|
|
(nios2_elf32_finish_dynamic_sections): Delete dynobj, use htab
|
|
|
|
|
equivalent directly instead. Don't segfault on looking for
|
|
|
|
|
.dynamic when dynamic sections have not been created. Don't
|
|
|
|
|
segfault on .got.plt being discarded.
|
|
|
|
|
(nios2_elf32_size_dynamic_sections): Delete plt and got vars.
|
|
|
|
|
Don't set "relocs" on .rela.plt. Do handle .sbss. Delete
|
|
|
|
|
fixme and another not so relevant comment.
|
|
|
|
|
(nios2_elf_add_symbol_hook): Delete dynobj var. If not
|
|
|
|
|
already set, set hash table dynobj on creating .sbss.
|
|
|
|
|
|
2017-02-28 08:32:36 +10:30
|
|
|
|
2017-02-28 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* reloc.c (BFD_RELOC_PPC_16DX_HA): New.
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_howto_raw <R_PPC64_16DX_HA>): New howto.
|
|
|
|
|
(ppc64_elf_reloc_type_lookup): Translate new bfd reloc.
|
|
|
|
|
(ppc64_elf_ha_reloc): Correct overflow test on REL16DX_HA.
|
|
|
|
|
(ppc64_elf_relocate_section): Likewise.
|
|
|
|
|
* elf32-ppc.c (ppc_elf_howto_raw <R_PPC_16DX_HA>): New howto.
|
|
|
|
|
(ppc_elf_reloc_type_lookup): Translate new bfd reloc.
|
|
|
|
|
(ppc_elf_check_relocs): Handle R_PPC_16DX_HA to pacify gcc.
|
|
|
|
|
* libbfd.h: Regenerate.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
|
2017-02-28 08:06:02 +10:30
|
|
|
|
2017-02-28 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (_bfd_elf_create_dynamic_sections): Don't make
|
|
|
|
|
dynamic .data.rel.ro read-only.
|
|
|
|
|
* elf32-arm.c (elf32_arm_finish_dynamic_symbol): Compare section
|
|
|
|
|
rather than section flags when deciding where copy reloc goes.
|
|
|
|
|
* elf32-cris.c (elf_cris_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf32-hppa.c (elf32_hppa_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf32-i386.c (elf_i386_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf32-metag.c (elf_metag_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf32-microblaze.c (microblaze_elf_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf32-nios2.c (nios2_elf32_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf32-or1k.c (or1k_elf_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf32-ppc.c (ppc_elf_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf32-s390.c (elf_s390_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf32-tic6x.c (elf32_tic6x_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf32-tilepro.c (tilepro_elf_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf64-s390.c (elf_s390_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elfnn-aarch64.c (elfNN_aarch64_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elfnn-riscv.c (riscv_elf_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_vxworks_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elfxx-sparc.c (_bfd_sparc_elf_finish_dynamic_symbol): Likewise.
|
|
|
|
|
* elfxx-tilegx.c (tilegx_elf_finish_dynamic_symbol): Likewise.
|
|
|
|
|
|
2017-02-28 00:14:08 +00:00
|
|
|
|
2017-02-28 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_perform_relocation): Also handle the
|
|
|
|
|
`jalr $0, $25' instruction encoding.
|
|
|
|
|
|
2017-02-27 11:33:05 +00:00
|
|
|
|
2017-02-27 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21180
|
|
|
|
|
* elf32-microblaze.c (microblaze_elf_finish_dynamic_symbol): Avoid
|
|
|
|
|
generating a seg-fault when encountering a symbol that has been
|
|
|
|
|
deleted by garbage collection.
|
|
|
|
|
|
2017-02-25 15:44:29 +10:30
|
|
|
|
2017-02-25 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-arc.c (struct dynamic_sections): Delete.
|
|
|
|
|
(enum dyn_section_types): Delete.
|
|
|
|
|
(dyn_section_names): Delete.
|
|
|
|
|
(arc_create_dynamic_sections): Delete.
|
|
|
|
|
(elf_arc_finish_dynamic_sections): Don't call the above. Don't
|
|
|
|
|
segfault on discarded .rela.plt section.
|
|
|
|
|
(elf_arc_size_dynamic_sections): Formatting. Don't call
|
|
|
|
|
arc_create_dynamic_sections. Don't allocate memory for sections
|
|
|
|
|
handled by the generic linker. Correct code finding relocs in
|
|
|
|
|
read-only sections. Set SEC_EXCLUDE on zero size .got,
|
|
|
|
|
.got.plt, and .dynbss sections. Do set .interp for pies.
|
|
|
|
|
|
2017-02-21 21:56:57 -08:00
|
|
|
|
2017-02-24 Andrew Waterman <andrew@sifive.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-riscv.c (GP_NAME): New macro.
|
|
|
|
|
(riscv_global_pointer_value): Use it.
|
|
|
|
|
(_bfd_riscv_relax_lui): If symbol and global pointer are in same
|
|
|
|
|
output section, consider only that section's alignment.
|
|
|
|
|
|
2017-02-23 22:27:50 +00:00
|
|
|
|
2017-02-23 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.h (_bfd_mips_relax_section): Remove prototype.
|
|
|
|
|
* elfxx-mips.c (_bfd_mips_relax_section): Remove function.
|
|
|
|
|
* elf64-mips.c (bfd_elf64_bfd_relax_section): Remove macro.
|
|
|
|
|
* elfn32-mips.c (bfd_elf32_bfd_relax_section): Likewise.
|
|
|
|
|
|
2017-02-23 19:26:53 +00:00
|
|
|
|
2017-02-23 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_calculate_relocation) <R_MIPS_JALR>
|
|
|
|
|
<R_MICROMIPS_JALR>: Discard relocation if `cross_mode_jump_p'
|
|
|
|
|
or misaligned.
|
|
|
|
|
|
2017-02-23 12:20:42 +10:30
|
|
|
|
2017-02-23 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 20744
|
|
|
|
|
* elf32-ppc.c (ppc_elf_howto_raw): Correct dst_mask on all VLE
|
|
|
|
|
16D relocations.
|
|
|
|
|
(ppc_elf_vle_split16): Correct field mask and shift for 16D relocs.
|
|
|
|
|
(ppc_elf_relocate_section): Correct calculation for VLE SDAREL
|
|
|
|
|
relocs.
|
|
|
|
|
|
2017-02-21 01:46:42 +00:00
|
|
|
|
2017-02-22 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20828
|
|
|
|
|
* elflink.c (bfd_elf_size_dynamic_sections): Move symbol version
|
|
|
|
|
processing ahead of the call to `elf_gc_sweep_symbol'.
|
|
|
|
|
|
2017-02-22 17:28:33 +00:00
|
|
|
|
2017-02-22 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21193
|
|
|
|
|
* opncls.c (bfd_create_gnu_debuglink_section): Give the newly
|
|
|
|
|
created section 4-byte alignment.
|
|
|
|
|
|
2017-02-22 08:10:58 +10:30
|
|
|
|
2017-02-22 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_finish_dynamic_sections): Don't segfault
|
|
|
|
|
on .got or .plt output section being discarded by script.
|
|
|
|
|
* elf32-ppc.c (ppc_elf_finish_dynamic_sections): Likewise. Move
|
|
|
|
|
vxworks splt temp.
|
|
|
|
|
|
2017-02-20 17:57:43 +10:30
|
|
|
|
2017-02-21 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-alpha.c (elf64_alpha_size_dynamic_sections): Only emit
|
|
|
|
|
DT_RELA, DT_RELASZ, and DT_RELAENT when DT_RELASZ is non-zero.
|
|
|
|
|
|
2017-02-20 17:20:45 +10:30
|
|
|
|
2017-02-20 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21181
|
|
|
|
|
* elflink.c (bfd_elf_final_link): Make DT_REL/DT_RELA zero
|
|
|
|
|
if DT_RELSZ/DT_RELASZ is zero.
|
|
|
|
|
|
2017-02-17 11:39:20 +00:00
|
|
|
|
2017-02-17 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* compress.c (bfd_get_full_section_contents): Remember to reduce
|
|
|
|
|
compressed size by the sizeof the compression header when
|
|
|
|
|
decompressing the contents.
|
|
|
|
|
|
2017-02-17 01:26:12 +00:00
|
|
|
|
2017-02-17 Pedro Alves <palves@redhat.com>
|
|
|
|
|
|
|
|
|
|
* srec.c (Chunk): Rename to ...
|
|
|
|
|
(_bfd_srec_len): ... this.
|
|
|
|
|
(S3Forced): Rename to ...
|
|
|
|
|
(_bfd_srec_forceS3): ... this.
|
|
|
|
|
* objcopy.c: Adjust all references.
|
|
|
|
|
|
2017-02-17 01:26:12 +00:00
|
|
|
|
2017-02-17 Pedro Alves <palves@redhat.com>
|
|
|
|
|
|
|
|
|
|
* archive.c (bsd_write_armap): Rename to ...
|
|
|
|
|
(_bfd_bsd_write_armap): ... this.
|
|
|
|
|
(coff_write_armap): Rename to ...
|
|
|
|
|
(_bfd_coff_write_armap): ... this.
|
|
|
|
|
* libbfd-in.h (bsd_write_armap): Rename to ...
|
|
|
|
|
(_bfd_bsd_write_armap): ... this.
|
|
|
|
|
(coff_write_armap): Rename to ...
|
|
|
|
|
(_bfd_coff_write_armap): ... this.
|
|
|
|
|
* aout-target.h, aout-tic30.c: Adjust all users.
|
|
|
|
|
* libbfd.h: Regenerate.
|
|
|
|
|
|
2017-02-17 01:26:12 +00:00
|
|
|
|
2017-02-17 Pedro Alves <palves@redhat.com>
|
|
|
|
|
|
|
|
|
|
* bfd-in.h (bfd_read, bfd_write): Adjust to rename.
|
|
|
|
|
(warn_deprecated): Rename to ...
|
|
|
|
|
(_bfd_warn_deprecated): ... this.
|
|
|
|
|
* libbfd.c (warn_deprecated): Rename to ...
|
|
|
|
|
(_bfd_warn_deprecated): ... this.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
|
2017-02-17 01:26:12 +00:00
|
|
|
|
2017-02-17 Pedro Alves <palves@redhat.com>
|
|
|
|
|
|
|
|
|
|
* bfdio.c (real_ftell): Rename to ...
|
|
|
|
|
(_bfd_real_ftell): ... this.
|
|
|
|
|
(real_fseek): Rename to ...
|
|
|
|
|
(_bfd_real_fseek): ... this.
|
|
|
|
|
(real_fopen): Rename to ...
|
|
|
|
|
(_bfd_real_fopen): ... this.
|
|
|
|
|
* libbfd-in.h (real_ftell): Rename to ...
|
|
|
|
|
(_bfd_real_ftell): ... this.
|
|
|
|
|
(real_fseek): Rename to ...
|
|
|
|
|
(_bfd_real_fseek): ... this.
|
|
|
|
|
(real_fopen): Rename to ...
|
|
|
|
|
(_bfd_real_fopen): ... this.
|
|
|
|
|
* cache.c, dwarf2.c, opncls.c: Adjust all callers.
|
|
|
|
|
* libbfd.h: Regenerate.
|
|
|
|
|
|
2017-02-17 01:26:11 +00:00
|
|
|
|
2017-02-17 Pedro Alves <palves@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf2.c, elf-attrs.c, elf32-nds32.c: Adjust all callers.
|
|
|
|
|
* libbfd.c (read_unsigned_leb128): Rename to ...
|
|
|
|
|
(_bfd_read_unsigned_leb128): ... this.
|
|
|
|
|
(read_signed_leb128): Rename to ...
|
|
|
|
|
(_bfd_read_signed_leb128): ... this.
|
|
|
|
|
(safe_read_leb128): Rename to ...
|
|
|
|
|
(_bfd_safe_read_leb128): ... this.
|
|
|
|
|
* libbfd-in.h (read_unsigned_leb128): Rename to ...
|
|
|
|
|
(_bfd_read_unsigned_leb128): ... this.
|
|
|
|
|
(read_signed_leb128): Rename to ...
|
|
|
|
|
(_bfd_read_signed_leb128): ... this.
|
|
|
|
|
(safe_read_leb128): Rename to ...
|
|
|
|
|
(_bfd_safe_read_leb128): ... this.
|
|
|
|
|
* libbfd.h: Renegerate.
|
|
|
|
|
|
2016-12-19 15:27:59 +00:00
|
|
|
|
2017-02-16 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
|
|
|
|
|
|
* dwarf2.c (_bfd_dwarf2_find_nearest_line): Perform symbol lookup
|
|
|
|
|
before trying to fine matching file and line information.
|
|
|
|
|
|
bfd/dwarf: Improve use of previously loaded dwarf information
When parsing DWARF data in order to report file/line type error messages
we perform section placement to make section addresses unique within
relocatable object files.
Currently, if we reuse previously loaded (and cached) dwarf data then we
neglect to perform section placement, the result is that the section
addresses will not be unique, and we might, incorrectly associate an
address with the wrong debug information, and so report an incorrect
file and line number.
Further we neglect to check that that bfd for which we are looking up
debug information is actually the bfd for which the previous debug
information was loaded, it is possible that we will reuse previously
loaded debug information for a different bfd.
And finally, due to following of gnu_debuglink links in one bfd to
another, the process of checking that the cached debug information is
valid requires us to track the original bfd in the cached debug
information. The original debug information here is either the bfd that
we're interested in, not the bfd we finally load the debug information
from.
bfd/ChangeLog:
* dwarf2.c (struct dwarf2_debug): Add orig_bfd member.
(_bfd_dwarf2_slurp_debug_info): If stashed debug information does
not match current bfd, then reload debug information. Record bfd
we're loading debug info for in the stash. If we have debug
informatin in the cache then perform section placement before
returning.
ld/ChangeLog:
* testsuite/ld-elf/dwarf.exp (build_tests): Add new tests.
* testsuite/ld-elf/dwarf2.err: New file.
* testsuite/ld-elf/dwarf2a.c: New file.
* testsuite/ld-elf/dwarf2b.c: New file.
* testsuite/ld-elf/dwarf3.c: New file.
* testsuite/ld-elf/dwarf3.err: New file.
2016-12-15 15:22:49 +00:00
|
|
|
|
2017-02-16 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
|
|
|
|
|
|
* dwarf2.c (struct dwarf2_debug): Add orig_bfd member.
|
|
|
|
|
(_bfd_dwarf2_slurp_debug_info): If stashed debug information does
|
|
|
|
|
not match current bfd, then reload debug information. Record bfd
|
|
|
|
|
we're loading debug info for in the stash. If we have debug
|
|
|
|
|
informatin in the cache then perform section placement before
|
|
|
|
|
returning.
|
|
|
|
|
|
2017-02-14 10:45:51 +10:30
|
|
|
|
2017-02-16 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21000
|
|
|
|
|
* elf-bfd.h (struct elf_backend_data): Add no_page_alias.
|
|
|
|
|
* elfxx-target.h (elf_backend_no_page_alias): Define.
|
|
|
|
|
(elfNN_bed): Init new field.
|
|
|
|
|
* elf.c (assign_file_positions_for_load_sections): If no_page_alias
|
|
|
|
|
ensure PT_LOAD segment starts on a new page.
|
|
|
|
|
* elf32-hppa.c (elf_backend_no_page_alias): Define.
|
|
|
|
|
|
2017-02-16 12:23:12 +10:30
|
|
|
|
2017-02-16 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21132
|
|
|
|
|
* elf32-hppa.c (allocate_plt_static): Allocate space for relocs
|
|
|
|
|
if pic.
|
|
|
|
|
|
2017-02-16 09:40:03 +00:00
|
|
|
|
2017-02-16 Jiong Wang <jiong.wang@arm.com>
|
|
|
|
|
|
|
|
|
|
* bfd.c (BFD_FLAGS_SAVED): Add BFD_LINKER_CREATED.
|
|
|
|
|
* bfd-in2.h: Regenerated.
|
|
|
|
|
|
2017-02-15 11:39:30 -08:00
|
|
|
|
2017-02-15 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21168
|
|
|
|
|
* elf32-i386.c (elf_i386_relocate_section): Allow
|
|
|
|
|
"lea foo@GOT, %reg" in PIC.
|
|
|
|
|
|
2017-02-15 10:55:51 -08:00
|
|
|
|
2017-02-15 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20244
|
|
|
|
|
* elf32-i386.c (elf_i386_relocate_section): Properly get IFUNC
|
|
|
|
|
symbol name when reporting R_386_GOT32/R_386_GOT32X relocation
|
|
|
|
|
error against local IFUNC symbol without a base register for
|
|
|
|
|
PIC.
|
|
|
|
|
|
2017-02-07 02:07:21 +00:00
|
|
|
|
2017-02-15 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elf32-ppc.c (ppc_elf_check_relocs): Use `%H:' rather than
|
|
|
|
|
`%P: %H:' with `info->callbacks->einfo'.
|
|
|
|
|
(ppc_elf_relocate_section): Likewise.
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_check_relocs): Likewise.
|
|
|
|
|
(ppc64_elf_edit_toc): Likewise.
|
|
|
|
|
(ppc64_elf_relocate_section): Likewise.
|
|
|
|
|
|
2017-02-14 15:59:13 +10:30
|
|
|
|
2017-02-14 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_gc_mark_dynamic_ref): Support
|
|
|
|
|
--gc-keep-exported, and test versioned field of sym rather than
|
|
|
|
|
looking for @ in name.
|
|
|
|
|
|
2017-02-08 11:26:07 -08:00
|
|
|
|
2017-02-13 Palmer Dabbelt <palmer@dabbelt.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-riscv.c (riscv_global_pointer_value): Change _gp to
|
|
|
|
|
__global_pointer$.
|
|
|
|
|
|
2017-02-13 17:51:27 +00:00
|
|
|
|
2017-02-13 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21151
|
|
|
|
|
* dwarf2.c (_bfd_dwarf2_find_nearest_line): Check for an invalid
|
|
|
|
|
unit length field.
|
|
|
|
|
|
2017-01-23 12:58:30 -08:00
|
|
|
|
2017-02-07 Andrew Waterman <andrew@sifive.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-riscv.c (riscv_elf_finish_dynamic_sections): Only write PLT
|
|
|
|
|
entry size if PLT header is written.
|
|
|
|
|
|
2017-02-07 06:05:59 -08:00
|
|
|
|
2017-02-06 Sheldon Lobo <sheldon.lobo@oracle.com>
|
|
|
|
|
|
|
|
|
|
Fix sparc64 dynamic relocation processing to use the dynamic
|
|
|
|
|
symbol count.
|
|
|
|
|
* elf64-sparc.c (elf64_sparc_slurp_one_reloc_table): Use 'dynamic'
|
|
|
|
|
to determine if bfd_get_symcount() or bfd_get_dynamic_symcount()
|
|
|
|
|
should be used.
|
|
|
|
|
|
2017-02-03 09:04:21 +00:00
|
|
|
|
2017-02-03 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 21096
|
|
|
|
|
* coffcode.h (coff_write_object_contents): Enlarge size of
|
|
|
|
|
s_name_buf in order to avoid compile time warning about possible
|
|
|
|
|
integer truncation.
|
|
|
|
|
* elf32-nds32.c (nds32_elf_ex9_import_table): Mask off lower
|
|
|
|
|
32-bits of insn value before printing into buffer.
|
|
|
|
|
|
2017-02-02 22:05:46 +00:00
|
|
|
|
2017-02-02 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_hash_sort_data): Add
|
|
|
|
|
`max_local_dynindx'.
|
|
|
|
|
(mips_elf_sort_hash_table): Handle it.
|
|
|
|
|
(mips_elf_sort_hash_table_f) <GGA_NONE>: For forced local
|
|
|
|
|
symbols bump up `max_local_dynindx' rather than
|
|
|
|
|
`max_non_got_dynindx'.
|
|
|
|
|
|
2017-02-02 21:43:26 +00:00
|
|
|
|
2017-02-02 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_hash_sort_data): Convert the
|
|
|
|
|
`min_got_dynindx', `max_unref_got_dynindx' and
|
|
|
|
|
`max_non_got_dynindx' members to the `bfd_size_type' data type.
|
|
|
|
|
(mips_elf_sort_hash_table): Adjust accordingly.
|
|
|
|
|
|
2017-02-02 21:30:27 +00:00
|
|
|
|
2017-02-02 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_sort_hash_table): Use `htab' throughout
|
|
|
|
|
to access the hash table.
|
|
|
|
|
|
2017-02-02 20:53:16 +00:00
|
|
|
|
2017-02-02 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.c (mips_elf_sort_hash_table): Move assertion on
|
|
|
|
|
non-NULL `htab' to the beginning.
|
|
|
|
|
|
2017-02-02 16:44:09 +00:00
|
|
|
|
2017-02-02 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elflink.c (elf_gc_sweep): Wrap overlong line.
|
|
|
|
|
|
2017-01-30 17:11:22 +00:00
|
|
|
|
2017-01-30 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* elfxx-mips.h (_bfd_mips_elf_insn32): Rename prototype to...
|
|
|
|
|
(_bfd_mips_elf_linker_flags): ... this. Add another parameter.
|
|
|
|
|
* elfxx-mips.c (mips_elf_link_hash_table): Add
|
|
|
|
|
`ignore_branch_isa' member.
|
|
|
|
|
(mips_elf_perform_relocation): Do not treat an ISA mode mismatch
|
|
|
|
|
in branch relocation calculation as an error if
|
|
|
|
|
`ignore_branch_isa' has been set.
|
|
|
|
|
(_bfd_mips_elf_insn32): Rename to...
|
|
|
|
|
(_bfd_mips_elf_linker_flags): ... this. Rename the `on'
|
|
|
|
|
parameter to `insn32' and add an `ignore_branch_isa' parameter.
|
|
|
|
|
Handle the new parameter.
|
|
|
|
|
|
2017-01-27 01:50:06 +01:00
|
|
|
|
2017-01-27 Hans-Peter Nilsson <hp@axis.com>
|
|
|
|
|
|
2017-01-27 09:12:14 +01:00
|
|
|
|
* elf32-cris.c (elf_cris_finish_dynamic_symbol): Remove now unused
|
|
|
|
|
local variable dynobj.
|
|
|
|
|
|
2017-01-27 01:50:06 +01:00
|
|
|
|
PR ld/20995
|
|
|
|
|
* elf32-cris.c (elf_cris_size_dynamic_sections): Handle sdynrelro.
|
|
|
|
|
(elf_cris_adjust_dynamic_symbol): Place variables copied into the
|
|
|
|
|
executable from read-only sections into sdynrelro.
|
|
|
|
|
(elf_cris_finish_dynamic_symbol): Select sreldynrelro for
|
|
|
|
|
dynamic relocs in sdynrelro.
|
|
|
|
|
(elf_backend_want_dynrelro): Define.
|
|
|
|
|
|
2017-01-25 17:56:46 +10:30
|
|
|
|
2017-01-25 Sebastian Huber <sebastian.huber@embedded-brains.de>
|
|
|
|
|
|
|
|
|
|
* config.bfd (*-*-rtemsaout*): Mark as removed.
|
|
|
|
|
|
2017-01-25 17:55:57 +10:30
|
|
|
|
2017-01-25 Sebastian Huber <sebastian.huber@embedded-brains.de>
|
|
|
|
|
|
|
|
|
|
* config.bfd (powerpcle-*-rtems*): Do not mark as removed.
|
|
|
|
|
(arm-*-rtems*): Move to (arm*-*-eabi*).
|
|
|
|
|
(i[3-7]86-*-rtems*): Move to (i[3-7]86-*-elf*).
|
|
|
|
|
(m68-*-rtems*): Move to (m68*-*-elf*).
|
|
|
|
|
|
2017-01-25 17:52:27 +10:30
|
|
|
|
2017-01-25 Sebastian Huber <sebastian.huber@embedded-brains.de>
|
|
|
|
|
|
|
|
|
|
* config.bfd (*-*-rtemscoff*): Mark as removed.
|
|
|
|
|
|
2017-01-23 11:38:20 +00:00
|
|
|
|
2017-01-24 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20828
|
|
|
|
|
* elflink.c (bfd_elf_record_link_assignment): Revert last
|
|
|
|
|
change and don't ever clear `forced_local'. Set `mark'
|
|
|
|
|
unconditionally.
|
|
|
|
|
(elf_gc_sweep_symbol_info, elf_gc_sweep_symbol): Reorder within
|
|
|
|
|
file.
|
|
|
|
|
(elf_gc_sweep): Move the call to `elf_gc_sweep_symbol'...
|
|
|
|
|
(bfd_elf_size_dynamic_sections): ... here.
|
|
|
|
|
* elf32-ppc.c (ppc_elf_tls_setup): Don't clear `forced_local'
|
|
|
|
|
and set `mark' instead in `__tls_get_addr_opt' processing.
|
|
|
|
|
* elf64-ppc.c (ppc64_elf_tls_setup): Likewise.
|
|
|
|
|
|
2017-01-24 08:43:01 +10:30
|
|
|
|
2017-01-24 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-ppc.c (ppc_elf_adjust_dynamic_symbol): Merge two cases
|
|
|
|
|
where dynamic relocs are preferable. Allow ifunc too.
|
|
|
|
|
(ensure_undefweak_dynamic): New function.
|
|
|
|
|
(allocate_dynrelocs): Use it here. Move plt handling last and
|
|
|
|
|
don't make symbols dynamic, simplifying loop. Only make undef
|
|
|
|
|
weak symbols with GOT entries dynamic. Correct condition
|
|
|
|
|
for GOT relocs. Handle dynamic relocs on ifuncs. Correct
|
|
|
|
|
comments. Remove goto.
|
|
|
|
|
(ppc_elf_relocate_section): Correct test for using dynamic
|
|
|
|
|
symbol on GOT relocs. Rearrange test for emitting GOT relocs
|
|
|
|
|
to suit. Set up explicit tls_index entries and implicit GOT
|
|
|
|
|
tls_index entries resolvable at link time for
|
|
|
|
|
__tls_get_addr_opt. Simplify test to clear mem for prelink.
|
|
|
|
|
* elf64-ppc.c (allocate_got): Correct condition for GOT relocs.
|
|
|
|
|
(ensure_undefweak_dynamic): New function.
|
|
|
|
|
(allocate_dynrelocs): Use it here. Only make undef weak symbols
|
|
|
|
|
with GOT entries dynamic. Remove unnecessary test of
|
|
|
|
|
WILL_CALL_FINISH_DYNAMIC_SYMBOL in PLT handling.
|
|
|
|
|
(ppc64_elf_relocate_section): Correct test for using dynamic
|
|
|
|
|
symbol on GOT relocs. Rearrange test for emitting GOT relocs
|
|
|
|
|
to suit. Set up explicit tls_index entries and implicit GOT
|
|
|
|
|
tls_index entries resolvable at link time for __tls_get_addr_opt.
|
|
|
|
|
Simplify expression to clear mem for prelink.
|
|
|
|
|
|
2017-01-23 17:07:13 +00:00
|
|
|
|
2017-01-23 Yury Norov <ynorov@caviumnetworks.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-aarch64.c: Fix relaxations for ILP32 mode.
|
|
|
|
|
|
2017-01-20 13:30:32 +00:00
|
|
|
|
2017-01-20 Jiong Wang <jiong.wang@arm.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-aarch64.c (elf_aarch64_hash_symbol): New function.
|
|
|
|
|
(elf_backend_hash_symbol): Define.
|
|
|
|
|
|
PR ld/20828: Fix linker script symbols wrongly forced local with section GC
Fix a generic ELF linker regression introduced with a chain of changes
made to unused input section garbage collection:
- commit 1a766c6843ce ("Also hide symbols without PLT nor GOT
references."),
<https://sourceware.org/ml/binutils/2011-09/msg00076.html>,
- commit 1d5316ab67e1 ("PR ld/13177: garbage collector retains zombie
references to external libraries"),
<https://sourceware.org/ml/binutils/2011-10/msg00161.html>,
- commit 6673f753c019 ("Fix PR 12772, garbage collection of dynamic
syms"), <https://sourceware.org/ml/binutils/2011-12/msg00077.html>,
causing the garbage collection of unused symbols present in a DSO
involved in a link to make identically named symbols ordinarily defined
(i.e. not hidden or PROVIDEd) by a linker script local, even though the
latter symbols are supposed to be global as if no DSO defined them as
well.
This is because linker script assignments are processed very late as
`lang_process' proceeds, down in the call to `ldemul_before_allocation',
which is made after the call to `lang_gc_sections' to do input section
garbage collecting. Consequently if unused, then any such DSO-defined
symbol has already been garbage-collected and internally marked local.
It would ordinarily be removed from dynamic symbol table output, however
a linker script assignment correctly replaces its original definition
with the new one and enters it into the dynamic symbol table produced as
it is supposed to be exported. The original local marking is however
retained making the symbol local in the dynamic symbol table and
therefore not available externally. This also causes a sorting problem
with the MIPS target, which does not expect non-section local dynamic
symbols to be output and produces an invalid binary.
Fix the problem then, by removing the `forced_local' marking for the
offending case and add suitable test cases. First to verify that unused
symbols ordinarily defined with linker script assignments remain
exported in the context of input section garbage collection whether or
not a DSO defining identically named symbols is present in the link.
Second that a linker version script still correctly retains or removes
such symbols as requested.
bfd/
PR ld/20828
* elflink.c (bfd_elf_record_link_assignment): Clear any
`forced_local' marking for DSO symbols that are not being
provided.
ld/
PR ld/20828
* testsuite/ld-elf/pr20828-1.sd: New test.
* testsuite/ld-elf/pr20828-2a.sd: New test.
* testsuite/ld-elf/pr20828-2b.sd: New test.
* testsuite/ld-elf/pr20828.ld: New test linker script.
* testsuite/ld-elf/pr20828.ver: New test version script.
* testsuite/ld-elf/pr20828.s: New test source.
* testsuite/ld-elf/shared.exp: Run the new test.
2017-01-16 22:10:57 +00:00
|
|
|
|
2017-01-18 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20828
|
|
|
|
|
* elflink.c (bfd_elf_record_link_assignment): Clear any
|
|
|
|
|
`forced_local' marking for DSO symbols that are not being
|
|
|
|
|
provided.
|
|
|
|
|
|
2017-01-17 09:46:28 +08:00
|
|
|
|
2017-01-17 Kuan-Lin Chen <kuanlinchentw@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-riscv.c (riscv_elf_object_p): New function.
|
|
|
|
|
|
2017-01-12 10:30:56 -08:00
|
|
|
|
2017-01-12 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21038
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_link_hash_table): Add
|
|
|
|
|
plt_bnd_eh_frame.
|
|
|
|
|
(elf_x86_64_check_relocs): Create .eh_frame section for the
|
|
|
|
|
.plt.bnd section.
|
|
|
|
|
(elf_x86_64_size_dynamic_sections): Allocate and initialize
|
|
|
|
|
.eh_frame section for the .plt.bnd section.
|
|
|
|
|
(elf_x86_64_finish_dynamic_sections): Adjust .eh_frame section
|
|
|
|
|
for the .plt.bnd section.
|
|
|
|
|
|
2017-01-12 16:56:54 +00:00
|
|
|
|
2017-01-12 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/20876
|
|
|
|
|
* opncls.c (find_separate_debug_file): Add include_dirs
|
|
|
|
|
parameter. Only include the directory part of the bfd's filename
|
|
|
|
|
in search paths if include_dirs is true. Add a couple of extra
|
|
|
|
|
locations for looking for debug files.
|
|
|
|
|
( bfd_follow_gnu_debuglink): Update invocation of
|
|
|
|
|
find_separate_debug_file.
|
|
|
|
|
(bfd_follow_gnu_debugaltlink): Likewise.
|
|
|
|
|
(get_build_id): New function: Finds the build-id of the given bfd.
|
|
|
|
|
(get_build_id_name): New function: Computes the name of the
|
|
|
|
|
separate debug info file for a bfd, based upon its build-id.
|
|
|
|
|
(check_build_id_file): New function: Checks to see if a separate
|
|
|
|
|
debug info file exists at the given location, and that its
|
|
|
|
|
build-id matches that of the original bfd.
|
|
|
|
|
(bfd_follow_build_id_debuglink): New function: Finds a separate
|
|
|
|
|
debug info file for a given bfd by using the build-id method.
|
|
|
|
|
* dwarf2.c (_bfd_dwarf2_slurp_debug_info): Try using the build-id
|
|
|
|
|
method of locating a separate debug info file before using the
|
|
|
|
|
debuglink method.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
|
2017-01-11 09:16:44 -08:00
|
|
|
|
2017-01-11 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21038
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_eh_frame_bnd_plt): New.
|
|
|
|
|
(elf_x86_64_bnd_arch_bed): Use elf_x86_64_eh_frame_bnd_plt and
|
|
|
|
|
elf_x86_64_eh_frame_plt_got.
|
|
|
|
|
(elf_x86_64_size_dynamic_sections): Get unwind info from
|
|
|
|
|
elf_x86_64_bnd_arch_bed for the BND PLT.
|
|
|
|
|
|
2017-01-11 15:05:53 +00:00
|
|
|
|
2017-01-11 Jeremy Soller <jackpot51@gmail.com>
|
|
|
|
|
|
|
|
|
|
* config.bfd: Add entries for i686-redox and x86_64-redox.
|
|
|
|
|
|
2017-01-10 14:18:11 -08:00
|
|
|
|
2017-01-10 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_check_relocs): Align .eh_frame section
|
|
|
|
|
to 4 bytes.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Align
|
|
|
|
|
.eh_frame section to 4 bytes for x32.
|
|
|
|
|
(elf_x86_64_check_relocs): Likewise.
|
|
|
|
|
|
2017-01-10 13:31:59 -08:00
|
|
|
|
2017-01-10 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20830
|
|
|
|
|
* elf32-i386.c (elf_i386_eh_frame_plt_got): New.
|
|
|
|
|
(PLT_GOT_FDE_LENGTH): Likewise.
|
|
|
|
|
(elf_i386_plt_layout): Add eh_frame_plt_got and
|
|
|
|
|
eh_frame_plt_got_size.
|
|
|
|
|
(elf_i386_plt): Updated.
|
|
|
|
|
(elf_i386_link_hash_table): Add plt_got_eh_frame.
|
|
|
|
|
(elf_i386_check_relocs): Create .eh_frame section for .plt.got.
|
|
|
|
|
(elf_i386_size_dynamic_sections): Allocate and initialize
|
|
|
|
|
.eh_frame section for .plt.got.
|
|
|
|
|
(elf_i386_finish_dynamic_sections): Adjust .eh_frame section for
|
|
|
|
|
.plt.got.
|
|
|
|
|
(elf_i386_nacl_plt): Add FIXME for eh_frame_plt_got and
|
|
|
|
|
eh_frame_plt_got_size.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_eh_frame_plt_got): New.
|
|
|
|
|
(PLT_GOT_FDE_LENGTH): Likewise.
|
|
|
|
|
(elf_x86_64_backend_data): Add eh_frame_plt_got and
|
|
|
|
|
eh_frame_plt_got_size.
|
|
|
|
|
(elf_x86_64_arch_bed): Updated.
|
|
|
|
|
(elf_x86_64_bnd_arch_bed): Add FIXME for eh_frame_plt_got and
|
|
|
|
|
eh_frame_plt_got_size.
|
|
|
|
|
(elf_x86_64_nacl_arch_bed): Likewise.
|
|
|
|
|
(elf_x86_64_link_hash_table): Add plt_got_eh_frame.
|
|
|
|
|
(elf_x86_64_check_relocs): Create .eh_frame section for .plt.got.
|
|
|
|
|
(elf_x86_64_size_dynamic_sections): Allocate and initialize
|
|
|
|
|
.eh_frame section for .plt.got.
|
|
|
|
|
(elf_x86_64_finish_dynamic_sections): Adjust .eh_frame section
|
|
|
|
|
for .plt.got.
|
|
|
|
|
|
2017-01-10 11:30:25 -08:00
|
|
|
|
2017-01-10 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_size_dynamic_sections): Set
|
|
|
|
|
plt_eh_frame->size to eh_frame_plt_size and use eh_frame_plt.
|
|
|
|
|
|
2017-01-09 16:49:48 +00:00
|
|
|
|
2017-01-09 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf2.c (lookup_address_in_function_table): Return early if
|
|
|
|
|
there are no functions in the given comp unit, or if the high
|
|
|
|
|
address of the last function in the comp unit is less than the
|
|
|
|
|
desired address.
|
|
|
|
|
|
2017-01-09 09:27:46 +00:00
|
|
|
|
2017-01-09 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21013
|
|
|
|
|
* coffgen.c (_bfd_coff_get_external_symbols): Generate an error
|
|
|
|
|
message if there are too many symbols to load.
|
|
|
|
|
|
2017-01-03 16:15:15 +00:00
|
|
|
|
2017-01-04 James Clarke <jrtc27@jrtc27.com>
|
|
|
|
|
|
|
|
|
|
* elf64-alpha.c (elf64_alpha_relax_opt_call): Don't set tsec_free
|
|
|
|
|
if relocs are cached.
|
|
|
|
|
|
2017-01-03 16:18:41 +00:00
|
|
|
|
2017-01-03 Rich Felker <bugdal@aerifal.cx>
|
|
|
|
|
|
|
|
|
|
PR ld/21017
|
|
|
|
|
* elf32-microblaze.c (microblaze_elf_check_relocs): Add an entry
|
|
|
|
|
for R_MICROBLAZE_GOTOFF_64.
|
|
|
|
|
|
2017-01-03 15:26:27 +00:00
|
|
|
|
2017-01-03 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* mach-o.c (bfd_mach_o_lookup_uuid_command): Fix compile time
|
|
|
|
|
warning about using a possibly uninitialised variable.
|
|
|
|
|
|
2017-01-02 22:31:27 +10:30
|
|
|
|
2017-01-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-hppa.c (ensure_undef_weak_dynamic): New function.
|
|
|
|
|
(allocate_plt_static, allocate_dynrelocs): Use it.
|
|
|
|
|
|
2017-01-02 22:28:29 +10:30
|
|
|
|
2017-01-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf-hppa.h (elf_hppa_fake_sections): Set SHF_INFO_LINK for
|
|
|
|
|
.PARISC.unwind section.
|
|
|
|
|
|
2017-01-02 22:06:28 +10:30
|
|
|
|
2017-01-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20989
|
|
|
|
|
* elfxx-sparc.c (gdop_relative_offset_ok): New function.
|
|
|
|
|
(_bfd_sparc_elf_relocate_section): Use it to validate GOT
|
|
|
|
|
indirect to GOT pointer relative code edit.
|
|
|
|
|
|
2017-01-02 14:06:43 +10:30
|
|
|
|
2017-01-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
Update year range in copyright notice of all files.
|
|
|
|
|
|
2017-01-02 13:55:05 +10:30
|
|
|
|
For older changes see ChangeLog-2016
|
2016-01-01 21:14:31 +10:30
|
|
|
|
|
2017-01-02 13:55:05 +10:30
|
|
|
|
Copyright (C) 2017 Free Software Foundation, Inc.
|
2016-01-01 21:14:31 +10:30
|
|
|
|
|
|
|
|
|
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:
|