binutils-gdb/ld
Nick Alcock ffeece6ac2 libctf, ld: prohibit getting the size or alignment of forwards
C allows you to do only a very few things with entities of incomplete
type (as opposed to pointers to them): make pointers to them and give
them cv-quals, roughly. In particular you can't sizeof them and you
can't get their alignment.

We cannot impose all the requirements the standard imposes on CTF users,
because the deduplicator can transform any structure type into a forward
for the purposes of breaking cycles: so CTF type graphs can easily
contain things like arrays of forward type (if you want to figure out
their size or alignment, you need to chase down the types this forward
might be a forward to in child TU dicts: we will soon add API functions
to make doing this much easier).

Nonetheless, it is still meaningless to ask for the size or alignment of
forwards: but libctf didn't prohibit this and returned nonsense from
internal implementation details when you asked (it returned the kind of
the pointed-to type as both the size and alignment, because forwards
reuse ctt_type as a type kind, and ctt_type and ctt_size overlap).  So
introduce a new error, ECTF_INCOMPLETE, which is returned when you try
to get the size or alignment of forwards: we also return it when you try
to do things that require libctf itself to get the size or alignment of
a forward, notably using a forward as an array index type (which C
should never do in any case) or adding forwards to structures without
specifying their offset explicitly.

The dumper will not emit size or alignment info for forwards any more.

(This should not be an API break since ctf_type_size and ctf_type_align
could both return errors before now: any code that isn't expecting error
returns is already potentially broken.)

include/ChangeLog
2021-01-05  Nick Alcock  <nick.alcock@oracle.com>

	* ctf-api.h (ECTF_INCOMPLETE): New.
	(ECTF_NERR): Adjust.

ld/ChangeLog
2021-01-05  Nick Alcock  <nick.alcock@oracle.com>

	* testsuite/ld-ctf/conflicting-cycle-1.parent.d: Adjust for dumper
	changes.
	* testsuite/ld-ctf/cross-tu-cyclic-conflicting.d: Likewise.
	* testsuite/ld-ctf/forward.c: New test...
	* testsuite/ld-ctf/forward.d: ... and results.

libctf/ChangeLog
2021-01-05  Nick Alcock  <nick.alcock@oracle.com>

	* ctf-types.c (ctf_type_resolve): Improve comment.
	(ctf_type_size): Yield ECTF_INCOMPLETE when applied to forwards.
	Emit errors into the right dict.
	(ctf_type_align): Likewise.
	* ctf-create.c (ctf_add_member_offset): Yield ECTF_INCOMPLETE
	when adding a member without explicit offset when this member, or
	the previous member, is incomplete.
	* ctf-dump.c (ctf_dump_format_type): Do not try to print the size of
	forwards.
	(ctf_dump_member): Do not try to print their alignment.
2021-01-05 14:53:39 +00:00
..
emulparams Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
emultempl PR27116, Spelling errors found by Debian style checker 2021-01-01 14:36:35 +10:30
po Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
scripttempl Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
testsuite libctf, ld: prohibit getting the size or alignment of forwards 2021-01-05 14:53:39 +00:00
.gitignore
aclocal.m4
ChangeLog libctf, ld: prohibit getting the size or alignment of forwards 2021-01-05 14:53:39 +00:00
ChangeLog-0001
ChangeLog-0203
ChangeLog-2004
ChangeLog-2005
ChangeLog-2006
ChangeLog-2007
ChangeLog-2008
ChangeLog-2009
ChangeLog-2010
ChangeLog-2011
ChangeLog-2012
ChangeLog-2013
ChangeLog-2014
ChangeLog-2015
ChangeLog-2016
ChangeLog-2017
ChangeLog-2018
ChangeLog-2019
ChangeLog-2020 ChangeLog rotation 2021-01-01 10:31:02 +10:30
ChangeLog-9197
ChangeLog-9899 PR27116, Spelling errors found by Debian style checker 2021-01-01 14:36:35 +10:30
config.in
configure
configure.ac Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
configure.host Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
configure.tgt PR27116, Spelling errors found by Debian style checker 2021-01-01 14:36:35 +10:30
deffile.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
deffilep.y Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
dep-in.sed
elf-hints-local.h
fdl.texi
gen-doc.texi Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
genscrba.sh
genscripts.sh Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
h8-doc.texi Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ld.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ld.texi PR27116, Spelling errors found by Debian style checker 2021-01-01 14:36:35 +10:30
ldbuildid.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldbuildid.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldcref.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldctor.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldctor.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldelf.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldelf.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldelfgen.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldelfgen.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldemul.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldemul.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldexp.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldexp.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldfile.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldfile.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldgram.y Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldint.texi Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldlang.c elf: Allow mixed ordered/unordered inputs for non-relocatable link 2021-01-04 12:38:05 -08:00
ldlang.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldlex-wrapper.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldlex.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldlex.l Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldmain.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldmain.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldmisc.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldmisc.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldver.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldver.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldwrite.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
ldwrite.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
lexsup.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
libdep_plugin.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
MAINTAINERS Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
Makefile.am Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
Makefile.in Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
mri.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
mri.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
NEWS Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
pe-dll.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
pe-dll.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
pep-dll.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
pep-dll.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
plugin.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
plugin.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
README Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
stamp-h.in
sysdep.h Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
testplug2.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
testplug3.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
testplug4.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
testplug.c Update year range in copyright notice of binutils files 2021-01-01 10:31:05 +10:30
TODO

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