binutils-gdb/ld
Laurent Alfonsi a504d23a83 Add --fix-stm32l4xx-629360 to the ARM linker to enable a link-time workaround for a bug in the bus matrix / memory controller for some of the STM32 Cortex-M4 based products (STM32L4xx).
bfd  * bfd-in2.h: Regenerate.
     * bfd-in.h (bfd_arm_stm32l4xx_fix): New enum. Specify how
     STM32L4XX instruction scanning should be done.
     (bfd_elf32_arm_set_stm32l4xx_fix)
     (bfd_elf32_arm_stm32l4xx_erratum_scan)
     (bfd_elf32_arm_stm32l4xx_fix_veneer_locations): Add prototypes.
     (bfd_elf32_arm_set_target_relocs): Add stm32l4xx fix type argument
     to prototype.
     * elf32-arm.c (STM32L4XX_ERRATUM_VENEER_SECTION_NAME)
     (STM32L4XX_ERRATUM_VENEER_ENTRY_NAME): Define macros.
     (elf32_stm32l4xx_erratum_type): New enum.
     (elf32_stm32l4xx_erratum_list): New struct. List of veneers or
     jumps to veneers.
     (_arm_elf_section_data): Add stm32l4xx_erratumcount,
     stm32l4xx_erratumlist.
     (elf32_arm_link_hash_table): Add stm32l4xx_erratum_glue_size,
     stm32l4xx_fix and num_stm32l4xx_fixes fields.
     (ctz): New function.
     (popcount): New function.
     (elf32_arm_link_hash_table_create): Initialize stm32l4xx_fix.
     (put_thumb2_insn): New function.
     (STM32L4XX_ERRATUM_LDM_VENEER_SIZE): Define. Size of a veneer for
     LDM instructions.
     (STM32L4XX_ERRATUM_VLDM_VENEER_SIZE): Define. Size of a veneer for
     VLDM instructions.
     (bfd_elf32_arm_allocate_interworking_sections): Initialise erratum
     glue section.
     (record_stm32l4xx_erratum_veneer) : New function. Create a single
     veneer, and its associated symbols.
     (bfd_elf32_arm_add_glue_sections_to_bfd): Add STM32L4XX erratum glue.
     (bfd_elf32_arm_set_stm32l4xx_fix): New function. Set the type of
     erratum workaround required.
     (bfd_elf32_arm_stm32l4xx_fix_veneer_locations): New function. Find
     out where veneers and branches to veneers have been placed in
     virtual memory after layout.
     (is_thumb2_ldmia): New function.
     (is_thumb2_ldmdb): Likewise.
     (is_thumb2_vldm ): Likewise.
     (stm32l4xx_need_create_replacing_stub): New function. Decide if a
     veneer must be emitted.
     (bfd_elf32_arm_stm32l4xx_erratum_scan): Scan the sections of an
     input BFD for potential erratum-triggering insns. Record results.
     (bfd_elf32_arm_set_target_relocs): Set stm32l4xx_fix field in
     global hash table.
     (elf32_arm_size_dynamic_sections): Collect glue information.
     (create_instruction_branch_absolute): New function.
     (create_instruction_ldmia): Likewise.
     (create_instruction_ldmdb): Likewise.
     (create_instruction_mov): Likewise.
     (create_instruction_sub): Likewise.
     (create_instruction_vldmia): Likewise.
     (create_instruction_vldmdb): Likewise.
     (create_instruction_udf_w): Likewise.
     (create_instruction_udf): Likewise.
     (push_thumb2_insn32): Likewise.
     (push_thumb2_insn16): Likewise.
     (stm32l4xx_fill_stub_udf): Likewise.
     (stm32l4xx_create_replacing_stub_ldmia): New function. Expands the
     replacing stub for ldmia instructions.
     (stm32l4xx_create_replacing_stub_ldmdb): Likewise for ldmdb.
     (stm32l4xx_create_replacing_stub_vldm): Likewise for vldm.
     (stm32l4xx_create_replacing_stub): New function. Dispatches the
     stub emission to the appropriate functions.
     (elf32_arm_write_section): Output veneers, and branches to veneers.

ld   * ld.texinfo: Description of the STM32L4xx erratum workaround.
     * emultempl/armelf.em (stm32l4xx_fix): New.
     (arm_elf_before_allocation): Choose the type of fix, scan for
     erratum.
     (gld${EMULATION_NAME}_finish): Fix veneer locations.
     (arm_elf_create_output_section_statements): Propagate
     stm32l4xx_fix value.
     (PARSE_AND_LIST_PROLOGUE): Define OPTION_STM32L4XX_FIX.
     (PARSE_AND_LIST_LONGOPTS): Add entry for handling
     --fix-stm32l4xx-629360.
     (PARSE_AND_LIST_OPTION): Add entry for helping on
     --fix-stm32l4xx-629360.
     (PARSE_AND_LIST_ARGS_CASES): Treat OPTION_STM32L4XX_FIX.

tests * ld-arm/arm-elf.exp (armelftests_common): Add STM32L4XX
       tests.
     * ld-arm/stm32l4xx-cannot-fix-far-ldm.d: New.
     * ld-arm/stm32l4xx-cannot-fix-far-ldm.s: Likewise.
     * ld-arm/stm32l4xx-cannot-fix-it-block.d: Likewise.
     * ld-arm/stm32l4xx-cannot-fix-it-block.s: Likewise.
     * ld-arm/stm32l4xx-fix-all.d: Likewise.
     * ld-arm/stm32l4xx-fix-all.s: Likewise.
     * ld-arm/stm32l4xx-fix-it-block.d: Likewise.
     * ld-arm/stm32l4xx-fix-it-block.s: Likewise.
     * ld-arm/stm32l4xx-fix-ldm.d: Likewise.
     * ld-arm/stm32l4xx-fix-ldm.s: Likewise.
     * ld-arm/stm32l4xx-fix-vldm.d: Likewise.
     * ld-arm/stm32l4xx-fix-vldm.s: Likewise.
2015-10-27 13:20:33 +00:00
..
emulparams Add "-z call-nop=PADDING" option to ld 2015-10-22 04:56:39 -07:00
emultempl Add --fix-stm32l4xx-629360 to the ARM linker to enable a link-time workaround for a bug in the bus matrix / memory controller for some of the STM32 Cortex-M4 based products (STM32L4xx). 2015-10-27 13:20:33 +00:00
po Updated Chinese translation for the linker (again!) 2015-10-14 09:55:30 +01:00
scripttempl New ARC implementation. 2015-10-07 14:20:19 +01:00
testsuite Add --fix-stm32l4xx-629360 to the ARM linker to enable a link-time workaround for a bug in the bus matrix / memory controller for some of the STM32 Cortex-M4 based products (STM32L4xx). 2015-10-27 13:20:33 +00:00
.gitignore
ChangeLog Add --fix-stm32l4xx-629360 to the ARM linker to enable a link-time workaround for a bug in the bus matrix / memory controller for some of the STM32 Cortex-M4 based products (STM32L4xx). 2015-10-27 13:20:33 +00: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-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 ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
Makefile.am New ARC implementation. 2015-10-07 14:20:19 +01:00
Makefile.in New ARC implementation. 2015-10-07 14:20:19 +01:00
NEWS Add --fix-stm32l4xx-629360 to the ARM linker to enable a link-time workaround for a bug in the bus matrix / memory controller for some of the STM32 Cortex-M4 based products (STM32L4xx). 2015-10-27 13:20:33 +00:00
README ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
TODO
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 Properly check --enable-compressed-debug-sections={yes,all} 2015-10-22 07:44:05 -07:00
configure.ac Properly check --enable-compressed-debug-sections={yes,all} 2015-10-22 07:44:05 -07:00
configure.host Remove trailing spaces in ld 2015-08-12 04:46:43 -07:00
configure.tgt New ARC implementation. 2015-10-07 14:20:19 +01:00
deffile.h ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
deffilep.y ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
dep-in.sed
elf-hints-local.h Remove trailing white spaces in ld 2013-01-10 20:08:03 +00:00
fdl.texi
gen-doc.texi ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
genscrba.sh
genscripts.sh ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
h8-doc.texi ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
ld.h ld: Extend options for altering orphan handling behaviour. 2015-09-04 22:30:55 +01:00
ld.texinfo Add --fix-stm32l4xx-629360 to the ARM linker to enable a link-time workaround for a bug in the bus matrix / memory controller for some of the STM32 Cortex-M4 based products (STM32L4xx). 2015-10-27 13:20:33 +00:00
ldbuildid.c ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
ldbuildid.h ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
ldcref.c ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
ldctor.c Add output_type to bfd_link_info 2015-08-18 05:51:19 -07:00
ldctor.h ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
ldemul.c ld: Extend options for altering orphan handling behaviour. 2015-09-04 22:30:55 +01:00
ldemul.h ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
ldexp.c Evaluate __start_* and __stop_* symbol PROVIDE expressions early 2015-10-27 12:54:59 +10:30
ldexp.h Delay converting linker script defined symbols from absolute 2015-09-18 12:39:16 +09:30
ldfile.c Add output_type to bfd_link_info 2015-08-18 05:51:19 -07:00
ldfile.h ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
ldgram.y Allow symbols in MEMORY region specification 2015-01-28 15:06:48 +10:30
ldint.texinfo Remove trailing spaces in ld 2015-08-12 04:46:43 -07:00
ldlang.c Evaluate __start_* and __stop_* symbol PROVIDE expressions early 2015-10-27 12:54:59 +10:30
ldlang.h ld: Add '--require-defined' command line option. 2015-08-04 10:00:05 +01:00
ldlex-wrapper.c ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
ldlex.h Add --no-dynamic-linker option to ld, for static PIE use 2015-09-20 15:52:27 +09:30
ldlex.l Eat newlines inside INPUT statements in linker scripts 2015-04-28 21:55:28 +02:00
ldmain.c 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
ldmain.h ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
ldmisc.c Make binutils abort message GDB friendly 2015-07-20 05:53:31 -07:00
ldmisc.h ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
ldver.c Correct printed year in copyright notices 2015-01-02 01:08:15 +10:30
ldver.h ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
ldwrite.c Add output_type to bfd_link_info 2015-08-18 05:51:19 -07:00
ldwrite.h ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
lexsup.c 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
mri.c ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
mri.h ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
pe-dll.c Add output_type to bfd_link_info 2015-08-18 05:51:19 -07:00
pe-dll.h ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
pep-dll.c ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
pep-dll.h ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
plugin.c Remove link_info.pic 2015-08-19 12:53:54 +09:30
plugin.h Update plugin_maybe_claim 2015-02-07 11:01:22 -08:00
stamp-h.in
sysdep.h ChangeLog rotatation and copyright year update 2015-01-02 00:53:45 +10:30
testplug.c The initial support for LDPT_GET_VIEW 2015-01-28 10:27:31 -08:00
testplug2.c Add a testcase for PR ld/17973 2015-02-14 06:26:20 -08:00
testplug3.c Remove unused dump_tv_tag 2015-02-11 13:35:07 -08:00

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-2015 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.