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