PR ld/20828: Fix linker script symbols wrongly forced local with section GC
Fix a generic ELF linker regression introduced with a chain of changes
made to unused input section garbage collection:
- commit 1a766c6843ce ("Also hide symbols without PLT nor GOT
references."),
<https://sourceware.org/ml/binutils/2011-09/msg00076.html>,
- commit 1d5316ab67e1 ("PR ld/13177: garbage collector retains zombie
references to external libraries"),
<https://sourceware.org/ml/binutils/2011-10/msg00161.html>,
- commit 6673f753c019 ("Fix PR 12772, garbage collection of dynamic
syms"), <https://sourceware.org/ml/binutils/2011-12/msg00077.html>,
causing the garbage collection of unused symbols present in a DSO
involved in a link to make identically named symbols ordinarily defined
(i.e. not hidden or PROVIDEd) by a linker script local, even though the
latter symbols are supposed to be global as if no DSO defined them as
well.
This is because linker script assignments are processed very late as
`lang_process' proceeds, down in the call to `ldemul_before_allocation',
which is made after the call to `lang_gc_sections' to do input section
garbage collecting. Consequently if unused, then any such DSO-defined
symbol has already been garbage-collected and internally marked local.
It would ordinarily be removed from dynamic symbol table output, however
a linker script assignment correctly replaces its original definition
with the new one and enters it into the dynamic symbol table produced as
it is supposed to be exported. The original local marking is however
retained making the symbol local in the dynamic symbol table and
therefore not available externally. This also causes a sorting problem
with the MIPS target, which does not expect non-section local dynamic
symbols to be output and produces an invalid binary.
Fix the problem then, by removing the `forced_local' marking for the
offending case and add suitable test cases. First to verify that unused
symbols ordinarily defined with linker script assignments remain
exported in the context of input section garbage collection whether or
not a DSO defining identically named symbols is present in the link.
Second that a linker version script still correctly retains or removes
such symbols as requested.
bfd/
PR ld/20828
* elflink.c (bfd_elf_record_link_assignment): Clear any
`forced_local' marking for DSO symbols that are not being
provided.
ld/
PR ld/20828
* testsuite/ld-elf/pr20828-1.sd: New test.
* testsuite/ld-elf/pr20828-2a.sd: New test.
* testsuite/ld-elf/pr20828-2b.sd: New test.
* testsuite/ld-elf/pr20828.ld: New test linker script.
* testsuite/ld-elf/pr20828.ver: New test version script.
* testsuite/ld-elf/pr20828.s: New test source.
* testsuite/ld-elf/shared.exp: Run the new test.
2017-01-16 22:10:57 +00:00
|
|
|
|
2017-01-18 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20828
|
|
|
|
|
* elflink.c (bfd_elf_record_link_assignment): Clear any
|
|
|
|
|
`forced_local' marking for DSO symbols that are not being
|
|
|
|
|
provided.
|
|
|
|
|
|
2017-01-17 09:46:28 +08:00
|
|
|
|
2017-01-17 Kuan-Lin Chen <kuanlinchentw@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elfnn-riscv.c (riscv_elf_object_p): New function.
|
|
|
|
|
|
2017-01-12 10:30:56 -08:00
|
|
|
|
2017-01-12 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21038
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_link_hash_table): Add
|
|
|
|
|
plt_bnd_eh_frame.
|
|
|
|
|
(elf_x86_64_check_relocs): Create .eh_frame section for the
|
|
|
|
|
.plt.bnd section.
|
|
|
|
|
(elf_x86_64_size_dynamic_sections): Allocate and initialize
|
|
|
|
|
.eh_frame section for the .plt.bnd section.
|
|
|
|
|
(elf_x86_64_finish_dynamic_sections): Adjust .eh_frame section
|
|
|
|
|
for the .plt.bnd section.
|
|
|
|
|
|
2017-01-12 16:56:54 +00:00
|
|
|
|
2017-01-12 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/20876
|
|
|
|
|
* opncls.c (find_separate_debug_file): Add include_dirs
|
|
|
|
|
parameter. Only include the directory part of the bfd's filename
|
|
|
|
|
in search paths if include_dirs is true. Add a couple of extra
|
|
|
|
|
locations for looking for debug files.
|
|
|
|
|
( bfd_follow_gnu_debuglink): Update invocation of
|
|
|
|
|
find_separate_debug_file.
|
|
|
|
|
(bfd_follow_gnu_debugaltlink): Likewise.
|
|
|
|
|
(get_build_id): New function: Finds the build-id of the given bfd.
|
|
|
|
|
(get_build_id_name): New function: Computes the name of the
|
|
|
|
|
separate debug info file for a bfd, based upon its build-id.
|
|
|
|
|
(check_build_id_file): New function: Checks to see if a separate
|
|
|
|
|
debug info file exists at the given location, and that its
|
|
|
|
|
build-id matches that of the original bfd.
|
|
|
|
|
(bfd_follow_build_id_debuglink): New function: Finds a separate
|
|
|
|
|
debug info file for a given bfd by using the build-id method.
|
|
|
|
|
* dwarf2.c (_bfd_dwarf2_slurp_debug_info): Try using the build-id
|
|
|
|
|
method of locating a separate debug info file before using the
|
|
|
|
|
debuglink method.
|
|
|
|
|
* bfd-in2.h: Regenerate.
|
|
|
|
|
|
2017-01-11 09:16:44 -08:00
|
|
|
|
2017-01-11 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/21038
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_eh_frame_bnd_plt): New.
|
|
|
|
|
(elf_x86_64_bnd_arch_bed): Use elf_x86_64_eh_frame_bnd_plt and
|
|
|
|
|
elf_x86_64_eh_frame_plt_got.
|
|
|
|
|
(elf_x86_64_size_dynamic_sections): Get unwind info from
|
|
|
|
|
elf_x86_64_bnd_arch_bed for the BND PLT.
|
|
|
|
|
|
2017-01-11 15:05:53 +00:00
|
|
|
|
2017-01-11 Jeremy Soller <jackpot51@gmail.com>
|
|
|
|
|
|
|
|
|
|
* config.bfd: Add entries for i686-redox and x86_64-redox.
|
|
|
|
|
|
2017-01-10 14:18:11 -08:00
|
|
|
|
2017-01-10 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_check_relocs): Align .eh_frame section
|
|
|
|
|
to 4 bytes.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Align
|
|
|
|
|
.eh_frame section to 4 bytes for x32.
|
|
|
|
|
(elf_x86_64_check_relocs): Likewise.
|
|
|
|
|
|
2017-01-10 13:31:59 -08:00
|
|
|
|
2017-01-10 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20830
|
|
|
|
|
* elf32-i386.c (elf_i386_eh_frame_plt_got): New.
|
|
|
|
|
(PLT_GOT_FDE_LENGTH): Likewise.
|
|
|
|
|
(elf_i386_plt_layout): Add eh_frame_plt_got and
|
|
|
|
|
eh_frame_plt_got_size.
|
|
|
|
|
(elf_i386_plt): Updated.
|
|
|
|
|
(elf_i386_link_hash_table): Add plt_got_eh_frame.
|
|
|
|
|
(elf_i386_check_relocs): Create .eh_frame section for .plt.got.
|
|
|
|
|
(elf_i386_size_dynamic_sections): Allocate and initialize
|
|
|
|
|
.eh_frame section for .plt.got.
|
|
|
|
|
(elf_i386_finish_dynamic_sections): Adjust .eh_frame section for
|
|
|
|
|
.plt.got.
|
|
|
|
|
(elf_i386_nacl_plt): Add FIXME for eh_frame_plt_got and
|
|
|
|
|
eh_frame_plt_got_size.
|
|
|
|
|
* elf64-x86-64.c (elf_x86_64_eh_frame_plt_got): New.
|
|
|
|
|
(PLT_GOT_FDE_LENGTH): Likewise.
|
|
|
|
|
(elf_x86_64_backend_data): Add eh_frame_plt_got and
|
|
|
|
|
eh_frame_plt_got_size.
|
|
|
|
|
(elf_x86_64_arch_bed): Updated.
|
|
|
|
|
(elf_x86_64_bnd_arch_bed): Add FIXME for eh_frame_plt_got and
|
|
|
|
|
eh_frame_plt_got_size.
|
|
|
|
|
(elf_x86_64_nacl_arch_bed): Likewise.
|
|
|
|
|
(elf_x86_64_link_hash_table): Add plt_got_eh_frame.
|
|
|
|
|
(elf_x86_64_check_relocs): Create .eh_frame section for .plt.got.
|
|
|
|
|
(elf_x86_64_size_dynamic_sections): Allocate and initialize
|
|
|
|
|
.eh_frame section for .plt.got.
|
|
|
|
|
(elf_x86_64_finish_dynamic_sections): Adjust .eh_frame section
|
|
|
|
|
for .plt.got.
|
|
|
|
|
|
2017-01-10 11:30:25 -08:00
|
|
|
|
2017-01-10 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* elf32-i386.c (elf_i386_size_dynamic_sections): Set
|
|
|
|
|
plt_eh_frame->size to eh_frame_plt_size and use eh_frame_plt.
|
|
|
|
|
|
2017-01-09 16:49:48 +00:00
|
|
|
|
2017-01-09 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf2.c (lookup_address_in_function_table): Return early if
|
|
|
|
|
there are no functions in the given comp unit, or if the high
|
|
|
|
|
address of the last function in the comp unit is less than the
|
|
|
|
|
desired address.
|
|
|
|
|
|
2017-01-09 09:27:46 +00:00
|
|
|
|
2017-01-09 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21013
|
|
|
|
|
* coffgen.c (_bfd_coff_get_external_symbols): Generate an error
|
|
|
|
|
message if there are too many symbols to load.
|
|
|
|
|
|
2017-01-03 16:15:15 +00:00
|
|
|
|
2017-01-04 James Clarke <jrtc27@jrtc27.com>
|
|
|
|
|
|
|
|
|
|
* elf64-alpha.c (elf64_alpha_relax_opt_call): Don't set tsec_free
|
|
|
|
|
if relocs are cached.
|
|
|
|
|
|
2017-01-03 16:18:41 +00:00
|
|
|
|
2017-01-03 Rich Felker <bugdal@aerifal.cx>
|
|
|
|
|
|
|
|
|
|
PR ld/21017
|
|
|
|
|
* elf32-microblaze.c (microblaze_elf_check_relocs): Add an entry
|
|
|
|
|
for R_MICROBLAZE_GOTOFF_64.
|
|
|
|
|
|
2017-01-03 15:26:27 +00:00
|
|
|
|
2017-01-03 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* mach-o.c (bfd_mach_o_lookup_uuid_command): Fix compile time
|
|
|
|
|
warning about using a possibly uninitialised variable.
|
|
|
|
|
|
2017-01-02 22:31:27 +10:30
|
|
|
|
2017-01-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf32-hppa.c (ensure_undef_weak_dynamic): New function.
|
|
|
|
|
(allocate_plt_static, allocate_dynrelocs): Use it.
|
|
|
|
|
|
2017-01-02 22:28:29 +10:30
|
|
|
|
2017-01-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* elf-hppa.h (elf_hppa_fake_sections): Set SHF_INFO_LINK for
|
|
|
|
|
.PARISC.unwind section.
|
|
|
|
|
|
2017-01-02 22:06:28 +10:30
|
|
|
|
2017-01-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR ld/20989
|
|
|
|
|
* elfxx-sparc.c (gdop_relative_offset_ok): New function.
|
|
|
|
|
(_bfd_sparc_elf_relocate_section): Use it to validate GOT
|
|
|
|
|
indirect to GOT pointer relative code edit.
|
|
|
|
|
|
2017-01-02 14:06:43 +10:30
|
|
|
|
2017-01-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
Update year range in copyright notice of all files.
|
|
|
|
|
|
2017-01-02 13:55:05 +10:30
|
|
|
|
For older changes see ChangeLog-2016
|
2016-01-01 21:14:31 +10:30
|
|
|
|
|
2017-01-02 13:55:05 +10:30
|
|
|
|
Copyright (C) 2017 Free Software Foundation, Inc.
|
2016-01-01 21:14:31 +10:30
|
|
|
|
|
|
|
|
|
Copying and distribution of this file, with or without modification,
|
|
|
|
|
are permitted in any medium without royalty provided the copyright
|
|
|
|
|
notice and this notice are preserved.
|
|
|
|
|
|
|
|
|
|
Local Variables:
|
|
|
|
|
mode: change-log
|
|
|
|
|
left-margin: 8
|
|
|
|
|
fill-column: 74
|
|
|
|
|
version-control: never
|
|
|
|
|
End:
|