binutils-gdb/ld
Maciej W. Rozycki 1f599d0e7b 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 15:14:54 +01:00
..
emulparams Add -z noreloc-overflow option to x86-64 ld 2016-03-15 11:07:54 -07:00
emultempl Ignore DWARF debug information with a version of 0 - assume that it is padding. 2016-04-04 12:53:33 +01:00
po Copyright update for binutils 2016-01-01 23:00:01 +10:30
scripttempl Ensure that the .rdata_pseudo_runtime_reloc sections are not discarded by gabage collection. 2016-03-18 11:45:43 +00:00
testsuite ELF/LD: Avoid producing hidden and internal dynamic symbols 2016-04-05 15:14:54 +01:00
.gitignore bfd/binutils/gas/gprof/ld/libiberty/opcodes: add .gitignore 2010-12-09 09:03:18 +00:00
ChangeLog ELF/LD: Avoid producing hidden and internal dynamic symbols 2016-04-05 15:14:54 +01:00
ChangeLog-0001 Add copyright notices 2012-12-10 12:48:03 +00:00
ChangeLog-0203 Add copyright notices 2012-12-10 12:48:03 +00:00
ChangeLog-2004 Add copyright notices 2012-12-10 12:48:03 +00:00
ChangeLog-2005 Add copyright notices 2012-12-10 12:48:03 +00:00
ChangeLog-2006 Add copyright notices 2012-12-10 12:48:03 +00:00
ChangeLog-2007 Add copyright notices 2012-12-10 12:48:03 +00:00
ChangeLog-2008 strip off +x bits on non-executable/script files 2013-12-07 02:03:03 -05:00
ChangeLog-2009 Remove trailing spaces in ld 2015-08-12 04:46:43 -07:00
ChangeLog-2010 Add copyright notices 2012-12-10 12:48:03 +00:00
ChangeLog-2011 Add copyright notices 2012-12-10 12:48:03 +00:00
ChangeLog-2012 Rotate binutils ChangeLog for 2013 2013-01-02 17:06:32 +00:00
ChangeLog-2013 New Year - binutils ChangeLog rotation 2014-01-08 05:32:12 -08:00
ChangeLog-2014 ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
ChangeLog-2015 binutils ChangeLog rotation 2016-01-01 22:59:17 +10:30
ChangeLog-9197 Remove trailing spaces in ld 2015-08-12 04:46:43 -07:00
ChangeLog-9899 Add copyright notices 2012-12-10 12:48:03 +00:00
MAINTAINERS Copyright update for binutils 2016-01-01 23:00:01 +10:30
Makefile.am Add -z noreloc-overflow option to x86-64 ld 2016-03-15 11:07:54 -07:00
Makefile.in Add -z noreloc-overflow option to x86-64 ld 2016-03-15 11:07:54 -07:00
NEWS Add -z noreloc-overflow option to x86-64 ld 2016-03-15 11:07:54 -07:00
README Copyright update for binutils 2016-01-01 23:00:01 +10:30
TODO 19990502 sourceware import 1999-05-03 07:29:11 +00:00
aclocal.m4 * configure.in (AC_CHECK_FUNCS): Add setlocale. 2012-04-05 08:43:41 +00:00
config.in Reset x86 Linux targets to not compressing debug sections by default. Enable compression of debug sections by default in the linker, if so configured. 2015-10-21 13:15:39 +01:00
configure enable -Wwrite-strings for gas 2016-03-31 07:30:56 -04:00
configure.ac Replace == with = in ld/configure.ac 2016-01-29 07:49:18 -08:00
configure.host Copyright update for binutils 2016-01-01 23:00:01 +10:30
configure.tgt Add aarch64-*-rtems* target 2016-02-26 14:07:27 -06:00
deffile.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
deffilep.y Copyright update for binutils 2016-01-01 23:00:01 +10:30
dep-in.sed * dep-in.sed: Don't use \n in replacement part of s command. 2009-06-04 06:57:56 +00:00
elf-hints-local.h Remove trailing white spaces in ld 2013-01-10 20:08:03 +00:00
fdl.texi etc/ChangeLog 2010-06-08 10:30:56 +00:00
gen-doc.texi Copyright update for binutils 2016-01-01 23:00:01 +10:30
genscrba.sh ld: 2008-01-11 09:11:18 +00:00
genscripts.sh Copyright update for binutils 2016-01-01 23:00:01 +10:30
h8-doc.texi Copyright update for binutils 2016-01-01 23:00:01 +10:30
ld.h Remove unused field from ld_config_type structure. 2016-02-25 10:33:29 +00:00
ld.texinfo Add -z noreloc-overflow option to x86-64 ld 2016-03-15 11:07:54 -07:00
ldbuildid.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldbuildid.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldcref.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldctor.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldctor.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldemul.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldemul.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldexp.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldexp.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldfile.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldfile.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldgram.y Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldint.texinfo Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldlang.c More cases of missing TO_ADDR in ldlang.c 2016-03-31 19:35:33 +10:30
ldlang.h Improve COFF/PE linker garbage collection by preventing the removal of sections containing exported symbols. 2016-03-22 12:25:08 +00:00
ldlex-wrapper.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldlex.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldlex.l Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldmain.c [x86] Resolve non-PIC undefweak symbols in executable 2016-02-26 04:55:57 -08:00
ldmain.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldmisc.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldmisc.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldver.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldver.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldwrite.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
ldwrite.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
lexsup.c Properly implement STT_COMMON 2016-02-26 05:01:34 -08:00
mri.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
mri.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
pe-dll.c Ignore DWARF debug information with a version of 0 - assume that it is padding. 2016-04-04 12:53:33 +01:00
pe-dll.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
pep-dll.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
pep-dll.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
plugin.c Remove use of alloca. 2016-03-21 16:31:46 +00:00
plugin.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
stamp-h.in 19990502 sourceware import 1999-05-03 07:29:11 +00:00
sysdep.h Copyright update for binutils 2016-01-01 23:00:01 +10:30
testplug.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
testplug2.c Copyright update for binutils 2016-01-01 23:00:01 +10:30
testplug3.c Copyright update for binutils 2016-01-01 23:00:01 +10:30

README

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

		README for LD

This is the GNU linker.  It is distributed with other "binary
utilities" which should be in ../binutils.  See ../binutils/README for
more general notes, including where to send bug reports.

There are many features of the linker:

* The linker uses a Binary File Descriptor library (../bfd)
  that it uses to read and write object files.  This helps
  insulate the linker itself from the format of object files.

* The linker supports a number of different object file
  formats.  It can even handle multiple formats at once:
  Read two input formats and write a third.

* The linker can be configured for cross-linking.

* The linker supports a control language.

* There is a user manual (ld.texinfo), as well as the
  beginnings of an internals manual (ldint.texinfo).

Installation
============

See ../binutils/README.

If you want to make a cross-linker, you may want to specify
a different search path of -lfoo libraries than the default.
You can do this by setting the LIB_PATH variable in ./Makefile
or using the --with-lib-path configure switch.

To build just the linker, make the target all-ld from the top level
directory (one directory above this one).

Porting to a new target
=======================

See the ldint.texinfo manual.

Reporting bugs etc
===========================

See ../binutils/README.

Known problems
==============

The Solaris linker normally exports all dynamic symbols from an
executable.  The GNU linker does not do this by default.  This is
because the GNU linker tries to present the same interface for all
similar targets (in this case, all native ELF targets).  This does not
matter for normal programs, but it can make a difference for programs
which try to dlopen an executable, such as PERL or Tcl.  You can make
the GNU linker export all dynamic symbols with the -E or
--export-dynamic command line option.

HP/UX 9.01 has a shell bug that causes the linker scripts to be
generated incorrectly.  The symptom of this appears to be "fatal error
- scanner input buffer overflow" error messages.  There are various
workarounds to this:
  * Build and install bash, and build with "make SHELL=bash".
  * Update to a version of HP/UX with a working shell (e.g., 9.05).
  * Replace "(. ${srcdir}/scripttempl/${SCRIPT_NAME}.sc)" in
    genscripts.sh with "sh ${srcdir}..." (no parens) and make sure the
    emulparams script used exports any shell variables it sets.

Copyright (C) 2012-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.