binutils-gdb/ld
Jens Remus 76f05e1dfb readelf/objdump: Dump SFrame CFA fixed FP and RA offsets
The SFrame format allows architectures to specify fixed offsets from the
CFA, if any, from which the frame pointer (FP) and/or return address
(RA) may be recovered. These offsets are stored in the SFrame header.

For instance the SFrame generation in the assembler for x86 AMD64
specifies a fixed offset from the CFA, from which the return address
(RA) may be recovered.

When dumping the SFrame header, for instance in readelf/objdump with
option --sframe, do also dump the specified fixed offsets from the CFA,
if any, from which the frame pointer (FP) and return address (RA) may
be recovered.

Update the common SFrame test case verification patterns to allow for
the optional dumping of the CFA fixed FP/RA offsets. Update the x86-
specific SFrame and SCFI test case verification patterns to require a
CFA fixed RA offset of -8.

libsframe/
	* sframe-dump.c: Dump CFA fixed FP and RA offsets.

gas/testsuite/
	* gas/cfi-sframe/cfi-sframe-common-1.d: Test for optional fixed
	FP and RA offsets.
	* gas/cfi-sframe/cfi-sframe-common-2.d: Likewise.
	* gas/cfi-sframe/cfi-sframe-common-3.d: Likewise.
	* gas/cfi-sframe/cfi-sframe-common-4.d: Likewise.
	* gas/cfi-sframe/cfi-sframe-common-5.d: Likewise.
	* gas/cfi-sframe/cfi-sframe-common-6.d: Likewise.
	* gas/cfi-sframe/cfi-sframe-common-7.d: Likewise.
	* gas/cfi-sframe/cfi-sframe-common-8.d: Likewise.
	* gas/cfi-sframe/cfi-sframe-x86_64-1.d: Test for fixed
	RA offset.
	* gas/cfi-sframe/common-empty-1.d: Test for optional fixed
	FP and RA offsets.
	* gas/cfi-sframe/common-empty-2.d: Likewise.
	* gas/cfi-sframe/common-empty-3.d: Likewise.
	* gas/scfi/x86_64/scfi-cfi-sections-1.d: Test for SFrame fixed
	RA offset.
	* gas/scfi/x86_64/scfi-dyn-stack-1.d: Likewise.

ld/testsuite/
	* ld-x86-64/sframe-plt-1.d: Test for SFrame fixed RA offset.
	* ld-x86-64/sframe-simple-1.d: Likewise.

Signed-off-by: Jens Remus <jremus@linux.ibm.com>
2024-07-04 10:34:12 +02:00
..
emulparams aarch64: Add DT_RELR support for ILP32 ABI 2024-06-25 11:07:51 +01:00
emultempl Add --rosegment option to BFD linker to stop the '-z separate-code' from generating two read-only segments. 2024-06-13 15:10:15 +01:00
po
scripttempl Ensure that the text segment is aligned on disk when using --rosegment. 2024-06-18 09:15:04 +01:00
testsuite readelf/objdump: Dump SFrame CFA fixed FP and RA offsets 2024-07-04 10:34:12 +02:00
.gitignore
aclocal.m4
ChangeLog
ChangeLog-0001
ChangeLog-0203
ChangeLog-2004
ChangeLog-2005 Add copyright notices 2012-12-10 12:48:03 +00:00
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-2015
ChangeLog-2016
ChangeLog-2017
ChangeLog-2018
ChangeLog-2019
ChangeLog-2020
ChangeLog-9197
ChangeLog-9899
config.in Regenerate configure files in ld sub-directory 2024-06-14 12:49:49 +01:00
configure Revert "Remove LIBINTL_DEP" 2024-06-20 21:15:27 +09:30
configure.ac Add --rosegment option to BFD linker to stop the '-z separate-code' from generating two read-only segments. 2024-06-13 15:10:15 +01:00
configure.host
configure.tgt
deffile.h Update year range in copyright notice of binutils files 2024-01-04 22:58:12 +10:30
deffilep.y
dep-in.sed
elf-hints-local.h
fdl.texi
gen-doc.texi
genscrba.sh
genscripts.sh Add --rosegment option to BFD linker to stop the '-z separate-code' from generating two read-only segments. 2024-06-13 15:10:15 +01:00
h8-doc.texi
ld.h
ld.texi Revert: 35fd2ddeb1 2024-06-26 13:17:25 +01:00
ldbuildid.c
ldbuildid.h
ldcref.c Update year range in copyright notice of binutils files 2024-01-04 22:58:12 +10:30
ldctor.c
ldctor.h
ldelf.c Revert: 35fd2ddeb1 2024-06-26 13:17:25 +01:00
ldelf.h
ldelfgen.c
ldelfgen.h Update year range in copyright notice of binutils files 2024-01-04 22:58:12 +10:30
ldemul.c
ldemul.h
ldexp.c Update year range in copyright notice of binutils files 2024-01-04 22:58:12 +10:30
ldexp.h
ldfile.c Revert: 35fd2ddeb1 2024-06-26 13:17:25 +01:00
ldfile.h Revert: 35fd2ddeb1 2024-06-26 13:17:25 +01:00
ldgram.y Revert: 35fd2ddeb1 2024-06-26 13:17:25 +01:00
ldint.texi ld/doc: drop stray blank 2024-06-28 13:16:14 +02:00
ldlang.c
ldlang.h Revert: 35fd2ddeb1 2024-06-26 13:17:25 +01:00
ldlex-wrapper.c
ldlex.h Add --rosegment option to BFD linker to stop the '-z separate-code' from generating two read-only segments. 2024-06-13 15:10:15 +01:00
ldlex.l
ldmain.c
ldmain.h
ldmisc.c
ldmisc.h
ldver.c
ldver.h
ldwrite.c
ldwrite.h
lexsup.c Revert: 35fd2ddeb1 2024-06-26 13:17:25 +01:00
libdep_plugin.c libdep plugin: fix bugs in parser and drop escaping 2024-06-24 16:00:14 +01:00
MAINTAINERS
Makefile.am Revert "Remove LIBINTL_DEP" 2024-06-20 21:15:27 +09:30
Makefile.in Revert "Remove LIBINTL_DEP" 2024-06-20 21:15:27 +09:30
mri.c
mri.h
NEWS x86: Add -z isa-level-report=[none|all|needed|used] 2024-06-14 13:38:19 -07:00
pdb.c
pdb.h
pe-dll.c Improve comments describing the Import Directory Table 2024-06-27 12:17:27 +01:00
pe-dll.h Update year range in copyright notice of binutils files 2024-01-04 22:58:12 +10:30
pep-dll-aarch64.c
pep-dll-x86_64.c
pep-dll.c
pep-dll.h Update year range in copyright notice of binutils files 2024-01-04 22:58:12 +10:30
plugin.c Revert: 35fd2ddeb1 2024-06-26 13:17:25 +01:00
plugin.h Update year range in copyright notice of binutils files 2024-01-04 22:58:12 +10:30
README
sysdep.h
testplug2.c
testplug3.c
testplug4.c
testplug.c
TODO 19990502 sourceware import 1999-05-03 07:29:11 +00:00

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.texi), as well as the
  beginnings of an internals manual (ldint.texi).

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.texi 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-2024 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.