* ld.texinfo (Options): Give more detail on -l option.

PR 10418.
This commit is contained in:
Ian Lance Taylor 1996-10-01 22:53:38 +00:00
parent 4fc7ca82bf
commit b61364cc71
2 changed files with 135 additions and 2 deletions

View file

@ -4,6 +4,8 @@ Tue Oct 1 16:17:33 1996 Joel Sherrill <joel@oarcorp.com>
Tue Oct 1 15:50:34 1996 Ian Lance Taylor <ian@cygnus.com> Tue Oct 1 15:50:34 1996 Ian Lance Taylor <ian@cygnus.com>
* ld.texinfo (Options): Give more detail on -l option.
* scripttempl/elfmips.sc: Handle CREATE_SHLIB the same way that * scripttempl/elfmips.sc: Handle CREATE_SHLIB the same way that
elf.sc does, so that glibc works better. elf.sc does, so that glibc works better.

View file

@ -392,6 +392,24 @@ path-list for occurrences of @code{lib@var{archive}.a} for every
@var{archive} specified. File extensions other than @code{.a} may be @var{archive} specified. File extensions other than @code{.a} may be
used on certain systems. used on certain systems.
The linker will search an archive only once, at the location where it is
specified on the command line. If the archive defines a symbol which
was undefined in some object which appeared before the archive on the
command line, the linker will include the appropriate file(s) from the
archive. However, an undefined symbol in an object appearing later on
the command line will not cause the linker to search the archive again.
See the @code{-(} option for a way to force the linker to search
archives multiple times.
You may list the same archive multiple times on the command line.
@ifset GENERIC
This type of archive searching is standard for Unix linkers. However,
if you are using @code{ld} on AIX, note that it is different from the
behaviour of the AIX linker.
@end ifset
@cindex search directory, from cmd line @cindex search directory, from cmd line
@kindex -L@var{dir} @kindex -L@var{dir}
@kindex --library-path=@var{dir} @kindex --library-path=@var{dir}
@ -1682,6 +1700,14 @@ Return the size in bytes of the output file's headers. You can use this number
as the start address of the first section, if you choose, to facilitate as the start address of the first section, if you choose, to facilitate
paging. paging.
@kindex MAX
@item MAX(@var{exp1}, @var{exp2})
Returns the maximum of @var{exp1} and @var{exp2}.
@kindex MIN
@item MIN(@var{exp1}, @var{exp2})
Returns the minimum of @var{exp1} and @var{exp2}.
@end table @end table
@node Semicolons @node Semicolons
@ -1822,6 +1848,7 @@ output file will match the order in the first input file.
* Section Placement:: Section Placement * Section Placement:: Section Placement
* Section Data Expressions:: Section Data Expressions * Section Data Expressions:: Section Data Expressions
* Section Options:: Optional Section Attributes * Section Options:: Optional Section Attributes
* Overlays:: Overlays
@end menu @end menu
@node Section Definition @node Section Definition
@ -2351,11 +2378,115 @@ of a section definition.
@end table @end table
@node Overlays
@subsection Overlays
@kindex OVERLAY
@cindex overlays
The @code{OVERLAY} command provides an easy way to describe sections
which are to be loaded as part of a single memory image but are to be
run at the same memory address. At run time, some sort of overlay
manager will copy the overlaid sections in and out of the runtime memory
address as required, perhaps by simply manipulating addressing bits.
This approach can be useful, for example, when a certain region of
memory is faster than another.
The @code{OVERLAY} command is used within a @code{SECTIONS} command. It
appears as follows:
@smallexample
@group
OVERLAY @var{start} : [ NOCROSSREFS ] AT ( @var{ldaddr} )
@{
@var{secname1} @{ @var{contents} @} :@var{phdr} =@var{fill}
@var{secname2} @{ @var{contents} @} :@var{phdr} =@var{fill}
@dots{}
@} >@var{region} :@var{phdr} =@var{fill}
@end group
@end smallexample
Everything is optional except @code{OVERLAY} (a keyword), and each
section must have a name (@var{secname1} and @var{secname2} above). The
section definitions within the @code{OVERLAY} construct are identical to
those within the general @code{SECTIONS} contruct (@pxref{SECTIONS}),
except that no addresses and no memory regions may be defined for
sections within an @code{OVERLAY}.
The sections are all defined with the same starting address. The load
addresses of the sections are arranged such that they are consecutive in
memory starting at the load address used for the @code{OVERLAY} as a
whole (as with normal section definitions, the load address is optional,
and defaults to the start address; the start address is also optional,
and defaults to @code{.}).
If the @code{NOCROSSREFS} keyword is used, and there any references
among the sections, the linker will report an error. Since the sections
all run at the same address, it normally does not make sense for one
section to refer directly to another. @xref{Option Commands,
NOCROSSREFS}.
For each section within the @code{OVERLAY}, the linker automatically
defines two symbols. The symbol @code{__load_start_@var{secname}} is
defined as the starting load address of the section. The symbol
@code{__load_stop_@var{secname}} is defined as the final load address of
the section. Any characters within @var{secname} which are not legal
within C identifiers are removed. C (or assembler) code may use these
symbols to move the overlaid sections around as necessary.
At the end of the overlay, the value of @code{.} is set to the start
address of the overlay plus the size of the largest section.
Here is an example. Remember that this would appear inside a
@code{SECTIONS} construct.
@smallexample
@group
OVERLAY 0x1000 : AT (0x4000)
@{
.text0 @{ o1/*.o(.text) @}
.text1 @{ o2/*.o(.text) @}
@}
@end group
@end smallexample
This will define both @code{.text0} and @code{.text1} to start at
address 0x1000. @code{.text0} will be loaded at address 0x4000, and
@code{.text1} will be loaded immediately after @code{.text0}. The
following symbols will be defined: @code{__load_start_text0},
@code{__load_stop_text0}, @code{__load_start_text1},
@code{__load_stop_text1}.
C code to copy overlay @code{.text1} into the overlay area might look
like the following.
@smallexample
@group
extern char __load_start_text1, __load_stop_text1;
memcpy ((char *) 0x1000, &__load_start_text1,
&__load_stop_text1 - &__load_start_text1);
@end group
@end smallexample
Note that the @code{OVERLAY} command is just syntactic sugar, since
everything it does can be done using the more basic commands. The above
example could have been written identically as follows.
@smallexample
@group
.text0 0x1000 : AT (0x4000) @{ o1/*.o(.text) @}
__load_start_text0 = LOADADDR (.text0);
__load_stop_text0 = LOADADDR (.text0) + SIZEOF (.text0);
.text1 0x1000 : AT (0x4000 + SIZEOF (.text0)) @{ o2/*.o(.text) @}
__load_start_text1 = LOADADDR (.text1);
__load_stop_text1 = LOADADDR (.text1) + SIZEOF (.text1);
. = 0x1000 + MAX (SIZEOF (.text0), SIZEOF (.text1));
@end group
@end smallexample
@node PHDRS @node PHDRS
@section ELF Program Headers @section ELF Program Headers
@kindex PHDRS @kindex PHDRS
@kindex program headers @cindex program headers
@kindex ELF program headers @cindex ELF program headers
The ELF object file format uses @dfn{program headers}, which are read by The ELF object file format uses @dfn{program headers}, which are read by
the system loader and describe how the program should be loaded into the system loader and describe how the program should be loaded into