binutils-gdb/ld
Senthil Kumar Selvaraj b660e9eb7a Fix PR21404 - assertion fail when calculating symbol size
Fix a host of problems related to adjustment of
symbol values and sizes when relaxing for avr.

1. Adjust symbol size first before adjusting symbol
value. Otherwise, a symbol whose value just got adjusted to the
relaxed address also ends up getting resized. See pr21404-1.s.

2. Reduce symbol sizes only if their span is below an
alignment boundary. Otherwise, the size gets decremented once when the
actual instruction is relaxed and padding bytes are added, and again
when the padding bytes are deleted (if padding ends up being unnecessary).
pr21404-2.s addresses that, and this bug is really the root cause of PR21404.

3. Adjust all symbol values before an alignment boundary.
Previous code did not adjust symbol values if they fell in the
would-be padded area, resulting in incorrect symbol values in some
cases (see pr21404-3.s).

4. Increase symbol sizes if alignment directives require so.
As pr21404-4.s shows
.global nonzero_sym
L1:
    jmp  L1
nonzero_sym:
    nop
    nop
    .p2align 2
.size nonzero_sym, .-nonzero_sym

The two nops satisfy the 4 byte alignment at assembly time and
therefore the size of nonzero_sym is 4. Relaxation shortens
the 4 byte jmp to a 2 byte rjmp, and to satisfy 4 byte alignment
the code places 2 extra padding bytes after the nops, increasing
nonzero_sym's size by 2. This wasn't handled before.

If the assembly code does not have any align directives, then the
boundary is the section size, and symbol values and sizes == boundary
should also get adjusted. To handle that case, add a did_pad variable
and use that to determine whether it should use < boundary or <= boundary.

Also get rid of reloc_toaddr, which is now redundant.  toaddr is now not
adjusted to handle the above case - the newly added
did_pad variable does the job.

pr21404-{5,6,7,8} are the same testcases written for local symbols, as
the code handles them slightly differently.
2017-05-04 10:34:29 +05:30
..
emulparams Implement -z dynamic-undefined-weak 2017-04-19 20:39:52 +09:30
emultempl PR 21274, ld segfaults linking PE DLL 2017-04-11 19:49:13 +09:30
po Add Serbian translation for the LD directory. 2017-01-27 11:27:50 +00:00
scripttempl Place read-only data in the text section on AVR Tiny targets. 2017-02-27 17:05:53 +00:00
testsuite Fix PR21404 - assertion fail when calculating symbol size 2017-05-04 10:34:29 +05:30
.gitignore
ChangeLog Fix PR21404 - assertion fail when calculating symbol size 2017-05-04 10:34:29 +05:30
ChangeLog-0001
ChangeLog-0203
ChangeLog-2004
ChangeLog-2005
ChangeLog-2006
ChangeLog-2007
ChangeLog-2008
ChangeLog-2009 Remove trailing spaces in ld 2015-08-12 04:46:43 -07:00
ChangeLog-2010
ChangeLog-2011
ChangeLog-2012
ChangeLog-2013
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-2016 ChangeLog rotation 2017-01-02 13:55:05 +10:30
ChangeLog-9197 Remove trailing spaces in ld 2015-08-12 04:46:43 -07:00
ChangeLog-9899
MAINTAINERS Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
Makefile.am Implement -z dynamic-undefined-weak 2017-04-19 20:39:52 +09:30
Makefile.in Implement -z dynamic-undefined-weak 2017-04-19 20:39:52 +09:30
NEWS Support ELF SHF_GNU_MBIND and PT_GNU_MBIND_XXX 2017-04-04 09:06:04 -07:00
README Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
TODO
aclocal.m4 Regenerate Makefile.in/aclocal.m4 automake 1.11.6 2016-04-15 16:20:55 -07:00
config.in Remove support for $PLATFORM in rpath search paths. 2016-11-04 13:57:40 +00:00
configure Add Serbian translation for the LD directory. 2017-01-27 11:27:50 +00:00
configure.ac Add Serbian translation for the LD directory. 2017-01-27 11:27:50 +00:00
configure.host Run more ld tests when not native 2017-01-02 23:48:08 +10:30
configure.tgt IA16 support 2017-04-03 09:13:19 -07:00
deffile.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
deffilep.y Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
dep-in.sed
elf-hints-local.h
fdl.texi
gen-doc.texi Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
genscrba.sh
genscripts.sh Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
h8-doc.texi Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ld.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ld.texinfo Implement -z dynamic-undefined-weak 2017-04-19 20:39:52 +09:30
ldbuildid.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldbuildid.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldcref.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldctor.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldctor.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldemul.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldemul.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldexp.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldexp.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldfile.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldfile.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldgram.y Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldint.texinfo Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldlang.c PR ld/21233: Avoid sweeping forced-undefined symbols in section GC 2017-04-04 23:21:44 +01:00
ldlang.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldlex-wrapper.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldlex.h Use noyywrap option in lex files. 2017-01-04 16:05:22 +00:00
ldlex.l Use noyywrap option in lex files. 2017-01-04 16:05:22 +00:00
ldmain.c Fix buffer overflows in ld when printing translated strings. 2017-01-31 12:07:04 +00:00
ldmain.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldmisc.c LD: vfinfo: Make clever formatters consistent WRT function name reporting 2017-02-15 13:41:51 +00:00
ldmisc.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldver.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldver.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldwrite.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
ldwrite.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
lexsup.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
mri.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
mri.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
pe-dll.c PR 21274, ld segfaults linking PE DLL 2017-04-11 19:49:13 +09:30
pe-dll.h PR 21274, ld segfaults linking PE DLL 2017-04-11 19:49:13 +09:30
pep-dll.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
pep-dll.h PR 21274, ld segfaults linking PE DLL 2017-04-11 19:49:13 +09:30
plugin.c Handle symbol defined in IR and referenced in DSO 2017-04-20 07:48:35 -07:00
plugin.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
stamp-h.in
sysdep.h Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
testplug.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
testplug2.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
testplug3.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +10:30
testplug4.c Update year range in copyright notice of all files. 2017-01-02 14:08:56 +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-2017 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.