2009-03-23 H.J. Lu <hongjiu.lu@intel.com>
[binutils.git] / ld / ld.texinfo
blob32e8783be81401f42dff7f490cb3a02f42fbb809
1 \input texinfo
2 @setfilename ld.info
3 @c Copyright 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000,
4 @c 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
5 @c Free Software Foundation, Inc.
6 @syncodeindex ky cp
7 @c man begin INCLUDE
8 @include configdoc.texi
9 @c (configdoc.texi is generated by the Makefile)
10 @include bfdver.texi
11 @c man end
13 @c @smallbook
15 @macro gcctabopt{body}
16 @code{\body\}
17 @end macro
19 @c man begin NAME
20 @ifset man
21 @c Configure for the generation of man pages
22 @set UsesEnvVars
23 @set GENERIC
24 @set ARM
25 @set H8300
26 @set HPPA
27 @set I960
28 @set M68HC11
29 @set M68K
30 @set MMIX
31 @set MSP430
32 @set POWERPC
33 @set POWERPC64
34 @set Renesas
35 @set SPU
36 @set TICOFF
37 @set WIN32
38 @set XTENSA
39 @end ifset
40 @c man end
42 @ifinfo
43 @format
44 START-INFO-DIR-ENTRY
45 * Ld: (ld).                       The GNU linker.
46 END-INFO-DIR-ENTRY
47 @end format
48 @end ifinfo
50 @copying
51 This file documents the @sc{gnu} linker LD
52 @ifset VERSION_PACKAGE
53 @value{VERSION_PACKAGE}
54 @end ifset
55 version @value{VERSION}.
57 Copyright @copyright{} 1991, 92, 93, 94, 95, 96, 97, 98, 99, 2000,
58 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc.
60 Permission is granted to copy, distribute and/or modify this document
61 under the terms of the GNU Free Documentation License, Version 1.3
62 or any later version published by the Free Software Foundation;
63 with no Invariant Sections, with no Front-Cover Texts, and with no
64 Back-Cover Texts.  A copy of the license is included in the
65 section entitled ``GNU Free Documentation License''.
66 @end copying
67 @iftex
68 @finalout
69 @setchapternewpage odd
70 @settitle The GNU linker
71 @titlepage
72 @title The GNU linker
73 @sp 1
74 @subtitle @code{ld}
75 @ifset VERSION_PACKAGE
76 @subtitle @value{VERSION_PACKAGE}
77 @end ifset
78 @subtitle Version @value{VERSION}
79 @author Steve Chamberlain
80 @author Ian Lance Taylor
81 @page
83 @tex
84 {\parskip=0pt
85 \hfill Red Hat Inc\par
86 \hfill nickc\@credhat.com, doc\@redhat.com\par
87 \hfill {\it The GNU linker}\par
88 \hfill Edited by Jeffrey Osier (jeffrey\@cygnus.com)\par
90 \global\parindent=0pt % Steve likes it this way.
91 @end tex
93 @vskip 0pt plus 1filll
94 @c man begin COPYRIGHT
95 Copyright @copyright{} 1991, 92, 93, 94, 95, 96, 97, 98, 99, 2000, 2001,
96 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc.
98 Permission is granted to copy, distribute and/or modify this document
99 under the terms of the GNU Free Documentation License, Version 1.3
100 or any later version published by the Free Software Foundation;
101 with no Invariant Sections, with no Front-Cover Texts, and with no
102 Back-Cover Texts.  A copy of the license is included in the
103 section entitled ``GNU Free Documentation License''.
104 @c man end
106 @end titlepage
107 @end iftex
108 @contents
109 @c FIXME: Talk about importance of *order* of args, cmds to linker!
111 @ifnottex
112 @node Top
113 @top LD
114 This file documents the @sc{gnu} linker ld
115 @ifset VERSION_PACKAGE
116 @value{VERSION_PACKAGE}
117 @end ifset
118 version @value{VERSION}.
120 This document is distributed under the terms of the GNU Free
121 Documentation License version 1.3.  A copy of the license is included
122 in the section entitled ``GNU Free Documentation License''.
124 @menu
125 * Overview::                    Overview
126 * Invocation::                  Invocation
127 * Scripts::                     Linker Scripts
128 @ifset GENERIC
129 * Machine Dependent::           Machine Dependent Features
130 @end ifset
131 @ifclear GENERIC
132 @ifset H8300
133 * H8/300::                      ld and the H8/300
134 @end ifset
135 @ifset Renesas
136 * Renesas::                     ld and other Renesas micros
137 @end ifset
138 @ifset I960
139 * i960::                        ld and the Intel 960 family
140 @end ifset
141 @ifset ARM
142 * ARM::                         ld and the ARM family
143 @end ifset
144 @ifset HPPA
145 * HPPA ELF32::                  ld and HPPA 32-bit ELF
146 @end ifset
147 @ifset M68HC11
148 * M68HC11/68HC12::              ld and the Motorola 68HC11 and 68HC12 families
149 @end ifset
150 @ifset M68K
151 * M68K::                        ld and Motorola 68K family
152 @end ifset
153 @ifset POWERPC
154 * PowerPC ELF32::               ld and PowerPC 32-bit ELF Support
155 @end ifset
156 @ifset POWERPC64
157 * PowerPC64 ELF64::             ld and PowerPC64 64-bit ELF Support
158 @end ifset
159 @ifset SPU
160 * SPU ELF::                     ld and SPU ELF Support
161 @end ifset
162 @ifset TICOFF
163 * TI COFF::                     ld and the TI COFF
164 @end ifset
165 @ifset WIN32
166 * Win32::                       ld and WIN32 (cygwin/mingw)
167 @end ifset
168 @ifset XTENSA
169 * Xtensa::                      ld and Xtensa Processors
170 @end ifset
171 @end ifclear
172 @ifclear SingleFormat
173 * BFD::                         BFD
174 @end ifclear
175 @c Following blank line required for remaining bug in makeinfo conds/menus
177 * Reporting Bugs::              Reporting Bugs
178 * MRI::                         MRI Compatible Script Files
179 * GNU Free Documentation License::  GNU Free Documentation License
180 * LD Index::                       LD Index
181 @end menu
182 @end ifnottex
184 @node Overview
185 @chapter Overview
187 @cindex @sc{gnu} linker
188 @cindex what is this?
190 @ifset man
191 @c man begin SYNOPSIS
192 ld [@b{options}] @var{objfile} @dots{}
193 @c man end
195 @c man begin SEEALSO
196 ar(1), nm(1), objcopy(1), objdump(1), readelf(1) and
197 the Info entries for @file{binutils} and
198 @file{ld}.
199 @c man end
200 @end ifset
202 @c man begin DESCRIPTION
204 @command{ld} combines a number of object and archive files, relocates
205 their data and ties up symbol references. Usually the last step in
206 compiling a program is to run @command{ld}.
208 @command{ld} accepts Linker Command Language files written in
209 a superset of AT&T's Link Editor Command Language syntax,
210 to provide explicit and total control over the linking process.
212 @ifset man
213 @c For the man only
214 This man page does not describe the command language; see the
215 @command{ld} entry in @code{info} for full details on the command
216 language and on other aspects of the GNU linker.
217 @end ifset
219 @ifclear SingleFormat
220 This version of @command{ld} uses the general purpose BFD libraries
221 to operate on object files. This allows @command{ld} to read, combine, and
222 write object files in many different formats---for example, COFF or
223 @code{a.out}.  Different formats may be linked together to produce any
224 available kind of object file.  @xref{BFD}, for more information.
225 @end ifclear
227 Aside from its flexibility, the @sc{gnu} linker is more helpful than other
228 linkers in providing diagnostic information.  Many linkers abandon
229 execution immediately upon encountering an error; whenever possible,
230 @command{ld} continues executing, allowing you to identify other errors
231 (or, in some cases, to get an output file in spite of the error).
233 @c man end
235 @node Invocation
236 @chapter Invocation
238 @c man begin DESCRIPTION
240 The @sc{gnu} linker @command{ld} is meant to cover a broad range of situations,
241 and to be as compatible as possible with other linkers.  As a result,
242 you have many choices to control its behavior.
244 @c man end
246 @ifset UsesEnvVars
247 @menu
248 * Options::                     Command Line Options
249 * Environment::                 Environment Variables
250 @end menu
252 @node Options
253 @section Command Line Options
254 @end ifset
256 @cindex command line
257 @cindex options
259 @c man begin OPTIONS
261 The linker supports a plethora of command-line options, but in actual
262 practice few of them are used in any particular context.
263 @cindex standard Unix system
264 For instance, a frequent use of @command{ld} is to link standard Unix
265 object files on a standard, supported Unix system.  On such a system, to
266 link a file @code{hello.o}:
268 @smallexample
269 ld -o @var{output} /lib/crt0.o hello.o -lc
270 @end smallexample
272 This tells @command{ld} to produce a file called @var{output} as the
273 result of linking the file @code{/lib/crt0.o} with @code{hello.o} and
274 the library @code{libc.a}, which will come from the standard search
275 directories.  (See the discussion of the @samp{-l} option below.)
277 Some of the command-line options to @command{ld} may be specified at any
278 point in the command line.  However, options which refer to files, such
279 as @samp{-l} or @samp{-T}, cause the file to be read at the point at
280 which the option appears in the command line, relative to the object
281 files and other file options.  Repeating non-file options with a
282 different argument will either have no further effect, or override prior
283 occurrences (those further to the left on the command line) of that
284 option.  Options which may be meaningfully specified more than once are
285 noted in the descriptions below.
287 @cindex object files
288 Non-option arguments are object files or archives which are to be linked
289 together.  They may follow, precede, or be mixed in with command-line
290 options, except that an object file argument may not be placed between
291 an option and its argument.
293 Usually the linker is invoked with at least one object file, but you can
294 specify other forms of binary input files using @samp{-l}, @samp{-R},
295 and the script command language.  If @emph{no} binary input files at all
296 are specified, the linker does not produce any output, and issues the
297 message @samp{No input files}.
299 If the linker cannot recognize the format of an object file, it will
300 assume that it is a linker script.  A script specified in this way
301 augments the main linker script used for the link (either the default
302 linker script or the one specified by using @samp{-T}).  This feature
303 permits the linker to link against a file which appears to be an object
304 or an archive, but actually merely defines some symbol values, or uses
305 @code{INPUT} or @code{GROUP} to load other objects.  Specifying a
306 script in this way merely augments the main linker script, with the
307 extra commands placed after the main script; use the @samp{-T} option
308 to replace the default linker script entirely, but note the effect of
309 the @code{INSERT} command.  @xref{Scripts}.
311 For options whose names are a single letter,
312 option arguments must either follow the option letter without intervening
313 whitespace, or be given as separate arguments immediately following the
314 option that requires them.
316 For options whose names are multiple letters, either one dash or two can
317 precede the option name; for example, @samp{-trace-symbol} and
318 @samp{--trace-symbol} are equivalent.  Note---there is one exception to
319 this rule.  Multiple letter options that start with a lower case 'o' can
320 only be preceded by two dashes.  This is to reduce confusion with the
321 @samp{-o} option.  So for example @samp{-omagic} sets the output file
322 name to @samp{magic} whereas @samp{--omagic} sets the NMAGIC flag on the
323 output.
325 Arguments to multiple-letter options must either be separated from the
326 option name by an equals sign, or be given as separate arguments
327 immediately following the option that requires them.  For example,
328 @samp{--trace-symbol foo} and @samp{--trace-symbol=foo} are equivalent.
329 Unique abbreviations of the names of multiple-letter options are
330 accepted.
332 Note---if the linker is being invoked indirectly, via a compiler driver
333 (e.g. @samp{gcc}) then all the linker command line options should be
334 prefixed by @samp{-Wl,} (or whatever is appropriate for the particular
335 compiler driver) like this:
337 @smallexample
338   gcc -Wl,--start-group foo.o bar.o -Wl,--end-group
339 @end smallexample
341 This is important, because otherwise the compiler driver program may
342 silently drop the linker options, resulting in a bad link.  Confusion
343 may also arise when passing options that require values through a
344 driver, as the use of a space between option and argument acts as
345 a separator, and causes the driver to pass only the option to the linker
346 and the argument to the compiler.  In this case, it is simplest to use
347 the joined forms of both single- and multiple-letter options, such as:
349 @smallexample
350   gcc foo.o bar.o -Wl,-eENTRY -Wl,-Map=a.map
351 @end smallexample
353 Here is a table of the generic command line switches accepted by the GNU
354 linker:
356 @table @gcctabopt
357 @include at-file.texi
359 @kindex -a @var{keyword}
360 @item -a @var{keyword}
361 This option is supported for HP/UX compatibility.  The @var{keyword}
362 argument must be one of the strings @samp{archive}, @samp{shared}, or
363 @samp{default}.  @samp{-aarchive} is functionally equivalent to
364 @samp{-Bstatic}, and the other two keywords are functionally equivalent
365 to @samp{-Bdynamic}.  This option may be used any number of times.
367 @ifset I960
368 @cindex architectures
369 @kindex -A @var{arch}
370 @item -A @var{architecture}
371 @kindex --architecture=@var{arch}
372 @itemx --architecture=@var{architecture}
373 In the current release of @command{ld}, this option is useful only for the
374 Intel 960 family of architectures.  In that @command{ld} configuration, the
375 @var{architecture} argument identifies the particular architecture in
376 the 960 family, enabling some safeguards and modifying the
377 archive-library search path.  @xref{i960,,@command{ld} and the Intel 960
378 family}, for details.
380 Future releases of @command{ld} may support similar functionality for
381 other architecture families.
382 @end ifset
384 @ifclear SingleFormat
385 @cindex binary input format
386 @kindex -b @var{format}
387 @kindex --format=@var{format}
388 @cindex input format
389 @cindex input format
390 @item -b @var{input-format}
391 @itemx --format=@var{input-format}
392 @command{ld} may be configured to support more than one kind of object
393 file.  If your @command{ld} is configured this way, you can use the
394 @samp{-b} option to specify the binary format for input object files
395 that follow this option on the command line.  Even when @command{ld} is
396 configured to support alternative object formats, you don't usually need
397 to specify this, as @command{ld} should be configured to expect as a
398 default input format the most usual format on each machine.
399 @var{input-format} is a text string, the name of a particular format
400 supported by the BFD libraries.  (You can list the available binary
401 formats with @samp{objdump -i}.)
402 @xref{BFD}.
404 You may want to use this option if you are linking files with an unusual
405 binary format.  You can also use @samp{-b} to switch formats explicitly (when
406 linking object files of different formats), by including
407 @samp{-b @var{input-format}} before each group of object files in a
408 particular format.
410 The default format is taken from the environment variable
411 @code{GNUTARGET}.
412 @ifset UsesEnvVars
413 @xref{Environment}.
414 @end ifset
415 You can also define the input format from a script, using the command
416 @code{TARGET};
417 @ifclear man
418 see @ref{Format Commands}.
419 @end ifclear
420 @end ifclear
422 @kindex -c @var{MRI-cmdfile}
423 @kindex --mri-script=@var{MRI-cmdfile}
424 @cindex compatibility, MRI
425 @item -c @var{MRI-commandfile}
426 @itemx --mri-script=@var{MRI-commandfile}
427 For compatibility with linkers produced by MRI, @command{ld} accepts script
428 files written in an alternate, restricted command language, described in
429 @ifclear man
430 @ref{MRI,,MRI Compatible Script Files}.
431 @end ifclear
432 @ifset man
433 the MRI Compatible Script Files section of GNU ld documentation.
434 @end ifset
435 Introduce MRI script files with
436 the option @samp{-c}; use the @samp{-T} option to run linker
437 scripts written in the general-purpose @command{ld} scripting language.
438 If @var{MRI-cmdfile} does not exist, @command{ld} looks for it in the directories
439 specified by any @samp{-L} options.
441 @cindex common allocation
442 @kindex -d
443 @kindex -dc
444 @kindex -dp
445 @item -d
446 @itemx -dc
447 @itemx -dp
448 These three options are equivalent; multiple forms are supported for
449 compatibility with other linkers.  They assign space to common symbols
450 even if a relocatable output file is specified (with @samp{-r}).  The
451 script command @code{FORCE_COMMON_ALLOCATION} has the same effect.
452 @xref{Miscellaneous Commands}.
454 @cindex entry point, from command line
455 @kindex -e @var{entry}
456 @kindex --entry=@var{entry}
457 @item -e @var{entry}
458 @itemx --entry=@var{entry}
459 Use @var{entry} as the explicit symbol for beginning execution of your
460 program, rather than the default entry point.  If there is no symbol
461 named @var{entry}, the linker will try to parse @var{entry} as a number,
462 and use that as the entry address (the number will be interpreted in
463 base 10; you may use a leading @samp{0x} for base 16, or a leading
464 @samp{0} for base 8).  @xref{Entry Point}, for a discussion of defaults
465 and other ways of specifying the entry point.
467 @kindex --exclude-libs
468 @item --exclude-libs @var{lib},@var{lib},...
469 Specifies a list of archive libraries from which symbols should not be automatically
470 exported.  The library names may be delimited by commas or colons.  Specifying
471 @code{--exclude-libs ALL} excludes symbols in all archive libraries from
472 automatic export.  This option is available only for the i386 PE targeted
473 port of the linker and for ELF targeted ports.  For i386 PE, symbols
474 explicitly listed in a .def file are still exported, regardless of this
475 option.  For ELF targeted ports, symbols affected by this option will
476 be treated as hidden.
478 @kindex --exclude-modules-for-implib
479 @item --exclude-modules-for-implib @var{module},@var{module},...
480 Specifies a list of object files or archive members, from which symbols
481 should not be automatically exported, but which should be copied wholesale
482 into the import library being generated during the link.  The module names
483 may be delimited by commas or colons, and must match exactly the filenames
484 used by @command{ld} to open the files; for archive members, this is simply
485 the member name, but for object files the name listed must include and
486 match precisely any path used to specify the input file on the linker's
487 command-line.  This option is available only for the i386 PE targeted port
488 of the linker.  Symbols explicitly listed in a .def file are still exported,
489 regardless of this option.
491 @cindex dynamic symbol table
492 @kindex -E
493 @kindex --export-dynamic
494 @item -E
495 @itemx --export-dynamic
496 When creating a dynamically linked executable, add all symbols to the
497 dynamic symbol table.  The dynamic symbol table is the set of symbols
498 which are visible from dynamic objects at run time.
500 If you do not use this option, the dynamic symbol table will normally
501 contain only those symbols which are referenced by some dynamic object
502 mentioned in the link.
504 If you use @code{dlopen} to load a dynamic object which needs to refer
505 back to the symbols defined by the program, rather than some other
506 dynamic object, then you will probably need to use this option when
507 linking the program itself.
509 You can also use the dynamic list to control what symbols should
510 be added to the dynamic symbol table if the output format supports it.
511 See the description of @samp{--dynamic-list}.
513 @ifclear SingleFormat
514 @cindex big-endian objects
515 @cindex endianness
516 @kindex -EB
517 @item -EB
518 Link big-endian objects.  This affects the default output format.
520 @cindex little-endian objects
521 @kindex -EL
522 @item -EL
523 Link little-endian objects.  This affects the default output format.
524 @end ifclear
526 @kindex -f @var{name}
527 @kindex --auxiliary=@var{name}
528 @item -f @var{name}
529 @itemx --auxiliary=@var{name}
530 When creating an ELF shared object, set the internal DT_AUXILIARY field
531 to the specified name.  This tells the dynamic linker that the symbol
532 table of the shared object should be used as an auxiliary filter on the
533 symbol table of the shared object @var{name}.
535 If you later link a program against this filter object, then, when you
536 run the program, the dynamic linker will see the DT_AUXILIARY field.  If
537 the dynamic linker resolves any symbols from the filter object, it will
538 first check whether there is a definition in the shared object
539 @var{name}.  If there is one, it will be used instead of the definition
540 in the filter object.  The shared object @var{name} need not exist.
541 Thus the shared object @var{name} may be used to provide an alternative
542 implementation of certain functions, perhaps for debugging or for
543 machine specific performance.
545 This option may be specified more than once.  The DT_AUXILIARY entries
546 will be created in the order in which they appear on the command line.
548 @kindex -F @var{name}
549 @kindex --filter=@var{name}
550 @item -F @var{name}
551 @itemx --filter=@var{name}
552 When creating an ELF shared object, set the internal DT_FILTER field to
553 the specified name.  This tells the dynamic linker that the symbol table
554 of the shared object which is being created should be used as a filter
555 on the symbol table of the shared object @var{name}.
557 If you later link a program against this filter object, then, when you
558 run the program, the dynamic linker will see the DT_FILTER field.  The
559 dynamic linker will resolve symbols according to the symbol table of the
560 filter object as usual, but it will actually link to the definitions
561 found in the shared object @var{name}.  Thus the filter object can be
562 used to select a subset of the symbols provided by the object
563 @var{name}.
565 Some older linkers used the @option{-F} option throughout a compilation
566 toolchain for specifying object-file format for both input and output
567 object files.
568 @ifclear SingleFormat
569 The @sc{gnu} linker uses other mechanisms for this purpose: the
570 @option{-b}, @option{--format}, @option{--oformat} options, the
571 @code{TARGET} command in linker scripts, and the @code{GNUTARGET}
572 environment variable.
573 @end ifclear
574 The @sc{gnu} linker will ignore the @option{-F} option when not
575 creating an ELF shared object.
577 @cindex finalization function
578 @kindex -fini=@var{name}
579 @item -fini=@var{name}
580 When creating an ELF executable or shared object, call NAME when the
581 executable or shared object is unloaded, by setting DT_FINI to the
582 address of the function.  By default, the linker uses @code{_fini} as
583 the function to call.
585 @kindex -g
586 @item -g
587 Ignored.  Provided for compatibility with other tools.
589 @kindex -G @var{value}
590 @kindex --gpsize=@var{value}
591 @cindex object size
592 @item -G @var{value}
593 @itemx --gpsize=@var{value}
594 Set the maximum size of objects to be optimized using the GP register to
595 @var{size}.  This is only meaningful for object file formats such as
596 MIPS ECOFF which supports putting large and small objects into different
597 sections.  This is ignored for other object file formats.
599 @cindex runtime library name
600 @kindex -h @var{name}
601 @kindex -soname=@var{name}
602 @item -h @var{name}
603 @itemx -soname=@var{name}
604 When creating an ELF shared object, set the internal DT_SONAME field to
605 the specified name.  When an executable is linked with a shared object
606 which has a DT_SONAME field, then when the executable is run the dynamic
607 linker will attempt to load the shared object specified by the DT_SONAME
608 field rather than the using the file name given to the linker.
610 @kindex -i
611 @cindex incremental link
612 @item -i
613 Perform an incremental link (same as option @samp{-r}).
615 @cindex initialization function
616 @kindex -init=@var{name}
617 @item -init=@var{name}
618 When creating an ELF executable or shared object, call NAME when the
619 executable or shared object is loaded, by setting DT_INIT to the address
620 of the function.  By default, the linker uses @code{_init} as the
621 function to call.
623 @cindex archive files, from cmd line
624 @kindex -l @var{namespec}
625 @kindex --library=@var{namespec}
626 @item -l @var{namespec}
627 @itemx --library=@var{namespec}
628 Add the archive or object file specified by @var{namespec} to the
629 list of files to link.  This option may be used any number of times.
630 If @var{namespec} is of the form @file{:@var{filename}}, @command{ld}
631 will search the library path for a file called @var{filename}, otherise it
632 will search the library path for a file called @file{lib@var{namespec}.a}.
634 On systems which support shared libraries, @command{ld} may also search for
635 files other than @file{lib@var{namespec}.a}.  Specifically, on ELF
636 and SunOS systems, @command{ld} will search a directory for a library
637 called @file{lib@var{namespec}.so} before searching for one called
638 @file{lib@var{namespec}.a}.  (By convention, a @code{.so} extension
639 indicates a shared library.)  Note that this behavior does not apply
640 to @file{:@var{filename}}, which always specifies a file called
641 @var{filename}.
643 The linker will search an archive only once, at the location where it is
644 specified on the command line.  If the archive defines a symbol which
645 was undefined in some object which appeared before the archive on the
646 command line, the linker will include the appropriate file(s) from the
647 archive.  However, an undefined symbol in an object appearing later on
648 the command line will not cause the linker to search the archive again.
650 See the @option{-(} option for a way to force the linker to search
651 archives multiple times.
653 You may list the same archive multiple times on the command line.
655 @ifset GENERIC
656 This type of archive searching is standard for Unix linkers.  However,
657 if you are using @command{ld} on AIX, note that it is different from the
658 behaviour of the AIX linker.
659 @end ifset
661 @cindex search directory, from cmd line
662 @kindex -L @var{dir}
663 @kindex --library-path=@var{dir}
664 @item -L @var{searchdir}
665 @itemx --library-path=@var{searchdir}
666 Add path @var{searchdir} to the list of paths that @command{ld} will search
667 for archive libraries and @command{ld} control scripts.  You may use this
668 option any number of times.  The directories are searched in the order
669 in which they are specified on the command line.  Directories specified
670 on the command line are searched before the default directories.  All
671 @option{-L} options apply to all @option{-l} options, regardless of the
672 order in which the options appear.
674 If @var{searchdir} begins with @code{=}, then the @code{=} will be replaced
675 by the @dfn{sysroot prefix}, a path specified when the linker is configured.
677 @ifset UsesEnvVars
678 The default set of paths searched (without being specified with
679 @samp{-L}) depends on which emulation mode @command{ld} is using, and in
680 some cases also on how it was configured.  @xref{Environment}.
681 @end ifset
683 The paths can also be specified in a link script with the
684 @code{SEARCH_DIR} command.  Directories specified this way are searched
685 at the point in which the linker script appears in the command line.
687 @cindex emulation
688 @kindex -m @var{emulation}
689 @item -m @var{emulation}
690 Emulate the @var{emulation} linker.  You can list the available
691 emulations with the @samp{--verbose} or @samp{-V} options.
693 If the @samp{-m} option is not used, the emulation is taken from the
694 @code{LDEMULATION} environment variable, if that is defined.
696 Otherwise, the default emulation depends upon how the linker was
697 configured.
699 @cindex link map
700 @kindex -M
701 @kindex --print-map
702 @item -M
703 @itemx --print-map
704 Print a link map to the standard output.  A link map provides
705 information about the link, including the following:
707 @itemize @bullet
708 @item
709 Where object files are mapped into memory.
710 @item
711 How common symbols are allocated.
712 @item
713 All archive members included in the link, with a mention of the symbol
714 which caused the archive member to be brought in.
715 @item
716 The values assigned to symbols.
718 Note - symbols whose values are computed by an expression which
719 involves a reference to a previous value of the same symbol may not
720 have correct result displayed in the link map.  This is because the
721 linker discards intermediate results and only retains the final value
722 of an expression.  Under such circumstances the linker will display
723 the final value enclosed by square brackets.  Thus for example a
724 linker script containing:
726 @smallexample
727    foo = 1
728    foo = foo * 4
729    foo = foo + 8
730 @end smallexample
732 will produce the following output in the link map if the @option{-M}
733 option is used:
735 @smallexample
736    0x00000001                foo = 0x1
737    [0x0000000c]                foo = (foo * 0x4)
738    [0x0000000c]                foo = (foo + 0x8)
739 @end smallexample
741 See @ref{Expressions} for more information about expressions in linker
742 scripts.
743 @end itemize
745 @kindex -n
746 @cindex read-only text
747 @cindex NMAGIC
748 @kindex --nmagic
749 @item -n
750 @itemx --nmagic
751 Turn off page alignment of sections, and mark the output as
752 @code{NMAGIC} if possible.
754 @kindex -N
755 @kindex --omagic
756 @cindex read/write from cmd line
757 @cindex OMAGIC
758 @item -N
759 @itemx --omagic
760 Set the text and data sections to be readable and writable.  Also, do
761 not page-align the data segment, and disable linking against shared
762 libraries.  If the output format supports Unix style magic numbers,
763 mark the output as @code{OMAGIC}. Note: Although a writable text section
764 is allowed for PE-COFF targets, it does not conform to the format
765 specification published by Microsoft.
767 @kindex --no-omagic
768 @cindex OMAGIC
769 @item --no-omagic
770 This option negates most of the effects of the @option{-N} option.  It
771 sets the text section to be read-only, and forces the data segment to
772 be page-aligned.  Note - this option does not enable linking against
773 shared libraries.  Use @option{-Bdynamic} for this.
775 @kindex -o @var{output}
776 @kindex --output=@var{output}
777 @cindex naming the output file
778 @item -o @var{output}
779 @itemx --output=@var{output}
780 Use @var{output} as the name for the program produced by @command{ld}; if this
781 option is not specified, the name @file{a.out} is used by default.  The
782 script command @code{OUTPUT} can also specify the output file name.
784 @kindex -O @var{level}
785 @cindex generating optimized output
786 @item -O @var{level}
787 If @var{level} is a numeric values greater than zero @command{ld} optimizes
788 the output.  This might take significantly longer and therefore probably
789 should only be enabled for the final binary.  At the moment this
790 option only affects ELF shared library generation.  Future releases of
791 the linker may make more use of this option.  Also currently there is
792 no difference in the linker's behaviour for different non-zero values
793 of this option.  Again this may change with future releases.
795 @kindex -q
796 @kindex --emit-relocs
797 @cindex retain relocations in final executable
798 @item -q
799 @itemx --emit-relocs
800 Leave relocation sections and contents in fully linked executables.
801 Post link analysis and optimization tools may need this information in
802 order to perform correct modifications of executables.  This results
803 in larger executables.
805 This option is currently only supported on ELF platforms.
807 @kindex --force-dynamic
808 @cindex forcing the creation of dynamic sections
809 @item --force-dynamic
810 Force the output file to have dynamic sections.  This option is specific
811 to VxWorks targets.
813 @cindex partial link
814 @cindex relocatable output
815 @kindex -r
816 @kindex --relocatable
817 @item -r
818 @itemx --relocatable
819 Generate relocatable output---i.e., generate an output file that can in
820 turn serve as input to @command{ld}.  This is often called @dfn{partial
821 linking}.  As a side effect, in environments that support standard Unix
822 magic numbers, this option also sets the output file's magic number to
823 @code{OMAGIC}.
824 @c ; see @option{-N}.
825 If this option is not specified, an absolute file is produced.  When
826 linking C++ programs, this option @emph{will not} resolve references to
827 constructors; to do that, use @samp{-Ur}.
829 When an input file does not have the same format as the output file,
830 partial linking is only supported if that input file does not contain any
831 relocations.  Different output formats can have further restrictions; for
832 example some @code{a.out}-based formats do not support partial linking
833 with input files in other formats at all.
835 This option does the same thing as @samp{-i}.
837 @kindex -R @var{file}
838 @kindex --just-symbols=@var{file}
839 @cindex symbol-only input
840 @item -R @var{filename}
841 @itemx --just-symbols=@var{filename}
842 Read symbol names and their addresses from @var{filename}, but do not
843 relocate it or include it in the output.  This allows your output file
844 to refer symbolically to absolute locations of memory defined in other
845 programs.  You may use this option more than once.
847 For compatibility with other ELF linkers, if the @option{-R} option is
848 followed by a directory name, rather than a file name, it is treated as
849 the @option{-rpath} option.
851 @kindex -s
852 @kindex --strip-all
853 @cindex strip all symbols
854 @item -s
855 @itemx --strip-all
856 Omit all symbol information from the output file.
858 @kindex -S
859 @kindex --strip-debug
860 @cindex strip debugger symbols
861 @item -S
862 @itemx --strip-debug
863 Omit debugger symbol information (but not all symbols) from the output file.
865 @kindex -t
866 @kindex --trace
867 @cindex input files, displaying
868 @item -t
869 @itemx --trace
870 Print the names of the input files as @command{ld} processes them.
872 @kindex -T @var{script}
873 @kindex --script=@var{script}
874 @cindex script files
875 @item -T @var{scriptfile}
876 @itemx --script=@var{scriptfile}
877 Use @var{scriptfile} as the linker script.  This script replaces
878 @command{ld}'s default linker script (rather than adding to it), so
879 @var{commandfile} must specify everything necessary to describe the
880 output file.  @xref{Scripts}.  If @var{scriptfile} does not exist in
881 the current directory, @code{ld} looks for it in the directories
882 specified by any preceding @samp{-L} options.  Multiple @samp{-T}
883 options accumulate.
885 @kindex -dT @var{script}
886 @kindex --default-script=@var{script}
887 @cindex script files
888 @item -dT @var{scriptfile}
889 @itemx --default-script=@var{scriptfile}
890 Use @var{scriptfile} as the default linker script.  @xref{Scripts}.
892 This option is similar to the @option{--script} option except that
893 processing of the script is delayed until after the rest of the
894 command line has been processed.  This allows options placed after the
895 @option{--default-script} option on the command line to affect the
896 behaviour of the linker script, which can be important when the linker
897 command line cannot be directly controlled by the user.  (eg because
898 the command line is being constructed by another tool, such as
899 @samp{gcc}).
901 @kindex -u @var{symbol}
902 @kindex --undefined=@var{symbol}
903 @cindex undefined symbol
904 @item -u @var{symbol}
905 @itemx --undefined=@var{symbol}
906 Force @var{symbol} to be entered in the output file as an undefined
907 symbol.  Doing this may, for example, trigger linking of additional
908 modules from standard libraries.  @samp{-u} may be repeated with
909 different option arguments to enter additional undefined symbols.  This
910 option is equivalent to the @code{EXTERN} linker script command.
912 @kindex -Ur
913 @cindex constructors
914 @item -Ur
915 For anything other than C++ programs, this option is equivalent to
916 @samp{-r}: it generates relocatable output---i.e., an output file that can in
917 turn serve as input to @command{ld}.  When linking C++ programs, @samp{-Ur}
918 @emph{does} resolve references to constructors, unlike @samp{-r}.
919 It does not work to use @samp{-Ur} on files that were themselves linked
920 with @samp{-Ur}; once the constructor table has been built, it cannot
921 be added to.  Use @samp{-Ur} only for the last partial link, and
922 @samp{-r} for the others.
924 @kindex --unique[=@var{SECTION}]
925 @item --unique[=@var{SECTION}]
926 Creates a separate output section for every input section matching
927 @var{SECTION}, or if the optional wildcard @var{SECTION} argument is
928 missing, for every orphan input section.  An orphan section is one not
929 specifically mentioned in a linker script.  You may use this option
930 multiple times on the command line;  It prevents the normal merging of
931 input sections with the same name, overriding output section assignments
932 in a linker script.
934 @kindex -v
935 @kindex -V
936 @kindex --version
937 @cindex version
938 @item -v
939 @itemx --version
940 @itemx -V
941 Display the version number for @command{ld}.  The @option{-V} option also
942 lists the supported emulations.
944 @kindex -x
945 @kindex --discard-all
946 @cindex deleting local symbols
947 @item -x
948 @itemx --discard-all
949 Delete all local symbols.
951 @kindex -X
952 @kindex --discard-locals
953 @cindex local symbols, deleting
954 @item -X
955 @itemx --discard-locals
956 Delete all temporary local symbols.  (These symbols start with
957 system-specific local label prefixes, typically @samp{.L} for ELF systems
958 or @samp{L} for traditional a.out systems.)
960 @kindex -y @var{symbol}
961 @kindex --trace-symbol=@var{symbol}
962 @cindex symbol tracing
963 @item -y @var{symbol}
964 @itemx --trace-symbol=@var{symbol}
965 Print the name of each linked file in which @var{symbol} appears.  This
966 option may be given any number of times.  On many systems it is necessary
967 to prepend an underscore.
969 This option is useful when you have an undefined symbol in your link but
970 don't know where the reference is coming from.
972 @kindex -Y @var{path}
973 @item -Y @var{path}
974 Add @var{path} to the default library search path.  This option exists
975 for Solaris compatibility.
977 @kindex -z @var{keyword}
978 @item -z @var{keyword}
979 The recognized keywords are:
980 @table @samp
982 @item combreloc
983 Combines multiple reloc sections and sorts them to make dynamic symbol
984 lookup caching possible.
986 @item defs
987 Disallows undefined symbols in object files.  Undefined symbols in
988 shared libraries are still allowed.
990 @item execstack
991 Marks the object as requiring executable stack.
993 @item initfirst
994 This option is only meaningful when building a shared object.
995 It marks the object so that its runtime initialization will occur
996 before the runtime initialization of any other objects brought into
997 the process at the same time.  Similarly the runtime finalization of
998 the object will occur after the runtime finalization of any other
999 objects.
1001 @item interpose
1002 Marks the object that its symbol table interposes before all symbols
1003 but the primary executable.
1005 @item lazy
1006 When generating an executable or shared library, mark it to tell the
1007 dynamic linker to defer function call resolution to the point when
1008 the function is called (lazy binding), rather than at load time.
1009 Lazy binding is the default.
1011 @item loadfltr
1012 Marks  the object that its filters be processed immediately at
1013 runtime.
1015 @item muldefs
1016 Allows multiple definitions.
1018 @item nocombreloc
1019 Disables multiple reloc sections combining.
1021 @item nocopyreloc
1022 Disables production of copy relocs.
1024 @item nodefaultlib
1025 Marks the object that the search for dependencies of this object will
1026 ignore any default library search paths.
1028 @item nodelete
1029 Marks the object shouldn't be unloaded at runtime.
1031 @item nodlopen
1032 Marks the object not available to @code{dlopen}.
1034 @item nodump
1035 Marks the object can not be dumped by @code{dldump}.
1037 @item noexecstack
1038 Marks the object as not requiring executable stack.
1040 @item norelro
1041 Don't create an ELF @code{PT_GNU_RELRO} segment header in the object.
1043 @item now
1044 When generating an executable or shared library, mark it to tell the
1045 dynamic linker to resolve all symbols when the program is started, or
1046 when the shared library is linked to using dlopen, instead of
1047 deferring function call resolution to the point when the function is
1048 first called.
1050 @item origin
1051 Marks the object may contain $ORIGIN.
1053 @item relro
1054 Create an ELF @code{PT_GNU_RELRO} segment header in the object.
1056 @item max-page-size=@var{value}
1057 Set the emulation maximum page size to @var{value}.
1059 @item common-page-size=@var{value}
1060 Set the emulation common page size to @var{value}.
1062 @end table
1064 Other keywords are ignored for Solaris compatibility.
1066 @kindex -(
1067 @cindex groups of archives
1068 @item -( @var{archives} -)
1069 @itemx --start-group @var{archives} --end-group
1070 The @var{archives} should be a list of archive files.  They may be
1071 either explicit file names, or @samp{-l} options.
1073 The specified archives are searched repeatedly until no new undefined
1074 references are created.  Normally, an archive is searched only once in
1075 the order that it is specified on the command line.  If a symbol in that
1076 archive is needed to resolve an undefined symbol referred to by an
1077 object in an archive that appears later on the command line, the linker
1078 would not be able to resolve that reference.  By grouping the archives,
1079 they all be searched repeatedly until all possible references are
1080 resolved.
1082 Using this option has a significant performance cost.  It is best to use
1083 it only when there are unavoidable circular references between two or
1084 more archives.
1086 @kindex --accept-unknown-input-arch
1087 @kindex --no-accept-unknown-input-arch
1088 @item --accept-unknown-input-arch
1089 @itemx --no-accept-unknown-input-arch
1090 Tells the linker to accept input files whose architecture cannot be
1091 recognised.  The assumption is that the user knows what they are doing
1092 and deliberately wants to link in these unknown input files.  This was
1093 the default behaviour of the linker, before release 2.14.  The default
1094 behaviour from release 2.14 onwards is to reject such input files, and
1095 so the @samp{--accept-unknown-input-arch} option has been added to
1096 restore the old behaviour.
1098 @kindex --as-needed
1099 @kindex --no-as-needed
1100 @item --as-needed
1101 @itemx --no-as-needed
1102 This option affects ELF DT_NEEDED tags for dynamic libraries mentioned
1103 on the command line after the @option{--as-needed} option.  Normally,
1104 the linker will add a DT_NEEDED tag for each dynamic library mentioned
1105 on the command line, regardless of whether the library is actually
1106 needed.  @option{--as-needed} causes a DT_NEEDED tag to only be emitted
1107 for a library that satisfies a symbol reference from regular objects
1108 which is undefined at the point that the library was linked, or, if
1109 the library is not found in the DT_NEEDED lists of other libraries
1110 linked up to that point, a reference from another dynamic library.
1111 @option{--no-as-needed} restores the default behaviour.
1113 @kindex --add-needed
1114 @kindex --no-add-needed
1115 @item --add-needed
1116 @itemx --no-add-needed
1117 This option affects the treatment of dynamic libraries from ELF
1118 DT_NEEDED tags in dynamic libraries mentioned on the command line after
1119 the @option{--no-add-needed} option.  Normally, the linker will add
1120 a DT_NEEDED tag for each dynamic library from DT_NEEDED tags.
1121 @option{--no-add-needed} causes DT_NEEDED tags will never be emitted
1122 for those libraries from DT_NEEDED tags. @option{--add-needed} restores
1123 the default behaviour.
1125 @kindex -assert @var{keyword}
1126 @item -assert @var{keyword}
1127 This option is ignored for SunOS compatibility.
1129 @kindex -Bdynamic
1130 @kindex -dy
1131 @kindex -call_shared
1132 @item -Bdynamic
1133 @itemx -dy
1134 @itemx -call_shared
1135 Link against dynamic libraries.  This is only meaningful on platforms
1136 for which shared libraries are supported.  This option is normally the
1137 default on such platforms.  The different variants of this option are
1138 for compatibility with various systems.  You may use this option
1139 multiple times on the command line: it affects library searching for
1140 @option{-l} options which follow it.
1142 @kindex -Bgroup
1143 @item -Bgroup
1144 Set the @code{DF_1_GROUP} flag in the @code{DT_FLAGS_1} entry in the dynamic
1145 section.  This causes the runtime linker to handle lookups in this
1146 object and its dependencies to be performed only inside the group.
1147 @option{--unresolved-symbols=report-all} is implied.  This option is
1148 only meaningful on ELF platforms which support shared libraries.
1150 @kindex -Bstatic
1151 @kindex -dn
1152 @kindex -non_shared
1153 @kindex -static
1154 @item -Bstatic
1155 @itemx -dn
1156 @itemx -non_shared
1157 @itemx -static
1158 Do not link against shared libraries.  This is only meaningful on
1159 platforms for which shared libraries are supported.  The different
1160 variants of this option are for compatibility with various systems.  You
1161 may use this option multiple times on the command line: it affects
1162 library searching for @option{-l} options which follow it.  This
1163 option also implies @option{--unresolved-symbols=report-all}.  This
1164 option can be used with @option{-shared}.  Doing so means that a
1165 shared library is being created but that all of the library's external
1166 references must be resolved by pulling in entries from static
1167 libraries.
1169 @kindex -Bsymbolic
1170 @item -Bsymbolic
1171 When creating a shared library, bind references to global symbols to the
1172 definition within the shared library, if any.  Normally, it is possible
1173 for a program linked against a shared library to override the definition
1174 within the shared library.  This option is only meaningful on ELF
1175 platforms which support shared libraries.
1177 @kindex -Bsymbolic-functions
1178 @item -Bsymbolic-functions
1179 When creating a shared library, bind references to global function
1180 symbols to the definition within the shared library, if any.
1181 This option is only meaningful on ELF platforms which support shared
1182 libraries.
1184 @kindex --dynamic-list=@var{dynamic-list-file}
1185 @item --dynamic-list=@var{dynamic-list-file}
1186 Specify the name of a dynamic list file to the linker.  This is
1187 typically used when creating shared libraries to specify a list of
1188 global symbols whose references shouldn't be bound to the definition
1189 within the shared library, or creating dynamically linked executables
1190 to specify a list of symbols which should be added to the symbol table
1191 in the executable.  This option is only meaningful on ELF platforms
1192 which support shared libraries.
1194 The format of the dynamic list is the same as the version node without
1195 scope and node name.  See @ref{VERSION} for more information.
1197 @kindex --dynamic-list-data
1198 @item --dynamic-list-data
1199 Include all global data symbols to the dynamic list.
1201 @kindex --dynamic-list-cpp-new
1202 @item --dynamic-list-cpp-new
1203 Provide the builtin dynamic list for C++ operator new and delete.  It
1204 is mainly useful for building shared libstdc++.
1206 @kindex --dynamic-list-cpp-typeinfo
1207 @item --dynamic-list-cpp-typeinfo
1208 Provide the builtin dynamic list for C++ runtime type identification.
1210 @kindex --check-sections
1211 @kindex --no-check-sections
1212 @item --check-sections
1213 @itemx --no-check-sections
1214 Asks the linker @emph{not} to check section addresses after they have
1215 been assigned to see if there are any overlaps.  Normally the linker will
1216 perform this check, and if it finds any overlaps it will produce
1217 suitable error messages.  The linker does know about, and does make
1218 allowances for sections in overlays.  The default behaviour can be
1219 restored by using the command line switch @option{--check-sections}.
1220 Section overlap is not usually checked for relocatable links.  You can
1221 force checking in that case by using the @option{--check-sections}
1222 option.
1224 @cindex cross reference table
1225 @kindex --cref
1226 @item --cref
1227 Output a cross reference table.  If a linker map file is being
1228 generated, the cross reference table is printed to the map file.
1229 Otherwise, it is printed on the standard output.
1231 The format of the table is intentionally simple, so that it may be
1232 easily processed by a script if necessary.  The symbols are printed out,
1233 sorted by name.  For each symbol, a list of file names is given.  If the
1234 symbol is defined, the first file listed is the location of the
1235 definition.  The remaining files contain references to the symbol.
1237 @cindex common allocation
1238 @kindex --no-define-common
1239 @item --no-define-common
1240 This option inhibits the assignment of addresses to common symbols.
1241 The script command @code{INHIBIT_COMMON_ALLOCATION} has the same effect.
1242 @xref{Miscellaneous Commands}.
1244 The @samp{--no-define-common} option allows decoupling
1245 the decision to assign addresses to Common symbols from the choice
1246 of the output file type; otherwise a non-Relocatable output type
1247 forces assigning addresses to Common symbols.
1248 Using @samp{--no-define-common} allows Common symbols that are referenced
1249 from a shared library to be assigned addresses only in the main program.
1250 This eliminates the unused duplicate space in the shared library,
1251 and also prevents any possible confusion over resolving to the wrong
1252 duplicate when there are many dynamic modules with specialized search
1253 paths for runtime symbol resolution.
1255 @cindex symbols, from command line
1256 @kindex --defsym=@var{symbol}=@var{exp}
1257 @item --defsym=@var{symbol}=@var{expression}
1258 Create a global symbol in the output file, containing the absolute
1259 address given by @var{expression}.  You may use this option as many
1260 times as necessary to define multiple symbols in the command line.  A
1261 limited form of arithmetic is supported for the @var{expression} in this
1262 context: you may give a hexadecimal constant or the name of an existing
1263 symbol, or use @code{+} and @code{-} to add or subtract hexadecimal
1264 constants or symbols.  If you need more elaborate expressions, consider
1265 using the linker command language from a script (@pxref{Assignments,,
1266 Assignment: Symbol Definitions}).  @emph{Note:} there should be no white
1267 space between @var{symbol}, the equals sign (``@key{=}''), and
1268 @var{expression}.
1270 @cindex demangling, from command line
1271 @kindex --demangle[=@var{style}]
1272 @kindex --no-demangle
1273 @item --demangle[=@var{style}]
1274 @itemx --no-demangle
1275 These options control whether to demangle symbol names in error messages
1276 and other output.  When the linker is told to demangle, it tries to
1277 present symbol names in a readable fashion: it strips leading
1278 underscores if they are used by the object file format, and converts C++
1279 mangled symbol names into user readable names.  Different compilers have
1280 different mangling styles.  The optional demangling style argument can be used
1281 to choose an appropriate demangling style for your compiler.  The linker will
1282 demangle by default unless the environment variable @samp{COLLECT_NO_DEMANGLE}
1283 is set.  These options may be used to override the default.
1285 @cindex dynamic linker, from command line
1286 @kindex -I@var{file}
1287 @kindex --dynamic-linker=@var{file}
1288 @item -I@var{file}
1289 @itemx --dynamic-linker=@var{file}
1290 Set the name of the dynamic linker.  This is only meaningful when
1291 generating dynamically linked ELF executables.  The default dynamic
1292 linker is normally correct; don't use this unless you know what you are
1293 doing.
1295 @kindex --fatal-warnings
1296 @kindex --no-fatal-warnings
1297 @item --fatal-warnings
1298 @itemx --no-fatal-warnings
1299 Treat all warnings as errors.  The default behaviour can be restored
1300 with the option @option{--no-fatal-warnings}.
1302 @kindex --force-exe-suffix
1303 @item  --force-exe-suffix
1304 Make sure that an output file has a .exe suffix.
1306 If a successfully built fully linked output file does not have a
1307 @code{.exe} or @code{.dll} suffix, this option forces the linker to copy
1308 the output file to one of the same name with a @code{.exe} suffix. This
1309 option is useful when using unmodified Unix makefiles on a Microsoft
1310 Windows host, since some versions of Windows won't run an image unless
1311 it ends in a @code{.exe} suffix.
1313 @kindex --gc-sections
1314 @kindex --no-gc-sections
1315 @cindex garbage collection
1316 @item --gc-sections
1317 @itemx --no-gc-sections
1318 Enable garbage collection of unused input sections.  It is ignored on
1319 targets that do not support this option.  The default behaviour (of not
1320 performing this garbage collection) can be restored by specifying
1321 @samp{--no-gc-sections} on the command line.
1323 @samp{--gc-sections} decides which input sections are used by
1324 examining symbols and relocations.  The section containing the entry
1325 symbol and all sections containing symbols undefined on the
1326 command-line will be kept, as will sections containing symbols
1327 referenced by dynamic objects.  Note that when building shared
1328 libraries, the linker must assume that any visible symbol is
1329 referenced.  Once this initial set of sections has been determined,
1330 the linker recursively marks as used any section referenced by their
1331 relocations.  See @samp{--entry} and @samp{--undefined}.
1333 This option can be set when doing a partial link (enabled with option
1334 @samp{-r}).  In this case the root of symbols kept must be explicitely 
1335 specified either by an @samp{--entry} or @samp{--undefined} option or by
1336 a @code{ENTRY} command in the linker script.
1338 @kindex --print-gc-sections
1339 @kindex --no-print-gc-sections
1340 @cindex garbage collection
1341 @item --print-gc-sections
1342 @itemx --no-print-gc-sections
1343 List all sections removed by garbage collection.  The listing is
1344 printed on stderr.  This option is only effective if garbage
1345 collection has been enabled via the @samp{--gc-sections}) option.  The
1346 default behaviour (of not listing the sections that are removed) can
1347 be restored by specifying @samp{--no-print-gc-sections} on the command
1348 line.
1350 @cindex help
1351 @cindex usage
1352 @kindex --help
1353 @item --help
1354 Print a summary of the command-line options on the standard output and exit.
1356 @kindex --target-help
1357 @item --target-help
1358 Print a summary of all target specific options on the standard output and exit.
1360 @kindex -Map=@var{mapfile}
1361 @item -Map=@var{mapfile}
1362 Print a link map to the file @var{mapfile}.  See the description of the
1363 @option{-M} option, above.
1365 @cindex memory usage
1366 @kindex --no-keep-memory
1367 @item --no-keep-memory
1368 @command{ld} normally optimizes for speed over memory usage by caching the
1369 symbol tables of input files in memory.  This option tells @command{ld} to
1370 instead optimize for memory usage, by rereading the symbol tables as
1371 necessary.  This may be required if @command{ld} runs out of memory space
1372 while linking a large executable.
1374 @kindex --no-undefined
1375 @kindex -z defs
1376 @item --no-undefined
1377 @itemx -z defs
1378 Report unresolved symbol references from regular object files.  This
1379 is done even if the linker is creating a non-symbolic shared library.
1380 The switch @option{--[no-]allow-shlib-undefined} controls the
1381 behaviour for reporting unresolved references found in shared
1382 libraries being linked in.
1384 @kindex --allow-multiple-definition
1385 @kindex -z muldefs
1386 @item --allow-multiple-definition
1387 @itemx -z muldefs
1388 Normally when a symbol is defined multiple times, the linker will
1389 report a fatal error. These options allow multiple definitions and the
1390 first definition will be used.
1392 @kindex --allow-shlib-undefined
1393 @kindex --no-allow-shlib-undefined
1394 @item --allow-shlib-undefined
1395 @itemx --no-allow-shlib-undefined
1396 Allows or disallows undefined symbols in shared libraries.
1397 This switch is similar to @option{--no-undefined} except that it
1398 determines the behaviour when the undefined symbols are in a
1399 shared library rather than a regular object file.  It does not affect
1400 how undefined symbols in regular object files are handled.
1402 The default behaviour is to report errors for any undefined symbols
1403 referenced in shared libraries if the linker is being used to create
1404 an executable, but to allow them if the linker is being used to create
1405 a shared library.
1407 The reasons for allowing undefined symbol references in shared
1408 libraries specified at link time are that:
1410 @itemize @bullet
1411 @item
1412 A shared library specified at link time may not be the same as the one
1413 that is available at load time, so the symbol might actually be
1414 resolvable at load time.
1415 @item
1416 There are some operating systems, eg BeOS and HPPA, where undefined
1417 symbols in shared libraries are normal.
1419 The BeOS kernel for example patches shared libraries at load time to
1420 select whichever function is most appropriate for the current
1421 architecture.  This is used, for example, to dynamically select an
1422 appropriate memset function.
1423 @end itemize
1425 @kindex --no-undefined-version
1426 @item --no-undefined-version
1427 Normally when a symbol has an undefined version, the linker will ignore
1428 it. This option disallows symbols with undefined version and a fatal error
1429 will be issued instead.
1431 @kindex --default-symver
1432 @item --default-symver
1433 Create and use a default symbol version (the soname) for unversioned
1434 exported symbols.
1436 @kindex --default-imported-symver
1437 @item --default-imported-symver
1438 Create and use a default symbol version (the soname) for unversioned
1439 imported symbols.
1441 @kindex --no-warn-mismatch
1442 @item --no-warn-mismatch
1443 Normally @command{ld} will give an error if you try to link together input
1444 files that are mismatched for some reason, perhaps because they have
1445 been compiled for different processors or for different endiannesses.
1446 This option tells @command{ld} that it should silently permit such possible
1447 errors.  This option should only be used with care, in cases when you
1448 have taken some special action that ensures that the linker errors are
1449 inappropriate.
1451 @kindex --no-warn-search-mismatch
1452 @item --no-warn-search-mismatch
1453 Normally @command{ld} will give a warning if it finds an incompatible
1454 library during a library search.  This option silences the warning.
1456 @kindex --no-whole-archive
1457 @item --no-whole-archive
1458 Turn off the effect of the @option{--whole-archive} option for subsequent
1459 archive files.
1461 @cindex output file after errors
1462 @kindex --noinhibit-exec
1463 @item --noinhibit-exec
1464 Retain the executable output file whenever it is still usable.
1465 Normally, the linker will not produce an output file if it encounters
1466 errors during the link process; it exits without writing an output file
1467 when it issues any error whatsoever.
1469 @kindex -nostdlib
1470 @item -nostdlib
1471 Only search library directories explicitly specified on the
1472 command line.  Library directories specified in linker scripts
1473 (including linker scripts specified on the command line) are ignored.
1475 @ifclear SingleFormat
1476 @kindex --oformat=@var{output-format}
1477 @item --oformat=@var{output-format}
1478 @command{ld} may be configured to support more than one kind of object
1479 file.  If your @command{ld} is configured this way, you can use the
1480 @samp{--oformat} option to specify the binary format for the output
1481 object file.  Even when @command{ld} is configured to support alternative
1482 object formats, you don't usually need to specify this, as @command{ld}
1483 should be configured to produce as a default output format the most
1484 usual format on each machine.  @var{output-format} is a text string, the
1485 name of a particular format supported by the BFD libraries.  (You can
1486 list the available binary formats with @samp{objdump -i}.)  The script
1487 command @code{OUTPUT_FORMAT} can also specify the output format, but
1488 this option overrides it.  @xref{BFD}.
1489 @end ifclear
1491 @kindex -pie
1492 @kindex --pic-executable
1493 @item -pie
1494 @itemx --pic-executable
1495 @cindex position independent executables
1496 Create a position independent executable.  This is currently only supported on
1497 ELF platforms.  Position independent executables are similar to shared
1498 libraries in that they are relocated by the dynamic linker to the virtual
1499 address the OS chooses for them (which can vary between invocations).  Like
1500 normal dynamically linked executables they can be executed and symbols
1501 defined in the executable cannot be overridden by shared libraries.
1503 @kindex -qmagic
1504 @item -qmagic
1505 This option is ignored for Linux compatibility.
1507 @kindex -Qy
1508 @item -Qy
1509 This option is ignored for SVR4 compatibility.
1511 @kindex --relax
1512 @cindex synthesizing linker
1513 @cindex relaxing addressing modes
1514 @item --relax
1515 An option with machine dependent effects.
1516 @ifset GENERIC
1517 This option is only supported on a few targets.
1518 @end ifset
1519 @ifset H8300
1520 @xref{H8/300,,@command{ld} and the H8/300}.
1521 @end ifset
1522 @ifset I960
1523 @xref{i960,, @command{ld} and the Intel 960 family}.
1524 @end ifset
1525 @ifset XTENSA
1526 @xref{Xtensa,, @command{ld} and Xtensa Processors}.
1527 @end ifset
1528 @ifset M68HC11
1529 @xref{M68HC11/68HC12,,@command{ld} and the 68HC11 and 68HC12}.
1530 @end ifset
1531 @ifset POWERPC
1532 @xref{PowerPC ELF32,,@command{ld} and PowerPC 32-bit ELF Support}.
1533 @end ifset
1535 On some platforms, the @samp{--relax} option performs global
1536 optimizations that become possible when the linker resolves addressing
1537 in the program, such as relaxing address modes and synthesizing new
1538 instructions in the output object file.
1540 On some platforms these link time global optimizations may make symbolic
1541 debugging of the resulting executable impossible.
1542 @ifset GENERIC
1543 This is known to be
1544 the case for the Matsushita MN10200 and MN10300 family of processors.
1545 @end ifset
1547 @ifset GENERIC
1548 On platforms where this is not supported, @samp{--relax} is accepted,
1549 but ignored.
1550 @end ifset
1552 @cindex retaining specified symbols
1553 @cindex stripping all but some symbols
1554 @cindex symbols, retaining selectively
1555 @kindex --retain-symbols-file=@var{filename}
1556 @item --retain-symbols-file=@var{filename}
1557 Retain @emph{only} the symbols listed in the file @var{filename},
1558 discarding all others.  @var{filename} is simply a flat file, with one
1559 symbol name per line.  This option is especially useful in environments
1560 @ifset GENERIC
1561 (such as VxWorks)
1562 @end ifset
1563 where a large global symbol table is accumulated gradually, to conserve
1564 run-time memory.
1566 @samp{--retain-symbols-file} does @emph{not} discard undefined symbols,
1567 or symbols needed for relocations.
1569 You may only specify @samp{--retain-symbols-file} once in the command
1570 line.  It overrides @samp{-s} and @samp{-S}.
1572 @ifset GENERIC
1573 @item -rpath=@var{dir}
1574 @cindex runtime library search path
1575 @kindex -rpath=@var{dir}
1576 Add a directory to the runtime library search path.  This is used when
1577 linking an ELF executable with shared objects.  All @option{-rpath}
1578 arguments are concatenated and passed to the runtime linker, which uses
1579 them to locate shared objects at runtime.  The @option{-rpath} option is
1580 also used when locating shared objects which are needed by shared
1581 objects explicitly included in the link; see the description of the
1582 @option{-rpath-link} option.  If @option{-rpath} is not used when linking an
1583 ELF executable, the contents of the environment variable
1584 @code{LD_RUN_PATH} will be used if it is defined.
1586 The @option{-rpath} option may also be used on SunOS.  By default, on
1587 SunOS, the linker will form a runtime search patch out of all the
1588 @option{-L} options it is given.  If a @option{-rpath} option is used, the
1589 runtime search path will be formed exclusively using the @option{-rpath}
1590 options, ignoring the @option{-L} options.  This can be useful when using
1591 gcc, which adds many @option{-L} options which may be on NFS mounted
1592 file systems.
1594 For compatibility with other ELF linkers, if the @option{-R} option is
1595 followed by a directory name, rather than a file name, it is treated as
1596 the @option{-rpath} option.
1597 @end ifset
1599 @ifset GENERIC
1600 @cindex link-time runtime library search path
1601 @kindex -rpath-link=@var{dir}
1602 @item -rpath-link=@var{dir}
1603 When using ELF or SunOS, one shared library may require another.  This
1604 happens when an @code{ld -shared} link includes a shared library as one
1605 of the input files.
1607 When the linker encounters such a dependency when doing a non-shared,
1608 non-relocatable link, it will automatically try to locate the required
1609 shared library and include it in the link, if it is not included
1610 explicitly.  In such a case, the @option{-rpath-link} option
1611 specifies the first set of directories to search.  The
1612 @option{-rpath-link} option may specify a sequence of directory names
1613 either by specifying a list of names separated by colons, or by
1614 appearing multiple times.
1616 This option should be used with caution as it overrides the search path
1617 that may have been hard compiled into a shared library. In such a case it
1618 is possible to use unintentionally a different search path than the
1619 runtime linker would do.
1621 The linker uses the following search paths to locate required shared
1622 libraries:
1623 @enumerate
1624 @item
1625 Any directories specified by @option{-rpath-link} options.
1626 @item
1627 Any directories specified by @option{-rpath} options.  The difference
1628 between @option{-rpath} and @option{-rpath-link} is that directories
1629 specified by @option{-rpath} options are included in the executable and
1630 used at runtime, whereas the @option{-rpath-link} option is only effective
1631 at link time. Searching @option{-rpath} in this way is only supported
1632 by native linkers and cross linkers which have been configured with
1633 the @option{--with-sysroot} option.
1634 @item
1635 On an ELF system, for native linkers, if the @option{-rpath} and
1636 @option{-rpath-link} options were not used, search the contents of the
1637 environment variable @code{LD_RUN_PATH}.
1638 @item
1639 On SunOS, if the @option{-rpath} option was not used, search any
1640 directories specified using @option{-L} options.
1641 @item
1642 For a native linker, the search the contents of the environment
1643 variable @code{LD_LIBRARY_PATH}.
1644 @item
1645 For a native ELF linker, the directories in @code{DT_RUNPATH} or
1646 @code{DT_RPATH} of a shared library are searched for shared
1647 libraries needed by it. The @code{DT_RPATH} entries are ignored if
1648 @code{DT_RUNPATH} entries exist.
1649 @item
1650 The default directories, normally @file{/lib} and @file{/usr/lib}.
1651 @item
1652 For a native linker on an ELF system, if the file @file{/etc/ld.so.conf}
1653 exists, the list of directories found in that file.
1654 @end enumerate
1656 If the required shared library is not found, the linker will issue a
1657 warning and continue with the link.
1658 @end ifset
1660 @kindex -shared
1661 @kindex -Bshareable
1662 @item -shared
1663 @itemx -Bshareable
1664 @cindex shared libraries
1665 Create a shared library.  This is currently only supported on ELF, XCOFF
1666 and SunOS platforms.  On SunOS, the linker will automatically create a
1667 shared library if the @option{-e} option is not used and there are
1668 undefined symbols in the link.
1670 @kindex --sort-common
1671 @item --sort-common
1672 @itemx --sort-common=ascending
1673 @itemx --sort-common=descending
1674 This option tells @command{ld} to sort the common symbols by alignment in
1675 ascending or descending order when it places them in the appropriate output
1676 sections.  The symbol alignments considered are sixteen-byte or larger,
1677 eight-byte, four-byte, two-byte, and one-byte. This is to prevent gaps
1678 between symbols due to alignment constraints.  If no sorting order is
1679 specified, then descending order is assumed.
1681 @kindex --sort-section=name
1682 @item --sort-section=name
1683 This option will apply @code{SORT_BY_NAME} to all wildcard section
1684 patterns in the linker script.
1686 @kindex --sort-section=alignment
1687 @item --sort-section=alignment
1688 This option will apply @code{SORT_BY_ALIGNMENT} to all wildcard section
1689 patterns in the linker script.
1691 @kindex --split-by-file
1692 @item --split-by-file[=@var{size}]
1693 Similar to @option{--split-by-reloc} but creates a new output section for
1694 each input file when @var{size} is reached.  @var{size} defaults to a
1695 size of 1 if not given.
1697 @kindex --split-by-reloc
1698 @item --split-by-reloc[=@var{count}]
1699 Tries to creates extra sections in the output file so that no single
1700 output section in the file contains more than @var{count} relocations.
1701 This is useful when generating huge relocatable files for downloading into
1702 certain real time kernels with the COFF object file format; since COFF
1703 cannot represent more than 65535 relocations in a single section.  Note
1704 that this will fail to work with object file formats which do not
1705 support arbitrary sections.  The linker will not split up individual
1706 input sections for redistribution, so if a single input section contains
1707 more than @var{count} relocations one output section will contain that
1708 many relocations.  @var{count} defaults to a value of 32768.
1710 @kindex --stats
1711 @item --stats
1712 Compute and display statistics about the operation of the linker, such
1713 as execution time and memory usage.
1715 @kindex --sysroot=@var{directory}
1716 @item --sysroot=@var{directory}
1717 Use @var{directory} as the location of the sysroot, overriding the
1718 configure-time default.  This option is only supported by linkers
1719 that were configured using @option{--with-sysroot}.
1721 @kindex --traditional-format
1722 @cindex traditional format
1723 @item --traditional-format
1724 For some targets, the output of @command{ld} is different in some ways from
1725 the output of some existing linker.  This switch requests @command{ld} to
1726 use the traditional format instead.
1728 @cindex dbx
1729 For example, on SunOS, @command{ld} combines duplicate entries in the
1730 symbol string table.  This can reduce the size of an output file with
1731 full debugging information by over 30 percent.  Unfortunately, the SunOS
1732 @code{dbx} program can not read the resulting program (@code{gdb} has no
1733 trouble).  The @samp{--traditional-format} switch tells @command{ld} to not
1734 combine duplicate entries.
1736 @kindex --section-start=@var{sectionname}=@var{org}
1737 @item --section-start=@var{sectionname}=@var{org}
1738 Locate a section in the output file at the absolute
1739 address given by @var{org}.  You may use this option as many
1740 times as necessary to locate multiple sections in the command
1741 line.
1742 @var{org} must be a single hexadecimal integer;
1743 for compatibility with other linkers, you may omit the leading
1744 @samp{0x} usually associated with hexadecimal values.  @emph{Note:} there
1745 should be no white space between @var{sectionname}, the equals
1746 sign (``@key{=}''), and @var{org}.
1748 @kindex -Tbss=@var{org}
1749 @kindex -Tdata=@var{org}
1750 @kindex -Ttext=@var{org}
1751 @cindex segment origins, cmd line
1752 @item -Tbss=@var{org}
1753 @itemx -Tdata=@var{org}
1754 @itemx -Ttext=@var{org}
1755 Same as @option{--section-start}, with @code{.bss}, @code{.data} or
1756 @code{.text} as the @var{sectionname}.
1758 @kindex -Ttext-segment=@var{org}
1759 @item -Ttext-segment=@var{org}
1760 @cindex text segment origin, cmd line
1761 When creating an ELF executable or shared object, it will set the address
1762 of the first byte of the text segment.
1764 @kindex --unresolved-symbols
1765 @item --unresolved-symbols=@var{method}
1766 Determine how to handle unresolved symbols.  There are four possible
1767 values for @samp{method}:
1769 @table @samp
1770 @item ignore-all
1771 Do not report any unresolved symbols.
1773 @item report-all
1774 Report all unresolved symbols.  This is the default.
1776 @item ignore-in-object-files
1777 Report unresolved symbols that are contained in shared libraries, but
1778 ignore them if they come from regular object files.
1780 @item ignore-in-shared-libs
1781 Report unresolved symbols that come from regular object files, but
1782 ignore them if they come from shared libraries.  This can be useful
1783 when creating a dynamic binary and it is known that all the shared
1784 libraries that it should be referencing are included on the linker's
1785 command line.
1786 @end table
1788 The behaviour for shared libraries on their own can also be controlled
1789 by the @option{--[no-]allow-shlib-undefined} option.
1791 Normally the linker will generate an error message for each reported
1792 unresolved symbol but the option @option{--warn-unresolved-symbols}
1793 can change this to a warning.
1795 @kindex --verbose
1796 @cindex verbose
1797 @item --dll-verbose
1798 @itemx --verbose
1799 Display the version number for @command{ld} and list the linker emulations
1800 supported.  Display which input files can and cannot be opened.  Display
1801 the linker script being used by the linker.
1803 @kindex --version-script=@var{version-scriptfile}
1804 @cindex version script, symbol versions
1805 @item --version-script=@var{version-scriptfile}
1806 Specify the name of a version script to the linker.  This is typically
1807 used when creating shared libraries to specify additional information
1808 about the version hierarchy for the library being created.  This option
1809 is only meaningful on ELF platforms which support shared libraries.
1810 @xref{VERSION}.
1812 @kindex --warn-common
1813 @cindex warnings, on combining symbols
1814 @cindex combining symbols, warnings on
1815 @item --warn-common
1816 Warn when a common symbol is combined with another common symbol or with
1817 a symbol definition.  Unix linkers allow this somewhat sloppy practise,
1818 but linkers on some other operating systems do not.  This option allows
1819 you to find potential problems from combining global symbols.
1820 Unfortunately, some C libraries use this practise, so you may get some
1821 warnings about symbols in the libraries as well as in your programs.
1823 There are three kinds of global symbols, illustrated here by C examples:
1825 @table @samp
1826 @item int i = 1;
1827 A definition, which goes in the initialized data section of the output
1828 file.
1830 @item extern int i;
1831 An undefined reference, which does not allocate space.
1832 There must be either a definition or a common symbol for the
1833 variable somewhere.
1835 @item int i;
1836 A common symbol.  If there are only (one or more) common symbols for a
1837 variable, it goes in the uninitialized data area of the output file.
1838 The linker merges multiple common symbols for the same variable into a
1839 single symbol.  If they are of different sizes, it picks the largest
1840 size.  The linker turns a common symbol into a declaration, if there is
1841 a definition of the same variable.
1842 @end table
1844 The @samp{--warn-common} option can produce five kinds of warnings.
1845 Each warning consists of a pair of lines: the first describes the symbol
1846 just encountered, and the second describes the previous symbol
1847 encountered with the same name.  One or both of the two symbols will be
1848 a common symbol.
1850 @enumerate
1851 @item
1852 Turning a common symbol into a reference, because there is already a
1853 definition for the symbol.
1854 @smallexample
1855 @var{file}(@var{section}): warning: common of `@var{symbol}'
1856    overridden by definition
1857 @var{file}(@var{section}): warning: defined here
1858 @end smallexample
1860 @item
1861 Turning a common symbol into a reference, because a later definition for
1862 the symbol is encountered.  This is the same as the previous case,
1863 except that the symbols are encountered in a different order.
1864 @smallexample
1865 @var{file}(@var{section}): warning: definition of `@var{symbol}'
1866    overriding common
1867 @var{file}(@var{section}): warning: common is here
1868 @end smallexample
1870 @item
1871 Merging a common symbol with a previous same-sized common symbol.
1872 @smallexample
1873 @var{file}(@var{section}): warning: multiple common
1874    of `@var{symbol}'
1875 @var{file}(@var{section}): warning: previous common is here
1876 @end smallexample
1878 @item
1879 Merging a common symbol with a previous larger common symbol.
1880 @smallexample
1881 @var{file}(@var{section}): warning: common of `@var{symbol}'
1882    overridden by larger common
1883 @var{file}(@var{section}): warning: larger common is here
1884 @end smallexample
1886 @item
1887 Merging a common symbol with a previous smaller common symbol.  This is
1888 the same as the previous case, except that the symbols are
1889 encountered in a different order.
1890 @smallexample
1891 @var{file}(@var{section}): warning: common of `@var{symbol}'
1892    overriding smaller common
1893 @var{file}(@var{section}): warning: smaller common is here
1894 @end smallexample
1895 @end enumerate
1897 @kindex --warn-constructors
1898 @item --warn-constructors
1899 Warn if any global constructors are used.  This is only useful for a few
1900 object file formats.  For formats like COFF or ELF, the linker can not
1901 detect the use of global constructors.
1903 @kindex --warn-multiple-gp
1904 @item --warn-multiple-gp
1905 Warn if multiple global pointer values are required in the output file.
1906 This is only meaningful for certain processors, such as the Alpha.
1907 Specifically, some processors put large-valued constants in a special
1908 section.  A special register (the global pointer) points into the middle
1909 of this section, so that constants can be loaded efficiently via a
1910 base-register relative addressing mode.  Since the offset in
1911 base-register relative mode is fixed and relatively small (e.g., 16
1912 bits), this limits the maximum size of the constant pool.  Thus, in
1913 large programs, it is often necessary to use multiple global pointer
1914 values in order to be able to address all possible constants.  This
1915 option causes a warning to be issued whenever this case occurs.
1917 @kindex --warn-once
1918 @cindex warnings, on undefined symbols
1919 @cindex undefined symbols, warnings on
1920 @item --warn-once
1921 Only warn once for each undefined symbol, rather than once per module
1922 which refers to it.
1924 @kindex --warn-section-align
1925 @cindex warnings, on section alignment
1926 @cindex section alignment, warnings on
1927 @item --warn-section-align
1928 Warn if the address of an output section is changed because of
1929 alignment.  Typically, the alignment will be set by an input section.
1930 The address will only be changed if it not explicitly specified; that
1931 is, if the @code{SECTIONS} command does not specify a start address for
1932 the section (@pxref{SECTIONS}).
1934 @kindex --warn-shared-textrel
1935 @item --warn-shared-textrel
1936 Warn if the linker adds a DT_TEXTREL to a shared object.
1938 @kindex --warn-unresolved-symbols
1939 @item --warn-unresolved-symbols
1940 If the linker is going to report an unresolved symbol (see the option
1941 @option{--unresolved-symbols}) it will normally generate an error.
1942 This option makes it generate a warning instead.
1944 @kindex --error-unresolved-symbols
1945 @item --error-unresolved-symbols
1946 This restores the linker's default behaviour of generating errors when
1947 it is reporting unresolved symbols.
1949 @kindex --whole-archive
1950 @cindex including an entire archive
1951 @item --whole-archive
1952 For each archive mentioned on the command line after the
1953 @option{--whole-archive} option, include every object file in the archive
1954 in the link, rather than searching the archive for the required object
1955 files.  This is normally used to turn an archive file into a shared
1956 library, forcing every object to be included in the resulting shared
1957 library.  This option may be used more than once.
1959 Two notes when using this option from gcc: First, gcc doesn't know
1960 about this option, so you have to use @option{-Wl,-whole-archive}.
1961 Second, don't forget to use @option{-Wl,-no-whole-archive} after your
1962 list of archives, because gcc will add its own list of archives to
1963 your link and you may not want this flag to affect those as well.
1965 @kindex --wrap=@var{symbol}
1966 @item --wrap=@var{symbol}
1967 Use a wrapper function for @var{symbol}.  Any undefined reference to
1968 @var{symbol} will be resolved to @code{__wrap_@var{symbol}}.  Any
1969 undefined reference to @code{__real_@var{symbol}} will be resolved to
1970 @var{symbol}.
1972 This can be used to provide a wrapper for a system function.  The
1973 wrapper function should be called @code{__wrap_@var{symbol}}.  If it
1974 wishes to call the system function, it should call
1975 @code{__real_@var{symbol}}.
1977 Here is a trivial example:
1979 @smallexample
1980 void *
1981 __wrap_malloc (size_t c)
1983   printf ("malloc called with %zu\n", c);
1984   return __real_malloc (c);
1986 @end smallexample
1988 If you link other code with this file using @option{--wrap malloc}, then
1989 all calls to @code{malloc} will call the function @code{__wrap_malloc}
1990 instead.  The call to @code{__real_malloc} in @code{__wrap_malloc} will
1991 call the real @code{malloc} function.
1993 You may wish to provide a @code{__real_malloc} function as well, so that
1994 links without the @option{--wrap} option will succeed.  If you do this,
1995 you should not put the definition of @code{__real_malloc} in the same
1996 file as @code{__wrap_malloc}; if you do, the assembler may resolve the
1997 call before the linker has a chance to wrap it to @code{malloc}.
1999 @kindex --eh-frame-hdr
2000 @item --eh-frame-hdr
2001 Request creation of @code{.eh_frame_hdr} section and ELF
2002 @code{PT_GNU_EH_FRAME} segment header.
2004 @kindex --enable-new-dtags
2005 @kindex --disable-new-dtags
2006 @item --enable-new-dtags
2007 @itemx --disable-new-dtags
2008 This linker can create the new dynamic tags in ELF. But the older ELF
2009 systems may not understand them. If you specify
2010 @option{--enable-new-dtags}, the dynamic tags will be created as needed.
2011 If you specify @option{--disable-new-dtags}, no new dynamic tags will be
2012 created. By default, the new dynamic tags are not created. Note that
2013 those options are only available for ELF systems.
2015 @kindex --hash-size=@var{number}
2016 @item --hash-size=@var{number}
2017 Set the default size of the linker's hash tables to a prime number
2018 close to @var{number}.  Increasing this value can reduce the length of
2019 time it takes the linker to perform its tasks, at the expense of
2020 increasing the linker's memory requirements.  Similarly reducing this
2021 value can reduce the memory requirements at the expense of speed.
2023 @kindex --hash-style=@var{style}
2024 @item --hash-style=@var{style}
2025 Set the type of linker's hash table(s).  @var{style} can be either
2026 @code{sysv} for classic ELF @code{.hash} section, @code{gnu} for
2027 new style GNU @code{.gnu.hash} section or @code{both} for both
2028 the classic ELF @code{.hash} and new style GNU @code{.gnu.hash}
2029 hash tables.  The default is @code{sysv}.
2031 @kindex --reduce-memory-overheads
2032 @item --reduce-memory-overheads
2033 This option reduces memory requirements at ld runtime, at the expense of
2034 linking speed.  This was introduced to select the old O(n^2) algorithm
2035 for link map file generation, rather than the new O(n) algorithm which uses
2036 about 40% more memory for symbol storage.
2038 Another effect of the switch is to set the default hash table size to
2039 1021, which again saves memory at the cost of lengthening the linker's
2040 run time.  This is not done however if the @option{--hash-size} switch
2041 has been used.
2043 The @option{--reduce-memory-overheads} switch may be also be used to
2044 enable other tradeoffs in future versions of the linker.
2046 @kindex --build-id
2047 @kindex --build-id=@var{style}
2048 @item --build-id
2049 @itemx --build-id=@var{style}
2050 Request creation of @code{.note.gnu.build-id} ELF note section.
2051 The contents of the note are unique bits identifying this linked
2052 file.  @var{style} can be @code{uuid} to use 128 random bits,
2053 @code{sha1} to use a 160-bit @sc{SHA1} hash on the normative
2054 parts of the output contents, @code{md5} to use a 128-bit
2055 @sc{MD5} hash on the normative parts of the output contents, or
2056 @code{0x@var{hexstring}} to use a chosen bit string specified as
2057 an even number of hexadecimal digits (@code{-} and @code{:}
2058 characters between digit pairs are ignored).  If @var{style} is
2059 omitted, @code{sha1} is used.
2061 The @code{md5} and @code{sha1} styles produces an identifier
2062 that is always the same in an identical output file, but will be
2063 unique among all nonidentical output files.  It is not intended
2064 to be compared as a checksum for the file's contents.  A linked
2065 file may be changed later by other tools, but the build ID bit
2066 string identifying the original linked file does not change.
2068 Passing @code{none} for @var{style} disables the setting from any
2069 @code{--build-id} options earlier on the command line.
2070 @end table
2072 @c man end
2074 @subsection Options Specific to i386 PE Targets
2076 @c man begin OPTIONS
2078 The i386 PE linker supports the @option{-shared} option, which causes
2079 the output to be a dynamically linked library (DLL) instead of a
2080 normal executable.  You should name the output @code{*.dll} when you
2081 use this option.  In addition, the linker fully supports the standard
2082 @code{*.def} files, which may be specified on the linker command line
2083 like an object file (in fact, it should precede archives it exports
2084 symbols from, to ensure that they get linked in, just like a normal
2085 object file).
2087 In addition to the options common to all targets, the i386 PE linker
2088 support additional command line options that are specific to the i386
2089 PE target.  Options that take values may be separated from their
2090 values by either a space or an equals sign.
2092 @table @gcctabopt
2094 @kindex --add-stdcall-alias
2095 @item --add-stdcall-alias
2096 If given, symbols with a stdcall suffix (@@@var{nn}) will be exported
2097 as-is and also with the suffix stripped.
2098 [This option is specific to the i386 PE targeted port of the linker]
2100 @kindex --base-file
2101 @item --base-file @var{file}
2102 Use @var{file} as the name of a file in which to save the base
2103 addresses of all the relocations needed for generating DLLs with
2104 @file{dlltool}.
2105 [This is an i386 PE specific option]
2107 @kindex --dll
2108 @item --dll
2109 Create a DLL instead of a regular executable.  You may also use
2110 @option{-shared} or specify a @code{LIBRARY} in a given @code{.def}
2111 file.
2112 [This option is specific to the i386 PE targeted port of the linker]
2114 @kindex --enable-long-section-names
2115 @kindex --disable-long-section-names
2116 @item --enable-long-section-names
2117 @itemx --disable-long-section-names
2118 The PE variants of the Coff object format add an extension that permits
2119 the use of section names longer than eight characters, the normal limit
2120 for Coff.  By default, these names are only allowed in object files, as
2121 fully-linked executable images do not carry the Coff string table required
2122 to support the longer names.  As a GNU extension, it is possible to
2123 allow their use in executable images as well, or to (probably pointlessly!)
2124 disallow it in object files, by using these two options.  Executable images
2125 generated with these long section names are slightly non-standard, carrying
2126 as they do a string table, and may generate confusing output when examined
2127 with non-GNU PE-aware tools, such as file viewers and dumpers.  However, 
2128 GDB relies on the use of PE long section names to find Dwarf-2 debug 
2129 information sections in an executable image at runtime, and so if neither
2130 option is specified on the command-line, @command{ld} will enable long
2131 section names, overriding the default and technically correct behaviour,
2132 when it finds the presence of debug information while linking an executable
2133 image and not stripping symbols.
2134 [This option is valid for all PE targeted ports of the linker]
2136 @kindex --enable-stdcall-fixup
2137 @kindex --disable-stdcall-fixup
2138 @item --enable-stdcall-fixup
2139 @itemx --disable-stdcall-fixup
2140 If the link finds a symbol that it cannot resolve, it will attempt to
2141 do ``fuzzy linking'' by looking for another defined symbol that differs
2142 only in the format of the symbol name (cdecl vs stdcall) and will
2143 resolve that symbol by linking to the match.  For example, the
2144 undefined symbol @code{_foo} might be linked to the function
2145 @code{_foo@@12}, or the undefined symbol @code{_bar@@16} might be linked
2146 to the function @code{_bar}.  When the linker does this, it prints a
2147 warning, since it normally should have failed to link, but sometimes
2148 import libraries generated from third-party dlls may need this feature
2149 to be usable.  If you specify @option{--enable-stdcall-fixup}, this
2150 feature is fully enabled and warnings are not printed.  If you specify
2151 @option{--disable-stdcall-fixup}, this feature is disabled and such
2152 mismatches are considered to be errors.
2153 [This option is specific to the i386 PE targeted port of the linker]
2155 @cindex DLLs, creating
2156 @kindex --export-all-symbols
2157 @item --export-all-symbols
2158 If given, all global symbols in the objects used to build a DLL will
2159 be exported by the DLL.  Note that this is the default if there
2160 otherwise wouldn't be any exported symbols.  When symbols are
2161 explicitly exported via DEF files or implicitly exported via function
2162 attributes, the default is to not export anything else unless this
2163 option is given.  Note that the symbols @code{DllMain@@12},
2164 @code{DllEntryPoint@@0}, @code{DllMainCRTStartup@@12}, and
2165 @code{impure_ptr} will not be automatically
2166 exported.  Also, symbols imported from other DLLs will not be
2167 re-exported, nor will symbols specifying the DLL's internal layout
2168 such as those beginning with @code{_head_} or ending with
2169 @code{_iname}.  In addition, no symbols from @code{libgcc},
2170 @code{libstd++}, @code{libmingw32}, or @code{crtX.o} will be exported.
2171 Symbols whose names begin with @code{__rtti_} or @code{__builtin_} will
2172 not be exported, to help with C++ DLLs.  Finally, there is an
2173 extensive list of cygwin-private symbols that are not exported
2174 (obviously, this applies on when building DLLs for cygwin targets).
2175 These cygwin-excludes are: @code{_cygwin_dll_entry@@12},
2176 @code{_cygwin_crt0_common@@8}, @code{_cygwin_noncygwin_dll_entry@@12},
2177 @code{_fmode}, @code{_impure_ptr}, @code{cygwin_attach_dll},
2178 @code{cygwin_premain0}, @code{cygwin_premain1}, @code{cygwin_premain2},
2179 @code{cygwin_premain3}, and @code{environ}.
2180 [This option is specific to the i386 PE targeted port of the linker]
2182 @kindex --exclude-symbols
2183 @item --exclude-symbols @var{symbol},@var{symbol},...
2184 Specifies a list of symbols which should not be automatically
2185 exported.  The symbol names may be delimited by commas or colons.
2186 [This option is specific to the i386 PE targeted port of the linker]
2188 @kindex --file-alignment
2189 @item --file-alignment
2190 Specify the file alignment.  Sections in the file will always begin at
2191 file offsets which are multiples of this number.  This defaults to
2192 512.
2193 [This option is specific to the i386 PE targeted port of the linker]
2195 @cindex heap size
2196 @kindex --heap
2197 @item --heap @var{reserve}
2198 @itemx --heap @var{reserve},@var{commit}
2199 Specify the number of bytes of memory to reserve (and optionally commit)
2200 to be used as heap for this program.  The default is 1Mb reserved, 4K
2201 committed.
2202 [This option is specific to the i386 PE targeted port of the linker]
2204 @cindex image base
2205 @kindex --image-base
2206 @item --image-base @var{value}
2207 Use @var{value} as the base address of your program or dll.  This is
2208 the lowest memory location that will be used when your program or dll
2209 is loaded.  To reduce the need to relocate and improve performance of
2210 your dlls, each should have a unique base address and not overlap any
2211 other dlls.  The default is 0x400000 for executables, and 0x10000000
2212 for dlls.
2213 [This option is specific to the i386 PE targeted port of the linker]
2215 @kindex --kill-at
2216 @item --kill-at
2217 If given, the stdcall suffixes (@@@var{nn}) will be stripped from
2218 symbols before they are exported.
2219 [This option is specific to the i386 PE targeted port of the linker]
2221 @kindex --large-address-aware
2222 @item --large-address-aware
2223 If given, the appropriate bit in the ``Characteristics'' field of the COFF
2224 header is set to indicate that this executable supports virtual addresses
2225 greater than 2 gigabytes.  This should be used in conjunction with the /3GB
2226 or /USERVA=@var{value} megabytes switch in the ``[operating systems]''
2227 section of the BOOT.INI.  Otherwise, this bit has no effect.
2228 [This option is specific to PE targeted ports of the linker]
2230 @kindex --major-image-version
2231 @item --major-image-version @var{value}
2232 Sets the major number of the ``image version''.  Defaults to 1.
2233 [This option is specific to the i386 PE targeted port of the linker]
2235 @kindex --major-os-version
2236 @item --major-os-version @var{value}
2237 Sets the major number of the ``os version''.  Defaults to 4.
2238 [This option is specific to the i386 PE targeted port of the linker]
2240 @kindex --major-subsystem-version
2241 @item --major-subsystem-version @var{value}
2242 Sets the major number of the ``subsystem version''.  Defaults to 4.
2243 [This option is specific to the i386 PE targeted port of the linker]
2245 @kindex --minor-image-version
2246 @item --minor-image-version @var{value}
2247 Sets the minor number of the ``image version''.  Defaults to 0.
2248 [This option is specific to the i386 PE targeted port of the linker]
2250 @kindex --minor-os-version
2251 @item --minor-os-version @var{value}
2252 Sets the minor number of the ``os version''.  Defaults to 0.
2253 [This option is specific to the i386 PE targeted port of the linker]
2255 @kindex --minor-subsystem-version
2256 @item --minor-subsystem-version @var{value}
2257 Sets the minor number of the ``subsystem version''.  Defaults to 0.
2258 [This option is specific to the i386 PE targeted port of the linker]
2260 @cindex DEF files, creating
2261 @cindex DLLs, creating
2262 @kindex --output-def
2263 @item --output-def @var{file}
2264 The linker will create the file @var{file} which will contain a DEF
2265 file corresponding to the DLL the linker is generating.  This DEF file
2266 (which should be called @code{*.def}) may be used to create an import
2267 library with @code{dlltool} or may be used as a reference to
2268 automatically or implicitly exported symbols.
2269 [This option is specific to the i386 PE targeted port of the linker]
2271 @cindex DLLs, creating
2272 @kindex --out-implib
2273 @item --out-implib @var{file}
2274 The linker will create the file @var{file} which will contain an
2275 import lib corresponding to the DLL the linker is generating. This
2276 import lib (which should be called @code{*.dll.a} or @code{*.a}
2277 may be used to link clients against the generated DLL; this behaviour
2278 makes it possible to skip a separate @code{dlltool} import library
2279 creation step.
2280 [This option is specific to the i386 PE targeted port of the linker]
2282 @kindex --enable-auto-image-base
2283 @item --enable-auto-image-base
2284 Automatically choose the image base for DLLs, unless one is specified
2285 using the @code{--image-base} argument.  By using a hash generated
2286 from the dllname to create unique image bases for each DLL, in-memory
2287 collisions and relocations which can delay program execution are
2288 avoided.
2289 [This option is specific to the i386 PE targeted port of the linker]
2291 @kindex --disable-auto-image-base
2292 @item --disable-auto-image-base
2293 Do not automatically generate a unique image base.  If there is no
2294 user-specified image base (@code{--image-base}) then use the platform
2295 default.
2296 [This option is specific to the i386 PE targeted port of the linker]
2298 @cindex DLLs, linking to
2299 @kindex --dll-search-prefix
2300 @item --dll-search-prefix @var{string}
2301 When linking dynamically to a dll without an import library,
2302 search for @code{<string><basename>.dll} in preference to
2303 @code{lib<basename>.dll}. This behaviour allows easy distinction
2304 between DLLs built for the various "subplatforms": native, cygwin,
2305 uwin, pw, etc.  For instance, cygwin DLLs typically use
2306 @code{--dll-search-prefix=cyg}.
2307 [This option is specific to the i386 PE targeted port of the linker]
2309 @kindex --enable-auto-import
2310 @item --enable-auto-import
2311 Do sophisticated linking of @code{_symbol} to @code{__imp__symbol} for
2312 DATA imports from DLLs, and create the necessary thunking symbols when
2313 building the import libraries with those DATA exports. Note: Use of the
2314 'auto-import' extension will cause the text section of the image file
2315 to be made writable. This does not conform to the PE-COFF format
2316 specification published by Microsoft.
2318 Note - use of the 'auto-import' extension will also cause read only
2319 data which would normally be placed into the .rdata section to be
2320 placed into the .data section instead.  This is in order to work
2321 around a problem with consts that is described here:
2322 http://www.cygwin.com/ml/cygwin/2004-09/msg01101.html
2324 Using 'auto-import' generally will 'just work' -- but sometimes you may
2325 see this message:
2327 "variable '<var>' can't be auto-imported. Please read the
2328 documentation for ld's @code{--enable-auto-import} for details."
2330 This message occurs when some (sub)expression accesses an address
2331 ultimately given by the sum of two constants (Win32 import tables only
2332 allow one).  Instances where this may occur include accesses to member
2333 fields of struct variables imported from a DLL, as well as using a
2334 constant index into an array variable imported from a DLL.  Any
2335 multiword variable (arrays, structs, long long, etc) may trigger
2336 this error condition.  However, regardless of the exact data type
2337 of the offending exported variable, ld will always detect it, issue
2338 the warning, and exit.
2340 There are several ways to address this difficulty, regardless of the
2341 data type of the exported variable:
2343 One way is to use --enable-runtime-pseudo-reloc switch. This leaves the task
2344 of adjusting references in your client code for runtime environment, so
2345 this method works only when runtime environment supports this feature.
2347 A second solution is to force one of the 'constants' to be a variable --
2348 that is, unknown and un-optimizable at compile time.  For arrays,
2349 there are two possibilities: a) make the indexee (the array's address)
2350 a variable, or b) make the 'constant' index a variable.  Thus:
2352 @example
2353 extern type extern_array[];
2354 extern_array[1] -->
2355    @{ volatile type *t=extern_array; t[1] @}
2356 @end example
2360 @example
2361 extern type extern_array[];
2362 extern_array[1] -->
2363    @{ volatile int t=1; extern_array[t] @}
2364 @end example
2366 For structs (and most other multiword data types) the only option
2367 is to make the struct itself (or the long long, or the ...) variable:
2369 @example
2370 extern struct s extern_struct;
2371 extern_struct.field -->
2372    @{ volatile struct s *t=&extern_struct; t->field @}
2373 @end example
2377 @example
2378 extern long long extern_ll;
2379 extern_ll -->
2380   @{ volatile long long * local_ll=&extern_ll; *local_ll @}
2381 @end example
2383 A third method of dealing with this difficulty is to abandon
2384 'auto-import' for the offending symbol and mark it with
2385 @code{__declspec(dllimport)}.  However, in practise that
2386 requires using compile-time #defines to indicate whether you are
2387 building a DLL, building client code that will link to the DLL, or
2388 merely building/linking to a static library.   In making the choice
2389 between the various methods of resolving the 'direct address with
2390 constant offset' problem, you should consider typical real-world usage:
2392 Original:
2393 @example
2394 --foo.h
2395 extern int arr[];
2396 --foo.c
2397 #include "foo.h"
2398 void main(int argc, char **argv)@{
2399   printf("%d\n",arr[1]);
2401 @end example
2403 Solution 1:
2404 @example
2405 --foo.h
2406 extern int arr[];
2407 --foo.c
2408 #include "foo.h"
2409 void main(int argc, char **argv)@{
2410   /* This workaround is for win32 and cygwin; do not "optimize" */
2411   volatile int *parr = arr;
2412   printf("%d\n",parr[1]);
2414 @end example
2416 Solution 2:
2417 @example
2418 --foo.h
2419 /* Note: auto-export is assumed (no __declspec(dllexport)) */
2420 #if (defined(_WIN32) || defined(__CYGWIN__)) && \
2421   !(defined(FOO_BUILD_DLL) || defined(FOO_STATIC))
2422 #define FOO_IMPORT __declspec(dllimport)
2423 #else
2424 #define FOO_IMPORT
2425 #endif
2426 extern FOO_IMPORT int arr[];
2427 --foo.c
2428 #include "foo.h"
2429 void main(int argc, char **argv)@{
2430   printf("%d\n",arr[1]);
2432 @end example
2434 A fourth way to avoid this problem is to re-code your
2435 library to use a functional interface rather than a data interface
2436 for the offending variables (e.g. set_foo() and get_foo() accessor
2437 functions).
2438 [This option is specific to the i386 PE targeted port of the linker]
2440 @kindex --disable-auto-import
2441 @item --disable-auto-import
2442 Do not attempt to do sophisticated linking of @code{_symbol} to
2443 @code{__imp__symbol} for DATA imports from DLLs.
2444 [This option is specific to the i386 PE targeted port of the linker]
2446 @kindex --enable-runtime-pseudo-reloc
2447 @item --enable-runtime-pseudo-reloc
2448 If your code contains expressions described in --enable-auto-import section,
2449 that is, DATA imports from DLL with non-zero offset, this switch will create
2450 a vector of 'runtime pseudo relocations' which can be used by runtime
2451 environment to adjust references to such data in your client code.
2452 [This option is specific to the i386 PE targeted port of the linker]
2454 @kindex --disable-runtime-pseudo-reloc
2455 @item --disable-runtime-pseudo-reloc
2456 Do not create pseudo relocations for non-zero offset DATA imports from
2457 DLLs.  This is the default.
2458 [This option is specific to the i386 PE targeted port of the linker]
2460 @kindex --enable-extra-pe-debug
2461 @item --enable-extra-pe-debug
2462 Show additional debug info related to auto-import symbol thunking.
2463 [This option is specific to the i386 PE targeted port of the linker]
2465 @kindex --section-alignment
2466 @item --section-alignment
2467 Sets the section alignment.  Sections in memory will always begin at
2468 addresses which are a multiple of this number.  Defaults to 0x1000.
2469 [This option is specific to the i386 PE targeted port of the linker]
2471 @cindex stack size
2472 @kindex --stack
2473 @item --stack @var{reserve}
2474 @itemx --stack @var{reserve},@var{commit}
2475 Specify the number of bytes of memory to reserve (and optionally commit)
2476 to be used as stack for this program.  The default is 2Mb reserved, 4K
2477 committed.
2478 [This option is specific to the i386 PE targeted port of the linker]
2480 @kindex --subsystem
2481 @item --subsystem @var{which}
2482 @itemx --subsystem @var{which}:@var{major}
2483 @itemx --subsystem @var{which}:@var{major}.@var{minor}
2484 Specifies the subsystem under which your program will execute.  The
2485 legal values for @var{which} are @code{native}, @code{windows},
2486 @code{console}, @code{posix}, and @code{xbox}.  You may optionally set
2487 the subsystem version also.  Numeric values are also accepted for
2488 @var{which}.
2489 [This option is specific to the i386 PE targeted port of the linker]
2491 The following options set flags in the @code{DllCharacteristics} field
2492 of the PE file header:
2493 [These options are specific to PE targeted ports of the linker]
2495 @kindex --dynamicbase
2496 @item --dynamicbase
2497 The image base address may be relocated using address space layout
2498 randomization (ASLR).  This feature was introduced with MS Windows
2499 Vista for i386 PE targets.
2501 @kindex --forceinteg
2502 @item --forceinteg
2503 Code integrity checks are enforced.
2505 @kindex --nxcompat
2506 @item --nxcompat
2507 The image is compatible with the Data Execution Prevention.
2508 This feature was introduced with MS Windows XP SP2 for i386 PE targets.
2510 @kindex --no-isolation
2511 @item --no-isolation
2512 Although the image understands isolation, do not isolate the image.
2514 @kindex --no-seh
2515 @item --no-seh
2516 The image does not use SEH. No SE handler may be called from
2517 this image.
2519 @kindex --no-bind
2520 @item --no-bind
2521 Do not bind this image.
2523 @kindex --wdmdriver
2524 @item --wdmdriver
2525 The driver uses the MS Windows Driver Model.
2527 @kindex --tsaware
2528 @item --tsaware
2529 The image is Terminal Server aware.
2531 @end table
2533 @c man end
2535 @ifset M68HC11
2536 @subsection Options specific to Motorola 68HC11 and 68HC12 targets
2538 @c man begin OPTIONS
2540 The 68HC11 and 68HC12 linkers support specific options to control the
2541 memory bank switching mapping and trampoline code generation.
2543 @table @gcctabopt
2545 @kindex --no-trampoline
2546 @item --no-trampoline
2547 This option disables the generation of trampoline. By default a trampoline
2548 is generated for each far function which is called using a @code{jsr}
2549 instruction (this happens when a pointer to a far function is taken).
2551 @kindex --bank-window
2552 @item --bank-window @var{name}
2553 This option indicates to the linker the name of the memory region in
2554 the @samp{MEMORY} specification that describes the memory bank window.
2555 The definition of such region is then used by the linker to compute
2556 paging and addresses within the memory window.
2558 @end table
2560 @c man end
2561 @end ifset
2563 @ifset M68K
2564 @subsection Options specific to Motorola 68K target
2566 @c man begin OPTIONS
2568 The following options are supported to control handling of GOT generation
2569 when linking for 68K targets.
2571 @table @gcctabopt
2573 @kindex --got
2574 @item --got=@var{type}
2575 This option tells the linker which GOT generation scheme to use.
2576 @var{type} should be one of @samp{single}, @samp{negative},
2577 @samp{multigot} or @samp{target}.  For more information refer to the
2578 Info entry for @file{ld}.
2580 @end table
2582 @c man end
2583 @end ifset
2585 @ifset UsesEnvVars
2586 @node Environment
2587 @section Environment Variables
2589 @c man begin ENVIRONMENT
2591 You can change the behaviour of @command{ld} with the environment variables
2592 @ifclear SingleFormat
2593 @code{GNUTARGET},
2594 @end ifclear
2595 @code{LDEMULATION} and @code{COLLECT_NO_DEMANGLE}.
2597 @ifclear SingleFormat
2598 @kindex GNUTARGET
2599 @cindex default input format
2600 @code{GNUTARGET} determines the input-file object format if you don't
2601 use @samp{-b} (or its synonym @samp{--format}).  Its value should be one
2602 of the BFD names for an input format (@pxref{BFD}).  If there is no
2603 @code{GNUTARGET} in the environment, @command{ld} uses the natural format
2604 of the target. If @code{GNUTARGET} is set to @code{default} then BFD
2605 attempts to discover the input format by examining binary input files;
2606 this method often succeeds, but there are potential ambiguities, since
2607 there is no method of ensuring that the magic number used to specify
2608 object-file formats is unique.  However, the configuration procedure for
2609 BFD on each system places the conventional format for that system first
2610 in the search-list, so ambiguities are resolved in favor of convention.
2611 @end ifclear
2613 @kindex LDEMULATION
2614 @cindex default emulation
2615 @cindex emulation, default
2616 @code{LDEMULATION} determines the default emulation if you don't use the
2617 @samp{-m} option.  The emulation can affect various aspects of linker
2618 behaviour, particularly the default linker script.  You can list the
2619 available emulations with the @samp{--verbose} or @samp{-V} options.  If
2620 the @samp{-m} option is not used, and the @code{LDEMULATION} environment
2621 variable is not defined, the default emulation depends upon how the
2622 linker was configured.
2624 @kindex COLLECT_NO_DEMANGLE
2625 @cindex demangling, default
2626 Normally, the linker will default to demangling symbols.  However, if
2627 @code{COLLECT_NO_DEMANGLE} is set in the environment, then it will
2628 default to not demangling symbols.  This environment variable is used in
2629 a similar fashion by the @code{gcc} linker wrapper program.  The default
2630 may be overridden by the @samp{--demangle} and @samp{--no-demangle}
2631 options.
2633 @c man end
2634 @end ifset
2636 @node Scripts
2637 @chapter Linker Scripts
2639 @cindex scripts
2640 @cindex linker scripts
2641 @cindex command files
2642 Every link is controlled by a @dfn{linker script}.  This script is
2643 written in the linker command language.
2645 The main purpose of the linker script is to describe how the sections in
2646 the input files should be mapped into the output file, and to control
2647 the memory layout of the output file.  Most linker scripts do nothing
2648 more than this.  However, when necessary, the linker script can also
2649 direct the linker to perform many other operations, using the commands
2650 described below.
2652 The linker always uses a linker script.  If you do not supply one
2653 yourself, the linker will use a default script that is compiled into the
2654 linker executable.  You can use the @samp{--verbose} command line option
2655 to display the default linker script.  Certain command line options,
2656 such as @samp{-r} or @samp{-N}, will affect the default linker script.
2658 You may supply your own linker script by using the @samp{-T} command
2659 line option.  When you do this, your linker script will replace the
2660 default linker script.
2662 You may also use linker scripts implicitly by naming them as input files
2663 to the linker, as though they were files to be linked.  @xref{Implicit
2664 Linker Scripts}.
2666 @menu
2667 * Basic Script Concepts::       Basic Linker Script Concepts
2668 * Script Format::               Linker Script Format
2669 * Simple Example::              Simple Linker Script Example
2670 * Simple Commands::             Simple Linker Script Commands
2671 * Assignments::                 Assigning Values to Symbols
2672 * SECTIONS::                    SECTIONS Command
2673 * MEMORY::                      MEMORY Command
2674 * PHDRS::                       PHDRS Command
2675 * VERSION::                     VERSION Command
2676 * Expressions::                 Expressions in Linker Scripts
2677 * Implicit Linker Scripts::     Implicit Linker Scripts
2678 @end menu
2680 @node Basic Script Concepts
2681 @section Basic Linker Script Concepts
2682 @cindex linker script concepts
2683 We need to define some basic concepts and vocabulary in order to
2684 describe the linker script language.
2686 The linker combines input files into a single output file.  The output
2687 file and each input file are in a special data format known as an
2688 @dfn{object file format}.  Each file is called an @dfn{object file}.
2689 The output file is often called an @dfn{executable}, but for our
2690 purposes we will also call it an object file.  Each object file has,
2691 among other things, a list of @dfn{sections}.  We sometimes refer to a
2692 section in an input file as an @dfn{input section}; similarly, a section
2693 in the output file is an @dfn{output section}.
2695 Each section in an object file has a name and a size.  Most sections
2696 also have an associated block of data, known as the @dfn{section
2697 contents}.  A section may be marked as @dfn{loadable}, which mean that
2698 the contents should be loaded into memory when the output file is run.
2699 A section with no contents may be @dfn{allocatable}, which means that an
2700 area in memory should be set aside, but nothing in particular should be
2701 loaded there (in some cases this memory must be zeroed out).  A section
2702 which is neither loadable nor allocatable typically contains some sort
2703 of debugging information.
2705 Every loadable or allocatable output section has two addresses.  The
2706 first is the @dfn{VMA}, or virtual memory address.  This is the address
2707 the section will have when the output file is run.  The second is the
2708 @dfn{LMA}, or load memory address.  This is the address at which the
2709 section will be loaded.  In most cases the two addresses will be the
2710 same.  An example of when they might be different is when a data section
2711 is loaded into ROM, and then copied into RAM when the program starts up
2712 (this technique is often used to initialize global variables in a ROM
2713 based system).  In this case the ROM address would be the LMA, and the
2714 RAM address would be the VMA.
2716 You can see the sections in an object file by using the @code{objdump}
2717 program with the @samp{-h} option.
2719 Every object file also has a list of @dfn{symbols}, known as the
2720 @dfn{symbol table}.  A symbol may be defined or undefined.  Each symbol
2721 has a name, and each defined symbol has an address, among other
2722 information.  If you compile a C or C++ program into an object file, you
2723 will get a defined symbol for every defined function and global or
2724 static variable.  Every undefined function or global variable which is
2725 referenced in the input file will become an undefined symbol.
2727 You can see the symbols in an object file by using the @code{nm}
2728 program, or by using the @code{objdump} program with the @samp{-t}
2729 option.
2731 @node Script Format
2732 @section Linker Script Format
2733 @cindex linker script format
2734 Linker scripts are text files.
2736 You write a linker script as a series of commands.  Each command is
2737 either a keyword, possibly followed by arguments, or an assignment to a
2738 symbol.  You may separate commands using semicolons.  Whitespace is
2739 generally ignored.
2741 Strings such as file or format names can normally be entered directly.
2742 If the file name contains a character such as a comma which would
2743 otherwise serve to separate file names, you may put the file name in
2744 double quotes.  There is no way to use a double quote character in a
2745 file name.
2747 You may include comments in linker scripts just as in C, delimited by
2748 @samp{/*} and @samp{*/}.  As in C, comments are syntactically equivalent
2749 to whitespace.
2751 @node Simple Example
2752 @section Simple Linker Script Example
2753 @cindex linker script example
2754 @cindex example of linker script
2755 Many linker scripts are fairly simple.
2757 The simplest possible linker script has just one command:
2758 @samp{SECTIONS}.  You use the @samp{SECTIONS} command to describe the
2759 memory layout of the output file.
2761 The @samp{SECTIONS} command is a powerful command.  Here we will
2762 describe a simple use of it.  Let's assume your program consists only of
2763 code, initialized data, and uninitialized data.  These will be in the
2764 @samp{.text}, @samp{.data}, and @samp{.bss} sections, respectively.
2765 Let's assume further that these are the only sections which appear in
2766 your input files.
2768 For this example, let's say that the code should be loaded at address
2769 0x10000, and that the data should start at address 0x8000000.  Here is a
2770 linker script which will do that:
2771 @smallexample
2772 SECTIONS
2774   . = 0x10000;
2775   .text : @{ *(.text) @}
2776   . = 0x8000000;
2777   .data : @{ *(.data) @}
2778   .bss : @{ *(.bss) @}
2780 @end smallexample
2782 You write the @samp{SECTIONS} command as the keyword @samp{SECTIONS},
2783 followed by a series of symbol assignments and output section
2784 descriptions enclosed in curly braces.
2786 The first line inside the @samp{SECTIONS} command of the above example
2787 sets the value of the special symbol @samp{.}, which is the location
2788 counter.  If you do not specify the address of an output section in some
2789 other way (other ways are described later), the address is set from the
2790 current value of the location counter.  The location counter is then
2791 incremented by the size of the output section.  At the start of the
2792 @samp{SECTIONS} command, the location counter has the value @samp{0}.
2794 The second line defines an output section, @samp{.text}.  The colon is
2795 required syntax which may be ignored for now.  Within the curly braces
2796 after the output section name, you list the names of the input sections
2797 which should be placed into this output section.  The @samp{*} is a
2798 wildcard which matches any file name.  The expression @samp{*(.text)}
2799 means all @samp{.text} input sections in all input files.
2801 Since the location counter is @samp{0x10000} when the output section
2802 @samp{.text} is defined, the linker will set the address of the
2803 @samp{.text} section in the output file to be @samp{0x10000}.
2805 The remaining lines define the @samp{.data} and @samp{.bss} sections in
2806 the output file.  The linker will place the @samp{.data} output section
2807 at address @samp{0x8000000}.  After the linker places the @samp{.data}
2808 output section, the value of the location counter will be
2809 @samp{0x8000000} plus the size of the @samp{.data} output section.  The
2810 effect is that the linker will place the @samp{.bss} output section
2811 immediately after the @samp{.data} output section in memory.
2813 The linker will ensure that each output section has the required
2814 alignment, by increasing the location counter if necessary.  In this
2815 example, the specified addresses for the @samp{.text} and @samp{.data}
2816 sections will probably satisfy any alignment constraints, but the linker
2817 may have to create a small gap between the @samp{.data} and @samp{.bss}
2818 sections.
2820 That's it!  That's a simple and complete linker script.
2822 @node Simple Commands
2823 @section Simple Linker Script Commands
2824 @cindex linker script simple commands
2825 In this section we describe the simple linker script commands.
2827 @menu
2828 * Entry Point::                 Setting the entry point
2829 * File Commands::               Commands dealing with files
2830 @ifclear SingleFormat
2831 * Format Commands::             Commands dealing with object file formats
2832 @end ifclear
2834 * REGION_ALIAS::                Assign alias names to memory regions
2835 * Miscellaneous Commands::      Other linker script commands
2836 @end menu
2838 @node Entry Point
2839 @subsection Setting the Entry Point
2840 @kindex ENTRY(@var{symbol})
2841 @cindex start of execution
2842 @cindex first instruction
2843 @cindex entry point
2844 The first instruction to execute in a program is called the @dfn{entry
2845 point}.  You can use the @code{ENTRY} linker script command to set the
2846 entry point.  The argument is a symbol name:
2847 @smallexample
2848 ENTRY(@var{symbol})
2849 @end smallexample
2851 There are several ways to set the entry point.  The linker will set the
2852 entry point by trying each of the following methods in order, and
2853 stopping when one of them succeeds:
2854 @itemize @bullet
2855 @item
2856 the @samp{-e} @var{entry} command-line option;
2857 @item
2858 the @code{ENTRY(@var{symbol})} command in a linker script;
2859 @item
2860 the value of the symbol @code{start}, if defined;
2861 @item
2862 the address of the first byte of the @samp{.text} section, if present;
2863 @item
2864 The address @code{0}.
2865 @end itemize
2867 @node File Commands
2868 @subsection Commands Dealing with Files
2869 @cindex linker script file commands
2870 Several linker script commands deal with files.
2872 @table @code
2873 @item INCLUDE @var{filename}
2874 @kindex INCLUDE @var{filename}
2875 @cindex including a linker script
2876 Include the linker script @var{filename} at this point.  The file will
2877 be searched for in the current directory, and in any directory specified
2878 with the @option{-L} option.  You can nest calls to @code{INCLUDE} up to
2879 10 levels deep.
2881 You can place @code{INCLUDE} directives at the top level, in @code{MEMORY} or
2882 @code{SECTIONS} commands, or in output section descriptions.
2884 @item INPUT(@var{file}, @var{file}, @dots{})
2885 @itemx INPUT(@var{file} @var{file} @dots{})
2886 @kindex INPUT(@var{files})
2887 @cindex input files in linker scripts
2888 @cindex input object files in linker scripts
2889 @cindex linker script input object files
2890 The @code{INPUT} command directs the linker to include the named files
2891 in the link, as though they were named on the command line.
2893 For example, if you always want to include @file{subr.o} any time you do
2894 a link, but you can't be bothered to put it on every link command line,
2895 then you can put @samp{INPUT (subr.o)} in your linker script.
2897 In fact, if you like, you can list all of your input files in the linker
2898 script, and then invoke the linker with nothing but a @samp{-T} option.
2900 In case a @dfn{sysroot prefix} is configured, and the filename starts
2901 with the @samp{/} character, and the script being processed was
2902 located inside the @dfn{sysroot prefix}, the filename will be looked
2903 for in the @dfn{sysroot prefix}.  Otherwise, the linker will try to
2904 open the file in the current directory.  If it is not found, the
2905 linker will search through the archive library search path.  See the
2906 description of @samp{-L} in @ref{Options,,Command Line Options}.
2908 If you use @samp{INPUT (-l@var{file})}, @command{ld} will transform the
2909 name to @code{lib@var{file}.a}, as with the command line argument
2910 @samp{-l}.
2912 When you use the @code{INPUT} command in an implicit linker script, the
2913 files will be included in the link at the point at which the linker
2914 script file is included.  This can affect archive searching.
2916 @item GROUP(@var{file}, @var{file}, @dots{})
2917 @itemx GROUP(@var{file} @var{file} @dots{})
2918 @kindex GROUP(@var{files})
2919 @cindex grouping input files
2920 The @code{GROUP} command is like @code{INPUT}, except that the named
2921 files should all be archives, and they are searched repeatedly until no
2922 new undefined references are created.  See the description of @samp{-(}
2923 in @ref{Options,,Command Line Options}.
2925 @item AS_NEEDED(@var{file}, @var{file}, @dots{})
2926 @itemx AS_NEEDED(@var{file} @var{file} @dots{})
2927 @kindex AS_NEEDED(@var{files})
2928 This construct can appear only inside of the @code{INPUT} or @code{GROUP}
2929 commands, among other filenames.  The files listed will be handled
2930 as if they appear directly in the @code{INPUT} or @code{GROUP} commands,
2931 with the exception of ELF shared libraries, that will be added only
2932 when they are actually needed.  This construct essentially enables
2933 @option{--as-needed} option for all the files listed inside of it
2934 and restores previous @option{--as-needed} resp. @option{--no-as-needed}
2935 setting afterwards.
2937 @item OUTPUT(@var{filename})
2938 @kindex OUTPUT(@var{filename})
2939 @cindex output file name in linker script
2940 The @code{OUTPUT} command names the output file.  Using
2941 @code{OUTPUT(@var{filename})} in the linker script is exactly like using
2942 @samp{-o @var{filename}} on the command line (@pxref{Options,,Command
2943 Line Options}).  If both are used, the command line option takes
2944 precedence.
2946 You can use the @code{OUTPUT} command to define a default name for the
2947 output file other than the usual default of @file{a.out}.
2949 @item SEARCH_DIR(@var{path})
2950 @kindex SEARCH_DIR(@var{path})
2951 @cindex library search path in linker script
2952 @cindex archive search path in linker script
2953 @cindex search path in linker script
2954 The @code{SEARCH_DIR} command adds @var{path} to the list of paths where
2955 @command{ld} looks for archive libraries.  Using
2956 @code{SEARCH_DIR(@var{path})} is exactly like using @samp{-L @var{path}}
2957 on the command line (@pxref{Options,,Command Line Options}).  If both
2958 are used, then the linker will search both paths.  Paths specified using
2959 the command line option are searched first.
2961 @item STARTUP(@var{filename})
2962 @kindex STARTUP(@var{filename})
2963 @cindex first input file
2964 The @code{STARTUP} command is just like the @code{INPUT} command, except
2965 that @var{filename} will become the first input file to be linked, as
2966 though it were specified first on the command line.  This may be useful
2967 when using a system in which the entry point is always the start of the
2968 first file.
2969 @end table
2971 @ifclear SingleFormat
2972 @node Format Commands
2973 @subsection Commands Dealing with Object File Formats
2974 A couple of linker script commands deal with object file formats.
2976 @table @code
2977 @item OUTPUT_FORMAT(@var{bfdname})
2978 @itemx OUTPUT_FORMAT(@var{default}, @var{big}, @var{little})
2979 @kindex OUTPUT_FORMAT(@var{bfdname})
2980 @cindex output file format in linker script
2981 The @code{OUTPUT_FORMAT} command names the BFD format to use for the
2982 output file (@pxref{BFD}).  Using @code{OUTPUT_FORMAT(@var{bfdname})} is
2983 exactly like using @samp{--oformat @var{bfdname}} on the command line
2984 (@pxref{Options,,Command Line Options}).  If both are used, the command
2985 line option takes precedence.
2987 You can use @code{OUTPUT_FORMAT} with three arguments to use different
2988 formats based on the @samp{-EB} and @samp{-EL} command line options.
2989 This permits the linker script to set the output format based on the
2990 desired endianness.
2992 If neither @samp{-EB} nor @samp{-EL} are used, then the output format
2993 will be the first argument, @var{default}.  If @samp{-EB} is used, the
2994 output format will be the second argument, @var{big}.  If @samp{-EL} is
2995 used, the output format will be the third argument, @var{little}.
2997 For example, the default linker script for the MIPS ELF target uses this
2998 command:
2999 @smallexample
3000 OUTPUT_FORMAT(elf32-bigmips, elf32-bigmips, elf32-littlemips)
3001 @end smallexample
3002 This says that the default format for the output file is
3003 @samp{elf32-bigmips}, but if the user uses the @samp{-EL} command line
3004 option, the output file will be created in the @samp{elf32-littlemips}
3005 format.
3007 @item TARGET(@var{bfdname})
3008 @kindex TARGET(@var{bfdname})
3009 @cindex input file format in linker script
3010 The @code{TARGET} command names the BFD format to use when reading input
3011 files.  It affects subsequent @code{INPUT} and @code{GROUP} commands.
3012 This command is like using @samp{-b @var{bfdname}} on the command line
3013 (@pxref{Options,,Command Line Options}).  If the @code{TARGET} command
3014 is used but @code{OUTPUT_FORMAT} is not, then the last @code{TARGET}
3015 command is also used to set the format for the output file.  @xref{BFD}.
3016 @end table
3017 @end ifclear
3019 @node REGION_ALIAS
3020 @subsection Assign alias names to memory regions
3021 @kindex REGION_ALIAS(@var{alias}, @var{region})
3022 @cindex region alias
3023 @cindex region names
3025 Alias names can be added to existing memory regions created with the
3026 @ref{MEMORY} command.  Each name corresponds to at most one memory region.
3028 @smallexample
3029 REGION_ALIAS(@var{alias}, @var{region})
3030 @end smallexample
3032 The @code{REGION_ALIAS} function creates an alias name @var{alias} for the
3033 memory region @var{region}.  This allows a flexible mapping of output sections
3034 to memory regions.  An example follows.
3036 Suppose we have an application for embedded systems which come with various
3037 memory storage devices.  All have a general purpose, volatile memory @code{RAM}
3038 that allows code execution or data storage.  Some may have a read-only,
3039 non-volatile memory @code{ROM} that allows code execution and read-only data
3040 access.  The last variant is a read-only, non-volatile memory @code{ROM2} with
3041 read-only data access and no code execution capability.  We have four output
3042 sections:
3044 @itemize @bullet
3045 @item
3046 @code{.text} program code;
3047 @item
3048 @code{.rodata} read-only data;
3049 @item
3050 @code{.data} read-write initialized data;
3051 @item
3052 @code{.bss} read-write zero initialized data.
3053 @end itemize
3055 The goal is to provide a linker command file that contains a system independent
3056 part defining the output sections and a system dependent part mapping the
3057 output sections to the memory regions available on the system.  Our embedded
3058 systems come with three different memory setups @code{A}, @code{B} and
3059 @code{C}:
3060 @multitable @columnfractions .25 .25 .25 .25
3061 @item Section @tab Variant A @tab Variant B @tab Variant C
3062 @item .text @tab RAM @tab ROM @tab ROM 
3063 @item .rodata @tab RAM @tab ROM @tab ROM2
3064 @item .data @tab RAM @tab RAM/ROM @tab RAM/ROM2
3065 @item .bss @tab RAM @tab RAM @tab RAM
3066 @end multitable
3067 The notation @code{RAM/ROM} or @code{RAM/ROM2} means that this section is
3068 loaded into region @code{ROM} or @code{ROM2} respectively.  Please note that
3069 the load address of the @code{.data} section starts in all three variants at
3070 the end of the @code{.rodata} section.
3072 The base linker script that deals with the output sections follows.  It
3073 includes the system dependent @code{linkcmds.memory} file that describes the
3074 memory layout:
3075 @smallexample
3076 INCLUDE linkcmds.memory
3078 SECTIONS
3079   @{
3080     .text :
3081       @{
3082         *(.text)
3083       @} > REGION_TEXT
3084     .rodata :
3085       @{
3086         *(.rodata)
3087         rodata_end = .;
3088       @} > REGION_RODATA
3089     .data : AT (rodata_end)
3090       @{
3091         data_start = .;
3092         *(.data)
3093       @} > REGION_DATA
3094     data_size = SIZEOF(.data);
3095     data_load_start = LOADADDR(.data);
3096     .bss :
3097       @{
3098         *(.bss)
3099       @} > REGION_BSS
3100   @}
3101 @end smallexample
3103 Now we need three different @code{linkcmds.memory} files to define memory
3104 regions and alias names.  The content of @code{linkcmds.memory} for the three
3105 variants @code{A}, @code{B} and @code{C}:
3106 @table @code
3107 @item A
3108 Here everything goes into the @code{RAM}.
3109 @smallexample
3110 MEMORY
3111   @{
3112     RAM : ORIGIN = 0, LENGTH = 4M
3113   @}
3115 REGION_ALIAS("REGION_TEXT", RAM);
3116 REGION_ALIAS("REGION_RODATA", RAM);
3117 REGION_ALIAS("REGION_DATA", RAM);
3118 REGION_ALIAS("REGION_BSS", RAM);
3119 @end smallexample
3120 @item B
3121 Program code and read-only data go into the @code{ROM}.  Read-write data goes
3122 into the @code{RAM}.  An image of the initialized data is loaded into the
3123 @code{ROM} and will be copied during system start into the @code{RAM}.
3124 @smallexample
3125 MEMORY
3126   @{
3127     ROM : ORIGIN = 0, LENGTH = 3M
3128     RAM : ORIGIN = 0x10000000, LENGTH = 1M
3129   @}
3131 REGION_ALIAS("REGION_TEXT", ROM);
3132 REGION_ALIAS("REGION_RODATA", ROM);
3133 REGION_ALIAS("REGION_DATA", RAM);
3134 REGION_ALIAS("REGION_BSS", RAM);
3135 @end smallexample
3136 @item C
3137 Program code goes into the @code{ROM}.  Read-only data goes into the
3138 @code{ROM2}.  Read-write data goes into the @code{RAM}.  An image of the
3139 initialized data is loaded into the @code{ROM2} and will be copied during
3140 system start into the @code{RAM}.
3141 @smallexample
3142 MEMORY
3143   @{
3144     ROM : ORIGIN = 0, LENGTH = 2M
3145     ROM2 : ORIGIN = 0x10000000, LENGTH = 1M
3146     RAM : ORIGIN = 0x20000000, LENGTH = 1M
3147   @}
3149 REGION_ALIAS("REGION_TEXT", ROM);
3150 REGION_ALIAS("REGION_RODATA", ROM2);
3151 REGION_ALIAS("REGION_DATA", RAM);
3152 REGION_ALIAS("REGION_BSS", RAM);
3153 @end smallexample
3154 @end table
3156 It is possible to write a common system initialization routine to copy the
3157 @code{.data} section from @code{ROM} or @code{ROM2} into the @code{RAM} if
3158 necessary:
3159 @smallexample
3160 #include <string.h>
3162 extern char data_start [];
3163 extern char data_size [];
3164 extern char data_load_start [];
3166 void copy_data(void)
3168   if (data_start != data_load_start)
3169     @{
3170       memcpy(data_start, data_load_start, (size_t) data_size);
3171     @}
3173 @end smallexample
3175 @node Miscellaneous Commands
3176 @subsection Other Linker Script Commands
3177 There are a few other linker scripts commands.
3179 @table @code
3180 @item ASSERT(@var{exp}, @var{message})
3181 @kindex ASSERT
3182 @cindex assertion in linker script
3183 Ensure that @var{exp} is non-zero.  If it is zero, then exit the linker
3184 with an error code, and print @var{message}.
3186 @item EXTERN(@var{symbol} @var{symbol} @dots{})
3187 @kindex EXTERN
3188 @cindex undefined symbol in linker script
3189 Force @var{symbol} to be entered in the output file as an undefined
3190 symbol.  Doing this may, for example, trigger linking of additional
3191 modules from standard libraries.  You may list several @var{symbol}s for
3192 each @code{EXTERN}, and you may use @code{EXTERN} multiple times.  This
3193 command has the same effect as the @samp{-u} command-line option.
3195 @item FORCE_COMMON_ALLOCATION
3196 @kindex FORCE_COMMON_ALLOCATION
3197 @cindex common allocation in linker script
3198 This command has the same effect as the @samp{-d} command-line option:
3199 to make @command{ld} assign space to common symbols even if a relocatable
3200 output file is specified (@samp{-r}).
3202 @item INHIBIT_COMMON_ALLOCATION
3203 @kindex INHIBIT_COMMON_ALLOCATION
3204 @cindex common allocation in linker script
3205 This command has the same effect as the @samp{--no-define-common}
3206 command-line option: to make @code{ld} omit the assignment of addresses
3207 to common symbols even for a non-relocatable output file.
3209 @item INSERT [ AFTER | BEFORE ] @var{output_section}
3210 @kindex INSERT
3211 @cindex insert user script into default script
3212 This command is typically used in a script specified by @samp{-T} to
3213 augment the default @code{SECTIONS} with, for example, overlays.  It
3214 inserts all prior linker script statements after (or before)
3215 @var{output_section}, and also causes @samp{-T} to not override the
3216 default linker script.  The exact insertion point is as for orphan
3217 sections.  @xref{Location Counter}.  The insertion happens after the
3218 linker has mapped input sections to output sections.  Prior to the
3219 insertion, since @samp{-T} scripts are parsed before the default
3220 linker script, statements in the @samp{-T} script occur before the
3221 default linker script statements in the internal linker representation
3222 of the script.  In particular, input section assignments will be made
3223 to @samp{-T} output sections before those in the default script.  Here
3224 is an example of how a @samp{-T} script using @code{INSERT} might look:
3226 @smallexample
3227 SECTIONS
3229   OVERLAY :
3230   @{
3231     .ov1 @{ ov1*(.text) @}
3232     .ov2 @{ ov2*(.text) @}
3233   @}
3235 INSERT AFTER .text;
3236 @end smallexample
3238 @item NOCROSSREFS(@var{section} @var{section} @dots{})
3239 @kindex NOCROSSREFS(@var{sections})
3240 @cindex cross references
3241 This command may be used to tell @command{ld} to issue an error about any
3242 references among certain output sections.
3244 In certain types of programs, particularly on embedded systems when
3245 using overlays, when one section is loaded into memory, another section
3246 will not be.  Any direct references between the two sections would be
3247 errors.  For example, it would be an error if code in one section called
3248 a function defined in the other section.
3250 The @code{NOCROSSREFS} command takes a list of output section names.  If
3251 @command{ld} detects any cross references between the sections, it reports
3252 an error and returns a non-zero exit status.  Note that the
3253 @code{NOCROSSREFS} command uses output section names, not input section
3254 names.
3256 @ifclear SingleFormat
3257 @item OUTPUT_ARCH(@var{bfdarch})
3258 @kindex OUTPUT_ARCH(@var{bfdarch})
3259 @cindex machine architecture
3260 @cindex architecture
3261 Specify a particular output machine architecture.  The argument is one
3262 of the names used by the BFD library (@pxref{BFD}).  You can see the
3263 architecture of an object file by using the @code{objdump} program with
3264 the @samp{-f} option.
3265 @end ifclear
3266 @end table
3268 @node Assignments
3269 @section Assigning Values to Symbols
3270 @cindex assignment in scripts
3271 @cindex symbol definition, scripts
3272 @cindex variables, defining
3273 You may assign a value to a symbol in a linker script.  This will define
3274 the symbol and place it into the symbol table with a global scope.
3276 @menu
3277 * Simple Assignments::          Simple Assignments
3278 * PROVIDE::                     PROVIDE
3279 * PROVIDE_HIDDEN::              PROVIDE_HIDDEN
3280 * Source Code Reference::       How to use a linker script defined symbol in source code
3281 @end menu
3283 @node Simple Assignments
3284 @subsection Simple Assignments
3286 You may assign to a symbol using any of the C assignment operators:
3288 @table @code
3289 @item @var{symbol} = @var{expression} ;
3290 @itemx @var{symbol} += @var{expression} ;
3291 @itemx @var{symbol} -= @var{expression} ;
3292 @itemx @var{symbol} *= @var{expression} ;
3293 @itemx @var{symbol} /= @var{expression} ;
3294 @itemx @var{symbol} <<= @var{expression} ;
3295 @itemx @var{symbol} >>= @var{expression} ;
3296 @itemx @var{symbol} &= @var{expression} ;
3297 @itemx @var{symbol} |= @var{expression} ;
3298 @end table
3300 The first case will define @var{symbol} to the value of
3301 @var{expression}.  In the other cases, @var{symbol} must already be
3302 defined, and the value will be adjusted accordingly.
3304 The special symbol name @samp{.} indicates the location counter.  You
3305 may only use this within a @code{SECTIONS} command.  @xref{Location Counter}.
3307 The semicolon after @var{expression} is required.
3309 Expressions are defined below; see @ref{Expressions}.
3311 You may write symbol assignments as commands in their own right, or as
3312 statements within a @code{SECTIONS} command, or as part of an output
3313 section description in a @code{SECTIONS} command.
3315 The section of the symbol will be set from the section of the
3316 expression; for more information, see @ref{Expression Section}.
3318 Here is an example showing the three different places that symbol
3319 assignments may be used:
3321 @smallexample
3322 floating_point = 0;
3323 SECTIONS
3325   .text :
3326     @{
3327       *(.text)
3328       _etext = .;
3329     @}
3330   _bdata = (. + 3) & ~ 3;
3331   .data : @{ *(.data) @}
3333 @end smallexample
3334 @noindent
3335 In this example, the symbol @samp{floating_point} will be defined as
3336 zero.  The symbol @samp{_etext} will be defined as the address following
3337 the last @samp{.text} input section.  The symbol @samp{_bdata} will be
3338 defined as the address following the @samp{.text} output section aligned
3339 upward to a 4 byte boundary.
3341 @node PROVIDE
3342 @subsection PROVIDE
3343 @cindex PROVIDE
3344 In some cases, it is desirable for a linker script to define a symbol
3345 only if it is referenced and is not defined by any object included in
3346 the link.  For example, traditional linkers defined the symbol
3347 @samp{etext}.  However, ANSI C requires that the user be able to use
3348 @samp{etext} as a function name without encountering an error.  The
3349 @code{PROVIDE} keyword may be used to define a symbol, such as
3350 @samp{etext}, only if it is referenced but not defined.  The syntax is
3351 @code{PROVIDE(@var{symbol} = @var{expression})}.
3353 Here is an example of using @code{PROVIDE} to define @samp{etext}:
3354 @smallexample
3355 SECTIONS
3357   .text :
3358     @{
3359       *(.text)
3360       _etext = .;
3361       PROVIDE(etext = .);
3362     @}
3364 @end smallexample
3366 In this example, if the program defines @samp{_etext} (with a leading
3367 underscore), the linker will give a multiple definition error.  If, on
3368 the other hand, the program defines @samp{etext} (with no leading
3369 underscore), the linker will silently use the definition in the program.
3370 If the program references @samp{etext} but does not define it, the
3371 linker will use the definition in the linker script.
3373 @node PROVIDE_HIDDEN
3374 @subsection PROVIDE_HIDDEN
3375 @cindex PROVIDE_HIDDEN
3376 Similar to @code{PROVIDE}.  For ELF targeted ports, the symbol will be
3377 hidden and won't be exported.
3379 @node Source Code Reference
3380 @subsection Source Code Reference
3382 Accessing a linker script defined variable from source code is not
3383 intuitive.  In particular a linker script symbol is not equivalent to
3384 a variable declaration in a high level language, it is instead a
3385 symbol that does not have a value.
3387 Before going further, it is important to note that compilers often
3388 transform names in the source code into different names when they are
3389 stored in the symbol table.  For example, Fortran compilers commonly
3390 prepend or append an underscore, and C++ performs extensive @samp{name
3391 mangling}.  Therefore there might be a discrepancy between the name
3392 of a variable as it is used in source code and the name of the same
3393 variable as it is defined in a linker script.  For example in C a
3394 linker script variable might be referred to as:
3396 @smallexample
3397   extern int foo;
3398 @end smallexample
3400 But in the linker script it might be defined as:
3402 @smallexample
3403   _foo = 1000;
3404 @end smallexample
3406 In the remaining examples however it is assumed that no name
3407 transformation has taken place.
3409 When a symbol is declared in a high level language such as C, two
3410 things happen.  The first is that the compiler reserves enough space
3411 in the program's memory to hold the @emph{value} of the symbol.  The
3412 second is that the compiler creates an entry in the program's symbol
3413 table which holds the symbol's @emph{address}.  ie the symbol table
3414 contains the address of the block of memory holding the symbol's
3415 value.  So for example the following C declaration, at file scope:
3417 @smallexample
3418   int foo = 1000;
3419 @end smallexample
3421 creates a entry called @samp{foo} in the symbol table.  This entry
3422 holds the address of an @samp{int} sized block of memory where the
3423 number 1000 is initially stored.
3425 When a program references a symbol the compiler generates code that
3426 first accesses the symbol table to find the address of the symbol's
3427 memory block and then code to read the value from that memory block.
3430 @smallexample
3431   foo = 1;
3432 @end smallexample
3434 looks up the symbol @samp{foo} in the symbol table, gets the address
3435 associated with this symbol and then writes the value 1 into that
3436 address.  Whereas:
3438 @smallexample
3439   int * a = & foo;
3440 @end smallexample
3442 looks up the symbol @samp{foo} in the symbol table, gets it address
3443 and then copies this address into the block of memory associated with
3444 the variable @samp{a}.
3446 Linker scripts symbol declarations, by contrast, create an entry in
3447 the symbol table but do not assign any memory to them.  Thus they are
3448 an address without a value.  So for example the linker script definition:
3450 @smallexample
3451   foo = 1000;
3452 @end smallexample
3454 creates an entry in the symbol table called @samp{foo} which holds
3455 the address of memory location 1000, but nothing special is stored at
3456 address 1000.  This means that you cannot access the @emph{value} of a
3457 linker script defined symbol - it has no value - all you can do is
3458 access the @emph{address} of a linker script defined symbol.
3460 Hence when you are using a linker script defined symbol in source code
3461 you should always take the address of the symbol, and never attempt to
3462 use its value.  For example suppose you want to copy the contents of a
3463 section of memory called .ROM into a section called .FLASH and the
3464 linker script contains these declarations:
3466 @smallexample
3467 @group
3468   start_of_ROM   = .ROM;
3469   end_of_ROM     = .ROM + sizeof (.ROM) - 1;
3470   start_of_FLASH = .FLASH;
3471 @end group
3472 @end smallexample
3474 Then the C source code to perform the copy would be:
3476 @smallexample
3477 @group
3478   extern char start_of_ROM, end_of_ROM, start_of_FLASH;
3480   memcpy (& start_of_FLASH, & start_of_ROM, & end_of_ROM - & start_of_ROM);
3481 @end group
3482 @end smallexample
3484 Note the use of the @samp{&} operators.  These are correct.
3486 @node SECTIONS
3487 @section SECTIONS Command
3488 @kindex SECTIONS
3489 The @code{SECTIONS} command tells the linker how to map input sections
3490 into output sections, and how to place the output sections in memory.
3492 The format of the @code{SECTIONS} command is:
3493 @smallexample
3494 SECTIONS
3496   @var{sections-command}
3497   @var{sections-command}
3498   @dots{}
3500 @end smallexample
3502 Each @var{sections-command} may of be one of the following:
3504 @itemize @bullet
3505 @item
3506 an @code{ENTRY} command (@pxref{Entry Point,,Entry command})
3507 @item
3508 a symbol assignment (@pxref{Assignments})
3509 @item
3510 an output section description
3511 @item
3512 an overlay description
3513 @end itemize
3515 The @code{ENTRY} command and symbol assignments are permitted inside the
3516 @code{SECTIONS} command for convenience in using the location counter in
3517 those commands.  This can also make the linker script easier to
3518 understand because you can use those commands at meaningful points in
3519 the layout of the output file.
3521 Output section descriptions and overlay descriptions are described
3522 below.
3524 If you do not use a @code{SECTIONS} command in your linker script, the
3525 linker will place each input section into an identically named output
3526 section in the order that the sections are first encountered in the
3527 input files.  If all input sections are present in the first file, for
3528 example, the order of sections in the output file will match the order
3529 in the first input file.  The first section will be at address zero.
3531 @menu
3532 * Output Section Description::  Output section description
3533 * Output Section Name::         Output section name
3534 * Output Section Address::      Output section address
3535 * Input Section::               Input section description
3536 * Output Section Data::         Output section data
3537 * Output Section Keywords::     Output section keywords
3538 * Output Section Discarding::   Output section discarding
3539 * Output Section Attributes::   Output section attributes
3540 * Overlay Description::         Overlay description
3541 @end menu
3543 @node Output Section Description
3544 @subsection Output Section Description
3545 The full description of an output section looks like this:
3546 @smallexample
3547 @group
3548 @var{section} [@var{address}] [(@var{type})] :
3549   [AT(@var{lma})] [ALIGN(@var{section_align})] [SUBALIGN(@var{subsection_align})]
3550   @{
3551     @var{output-section-command}
3552     @var{output-section-command}
3553     @dots{}
3554   @} [>@var{region}] [AT>@var{lma_region}] [:@var{phdr} :@var{phdr} @dots{}] [=@var{fillexp}]
3555 @end group
3556 @end smallexample
3558 Most output sections do not use most of the optional section attributes.
3560 The whitespace around @var{section} is required, so that the section
3561 name is unambiguous.  The colon and the curly braces are also required.
3562 The line breaks and other white space are optional.
3564 Each @var{output-section-command} may be one of the following:
3566 @itemize @bullet
3567 @item
3568 a symbol assignment (@pxref{Assignments})
3569 @item
3570 an input section description (@pxref{Input Section})
3571 @item
3572 data values to include directly (@pxref{Output Section Data})
3573 @item
3574 a special output section keyword (@pxref{Output Section Keywords})
3575 @end itemize
3577 @node Output Section Name
3578 @subsection Output Section Name
3579 @cindex name, section
3580 @cindex section name
3581 The name of the output section is @var{section}.  @var{section} must
3582 meet the constraints of your output format.  In formats which only
3583 support a limited number of sections, such as @code{a.out}, the name
3584 must be one of the names supported by the format (@code{a.out}, for
3585 example, allows only @samp{.text}, @samp{.data} or @samp{.bss}). If the
3586 output format supports any number of sections, but with numbers and not
3587 names (as is the case for Oasys), the name should be supplied as a
3588 quoted numeric string.  A section name may consist of any sequence of
3589 characters, but a name which contains any unusual characters such as
3590 commas must be quoted.
3592 The output section name @samp{/DISCARD/} is special; @ref{Output Section
3593 Discarding}.
3595 @node Output Section Address
3596 @subsection Output Section Address
3597 @cindex address, section
3598 @cindex section address
3599 The @var{address} is an expression for the VMA (the virtual memory
3600 address) of the output section.  If you do not provide @var{address},
3601 the linker will set it based on @var{region} if present, or otherwise
3602 based on the current value of the location counter.
3604 If you provide @var{address}, the address of the output section will be
3605 set to precisely that.  If you provide neither @var{address} nor
3606 @var{region}, then the address of the output section will be set to the
3607 current value of the location counter aligned to the alignment
3608 requirements of the output section.  The alignment requirement of the
3609 output section is the strictest alignment of any input section contained
3610 within the output section.
3612 For example,
3613 @smallexample
3614 .text . : @{ *(.text) @}
3615 @end smallexample
3616 @noindent
3618 @smallexample
3619 .text : @{ *(.text) @}
3620 @end smallexample
3621 @noindent
3622 are subtly different.  The first will set the address of the
3623 @samp{.text} output section to the current value of the location
3624 counter.  The second will set it to the current value of the location
3625 counter aligned to the strictest alignment of a @samp{.text} input
3626 section.
3628 The @var{address} may be an arbitrary expression; @ref{Expressions}.
3629 For example, if you want to align the section on a 0x10 byte boundary,
3630 so that the lowest four bits of the section address are zero, you could
3631 do something like this:
3632 @smallexample
3633 .text ALIGN(0x10) : @{ *(.text) @}
3634 @end smallexample
3635 @noindent
3636 This works because @code{ALIGN} returns the current location counter
3637 aligned upward to the specified value.
3639 Specifying @var{address} for a section will change the value of the
3640 location counter.
3642 @node Input Section
3643 @subsection Input Section Description
3644 @cindex input sections
3645 @cindex mapping input sections to output sections
3646 The most common output section command is an input section description.
3648 The input section description is the most basic linker script operation.
3649 You use output sections to tell the linker how to lay out your program
3650 in memory.  You use input section descriptions to tell the linker how to
3651 map the input files into your memory layout.
3653 @menu
3654 * Input Section Basics::        Input section basics
3655 * Input Section Wildcards::     Input section wildcard patterns
3656 * Input Section Common::        Input section for common symbols
3657 * Input Section Keep::          Input section and garbage collection
3658 * Input Section Example::       Input section example
3659 @end menu
3661 @node Input Section Basics
3662 @subsubsection Input Section Basics
3663 @cindex input section basics
3664 An input section description consists of a file name optionally followed
3665 by a list of section names in parentheses.
3667 The file name and the section name may be wildcard patterns, which we
3668 describe further below (@pxref{Input Section Wildcards}).
3670 The most common input section description is to include all input
3671 sections with a particular name in the output section.  For example, to
3672 include all input @samp{.text} sections, you would write:
3673 @smallexample
3674 *(.text)
3675 @end smallexample
3676 @noindent
3677 Here the @samp{*} is a wildcard which matches any file name.  To exclude a list
3678 of files from matching the file name wildcard, EXCLUDE_FILE may be used to
3679 match all files except the ones specified in the EXCLUDE_FILE list.  For
3680 example:
3681 @smallexample
3682 *(EXCLUDE_FILE (*crtend.o *otherfile.o) .ctors)
3683 @end smallexample
3684 will cause all .ctors sections from all files except @file{crtend.o} and
3685 @file{otherfile.o} to be included.
3687 There are two ways to include more than one section:
3688 @smallexample
3689 *(.text .rdata)
3690 *(.text) *(.rdata)
3691 @end smallexample
3692 @noindent
3693 The difference between these is the order in which the @samp{.text} and
3694 @samp{.rdata} input sections will appear in the output section.  In the
3695 first example, they will be intermingled, appearing in the same order as
3696 they are found in the linker input.  In the second example, all
3697 @samp{.text} input sections will appear first, followed by all
3698 @samp{.rdata} input sections.
3700 You can specify a file name to include sections from a particular file.
3701 You would do this if one or more of your files contain special data that
3702 needs to be at a particular location in memory.  For example:
3703 @smallexample
3704 data.o(.data)
3705 @end smallexample
3707 You can also specify files within archives by writing a pattern
3708 matching the archive, a colon, then the pattern matching the file,
3709 with no whitespace around the colon.
3711 @table @samp
3712 @item archive:file
3713 matches file within archive
3714 @item archive:
3715 matches the whole archive
3716 @item :file
3717 matches file but not one in an archive
3718 @end table
3720 Either one or both of @samp{archive} and @samp{file} can contain shell
3721 wildcards.  On DOS based file systems, the linker will assume that a
3722 single letter followed by a colon is a drive specifier, so
3723 @samp{c:myfile.o} is a simple file specification, not @samp{myfile.o}
3724 within an archive called @samp{c}.  @samp{archive:file} filespecs may
3725 also be used within an @code{EXCLUDE_FILE} list, but may not appear in
3726 other linker script contexts.  For instance, you cannot extract a file
3727 from an archive by using @samp{archive:file} in an @code{INPUT}
3728 command.
3730 If you use a file name without a list of sections, then all sections in
3731 the input file will be included in the output section.  This is not
3732 commonly done, but it may by useful on occasion.  For example:
3733 @smallexample
3734 data.o
3735 @end smallexample
3737 When you use a file name which is not an @samp{archive:file} specifier
3738 and does not contain any wild card
3739 characters, the linker will first see if you also specified the file
3740 name on the linker command line or in an @code{INPUT} command.  If you
3741 did not, the linker will attempt to open the file as an input file, as
3742 though it appeared on the command line.  Note that this differs from an
3743 @code{INPUT} command, because the linker will not search for the file in
3744 the archive search path.
3746 @node Input Section Wildcards
3747 @subsubsection Input Section Wildcard Patterns
3748 @cindex input section wildcards
3749 @cindex wildcard file name patterns
3750 @cindex file name wildcard patterns
3751 @cindex section name wildcard patterns
3752 In an input section description, either the file name or the section
3753 name or both may be wildcard patterns.
3755 The file name of @samp{*} seen in many examples is a simple wildcard
3756 pattern for the file name.
3758 The wildcard patterns are like those used by the Unix shell.
3760 @table @samp
3761 @item *
3762 matches any number of characters
3763 @item ?
3764 matches any single character
3765 @item [@var{chars}]
3766 matches a single instance of any of the @var{chars}; the @samp{-}
3767 character may be used to specify a range of characters, as in
3768 @samp{[a-z]} to match any lower case letter
3769 @item \
3770 quotes the following character
3771 @end table
3773 When a file name is matched with a wildcard, the wildcard characters
3774 will not match a @samp{/} character (used to separate directory names on
3775 Unix).  A pattern consisting of a single @samp{*} character is an
3776 exception; it will always match any file name, whether it contains a
3777 @samp{/} or not.  In a section name, the wildcard characters will match
3778 a @samp{/} character.
3780 File name wildcard patterns only match files which are explicitly
3781 specified on the command line or in an @code{INPUT} command.  The linker
3782 does not search directories to expand wildcards.
3784 If a file name matches more than one wildcard pattern, or if a file name
3785 appears explicitly and is also matched by a wildcard pattern, the linker
3786 will use the first match in the linker script.  For example, this
3787 sequence of input section descriptions is probably in error, because the
3788 @file{data.o} rule will not be used:
3789 @smallexample
3790 .data : @{ *(.data) @}
3791 .data1 : @{ data.o(.data) @}
3792 @end smallexample
3794 @cindex SORT_BY_NAME
3795 Normally, the linker will place files and sections matched by wildcards
3796 in the order in which they are seen during the link.  You can change
3797 this by using the @code{SORT_BY_NAME} keyword, which appears before a wildcard
3798 pattern in parentheses (e.g., @code{SORT_BY_NAME(.text*)}).  When the
3799 @code{SORT_BY_NAME} keyword is used, the linker will sort the files or sections
3800 into ascending order by name before placing them in the output file.
3802 @cindex SORT_BY_ALIGNMENT
3803 @code{SORT_BY_ALIGNMENT} is very similar to @code{SORT_BY_NAME}. The
3804 difference is @code{SORT_BY_ALIGNMENT} will sort sections into
3805 ascending order by alignment before placing them in the output file.
3807 @cindex SORT
3808 @code{SORT} is an alias for @code{SORT_BY_NAME}.
3810 When there are nested section sorting commands in linker script, there
3811 can be at most 1 level of nesting for section sorting commands.
3813 @enumerate
3814 @item
3815 @code{SORT_BY_NAME} (@code{SORT_BY_ALIGNMENT} (wildcard section pattern)).
3816 It will sort the input sections by name first, then by alignment if 2
3817 sections have the same name.
3818 @item
3819 @code{SORT_BY_ALIGNMENT} (@code{SORT_BY_NAME} (wildcard section pattern)).
3820 It will sort the input sections by alignment first, then by name if 2
3821 sections have the same alignment.
3822 @item
3823 @code{SORT_BY_NAME} (@code{SORT_BY_NAME} (wildcard section pattern)) is
3824 treated the same as @code{SORT_BY_NAME} (wildcard section pattern).
3825 @item
3826 @code{SORT_BY_ALIGNMENT} (@code{SORT_BY_ALIGNMENT} (wildcard section pattern))
3827 is treated the same as @code{SORT_BY_ALIGNMENT} (wildcard section pattern).
3828 @item
3829 All other nested section sorting commands are invalid.
3830 @end enumerate
3832 When both command line section sorting option and linker script
3833 section sorting command are used, section sorting command always
3834 takes precedence over the command line option.
3836 If the section sorting command in linker script isn't nested, the
3837 command line option will make the section sorting command to be
3838 treated as nested sorting command.
3840 @enumerate
3841 @item
3842 @code{SORT_BY_NAME} (wildcard section pattern ) with
3843 @option{--sort-sections alignment} is equivalent to
3844 @code{SORT_BY_NAME} (@code{SORT_BY_ALIGNMENT} (wildcard section pattern)).
3845 @item
3846 @code{SORT_BY_ALIGNMENT} (wildcard section pattern) with
3847 @option{--sort-section name} is equivalent to
3848 @code{SORT_BY_ALIGNMENT} (@code{SORT_BY_NAME} (wildcard section pattern)).
3849 @end enumerate
3851 If the section sorting command in linker script is nested, the
3852 command line option will be ignored.
3854 If you ever get confused about where input sections are going, use the
3855 @samp{-M} linker option to generate a map file.  The map file shows
3856 precisely how input sections are mapped to output sections.
3858 This example shows how wildcard patterns might be used to partition
3859 files.  This linker script directs the linker to place all @samp{.text}
3860 sections in @samp{.text} and all @samp{.bss} sections in @samp{.bss}.
3861 The linker will place the @samp{.data} section from all files beginning
3862 with an upper case character in @samp{.DATA}; for all other files, the
3863 linker will place the @samp{.data} section in @samp{.data}.
3864 @smallexample
3865 @group
3866 SECTIONS @{
3867   .text : @{ *(.text) @}
3868   .DATA : @{ [A-Z]*(.data) @}
3869   .data : @{ *(.data) @}
3870   .bss : @{ *(.bss) @}
3872 @end group
3873 @end smallexample
3875 @node Input Section Common
3876 @subsubsection Input Section for Common Symbols
3877 @cindex common symbol placement
3878 @cindex uninitialized data placement
3879 A special notation is needed for common symbols, because in many object
3880 file formats common symbols do not have a particular input section.  The
3881 linker treats common symbols as though they are in an input section
3882 named @samp{COMMON}.
3884 You may use file names with the @samp{COMMON} section just as with any
3885 other input sections.  You can use this to place common symbols from a
3886 particular input file in one section while common symbols from other
3887 input files are placed in another section.
3889 In most cases, common symbols in input files will be placed in the
3890 @samp{.bss} section in the output file.  For example:
3891 @smallexample
3892 .bss @{ *(.bss) *(COMMON) @}
3893 @end smallexample
3895 @cindex scommon section
3896 @cindex small common symbols
3897 Some object file formats have more than one type of common symbol.  For
3898 example, the MIPS ELF object file format distinguishes standard common
3899 symbols and small common symbols.  In this case, the linker will use a
3900 different special section name for other types of common symbols.  In
3901 the case of MIPS ELF, the linker uses @samp{COMMON} for standard common
3902 symbols and @samp{.scommon} for small common symbols.  This permits you
3903 to map the different types of common symbols into memory at different
3904 locations.
3906 @cindex [COMMON]
3907 You will sometimes see @samp{[COMMON]} in old linker scripts.  This
3908 notation is now considered obsolete.  It is equivalent to
3909 @samp{*(COMMON)}.
3911 @node Input Section Keep
3912 @subsubsection Input Section and Garbage Collection
3913 @cindex KEEP
3914 @cindex garbage collection
3915 When link-time garbage collection is in use (@samp{--gc-sections}),
3916 it is often useful to mark sections that should not be eliminated.
3917 This is accomplished by surrounding an input section's wildcard entry
3918 with @code{KEEP()}, as in @code{KEEP(*(.init))} or
3919 @code{KEEP(SORT_BY_NAME(*)(.ctors))}.
3921 @node Input Section Example
3922 @subsubsection Input Section Example
3923 The following example is a complete linker script.  It tells the linker
3924 to read all of the sections from file @file{all.o} and place them at the
3925 start of output section @samp{outputa} which starts at location
3926 @samp{0x10000}.  All of section @samp{.input1} from file @file{foo.o}
3927 follows immediately, in the same output section.  All of section
3928 @samp{.input2} from @file{foo.o} goes into output section
3929 @samp{outputb}, followed by section @samp{.input1} from @file{foo1.o}.
3930 All of the remaining @samp{.input1} and @samp{.input2} sections from any
3931 files are written to output section @samp{outputc}.
3933 @smallexample
3934 @group
3935 SECTIONS @{
3936   outputa 0x10000 :
3937     @{
3938     all.o
3939     foo.o (.input1)
3940     @}
3941 @end group
3942 @group
3943   outputb :
3944     @{
3945     foo.o (.input2)
3946     foo1.o (.input1)
3947     @}
3948 @end group
3949 @group
3950   outputc :
3951     @{
3952     *(.input1)
3953     *(.input2)
3954     @}
3956 @end group
3957 @end smallexample
3959 @node Output Section Data
3960 @subsection Output Section Data
3961 @cindex data
3962 @cindex section data
3963 @cindex output section data
3964 @kindex BYTE(@var{expression})
3965 @kindex SHORT(@var{expression})
3966 @kindex LONG(@var{expression})
3967 @kindex QUAD(@var{expression})
3968 @kindex SQUAD(@var{expression})
3969 You can include explicit bytes of data in an output section by using
3970 @code{BYTE}, @code{SHORT}, @code{LONG}, @code{QUAD}, or @code{SQUAD} as
3971 an output section command.  Each keyword is followed by an expression in
3972 parentheses providing the value to store (@pxref{Expressions}).  The
3973 value of the expression is stored at the current value of the location
3974 counter.
3976 The @code{BYTE}, @code{SHORT}, @code{LONG}, and @code{QUAD} commands
3977 store one, two, four, and eight bytes (respectively).  After storing the
3978 bytes, the location counter is incremented by the number of bytes
3979 stored.
3981 For example, this will store the byte 1 followed by the four byte value
3982 of the symbol @samp{addr}:
3983 @smallexample
3984 BYTE(1)
3985 LONG(addr)
3986 @end smallexample
3988 When using a 64 bit host or target, @code{QUAD} and @code{SQUAD} are the
3989 same; they both store an 8 byte, or 64 bit, value.  When both host and
3990 target are 32 bits, an expression is computed as 32 bits.  In this case
3991 @code{QUAD} stores a 32 bit value zero extended to 64 bits, and
3992 @code{SQUAD} stores a 32 bit value sign extended to 64 bits.
3994 If the object file format of the output file has an explicit endianness,
3995 which is the normal case, the value will be stored in that endianness.
3996 When the object file format does not have an explicit endianness, as is
3997 true of, for example, S-records, the value will be stored in the
3998 endianness of the first input object file.
4000 Note---these commands only work inside a section description and not
4001 between them, so the following will produce an error from the linker:
4002 @smallexample
4003 SECTIONS @{@ .text : @{@ *(.text) @}@ LONG(1) .data : @{@ *(.data) @}@ @}@
4004 @end smallexample
4005 whereas this will work:
4006 @smallexample
4007 SECTIONS @{@ .text : @{@ *(.text) ; LONG(1) @}@ .data : @{@ *(.data) @}@ @}@
4008 @end smallexample
4010 @kindex FILL(@var{expression})
4011 @cindex holes, filling
4012 @cindex unspecified memory
4013 You may use the @code{FILL} command to set the fill pattern for the
4014 current section.  It is followed by an expression in parentheses.  Any
4015 otherwise unspecified regions of memory within the section (for example,
4016 gaps left due to the required alignment of input sections) are filled
4017 with the value of the expression, repeated as
4018 necessary.  A @code{FILL} statement covers memory locations after the
4019 point at which it occurs in the section definition; by including more
4020 than one @code{FILL} statement, you can have different fill patterns in
4021 different parts of an output section.
4023 This example shows how to fill unspecified regions of memory with the
4024 value @samp{0x90}:
4025 @smallexample
4026 FILL(0x90909090)
4027 @end smallexample
4029 The @code{FILL} command is similar to the @samp{=@var{fillexp}} output
4030 section attribute, but it only affects the
4031 part of the section following the @code{FILL} command, rather than the
4032 entire section.  If both are used, the @code{FILL} command takes
4033 precedence.  @xref{Output Section Fill}, for details on the fill
4034 expression.
4036 @node Output Section Keywords
4037 @subsection Output Section Keywords
4038 There are a couple of keywords which can appear as output section
4039 commands.
4041 @table @code
4042 @kindex CREATE_OBJECT_SYMBOLS
4043 @cindex input filename symbols
4044 @cindex filename symbols
4045 @item CREATE_OBJECT_SYMBOLS
4046 The command tells the linker to create a symbol for each input file.
4047 The name of each symbol will be the name of the corresponding input
4048 file.  The section of each symbol will be the output section in which
4049 the @code{CREATE_OBJECT_SYMBOLS} command appears.
4051 This is conventional for the a.out object file format.  It is not
4052 normally used for any other object file format.
4054 @kindex CONSTRUCTORS
4055 @cindex C++ constructors, arranging in link
4056 @cindex constructors, arranging in link
4057 @item CONSTRUCTORS
4058 When linking using the a.out object file format, the linker uses an
4059 unusual set construct to support C++ global constructors and
4060 destructors.  When linking object file formats which do not support
4061 arbitrary sections, such as ECOFF and XCOFF, the linker will
4062 automatically recognize C++ global constructors and destructors by name.
4063 For these object file formats, the @code{CONSTRUCTORS} command tells the
4064 linker to place constructor information in the output section where the
4065 @code{CONSTRUCTORS} command appears.  The @code{CONSTRUCTORS} command is
4066 ignored for other object file formats.
4068 The symbol @w{@code{__CTOR_LIST__}} marks the start of the global
4069 constructors, and the symbol @w{@code{__CTOR_END__}} marks the end.
4070 Similarly, @w{@code{__DTOR_LIST__}} and @w{@code{__DTOR_END__}} mark
4071 the start and end of the global destructors.  The
4072 first word in the list is the number of entries, followed by the address
4073 of each constructor or destructor, followed by a zero word.  The
4074 compiler must arrange to actually run the code.  For these object file
4075 formats @sc{gnu} C++ normally calls constructors from a subroutine
4076 @code{__main}; a call to @code{__main} is automatically inserted into
4077 the startup code for @code{main}.  @sc{gnu} C++ normally runs
4078 destructors either by using @code{atexit}, or directly from the function
4079 @code{exit}.
4081 For object file formats such as @code{COFF} or @code{ELF} which support
4082 arbitrary section names, @sc{gnu} C++ will normally arrange to put the
4083 addresses of global constructors and destructors into the @code{.ctors}
4084 and @code{.dtors} sections.  Placing the following sequence into your
4085 linker script will build the sort of table which the @sc{gnu} C++
4086 runtime code expects to see.
4088 @smallexample
4089       __CTOR_LIST__ = .;
4090       LONG((__CTOR_END__ - __CTOR_LIST__) / 4 - 2)
4091       *(.ctors)
4092       LONG(0)
4093       __CTOR_END__ = .;
4094       __DTOR_LIST__ = .;
4095       LONG((__DTOR_END__ - __DTOR_LIST__) / 4 - 2)
4096       *(.dtors)
4097       LONG(0)
4098       __DTOR_END__ = .;
4099 @end smallexample
4101 If you are using the @sc{gnu} C++ support for initialization priority,
4102 which provides some control over the order in which global constructors
4103 are run, you must sort the constructors at link time to ensure that they
4104 are executed in the correct order.  When using the @code{CONSTRUCTORS}
4105 command, use @samp{SORT_BY_NAME(CONSTRUCTORS)} instead.  When using the
4106 @code{.ctors} and @code{.dtors} sections, use @samp{*(SORT_BY_NAME(.ctors))} and
4107 @samp{*(SORT_BY_NAME(.dtors))} instead of just @samp{*(.ctors)} and
4108 @samp{*(.dtors)}.
4110 Normally the compiler and linker will handle these issues automatically,
4111 and you will not need to concern yourself with them.  However, you may
4112 need to consider this if you are using C++ and writing your own linker
4113 scripts.
4115 @end table
4117 @node Output Section Discarding
4118 @subsection Output Section Discarding
4119 @cindex discarding sections
4120 @cindex sections, discarding
4121 @cindex removing sections
4122 The linker will not create output sections with no contents.  This is
4123 for convenience when referring to input sections that may or may not
4124 be present in any of the input files.  For example:
4125 @smallexample
4126 .foo : @{ *(.foo) @}
4127 @end smallexample
4128 @noindent
4129 will only create a @samp{.foo} section in the output file if there is a
4130 @samp{.foo} section in at least one input file, and if the input
4131 sections are not all empty.  Other link script directives that allocate
4132 space in an output section will also create the output section.
4134 The linker will ignore address assignments (@pxref{Output Section Address})
4135 on discarded output sections, except when the linker script defines
4136 symbols in the output section.  In that case the linker will obey
4137 the address assignments, possibly advancing dot even though the
4138 section is discarded.
4140 @cindex /DISCARD/
4141 The special output section name @samp{/DISCARD/} may be used to discard
4142 input sections.  Any input sections which are assigned to an output
4143 section named @samp{/DISCARD/} are not included in the output file.
4145 @node Output Section Attributes
4146 @subsection Output Section Attributes
4147 @cindex output section attributes
4148 We showed above that the full description of an output section looked
4149 like this:
4150 @smallexample
4151 @group
4152 @var{section} [@var{address}] [(@var{type})] :
4153   [AT(@var{lma})] [ALIGN(@var{section_align})] [SUBALIGN(@var{subsection_align})]
4154   @{
4155     @var{output-section-command}
4156     @var{output-section-command}
4157     @dots{}
4158   @} [>@var{region}] [AT>@var{lma_region}] [:@var{phdr} :@var{phdr} @dots{}] [=@var{fillexp}]
4159 @end group
4160 @end smallexample
4161 We've already described @var{section}, @var{address}, and
4162 @var{output-section-command}.  In this section we will describe the
4163 remaining section attributes.
4165 @menu
4166 * Output Section Type::         Output section type
4167 * Output Section LMA::          Output section LMA
4168 * Forced Output Alignment::     Forced Output Alignment
4169 * Forced Input Alignment::      Forced Input Alignment
4170 * Output Section Region::       Output section region
4171 * Output Section Phdr::         Output section phdr
4172 * Output Section Fill::         Output section fill
4173 @end menu
4175 @node Output Section Type
4176 @subsubsection Output Section Type
4177 Each output section may have a type.  The type is a keyword in
4178 parentheses.  The following types are defined:
4180 @table @code
4181 @item NOLOAD
4182 The section should be marked as not loadable, so that it will not be
4183 loaded into memory when the program is run.
4184 @item DSECT
4185 @itemx COPY
4186 @itemx INFO
4187 @itemx OVERLAY
4188 These type names are supported for backward compatibility, and are
4189 rarely used.  They all have the same effect: the section should be
4190 marked as not allocatable, so that no memory is allocated for the
4191 section when the program is run.
4192 @end table
4194 @kindex NOLOAD
4195 @cindex prevent unnecessary loading
4196 @cindex loading, preventing
4197 The linker normally sets the attributes of an output section based on
4198 the input sections which map into it.  You can override this by using
4199 the section type.  For example, in the script sample below, the
4200 @samp{ROM} section is addressed at memory location @samp{0} and does not
4201 need to be loaded when the program is run.  The contents of the
4202 @samp{ROM} section will appear in the linker output file as usual.
4203 @smallexample
4204 @group
4205 SECTIONS @{
4206   ROM 0 (NOLOAD) : @{ @dots{} @}
4207   @dots{}
4209 @end group
4210 @end smallexample
4212 @node Output Section LMA
4213 @subsubsection Output Section LMA
4214 @kindex AT>@var{lma_region}
4215 @kindex AT(@var{lma})
4216 @cindex load address
4217 @cindex section load address
4218 Every section has a virtual address (VMA) and a load address (LMA); see
4219 @ref{Basic Script Concepts}.  The address expression which may appear in
4220 an output section description sets the VMA (@pxref{Output Section
4221 Address}).
4223 The expression @var{lma} that follows the @code{AT} keyword specifies
4224 the load address of the section.
4226 Alternatively, with @samp{AT>@var{lma_region}} expression, you may
4227 specify a memory region for the section's load address. @xref{MEMORY}.
4228 Note that if the section has not had a VMA assigned to it then the
4229 linker will use the @var{lma_region} as the VMA region as well.
4231 If neither @code{AT} nor @code{AT>} is specified for an allocatable
4232 section, the linker will set the LMA such that the difference between
4233 VMA and LMA for the section is the same as the preceding output
4234 section in the same region.  If there is no preceding output section
4235 or the section is not allocatable, the linker will set the LMA equal
4236 to the VMA.
4237 @xref{Output Section Region}.
4239 @cindex ROM initialized data
4240 @cindex initialized data in ROM
4241 This feature is designed to make it easy to build a ROM image.  For
4242 example, the following linker script creates three output sections: one
4243 called @samp{.text}, which starts at @code{0x1000}, one called
4244 @samp{.mdata}, which is loaded at the end of the @samp{.text} section
4245 even though its VMA is @code{0x2000}, and one called @samp{.bss} to hold
4246 uninitialized data at address @code{0x3000}.  The symbol @code{_data} is
4247 defined with the value @code{0x2000}, which shows that the location
4248 counter holds the VMA value, not the LMA value.
4250 @smallexample
4251 @group
4252 SECTIONS
4253   @{
4254   .text 0x1000 : @{ *(.text) _etext = . ; @}
4255   .mdata 0x2000 :
4256     AT ( ADDR (.text) + SIZEOF (.text) )
4257     @{ _data = . ; *(.data); _edata = . ;  @}
4258   .bss 0x3000 :
4259     @{ _bstart = . ;  *(.bss) *(COMMON) ; _bend = . ;@}
4261 @end group
4262 @end smallexample
4264 The run-time initialization code for use with a program generated with
4265 this linker script would include something like the following, to copy
4266 the initialized data from the ROM image to its runtime address.  Notice
4267 how this code takes advantage of the symbols defined by the linker
4268 script.
4270 @smallexample
4271 @group
4272 extern char _etext, _data, _edata, _bstart, _bend;
4273 char *src = &_etext;
4274 char *dst = &_data;
4276 /* ROM has data at end of text; copy it. */
4277 while (dst < &_edata) @{
4278   *dst++ = *src++;
4281 /* Zero bss */
4282 for (dst = &_bstart; dst< &_bend; dst++)
4283   *dst = 0;
4284 @end group
4285 @end smallexample
4287 @node Forced Output Alignment
4288 @subsubsection Forced Output Alignment
4289 @kindex ALIGN(@var{section_align})
4290 @cindex forcing output section alignment
4291 @cindex output section alignment
4292 You can increase an output section's alignment by using ALIGN.
4294 @node Forced Input Alignment
4295 @subsubsection Forced Input Alignment
4296 @kindex SUBALIGN(@var{subsection_align})
4297 @cindex forcing input section alignment
4298 @cindex input section alignment
4299 You can force input section alignment within an output section by using
4300 SUBALIGN.  The value specified overrides any alignment given by input
4301 sections, whether larger or smaller.
4303 @node Output Section Region
4304 @subsubsection Output Section Region
4305 @kindex >@var{region}
4306 @cindex section, assigning to memory region
4307 @cindex memory regions and sections
4308 You can assign a section to a previously defined region of memory by
4309 using @samp{>@var{region}}.  @xref{MEMORY}.
4311 Here is a simple example:
4312 @smallexample
4313 @group
4314 MEMORY @{ rom : ORIGIN = 0x1000, LENGTH = 0x1000 @}
4315 SECTIONS @{ ROM : @{ *(.text) @} >rom @}
4316 @end group
4317 @end smallexample
4319 @node Output Section Phdr
4320 @subsubsection Output Section Phdr
4321 @kindex :@var{phdr}
4322 @cindex section, assigning to program header
4323 @cindex program headers and sections
4324 You can assign a section to a previously defined program segment by
4325 using @samp{:@var{phdr}}.  @xref{PHDRS}.  If a section is assigned to
4326 one or more segments, then all subsequent allocated sections will be
4327 assigned to those segments as well, unless they use an explicitly
4328 @code{:@var{phdr}} modifier.  You can use @code{:NONE} to tell the
4329 linker to not put the section in any segment at all.
4331 Here is a simple example:
4332 @smallexample
4333 @group
4334 PHDRS @{ text PT_LOAD ; @}
4335 SECTIONS @{ .text : @{ *(.text) @} :text @}
4336 @end group
4337 @end smallexample
4339 @node Output Section Fill
4340 @subsubsection Output Section Fill
4341 @kindex =@var{fillexp}
4342 @cindex section fill pattern
4343 @cindex fill pattern, entire section
4344 You can set the fill pattern for an entire section by using
4345 @samp{=@var{fillexp}}.  @var{fillexp} is an expression
4346 (@pxref{Expressions}).  Any otherwise unspecified regions of memory
4347 within the output section (for example, gaps left due to the required
4348 alignment of input sections) will be filled with the value, repeated as
4349 necessary.  If the fill expression is a simple hex number, ie. a string
4350 of hex digit starting with @samp{0x} and without a trailing @samp{k} or @samp{M}, then
4351 an arbitrarily long sequence of hex digits can be used to specify the
4352 fill pattern;  Leading zeros become part of the pattern too.  For all
4353 other cases, including extra parentheses or a unary @code{+}, the fill
4354 pattern is the four least significant bytes of the value of the
4355 expression.  In all cases, the number is big-endian.
4357 You can also change the fill value with a @code{FILL} command in the
4358 output section commands; (@pxref{Output Section Data}).
4360 Here is a simple example:
4361 @smallexample
4362 @group
4363 SECTIONS @{ .text : @{ *(.text) @} =0x90909090 @}
4364 @end group
4365 @end smallexample
4367 @node Overlay Description
4368 @subsection Overlay Description
4369 @kindex OVERLAY
4370 @cindex overlays
4371 An overlay description provides an easy way to describe sections which
4372 are to be loaded as part of a single memory image but are to be run at
4373 the same memory address.  At run time, some sort of overlay manager will
4374 copy the overlaid sections in and out of the runtime memory address as
4375 required, perhaps by simply manipulating addressing bits.  This approach
4376 can be useful, for example, when a certain region of memory is faster
4377 than another.
4379 Overlays are described using the @code{OVERLAY} command.  The
4380 @code{OVERLAY} command is used within a @code{SECTIONS} command, like an
4381 output section description.  The full syntax of the @code{OVERLAY}
4382 command is as follows:
4383 @smallexample
4384 @group
4385 OVERLAY [@var{start}] : [NOCROSSREFS] [AT ( @var{ldaddr} )]
4386   @{
4387     @var{secname1}
4388       @{
4389         @var{output-section-command}
4390         @var{output-section-command}
4391         @dots{}
4392       @} [:@var{phdr}@dots{}] [=@var{fill}]
4393     @var{secname2}
4394       @{
4395         @var{output-section-command}
4396         @var{output-section-command}
4397         @dots{}
4398       @} [:@var{phdr}@dots{}] [=@var{fill}]
4399     @dots{}
4400   @} [>@var{region}] [:@var{phdr}@dots{}] [=@var{fill}]
4401 @end group
4402 @end smallexample
4404 Everything is optional except @code{OVERLAY} (a keyword), and each
4405 section must have a name (@var{secname1} and @var{secname2} above).  The
4406 section definitions within the @code{OVERLAY} construct are identical to
4407 those within the general @code{SECTIONS} contruct (@pxref{SECTIONS}),
4408 except that no addresses and no memory regions may be defined for
4409 sections within an @code{OVERLAY}.
4411 The sections are all defined with the same starting address.  The load
4412 addresses of the sections are arranged such that they are consecutive in
4413 memory starting at the load address used for the @code{OVERLAY} as a
4414 whole (as with normal section definitions, the load address is optional,
4415 and defaults to the start address; the start address is also optional,
4416 and defaults to the current value of the location counter).
4418 If the @code{NOCROSSREFS} keyword is used, and there any references
4419 among the sections, the linker will report an error.  Since the sections
4420 all run at the same address, it normally does not make sense for one
4421 section to refer directly to another.  @xref{Miscellaneous Commands,
4422 NOCROSSREFS}.
4424 For each section within the @code{OVERLAY}, the linker automatically
4425 provides two symbols.  The symbol @code{__load_start_@var{secname}} is
4426 defined as the starting load address of the section.  The symbol
4427 @code{__load_stop_@var{secname}} is defined as the final load address of
4428 the section.  Any characters within @var{secname} which are not legal
4429 within C identifiers are removed.  C (or assembler) code may use these
4430 symbols to move the overlaid sections around as necessary.
4432 At the end of the overlay, the value of the location counter is set to
4433 the start address of the overlay plus the size of the largest section.
4435 Here is an example.  Remember that this would appear inside a
4436 @code{SECTIONS} construct.
4437 @smallexample
4438 @group
4439   OVERLAY 0x1000 : AT (0x4000)
4440    @{
4441      .text0 @{ o1/*.o(.text) @}
4442      .text1 @{ o2/*.o(.text) @}
4443    @}
4444 @end group
4445 @end smallexample
4446 @noindent
4447 This will define both @samp{.text0} and @samp{.text1} to start at
4448 address 0x1000.  @samp{.text0} will be loaded at address 0x4000, and
4449 @samp{.text1} will be loaded immediately after @samp{.text0}.  The
4450 following symbols will be defined if referenced: @code{__load_start_text0},
4451 @code{__load_stop_text0}, @code{__load_start_text1},
4452 @code{__load_stop_text1}.
4454 C code to copy overlay @code{.text1} into the overlay area might look
4455 like the following.
4457 @smallexample
4458 @group
4459   extern char __load_start_text1, __load_stop_text1;
4460   memcpy ((char *) 0x1000, &__load_start_text1,
4461           &__load_stop_text1 - &__load_start_text1);
4462 @end group
4463 @end smallexample
4465 Note that the @code{OVERLAY} command is just syntactic sugar, since
4466 everything it does can be done using the more basic commands.  The above
4467 example could have been written identically as follows.
4469 @smallexample
4470 @group
4471   .text0 0x1000 : AT (0x4000) @{ o1/*.o(.text) @}
4472   PROVIDE (__load_start_text0 = LOADADDR (.text0));
4473   PROVIDE (__load_stop_text0 = LOADADDR (.text0) + SIZEOF (.text0));
4474   .text1 0x1000 : AT (0x4000 + SIZEOF (.text0)) @{ o2/*.o(.text) @}
4475   PROVIDE (__load_start_text1 = LOADADDR (.text1));
4476   PROVIDE (__load_stop_text1 = LOADADDR (.text1) + SIZEOF (.text1));
4477   . = 0x1000 + MAX (SIZEOF (.text0), SIZEOF (.text1));
4478 @end group
4479 @end smallexample
4481 @node MEMORY
4482 @section MEMORY Command
4483 @kindex MEMORY
4484 @cindex memory regions
4485 @cindex regions of memory
4486 @cindex allocating memory
4487 @cindex discontinuous memory
4488 The linker's default configuration permits allocation of all available
4489 memory.  You can override this by using the @code{MEMORY} command.
4491 The @code{MEMORY} command describes the location and size of blocks of
4492 memory in the target.  You can use it to describe which memory regions
4493 may be used by the linker, and which memory regions it must avoid.  You
4494 can then assign sections to particular memory regions.  The linker will
4495 set section addresses based on the memory regions, and will warn about
4496 regions that become too full.  The linker will not shuffle sections
4497 around to fit into the available regions.
4499 A linker script may contain at most one use of the @code{MEMORY}
4500 command.  However, you can define as many blocks of memory within it as
4501 you wish.  The syntax is:
4502 @smallexample
4503 @group
4504 MEMORY
4505   @{
4506     @var{name} [(@var{attr})] : ORIGIN = @var{origin}, LENGTH = @var{len}
4507     @dots{}
4508   @}
4509 @end group
4510 @end smallexample
4512 The @var{name} is a name used in the linker script to refer to the
4513 region.  The region name has no meaning outside of the linker script.
4514 Region names are stored in a separate name space, and will not conflict
4515 with symbol names, file names, or section names.  Each memory region
4516 must have a distinct name within the @code{MEMORY} command.  However you can
4517 add later alias names to existing memory regions with the @ref{REGION_ALIAS}
4518 command.  
4520 @cindex memory region attributes
4521 The @var{attr} string is an optional list of attributes that specify
4522 whether to use a particular memory region for an input section which is
4523 not explicitly mapped in the linker script.  As described in
4524 @ref{SECTIONS}, if you do not specify an output section for some input
4525 section, the linker will create an output section with the same name as
4526 the input section.  If you define region attributes, the linker will use
4527 them to select the memory region for the output section that it creates.
4529 The @var{attr} string must consist only of the following characters:
4530 @table @samp
4531 @item R
4532 Read-only section
4533 @item W
4534 Read/write section
4535 @item X
4536 Executable section
4537 @item A
4538 Allocatable section
4539 @item I
4540 Initialized section
4541 @item L
4542 Same as @samp{I}
4543 @item !
4544 Invert the sense of any of the preceding attributes
4545 @end table
4547 If a unmapped section matches any of the listed attributes other than
4548 @samp{!}, it will be placed in the memory region.  The @samp{!}
4549 attribute reverses this test, so that an unmapped section will be placed
4550 in the memory region only if it does not match any of the listed
4551 attributes.
4553 @kindex ORIGIN =
4554 @kindex o =
4555 @kindex org =
4556 The @var{origin} is an numerical expression for the start address of
4557 the memory region.  The expression must evaluate to a constant and it
4558 cannot involve any symbols.  The keyword @code{ORIGIN} may be
4559 abbreviated to @code{org} or @code{o} (but not, for example,
4560 @code{ORG}).
4562 @kindex LENGTH =
4563 @kindex len =
4564 @kindex l =
4565 The @var{len} is an expression for the size in bytes of the memory
4566 region.  As with the @var{origin} expression, the expression must
4567 be numerical only and must evaluate to a constant.  The keyword
4568 @code{LENGTH} may be abbreviated to @code{len} or @code{l}.
4570 In the following example, we specify that there are two memory regions
4571 available for allocation: one starting at @samp{0} for 256 kilobytes,
4572 and the other starting at @samp{0x40000000} for four megabytes.  The
4573 linker will place into the @samp{rom} memory region every section which
4574 is not explicitly mapped into a memory region, and is either read-only
4575 or executable.  The linker will place other sections which are not
4576 explicitly mapped into a memory region into the @samp{ram} memory
4577 region.
4579 @smallexample
4580 @group
4581 MEMORY
4582   @{
4583     rom (rx)  : ORIGIN = 0, LENGTH = 256K
4584     ram (!rx) : org = 0x40000000, l = 4M
4585   @}
4586 @end group
4587 @end smallexample
4589 Once you define a memory region, you can direct the linker to place
4590 specific output sections into that memory region by using the
4591 @samp{>@var{region}} output section attribute.  For example, if you have
4592 a memory region named @samp{mem}, you would use @samp{>mem} in the
4593 output section definition.  @xref{Output Section Region}.  If no address
4594 was specified for the output section, the linker will set the address to
4595 the next available address within the memory region.  If the combined
4596 output sections directed to a memory region are too large for the
4597 region, the linker will issue an error message.
4599 It is possible to access the origin and length of a memory in an
4600 expression via the @code{ORIGIN(@var{memory})} and
4601 @code{LENGTH(@var{memory})} functions:
4603 @smallexample
4604 @group
4605   _fstack = ORIGIN(ram) + LENGTH(ram) - 4;
4606 @end group
4607 @end smallexample
4609 @node PHDRS
4610 @section PHDRS Command
4611 @kindex PHDRS
4612 @cindex program headers
4613 @cindex ELF program headers
4614 @cindex program segments
4615 @cindex segments, ELF
4616 The ELF object file format uses @dfn{program headers}, also knows as
4617 @dfn{segments}.  The program headers describe how the program should be
4618 loaded into memory.  You can print them out by using the @code{objdump}
4619 program with the @samp{-p} option.
4621 When you run an ELF program on a native ELF system, the system loader
4622 reads the program headers in order to figure out how to load the
4623 program.  This will only work if the program headers are set correctly.
4624 This manual does not describe the details of how the system loader
4625 interprets program headers; for more information, see the ELF ABI.
4627 The linker will create reasonable program headers by default.  However,
4628 in some cases, you may need to specify the program headers more
4629 precisely.  You may use the @code{PHDRS} command for this purpose.  When
4630 the linker sees the @code{PHDRS} command in the linker script, it will
4631 not create any program headers other than the ones specified.
4633 The linker only pays attention to the @code{PHDRS} command when
4634 generating an ELF output file.  In other cases, the linker will simply
4635 ignore @code{PHDRS}.
4637 This is the syntax of the @code{PHDRS} command.  The words @code{PHDRS},
4638 @code{FILEHDR}, @code{AT}, and @code{FLAGS} are keywords.
4640 @smallexample
4641 @group
4642 PHDRS
4644   @var{name} @var{type} [ FILEHDR ] [ PHDRS ] [ AT ( @var{address} ) ]
4645         [ FLAGS ( @var{flags} ) ] ;
4647 @end group
4648 @end smallexample
4650 The @var{name} is used only for reference in the @code{SECTIONS} command
4651 of the linker script.  It is not put into the output file.  Program
4652 header names are stored in a separate name space, and will not conflict
4653 with symbol names, file names, or section names.  Each program header
4654 must have a distinct name.
4656 Certain program header types describe segments of memory which the
4657 system loader will load from the file.  In the linker script, you
4658 specify the contents of these segments by placing allocatable output
4659 sections in the segments.  You use the @samp{:@var{phdr}} output section
4660 attribute to place a section in a particular segment.  @xref{Output
4661 Section Phdr}.
4663 It is normal to put certain sections in more than one segment.  This
4664 merely implies that one segment of memory contains another.  You may
4665 repeat @samp{:@var{phdr}}, using it once for each segment which should
4666 contain the section.
4668 If you place a section in one or more segments using @samp{:@var{phdr}},
4669 then the linker will place all subsequent allocatable sections which do
4670 not specify @samp{:@var{phdr}} in the same segments.  This is for
4671 convenience, since generally a whole set of contiguous sections will be
4672 placed in a single segment.  You can use @code{:NONE} to override the
4673 default segment and tell the linker to not put the section in any
4674 segment at all.
4676 @kindex FILEHDR
4677 @kindex PHDRS
4678 You may use the @code{FILEHDR} and @code{PHDRS} keywords appear after
4679 the program header type to further describe the contents of the segment.
4680 The @code{FILEHDR} keyword means that the segment should include the ELF
4681 file header.  The @code{PHDRS} keyword means that the segment should
4682 include the ELF program headers themselves.
4684 The @var{type} may be one of the following.  The numbers indicate the
4685 value of the keyword.
4687 @table @asis
4688 @item @code{PT_NULL} (0)
4689 Indicates an unused program header.
4691 @item @code{PT_LOAD} (1)
4692 Indicates that this program header describes a segment to be loaded from
4693 the file.
4695 @item @code{PT_DYNAMIC} (2)
4696 Indicates a segment where dynamic linking information can be found.
4698 @item @code{PT_INTERP} (3)
4699 Indicates a segment where the name of the program interpreter may be
4700 found.
4702 @item @code{PT_NOTE} (4)
4703 Indicates a segment holding note information.
4705 @item @code{PT_SHLIB} (5)
4706 A reserved program header type, defined but not specified by the ELF
4707 ABI.
4709 @item @code{PT_PHDR} (6)
4710 Indicates a segment where the program headers may be found.
4712 @item @var{expression}
4713 An expression giving the numeric type of the program header.  This may
4714 be used for types not defined above.
4715 @end table
4717 You can specify that a segment should be loaded at a particular address
4718 in memory by using an @code{AT} expression.  This is identical to the
4719 @code{AT} command used as an output section attribute (@pxref{Output
4720 Section LMA}).  The @code{AT} command for a program header overrides the
4721 output section attribute.
4723 The linker will normally set the segment flags based on the sections
4724 which comprise the segment.  You may use the @code{FLAGS} keyword to
4725 explicitly specify the segment flags.  The value of @var{flags} must be
4726 an integer.  It is used to set the @code{p_flags} field of the program
4727 header.
4729 Here is an example of @code{PHDRS}.  This shows a typical set of program
4730 headers used on a native ELF system.
4732 @example
4733 @group
4734 PHDRS
4736   headers PT_PHDR PHDRS ;
4737   interp PT_INTERP ;
4738   text PT_LOAD FILEHDR PHDRS ;
4739   data PT_LOAD ;
4740   dynamic PT_DYNAMIC ;
4743 SECTIONS
4745   . = SIZEOF_HEADERS;
4746   .interp : @{ *(.interp) @} :text :interp
4747   .text : @{ *(.text) @} :text
4748   .rodata : @{ *(.rodata) @} /* defaults to :text */
4749   @dots{}
4750   . = . + 0x1000; /* move to a new page in memory */
4751   .data : @{ *(.data) @} :data
4752   .dynamic : @{ *(.dynamic) @} :data :dynamic
4753   @dots{}
4755 @end group
4756 @end example
4758 @node VERSION
4759 @section VERSION Command
4760 @kindex VERSION @{script text@}
4761 @cindex symbol versions
4762 @cindex version script
4763 @cindex versions of symbols
4764 The linker supports symbol versions when using ELF.  Symbol versions are
4765 only useful when using shared libraries.  The dynamic linker can use
4766 symbol versions to select a specific version of a function when it runs
4767 a program that may have been linked against an earlier version of the
4768 shared library.
4770 You can include a version script directly in the main linker script, or
4771 you can supply the version script as an implicit linker script.  You can
4772 also use the @samp{--version-script} linker option.
4774 The syntax of the @code{VERSION} command is simply
4775 @smallexample
4776 VERSION @{ version-script-commands @}
4777 @end smallexample
4779 The format of the version script commands is identical to that used by
4780 Sun's linker in Solaris 2.5.  The version script defines a tree of
4781 version nodes.  You specify the node names and interdependencies in the
4782 version script.  You can specify which symbols are bound to which
4783 version nodes, and you can reduce a specified set of symbols to local
4784 scope so that they are not globally visible outside of the shared
4785 library.
4787 The easiest way to demonstrate the version script language is with a few
4788 examples.
4790 @smallexample
4791 VERS_1.1 @{
4792          global:
4793                  foo1;
4794          local:
4795                  old*;
4796                  original*;
4797                  new*;
4800 VERS_1.2 @{
4801                  foo2;
4802 @} VERS_1.1;
4804 VERS_2.0 @{
4805                  bar1; bar2;
4806          extern "C++" @{
4807                  ns::*;
4808                  "int f(int, double)";
4809          @}
4810 @} VERS_1.2;
4811 @end smallexample
4813 This example version script defines three version nodes.  The first
4814 version node defined is @samp{VERS_1.1}; it has no other dependencies.
4815 The script binds the symbol @samp{foo1} to @samp{VERS_1.1}.  It reduces
4816 a number of symbols to local scope so that they are not visible outside
4817 of the shared library; this is done using wildcard patterns, so that any
4818 symbol whose name begins with @samp{old}, @samp{original}, or @samp{new}
4819 is matched.  The wildcard patterns available are the same as those used
4820 in the shell when matching filenames (also known as ``globbing'').
4821 However, if you specify the symbol name inside double quotes, then the
4822 name is treated as literal, rather than as a glob pattern.
4824 Next, the version script defines node @samp{VERS_1.2}.  This node
4825 depends upon @samp{VERS_1.1}.  The script binds the symbol @samp{foo2}
4826 to the version node @samp{VERS_1.2}.
4828 Finally, the version script defines node @samp{VERS_2.0}.  This node
4829 depends upon @samp{VERS_1.2}.  The scripts binds the symbols @samp{bar1}
4830 and @samp{bar2} are bound to the version node @samp{VERS_2.0}.
4832 When the linker finds a symbol defined in a library which is not
4833 specifically bound to a version node, it will effectively bind it to an
4834 unspecified base version of the library.  You can bind all otherwise
4835 unspecified symbols to a given version node by using @samp{global: *;}
4836 somewhere in the version script.  Note that it's slightly crazy to use
4837 wildcards in a global spec except on the last version node.  Global
4838 wildcards elsewhere run the risk of accidentally adding symbols to the
4839 set exported for an old version.  That's wrong since older versions
4840 ought to have a fixed set of symbols.
4842 The names of the version nodes have no specific meaning other than what
4843 they might suggest to the person reading them.  The @samp{2.0} version
4844 could just as well have appeared in between @samp{1.1} and @samp{1.2}.
4845 However, this would be a confusing way to write a version script.
4847 Node name can be omitted, provided it is the only version node
4848 in the version script.  Such version script doesn't assign any versions to
4849 symbols, only selects which symbols will be globally visible out and which
4850 won't.
4852 @smallexample
4853 @{ global: foo; bar; local: *; @};
4854 @end smallexample
4856 When you link an application against a shared library that has versioned
4857 symbols, the application itself knows which version of each symbol it
4858 requires, and it also knows which version nodes it needs from each
4859 shared library it is linked against.  Thus at runtime, the dynamic
4860 loader can make a quick check to make sure that the libraries you have
4861 linked against do in fact supply all of the version nodes that the
4862 application will need to resolve all of the dynamic symbols.  In this
4863 way it is possible for the dynamic linker to know with certainty that
4864 all external symbols that it needs will be resolvable without having to
4865 search for each symbol reference.
4867 The symbol versioning is in effect a much more sophisticated way of
4868 doing minor version checking that SunOS does.  The fundamental problem
4869 that is being addressed here is that typically references to external
4870 functions are bound on an as-needed basis, and are not all bound when
4871 the application starts up.  If a shared library is out of date, a
4872 required interface may be missing; when the application tries to use
4873 that interface, it may suddenly and unexpectedly fail.  With symbol
4874 versioning, the user will get a warning when they start their program if
4875 the libraries being used with the application are too old.
4877 There are several GNU extensions to Sun's versioning approach.  The
4878 first of these is the ability to bind a symbol to a version node in the
4879 source file where the symbol is defined instead of in the versioning
4880 script.  This was done mainly to reduce the burden on the library
4881 maintainer.  You can do this by putting something like:
4882 @smallexample
4883 __asm__(".symver original_foo,foo@@VERS_1.1");
4884 @end smallexample
4885 @noindent
4886 in the C source file.  This renames the function @samp{original_foo} to
4887 be an alias for @samp{foo} bound to the version node @samp{VERS_1.1}.
4888 The @samp{local:} directive can be used to prevent the symbol
4889 @samp{original_foo} from being exported. A @samp{.symver} directive
4890 takes precedence over a version script.
4892 The second GNU extension is to allow multiple versions of the same
4893 function to appear in a given shared library.  In this way you can make
4894 an incompatible change to an interface without increasing the major
4895 version number of the shared library, while still allowing applications
4896 linked against the old interface to continue to function.
4898 To do this, you must use multiple @samp{.symver} directives in the
4899 source file.  Here is an example:
4901 @smallexample
4902 __asm__(".symver original_foo,foo@@");
4903 __asm__(".symver old_foo,foo@@VERS_1.1");
4904 __asm__(".symver old_foo1,foo@@VERS_1.2");
4905 __asm__(".symver new_foo,foo@@@@VERS_2.0");
4906 @end smallexample
4908 In this example, @samp{foo@@} represents the symbol @samp{foo} bound to the
4909 unspecified base version of the symbol.  The source file that contains this
4910 example would define 4 C functions: @samp{original_foo}, @samp{old_foo},
4911 @samp{old_foo1}, and @samp{new_foo}.
4913 When you have multiple definitions of a given symbol, there needs to be
4914 some way to specify a default version to which external references to
4915 this symbol will be bound.  You can do this with the
4916 @samp{foo@@@@VERS_2.0} type of @samp{.symver} directive.  You can only
4917 declare one version of a symbol as the default in this manner; otherwise
4918 you would effectively have multiple definitions of the same symbol.
4920 If you wish to bind a reference to a specific version of the symbol
4921 within the shared library, you can use the aliases of convenience
4922 (i.e., @samp{old_foo}), or you can use the @samp{.symver} directive to
4923 specifically bind to an external version of the function in question.
4925 You can also specify the language in the version script:
4927 @smallexample
4928 VERSION extern "lang" @{ version-script-commands @}
4929 @end smallexample
4931 The supported @samp{lang}s are @samp{C}, @samp{C++}, and @samp{Java}.
4932 The linker will iterate over the list of symbols at the link time and
4933 demangle them according to @samp{lang} before matching them to the
4934 patterns specified in @samp{version-script-commands}.
4936 Demangled names may contains spaces and other special characters.  As
4937 described above, you can use a glob pattern to match demangled names,
4938 or you can use a double-quoted string to match the string exactly.  In
4939 the latter case, be aware that minor differences (such as differing
4940 whitespace) between the version script and the demangler output will
4941 cause a mismatch.  As the exact string generated by the demangler
4942 might change in the future, even if the mangled name does not, you
4943 should check that all of your version directives are behaving as you
4944 expect when you upgrade.
4946 @node Expressions
4947 @section Expressions in Linker Scripts
4948 @cindex expressions
4949 @cindex arithmetic
4950 The syntax for expressions in the linker script language is identical to
4951 that of C expressions.  All expressions are evaluated as integers.  All
4952 expressions are evaluated in the same size, which is 32 bits if both the
4953 host and target are 32 bits, and is otherwise 64 bits.
4955 You can use and set symbol values in expressions.
4957 The linker defines several special purpose builtin functions for use in
4958 expressions.
4960 @menu
4961 * Constants::                   Constants
4962 * Symbols::                     Symbol Names
4963 * Orphan Sections::             Orphan Sections
4964 * Location Counter::            The Location Counter
4965 * Operators::                   Operators
4966 * Evaluation::                  Evaluation
4967 * Expression Section::          The Section of an Expression
4968 * Builtin Functions::           Builtin Functions
4969 @end menu
4971 @node Constants
4972 @subsection Constants
4973 @cindex integer notation
4974 @cindex constants in linker scripts
4975 All constants are integers.
4977 As in C, the linker considers an integer beginning with @samp{0} to be
4978 octal, and an integer beginning with @samp{0x} or @samp{0X} to be
4979 hexadecimal.  Alternatively the linker accepts suffixes of @samp{h} or
4980 @samp{H} for hexadeciaml, @samp{o} or @samp{O} for octal, @samp{b} or
4981 @samp{B} for binary and @samp{d} or @samp{D} for decimal.  Any integer
4982 value without a prefix or a suffix is considered to be decimal.
4984 @cindex scaled integers
4985 @cindex K and M integer suffixes
4986 @cindex M and K integer suffixes
4987 @cindex suffixes for integers
4988 @cindex integer suffixes
4989 In addition, you can use the suffixes @code{K} and @code{M} to scale a
4990 constant by
4991 @c TEXI2ROFF-KILL
4992 @ifnottex
4993 @c END TEXI2ROFF-KILL
4994 @code{1024} or @code{1024*1024}
4995 @c TEXI2ROFF-KILL
4996 @end ifnottex
4997 @tex
4998 ${\rm 1024}$ or ${\rm 1024}^2$
4999 @end tex
5000 @c END TEXI2ROFF-KILL
5001 respectively.  For example, the following
5002 all refer to the same quantity:
5004 @smallexample
5005 _fourk_1 = 4K;
5006 _fourk_2 = 4096;
5007 _fourk_3 = 0x1000;
5008 _fourk_4 = 10000o;
5009 @end smallexample
5011 Note - the @code{K} and @code{M} suffixes cannot be used in
5012 conjunction with the base suffixes mentioned above.
5014 @node Symbols
5015 @subsection Symbol Names
5016 @cindex symbol names
5017 @cindex names
5018 @cindex quoted symbol names
5019 @kindex "
5020 Unless quoted, symbol names start with a letter, underscore, or period
5021 and may include letters, digits, underscores, periods, and hyphens.
5022 Unquoted symbol names must not conflict with any keywords.  You can
5023 specify a symbol which contains odd characters or has the same name as a
5024 keyword by surrounding the symbol name in double quotes:
5025 @smallexample
5026 "SECTION" = 9;
5027 "with a space" = "also with a space" + 10;
5028 @end smallexample
5030 Since symbols can contain many non-alphabetic characters, it is safest
5031 to delimit symbols with spaces.  For example, @samp{A-B} is one symbol,
5032 whereas @samp{A - B} is an expression involving subtraction.
5034 @node Orphan Sections
5035 @subsection Orphan Sections
5036 @cindex orphan
5037 Orphan sections are sections present in the input files which
5038 are not explicitly placed into the output file by the linker
5039 script.  The linker will still copy these sections into the
5040 output file, but it has to guess as to where they should be
5041 placed.  The linker uses a simple heuristic to do this.  It
5042 attempts to place orphan sections after non-orphan sections of the
5043 same attribute, such as code vs data, loadable vs non-loadable, etc.
5044 If there is not enough room to do this then it places
5045 at the end of the file.
5047 For ELF targets, the attribute of the section includes section type as
5048 well as section flag.
5050 If an orphaned section's name is representable as a C identifier then
5051 the linker will automatically @pxref{PROVIDE} two symbols:
5052 __start_SECNAME and __end_SECNAME, where SECNAME is the name of the
5053 section.  These indicate the start address and end address of the
5054 orphaned section respectively.  Note: most section names are not
5055 representable as C identifiers because they contain a @samp{.}
5056 character.
5058 @node Location Counter
5059 @subsection The Location Counter
5060 @kindex .
5061 @cindex dot
5062 @cindex location counter
5063 @cindex current output location
5064 The special linker variable @dfn{dot} @samp{.} always contains the
5065 current output location counter.  Since the @code{.} always refers to a
5066 location in an output section, it may only appear in an expression
5067 within a @code{SECTIONS} command.  The @code{.} symbol may appear
5068 anywhere that an ordinary symbol is allowed in an expression.
5070 @cindex holes
5071 Assigning a value to @code{.} will cause the location counter to be
5072 moved.  This may be used to create holes in the output section.  The
5073 location counter may not be moved backwards inside an output section,
5074 and may not be moved backwards outside of an output section if so
5075 doing creates areas with overlapping LMAs.
5077 @smallexample
5078 SECTIONS
5080   output :
5081     @{
5082       file1(.text)
5083       . = . + 1000;
5084       file2(.text)
5085       . += 1000;
5086       file3(.text)
5087     @} = 0x12345678;
5089 @end smallexample
5090 @noindent
5091 In the previous example, the @samp{.text} section from @file{file1} is
5092 located at the beginning of the output section @samp{output}.  It is
5093 followed by a 1000 byte gap.  Then the @samp{.text} section from
5094 @file{file2} appears, also with a 1000 byte gap following before the
5095 @samp{.text} section from @file{file3}.  The notation @samp{= 0x12345678}
5096 specifies what data to write in the gaps (@pxref{Output Section Fill}).
5098 @cindex dot inside sections
5099 Note: @code{.} actually refers to the byte offset from the start of the
5100 current containing object.  Normally this is the @code{SECTIONS}
5101 statement, whose start address is 0, hence @code{.} can be used as an
5102 absolute address.  If @code{.} is used inside a section description
5103 however, it refers to the byte offset from the start of that section,
5104 not an absolute address.  Thus in a script like this:
5106 @smallexample
5107 SECTIONS
5109     . = 0x100
5110     .text: @{
5111       *(.text)
5112       . = 0x200
5113     @}
5114     . = 0x500
5115     .data: @{
5116       *(.data)
5117       . += 0x600
5118     @}
5120 @end smallexample
5122 The @samp{.text} section will be assigned a starting address of 0x100
5123 and a size of exactly 0x200 bytes, even if there is not enough data in
5124 the @samp{.text} input sections to fill this area.  (If there is too
5125 much data, an error will be produced because this would be an attempt to
5126 move @code{.} backwards).  The @samp{.data} section will start at 0x500
5127 and it will have an extra 0x600 bytes worth of space after the end of
5128 the values from the @samp{.data} input sections and before the end of
5129 the @samp{.data} output section itself.
5131 @cindex dot outside sections
5132 Setting symbols to the value of the location counter outside of an
5133 output section statement can result in unexpected values if the linker
5134 needs to place orphan sections.  For example, given the following:
5136 @smallexample
5137 SECTIONS
5139     start_of_text = . ;
5140     .text: @{ *(.text) @}
5141     end_of_text = . ;
5143     start_of_data = . ;
5144     .data: @{ *(.data) @}
5145     end_of_data = . ;
5147 @end smallexample
5149 If the linker needs to place some input section, e.g. @code{.rodata},
5150 not mentioned in the script, it might choose to place that section
5151 between @code{.text} and @code{.data}.  You might think the linker
5152 should place @code{.rodata} on the blank line in the above script, but
5153 blank lines are of no particular significance to the linker.  As well,
5154 the linker doesn't associate the above symbol names with their
5155 sections.  Instead, it assumes that all assignments or other
5156 statements belong to the previous output section, except for the
5157 special case of an assignment to @code{.}.  I.e., the linker will
5158 place the orphan @code{.rodata} section as if the script was written
5159 as follows:
5161 @smallexample
5162 SECTIONS
5164     start_of_text = . ;
5165     .text: @{ *(.text) @}
5166     end_of_text = . ;
5168     start_of_data = . ;
5169     .rodata: @{ *(.rodata) @}
5170     .data: @{ *(.data) @}
5171     end_of_data = . ;
5173 @end smallexample
5175 This may or may not be the script author's intention for the value of
5176 @code{start_of_data}.  One way to influence the orphan section
5177 placement is to assign the location counter to itself, as the linker
5178 assumes that an assignment to @code{.} is setting the start address of
5179 a following output section and thus should be grouped with that
5180 section.  So you could write:
5182 @smallexample
5183 SECTIONS
5185     start_of_text = . ;
5186     .text: @{ *(.text) @}
5187     end_of_text = . ;
5189     . = . ;
5190     start_of_data = . ;
5191     .data: @{ *(.data) @}
5192     end_of_data = . ;
5194 @end smallexample
5196 Now, the orphan @code{.rodata} section will be placed between
5197 @code{end_of_text} and @code{start_of_data}.
5199 @need 2000
5200 @node Operators
5201 @subsection Operators
5202 @cindex operators for arithmetic
5203 @cindex arithmetic operators
5204 @cindex precedence in expressions
5205 The linker recognizes the standard C set of arithmetic operators, with
5206 the standard bindings and precedence levels:
5207 @c TEXI2ROFF-KILL
5208 @ifnottex
5209 @c END TEXI2ROFF-KILL
5210 @smallexample
5211 precedence      associativity   Operators                Notes
5212 (highest)
5213 1               left            !  -  ~                  (1)
5214 2               left            *  /  %
5215 3               left            +  -
5216 4               left            >>  <<
5217 5               left            ==  !=  >  <  <=  >=
5218 6               left            &
5219 7               left            |
5220 8               left            &&
5221 9               left            ||
5222 10              right           ? :
5223 11              right           &=  +=  -=  *=  /=       (2)
5224 (lowest)
5225 @end smallexample
5226 Notes:
5227 (1) Prefix operators
5228 (2) @xref{Assignments}.
5229 @c TEXI2ROFF-KILL
5230 @end ifnottex
5231 @tex
5232 \vskip \baselineskip
5233 %"lispnarrowing" is the extra indent used generally for smallexample
5234 \hskip\lispnarrowing\vbox{\offinterlineskip
5235 \hrule
5236 \halign
5237 {\vrule#&\strut\hfil\ #\ \hfil&\vrule#&\strut\hfil\ #\ \hfil&\vrule#&\strut\hfil\ {\tt #}\ \hfil&\vrule#\cr
5238 height2pt&\omit&&\omit&&\omit&\cr
5239 &Precedence&&  Associativity  &&{\rm Operators}&\cr
5240 height2pt&\omit&&\omit&&\omit&\cr
5241 \noalign{\hrule}
5242 height2pt&\omit&&\omit&&\omit&\cr
5243 &highest&&&&&\cr
5244 % '176 is tilde, '~' in tt font
5245 &1&&left&&\qquad-          \char'176\      !\qquad\dag&\cr
5246 &2&&left&&*          /        \%&\cr
5247 &3&&left&&+          -&\cr
5248 &4&&left&&>>         <<&\cr
5249 &5&&left&&==         !=       >      <      <=      >=&\cr
5250 &6&&left&&\&&\cr
5251 &7&&left&&|&\cr
5252 &8&&left&&{\&\&}&\cr
5253 &9&&left&&||&\cr
5254 &10&&right&&?        :&\cr
5255 &11&&right&&\qquad\&=      +=       -=     *=     /=\qquad\ddag&\cr
5256 &lowest&&&&&\cr
5257 height2pt&\omit&&\omit&&\omit&\cr}
5258 \hrule}
5259 @end tex
5260 @iftex
5262 @obeylines@parskip=0pt@parindent=0pt
5263 @dag@quad Prefix operators.
5264 @ddag@quad @xref{Assignments}.
5266 @end iftex
5267 @c END TEXI2ROFF-KILL
5269 @node Evaluation
5270 @subsection Evaluation
5271 @cindex lazy evaluation
5272 @cindex expression evaluation order
5273 The linker evaluates expressions lazily.  It only computes the value of
5274 an expression when absolutely necessary.
5276 The linker needs some information, such as the value of the start
5277 address of the first section, and the origins and lengths of memory
5278 regions, in order to do any linking at all.  These values are computed
5279 as soon as possible when the linker reads in the linker script.
5281 However, other values (such as symbol values) are not known or needed
5282 until after storage allocation.  Such values are evaluated later, when
5283 other information (such as the sizes of output sections) is available
5284 for use in the symbol assignment expression.
5286 The sizes of sections cannot be known until after allocation, so
5287 assignments dependent upon these are not performed until after
5288 allocation.
5290 Some expressions, such as those depending upon the location counter
5291 @samp{.}, must be evaluated during section allocation.
5293 If the result of an expression is required, but the value is not
5294 available, then an error results.  For example, a script like the
5295 following
5296 @smallexample
5297 @group
5298 SECTIONS
5299   @{
5300     .text 9+this_isnt_constant :
5301       @{ *(.text) @}
5302   @}
5303 @end group
5304 @end smallexample
5305 @noindent
5306 will cause the error message @samp{non constant expression for initial
5307 address}.
5309 @node Expression Section
5310 @subsection The Section of an Expression
5311 @cindex expression sections
5312 @cindex absolute expressions
5313 @cindex relative expressions
5314 @cindex absolute and relocatable symbols
5315 @cindex relocatable and absolute symbols
5316 @cindex symbols, relocatable and absolute
5317 When the linker evaluates an expression, the result is either absolute
5318 or relative to some section.  A relative expression is expressed as a
5319 fixed offset from the base of a section.
5321 The position of the expression within the linker script determines
5322 whether it is absolute or relative.  An expression which appears within
5323 an output section definition is relative to the base of the output
5324 section.  An expression which appears elsewhere will be absolute.
5326 A symbol set to a relative expression will be relocatable if you request
5327 relocatable output using the @samp{-r} option.  That means that a
5328 further link operation may change the value of the symbol.  The symbol's
5329 section will be the section of the relative expression.
5331 A symbol set to an absolute expression will retain the same value
5332 through any further link operation.  The symbol will be absolute, and
5333 will not have any particular associated section.
5335 You can use the builtin function @code{ABSOLUTE} to force an expression
5336 to be absolute when it would otherwise be relative.  For example, to
5337 create an absolute symbol set to the address of the end of the output
5338 section @samp{.data}:
5339 @smallexample
5340 SECTIONS
5341   @{
5342     .data : @{ *(.data) _edata = ABSOLUTE(.); @}
5343   @}
5344 @end smallexample
5345 @noindent
5346 If @samp{ABSOLUTE} were not used, @samp{_edata} would be relative to the
5347 @samp{.data} section.
5349 @node Builtin Functions
5350 @subsection Builtin Functions
5351 @cindex functions in expressions
5352 The linker script language includes a number of builtin functions for
5353 use in linker script expressions.
5355 @table @code
5356 @item ABSOLUTE(@var{exp})
5357 @kindex ABSOLUTE(@var{exp})
5358 @cindex expression, absolute
5359 Return the absolute (non-relocatable, as opposed to non-negative) value
5360 of the expression @var{exp}.  Primarily useful to assign an absolute
5361 value to a symbol within a section definition, where symbol values are
5362 normally section relative.  @xref{Expression Section}.
5364 @item ADDR(@var{section})
5365 @kindex ADDR(@var{section})
5366 @cindex section address in expression
5367 Return the absolute address (the VMA) of the named @var{section}.  Your
5368 script must previously have defined the location of that section.  In
5369 the following example, @code{symbol_1} and @code{symbol_2} are assigned
5370 identical values:
5371 @smallexample
5372 @group
5373 SECTIONS @{ @dots{}
5374   .output1 :
5375     @{
5376     start_of_output_1 = ABSOLUTE(.);
5377     @dots{}
5378     @}
5379   .output :
5380     @{
5381     symbol_1 = ADDR(.output1);
5382     symbol_2 = start_of_output_1;
5383     @}
5384 @dots{} @}
5385 @end group
5386 @end smallexample
5388 @item ALIGN(@var{align})
5389 @itemx ALIGN(@var{exp},@var{align})
5390 @kindex ALIGN(@var{align})
5391 @kindex ALIGN(@var{exp},@var{align})
5392 @cindex round up location counter
5393 @cindex align location counter
5394 @cindex round up expression
5395 @cindex align expression
5396 Return the location counter (@code{.}) or arbitrary expression aligned
5397 to the next @var{align} boundary.  The single operand @code{ALIGN}
5398 doesn't change the value of the location counter---it just does
5399 arithmetic on it.  The two operand @code{ALIGN} allows an arbitrary
5400 expression to be aligned upwards (@code{ALIGN(@var{align})} is
5401 equivalent to @code{ALIGN(., @var{align})}).
5403 Here is an example which aligns the output @code{.data} section to the
5404 next @code{0x2000} byte boundary after the preceding section and sets a
5405 variable within the section to the next @code{0x8000} boundary after the
5406 input sections:
5407 @smallexample
5408 @group
5409 SECTIONS @{ @dots{}
5410   .data ALIGN(0x2000): @{
5411     *(.data)
5412     variable = ALIGN(0x8000);
5413   @}
5414 @dots{} @}
5415 @end group
5416 @end smallexample
5417 @noindent
5418 The first use of @code{ALIGN} in this example specifies the location of
5419 a section because it is used as the optional @var{address} attribute of
5420 a section definition (@pxref{Output Section Address}).  The second use
5421 of @code{ALIGN} is used to defines the value of a symbol.
5423 The builtin function @code{NEXT} is closely related to @code{ALIGN}.
5425 @item ALIGNOF(@var{section})
5426 @kindex ALIGNOF(@var{section})
5427 @cindex section alignment
5428 Return the alignment in bytes of the named @var{section}, if that section has
5429 been allocated.  If the section has not been allocated when this is
5430 evaluated, the linker will report an error. In the following example,
5431 the alignment of the @code{.output} section is stored as the first
5432 value in that section.
5433 @smallexample
5434 @group
5435 SECTIONS@{ @dots{}
5436   .output @{
5437     LONG (ALIGNOF (.output))
5438     @dots{}
5439     @}
5440 @dots{} @}
5441 @end group
5442 @end smallexample
5444 @item BLOCK(@var{exp})
5445 @kindex BLOCK(@var{exp})
5446 This is a synonym for @code{ALIGN}, for compatibility with older linker
5447 scripts.  It is most often seen when setting the address of an output
5448 section.
5450 @item DATA_SEGMENT_ALIGN(@var{maxpagesize}, @var{commonpagesize})
5451 @kindex DATA_SEGMENT_ALIGN(@var{maxpagesize}, @var{commonpagesize})
5452 This is equivalent to either
5453 @smallexample
5454 (ALIGN(@var{maxpagesize}) + (. & (@var{maxpagesize} - 1)))
5455 @end smallexample
5457 @smallexample
5458 (ALIGN(@var{maxpagesize}) + (. & (@var{maxpagesize} - @var{commonpagesize})))
5459 @end smallexample
5460 @noindent
5461 depending on whether the latter uses fewer @var{commonpagesize} sized pages
5462 for the data segment (area between the result of this expression and
5463 @code{DATA_SEGMENT_END}) than the former or not.
5464 If the latter form is used, it means @var{commonpagesize} bytes of runtime
5465 memory will be saved at the expense of up to @var{commonpagesize} wasted
5466 bytes in the on-disk file.
5468 This expression can only be used directly in @code{SECTIONS} commands, not in
5469 any output section descriptions and only once in the linker script.
5470 @var{commonpagesize} should be less or equal to @var{maxpagesize} and should
5471 be the system page size the object wants to be optimized for (while still
5472 working on system page sizes up to @var{maxpagesize}).
5474 @noindent
5475 Example:
5476 @smallexample
5477   . = DATA_SEGMENT_ALIGN(0x10000, 0x2000);
5478 @end smallexample
5480 @item DATA_SEGMENT_END(@var{exp})
5481 @kindex DATA_SEGMENT_END(@var{exp})
5482 This defines the end of data segment for @code{DATA_SEGMENT_ALIGN}
5483 evaluation purposes.
5485 @smallexample
5486   . = DATA_SEGMENT_END(.);
5487 @end smallexample
5489 @item DATA_SEGMENT_RELRO_END(@var{offset}, @var{exp})
5490 @kindex DATA_SEGMENT_RELRO_END(@var{offset}, @var{exp})
5491 This defines the end of the @code{PT_GNU_RELRO} segment when
5492 @samp{-z relro} option is used.  Second argument is returned.
5493 When @samp{-z relro} option is not present, @code{DATA_SEGMENT_RELRO_END}
5494 does nothing, otherwise @code{DATA_SEGMENT_ALIGN} is padded so that
5495 @var{exp} + @var{offset} is aligned to the most commonly used page
5496 boundary for particular target.  If present in the linker script,
5497 it must always come in between @code{DATA_SEGMENT_ALIGN} and
5498 @code{DATA_SEGMENT_END}.
5500 @smallexample
5501   . = DATA_SEGMENT_RELRO_END(24, .);
5502 @end smallexample
5504 @item DEFINED(@var{symbol})
5505 @kindex DEFINED(@var{symbol})
5506 @cindex symbol defaults
5507 Return 1 if @var{symbol} is in the linker global symbol table and is
5508 defined before the statement using DEFINED in the script, otherwise
5509 return 0.  You can use this function to provide
5510 default values for symbols.  For example, the following script fragment
5511 shows how to set a global symbol @samp{begin} to the first location in
5512 the @samp{.text} section---but if a symbol called @samp{begin} already
5513 existed, its value is preserved:
5515 @smallexample
5516 @group
5517 SECTIONS @{ @dots{}
5518   .text : @{
5519     begin = DEFINED(begin) ? begin : . ;
5520     @dots{}
5521   @}
5522   @dots{}
5524 @end group
5525 @end smallexample
5527 @item LENGTH(@var{memory})
5528 @kindex LENGTH(@var{memory})
5529 Return the length of the memory region named @var{memory}.
5531 @item LOADADDR(@var{section})
5532 @kindex LOADADDR(@var{section})
5533 @cindex section load address in expression
5534 Return the absolute LMA of the named @var{section}.  This is normally
5535 the same as @code{ADDR}, but it may be different if the @code{AT}
5536 attribute is used in the output section definition (@pxref{Output
5537 Section LMA}).
5539 @kindex MAX
5540 @item MAX(@var{exp1}, @var{exp2})
5541 Returns the maximum of @var{exp1} and @var{exp2}.
5543 @kindex MIN
5544 @item MIN(@var{exp1}, @var{exp2})
5545 Returns the minimum of @var{exp1} and @var{exp2}.
5547 @item NEXT(@var{exp})
5548 @kindex NEXT(@var{exp})
5549 @cindex unallocated address, next
5550 Return the next unallocated address that is a multiple of @var{exp}.
5551 This function is closely related to @code{ALIGN(@var{exp})}; unless you
5552 use the @code{MEMORY} command to define discontinuous memory for the
5553 output file, the two functions are equivalent.
5555 @item ORIGIN(@var{memory})
5556 @kindex ORIGIN(@var{memory})
5557 Return the origin of the memory region named @var{memory}.
5559 @item SEGMENT_START(@var{segment}, @var{default})
5560 @kindex SEGMENT_START(@var{segment}, @var{default})
5561 Return the base address of the named @var{segment}.  If an explicit
5562 value has been given for this segment (with a command-line @samp{-T}
5563 option) that value will be returned; otherwise the value will be
5564 @var{default}.  At present, the @samp{-T} command-line option can only
5565 be used to set the base address for the ``text'', ``data'', and
5566 ``bss'' sections, but you use @code{SEGMENT_START} with any segment
5567 name.
5569 @item SIZEOF(@var{section})
5570 @kindex SIZEOF(@var{section})
5571 @cindex section size
5572 Return the size in bytes of the named @var{section}, if that section has
5573 been allocated.  If the section has not been allocated when this is
5574 evaluated, the linker will report an error.  In the following example,
5575 @code{symbol_1} and @code{symbol_2} are assigned identical values:
5576 @smallexample
5577 @group
5578 SECTIONS@{ @dots{}
5579   .output @{
5580     .start = . ;
5581     @dots{}
5582     .end = . ;
5583     @}
5584   symbol_1 = .end - .start ;
5585   symbol_2 = SIZEOF(.output);
5586 @dots{} @}
5587 @end group
5588 @end smallexample
5590 @item SIZEOF_HEADERS
5591 @itemx sizeof_headers
5592 @kindex SIZEOF_HEADERS
5593 @cindex header size
5594 Return the size in bytes of the output file's headers.  This is
5595 information which appears at the start of the output file.  You can use
5596 this number when setting the start address of the first section, if you
5597 choose, to facilitate paging.
5599 @cindex not enough room for program headers
5600 @cindex program headers, not enough room
5601 When producing an ELF output file, if the linker script uses the
5602 @code{SIZEOF_HEADERS} builtin function, the linker must compute the
5603 number of program headers before it has determined all the section
5604 addresses and sizes.  If the linker later discovers that it needs
5605 additional program headers, it will report an error @samp{not enough
5606 room for program headers}.  To avoid this error, you must avoid using
5607 the @code{SIZEOF_HEADERS} function, or you must rework your linker
5608 script to avoid forcing the linker to use additional program headers, or
5609 you must define the program headers yourself using the @code{PHDRS}
5610 command (@pxref{PHDRS}).
5611 @end table
5613 @node Implicit Linker Scripts
5614 @section Implicit Linker Scripts
5615 @cindex implicit linker scripts
5616 If you specify a linker input file which the linker can not recognize as
5617 an object file or an archive file, it will try to read the file as a
5618 linker script.  If the file can not be parsed as a linker script, the
5619 linker will report an error.
5621 An implicit linker script will not replace the default linker script.
5623 Typically an implicit linker script would contain only symbol
5624 assignments, or the @code{INPUT}, @code{GROUP}, or @code{VERSION}
5625 commands.
5627 Any input files read because of an implicit linker script will be read
5628 at the position in the command line where the implicit linker script was
5629 read.  This can affect archive searching.
5631 @ifset GENERIC
5632 @node Machine Dependent
5633 @chapter Machine Dependent Features
5635 @cindex machine dependencies
5636 @command{ld} has additional features on some platforms; the following
5637 sections describe them.  Machines where @command{ld} has no additional
5638 functionality are not listed.
5640 @menu
5641 @ifset H8300
5642 * H8/300::                      @command{ld} and the H8/300
5643 @end ifset
5644 @ifset I960
5645 * i960::                        @command{ld} and the Intel 960 family
5646 @end ifset
5647 @ifset ARM
5648 * ARM::                         @command{ld} and the ARM family
5649 @end ifset
5650 @ifset HPPA
5651 * HPPA ELF32::                  @command{ld} and HPPA 32-bit ELF
5652 @end ifset
5653 @ifset M68K
5654 * M68K::                        @command{ld} and the Motorola 68K family
5655 @end ifset
5656 @ifset MMIX
5657 * MMIX::                        @command{ld} and MMIX
5658 @end ifset
5659 @ifset MSP430
5660 * MSP430::                      @command{ld} and MSP430
5661 @end ifset
5662 @ifset M68HC11
5663 * M68HC11/68HC12::              @code{ld} and the Motorola 68HC11 and 68HC12 families
5664 @end ifset
5665 @ifset POWERPC
5666 * PowerPC ELF32::               @command{ld} and PowerPC 32-bit ELF Support
5667 @end ifset
5668 @ifset POWERPC64
5669 * PowerPC64 ELF64::             @command{ld} and PowerPC64 64-bit ELF Support
5670 @end ifset
5671 @ifset SPU
5672 * SPU ELF::                     @command{ld} and SPU ELF Support
5673 @end ifset
5674 @ifset TICOFF
5675 * TI COFF::                     @command{ld} and TI COFF
5676 @end ifset
5677 @ifset WIN32
5678 * WIN32::                       @command{ld} and WIN32 (cygwin/mingw)
5679 @end ifset
5680 @ifset XTENSA
5681 * Xtensa::                      @command{ld} and Xtensa Processors
5682 @end ifset
5683 @end menu
5684 @end ifset
5686 @ifset H8300
5687 @ifclear GENERIC
5688 @raisesections
5689 @end ifclear
5691 @node H8/300
5692 @section @command{ld} and the H8/300
5694 @cindex H8/300 support
5695 For the H8/300, @command{ld} can perform these global optimizations when
5696 you specify the @samp{--relax} command-line option.
5698 @table @emph
5699 @cindex relaxing on H8/300
5700 @item relaxing address modes
5701 @command{ld} finds all @code{jsr} and @code{jmp} instructions whose
5702 targets are within eight bits, and turns them into eight-bit
5703 program-counter relative @code{bsr} and @code{bra} instructions,
5704 respectively.
5706 @cindex synthesizing on H8/300
5707 @item synthesizing instructions
5708 @c FIXME: specifically mov.b, or any mov instructions really?
5709 @command{ld} finds all @code{mov.b} instructions which use the
5710 sixteen-bit absolute address form, but refer to the top
5711 page of memory, and changes them to use the eight-bit address form.
5712 (That is: the linker turns @samp{mov.b @code{@@}@var{aa}:16} into
5713 @samp{mov.b @code{@@}@var{aa}:8} whenever the address @var{aa} is in the
5714 top page of memory).
5716 @item bit manipulation instructions
5717 @command{ld} finds all bit manipulation instructions like @code{band, bclr,
5718 biand, bild, bior, bist, bixor, bld, bnot, bor, bset, bst, btst, bxor}
5719 which use 32 bit and 16 bit absolute address form, but refer to the top
5720 page of memory, and changes them to use the 8 bit address form.
5721 (That is: the linker turns @samp{bset #xx:3,@code{@@}@var{aa}:32} into
5722 @samp{bset #xx:3,@code{@@}@var{aa}:8} whenever the address @var{aa} is in
5723 the top page of memory).
5725 @item system control instructions
5726 @command{ld} finds all @code{ldc.w, stc.w} instructions which use the
5727 32 bit absolute address form, but refer to the top page of memory, and
5728 changes them to use 16 bit address form.
5729 (That is: the linker turns @samp{ldc.w @code{@@}@var{aa}:32,ccr} into
5730 @samp{ldc.w @code{@@}@var{aa}:16,ccr} whenever the address @var{aa} is in
5731 the top page of memory).
5732 @end table
5734 @ifclear GENERIC
5735 @lowersections
5736 @end ifclear
5737 @end ifset
5739 @ifclear GENERIC
5740 @ifset Renesas
5741 @c This stuff is pointless to say unless you're especially concerned
5742 @c with Renesas chips; don't enable it for generic case, please.
5743 @node Renesas
5744 @chapter @command{ld} and Other Renesas Chips
5746 @command{ld} also supports the Renesas (formerly Hitachi) H8/300H,
5747 H8/500, and SH chips.  No special features, commands, or command-line
5748 options are required for these chips.
5749 @end ifset
5750 @end ifclear
5752 @ifset I960
5753 @ifclear GENERIC
5754 @raisesections
5755 @end ifclear
5757 @node i960
5758 @section @command{ld} and the Intel 960 Family
5760 @cindex i960 support
5762 You can use the @samp{-A@var{architecture}} command line option to
5763 specify one of the two-letter names identifying members of the 960
5764 family; the option specifies the desired output target, and warns of any
5765 incompatible instructions in the input files.  It also modifies the
5766 linker's search strategy for archive libraries, to support the use of
5767 libraries specific to each particular architecture, by including in the
5768 search loop names suffixed with the string identifying the architecture.
5770 For example, if your @command{ld} command line included @w{@samp{-ACA}} as
5771 well as @w{@samp{-ltry}}, the linker would look (in its built-in search
5772 paths, and in any paths you specify with @samp{-L}) for a library with
5773 the names
5775 @smallexample
5776 @group
5778 libtry.a
5779 tryca
5780 libtryca.a
5781 @end group
5782 @end smallexample
5784 @noindent
5785 The first two possibilities would be considered in any event; the last
5786 two are due to the use of @w{@samp{-ACA}}.
5788 You can meaningfully use @samp{-A} more than once on a command line, since
5789 the 960 architecture family allows combination of target architectures; each
5790 use will add another pair of name variants to search for when @w{@samp{-l}}
5791 specifies a library.
5793 @cindex @option{--relax} on i960
5794 @cindex relaxing on i960
5795 @command{ld} supports the @samp{--relax} option for the i960 family.  If
5796 you specify @samp{--relax}, @command{ld} finds all @code{balx} and
5797 @code{calx} instructions whose targets are within 24 bits, and turns
5798 them into 24-bit program-counter relative @code{bal} and @code{cal}
5799 instructions, respectively.  @command{ld} also turns @code{cal}
5800 instructions into @code{bal} instructions when it determines that the
5801 target subroutine is a leaf routine (that is, the target subroutine does
5802 not itself call any subroutines).
5804 @ifclear GENERIC
5805 @lowersections
5806 @end ifclear
5807 @end ifset
5809 @ifset ARM
5810 @ifclear GENERIC
5811 @raisesections
5812 @end ifclear
5814 @ifset M68HC11
5815 @ifclear GENERIC
5816 @raisesections
5817 @end ifclear
5819 @node M68HC11/68HC12
5820 @section @command{ld} and the Motorola 68HC11 and 68HC12 families
5822 @cindex M68HC11 and 68HC12 support
5824 @subsection Linker Relaxation
5826 For the Motorola 68HC11, @command{ld} can perform these global
5827 optimizations when you specify the @samp{--relax} command-line option.
5829 @table @emph
5830 @cindex relaxing on M68HC11
5831 @item relaxing address modes
5832 @command{ld} finds all @code{jsr} and @code{jmp} instructions whose
5833 targets are within eight bits, and turns them into eight-bit
5834 program-counter relative @code{bsr} and @code{bra} instructions,
5835 respectively.
5837 @command{ld} also looks at all 16-bit extended addressing modes and
5838 transforms them in a direct addressing mode when the address is in
5839 page 0 (between 0 and 0x0ff).
5841 @item relaxing gcc instruction group
5842 When @command{gcc} is called with @option{-mrelax}, it can emit group
5843 of instructions that the linker can optimize to use a 68HC11 direct
5844 addressing mode. These instructions consists of @code{bclr} or
5845 @code{bset} instructions.
5847 @end table
5849 @subsection Trampoline Generation
5851 @cindex trampoline generation on M68HC11
5852 @cindex trampoline generation on M68HC12
5853 For 68HC11 and 68HC12, @command{ld} can generate trampoline code to
5854 call a far function using a normal @code{jsr} instruction. The linker
5855 will also change the relocation to some far function to use the
5856 trampoline address instead of the function address. This is typically the
5857 case when a pointer to a function is taken. The pointer will in fact
5858 point to the function trampoline.
5860 @ifclear GENERIC
5861 @lowersections
5862 @end ifclear
5863 @end ifset
5865 @node ARM
5866 @section @command{ld} and the ARM family
5868 @cindex ARM interworking support
5869 @kindex --support-old-code
5870 For the ARM, @command{ld} will generate code stubs to allow functions calls
5871 between ARM and Thumb code.  These stubs only work with code that has
5872 been compiled and assembled with the @samp{-mthumb-interwork} command
5873 line option.  If it is necessary to link with old ARM object files or
5874 libraries, which have not been compiled with the -mthumb-interwork
5875 option then the @samp{--support-old-code} command line switch should be
5876 given to the linker.  This will make it generate larger stub functions
5877 which will work with non-interworking aware ARM code.  Note, however,
5878 the linker does not support generating stubs for function calls to
5879 non-interworking aware Thumb code.
5881 @cindex thumb entry point
5882 @cindex entry point, thumb
5883 @kindex --thumb-entry=@var{entry}
5884 The @samp{--thumb-entry} switch is a duplicate of the generic
5885 @samp{--entry} switch, in that it sets the program's starting address.
5886 But it also sets the bottom bit of the address, so that it can be
5887 branched to using a BX instruction, and the program will start
5888 executing in Thumb mode straight away.
5890 @cindex PE import table prefixing
5891 @kindex --use-nul-prefixed-import-tables
5892 The @samp{--use-nul-prefixed-import-tables} switch is specifying, that
5893 the import tables idata4 and idata5 have to be generated with a zero
5894 elememt prefix for import libraries. This is the old style to generate
5895 import tables. By default this option is turned off.
5897 @cindex BE8
5898 @kindex --be8
5899 The @samp{--be8} switch instructs @command{ld} to generate BE8 format
5900 executables.  This option is only valid when linking big-endian objects.
5901 The resulting image will contain big-endian data and little-endian code.
5903 @cindex TARGET1
5904 @kindex --target1-rel
5905 @kindex --target1-abs
5906 The @samp{R_ARM_TARGET1} relocation is typically used for entries in the
5907 @samp{.init_array} section.  It is interpreted as either @samp{R_ARM_REL32}
5908 or @samp{R_ARM_ABS32}, depending on the target.  The @samp{--target1-rel}
5909 and @samp{--target1-abs} switches override the default.
5911 @cindex TARGET2
5912 @kindex --target2=@var{type}
5913 The @samp{--target2=type} switch overrides the default definition of the
5914 @samp{R_ARM_TARGET2} relocation.  Valid values for @samp{type}, their
5915 meanings, and target defaults are as follows:
5916 @table @samp
5917 @item rel
5918 @samp{R_ARM_REL32} (arm*-*-elf, arm*-*-eabi)
5919 @item abs
5920 @samp{R_ARM_ABS32} (arm*-*-symbianelf)
5921 @item got-rel
5922 @samp{R_ARM_GOT_PREL} (arm*-*-linux, arm*-*-*bsd)
5923 @end table
5925 @cindex FIX_V4BX
5926 @kindex --fix-v4bx
5927 The @samp{R_ARM_V4BX} relocation (defined by the ARM AAELF
5928 specification) enables objects compiled for the ARMv4 architecture to be
5929 interworking-safe when linked with other objects compiled for ARMv4t, but
5930 also allows pure ARMv4 binaries to be built from the same ARMv4 objects.
5932 In the latter case, the switch @option{--fix-v4bx} must be passed to the
5933 linker, which causes v4t @code{BX rM} instructions to be rewritten as
5934 @code{MOV PC,rM}, since v4 processors do not have a @code{BX} instruction.
5936 In the former case, the switch should not be used, and @samp{R_ARM_V4BX}
5937 relocations are ignored.
5939 @cindex FIX_V4BX_INTERWORKING
5940 @kindex --fix-v4bx-interworking
5941 Replace @code{BX rM} instructions identified by @samp{R_ARM_V4BX}
5942 relocations with a branch to the following veneer:
5944 @smallexample
5945 TST rM, #1
5946 MOVEQ PC, rM
5947 BX Rn
5948 @end smallexample
5950 This allows generation of libraries/applications that work on ARMv4 cores
5951 and are still interworking safe.  Note that the above veneer clobbers the
5952 condition flags, so may cause incorrect progrm behavior in rare cases.
5954 @cindex USE_BLX
5955 @kindex --use-blx
5956 The @samp{--use-blx} switch enables the linker to use ARM/Thumb
5957 BLX instructions (available on ARMv5t and above) in various
5958 situations. Currently it is used to perform calls via the PLT from Thumb
5959 code using BLX rather than using BX and a mode-switching stub before
5960 each PLT entry. This should lead to such calls executing slightly faster.
5962 This option is enabled implicitly for SymbianOS, so there is no need to
5963 specify it if you are using that target.
5965 @cindex VFP11_DENORM_FIX
5966 @kindex --vfp11-denorm-fix
5967 The @samp{--vfp11-denorm-fix} switch enables a link-time workaround for a
5968 bug in certain VFP11 coprocessor hardware, which sometimes allows
5969 instructions with denorm operands (which must be handled by support code)
5970 to have those operands overwritten by subsequent instructions before
5971 the support code can read the intended values.
5973 The bug may be avoided in scalar mode if you allow at least one
5974 intervening instruction between a VFP11 instruction which uses a register
5975 and another instruction which writes to the same register, or at least two
5976 intervening instructions if vector mode is in use. The bug only affects
5977 full-compliance floating-point mode: you do not need this workaround if
5978 you are using "runfast" mode. Please contact ARM for further details.
5980 If you know you are using buggy VFP11 hardware, you can
5981 enable this workaround by specifying the linker option
5982 @samp{--vfp-denorm-fix=scalar} if you are using the VFP11 scalar
5983 mode only, or @samp{--vfp-denorm-fix=vector} if you are using
5984 vector mode (the latter also works for scalar code). The default is
5985 @samp{--vfp-denorm-fix=none}.
5987 If the workaround is enabled, instructions are scanned for
5988 potentially-troublesome sequences, and a veneer is created for each
5989 such sequence which may trigger the erratum. The veneer consists of the
5990 first instruction of the sequence and a branch back to the subsequent
5991 instruction. The original instruction is then replaced with a branch to
5992 the veneer. The extra cycles required to call and return from the veneer
5993 are sufficient to avoid the erratum in both the scalar and vector cases.
5995 @cindex NO_ENUM_SIZE_WARNING
5996 @kindex --no-enum-size-warning
5997 The @option{--no-enum-size-warning} switch prevents the linker from
5998 warning when linking object files that specify incompatible EABI
5999 enumeration size attributes.  For example, with this switch enabled,
6000 linking of an object file using 32-bit enumeration values with another
6001 using enumeration values fitted into the smallest possible space will
6002 not be diagnosed.
6004 @cindex NO_WCHAR_SIZE_WARNING
6005 @kindex --no-wchar-size-warning
6006 The @option{--no-wchar-size-warning} switch prevents the linker from
6007 warning when linking object files that specify incompatible EABI
6008 @code{wchar_t} size attributes.  For example, with this switch enabled,
6009 linking of an object file using 32-bit @code{wchar_t} values with another
6010 using 16-bit @code{wchar_t} values will not be diagnosed.
6012 @cindex PIC_VENEER
6013 @kindex --pic-veneer
6014 The @samp{--pic-veneer} switch makes the linker use PIC sequences for
6015 ARM/Thumb interworking veneers, even if the rest of the binary
6016 is not PIC.  This avoids problems on uClinux targets where
6017 @samp{--emit-relocs} is used to generate relocatable binaries.
6019 @cindex STUB_GROUP_SIZE
6020 @kindex --stub-group-size=@var{N}
6021 The linker will automatically generate and insert small sequences of
6022 code into a linked ARM ELF executable whenever an attempt is made to
6023 perform a function call to a symbol that is too far away.  The
6024 placement of these sequences of instructions - called stubs - is
6025 controlled by the command line option @option{--stub-group-size=N}.
6026 The placement is important because a poor choice can create a need for
6027 duplicate stubs, increasing the code sizw.  The linker will try to
6028 group stubs together in order to reduce interruptions to the flow of
6029 code, but it needs guidance as to how big these groups should be and
6030 where they should be placed.
6032 The value of @samp{N}, the parameter to the
6033 @option{--stub-group-size=} option controls where the stub groups are
6034 placed.  If it is negative then all stubs are placed after the first
6035 branch that needs them.  If it is positive then the stubs can be
6036 placed either before or after the branches that need them.  If the
6037 value of @samp{N} is 1 (either +1 or -1) then the linker will choose
6038 exactly where to place groups of stubs, using its built in heuristics.
6039 A value of @samp{N} greater than 1 (or smaller than -1) tells the
6040 linker that a single group of stubs can service at most @samp{N} bytes
6041 from the input sections.
6043 The default, if @option{--stub-group-size=} is not specified, is
6044 @samp{N = +1}.
6046 Farcalls stubs insertion is fully supported for the ARM-EABI target
6047 only, because it relies on object files properties not present
6048 otherwise.
6050 @ifclear GENERIC
6051 @lowersections
6052 @end ifclear
6053 @end ifset
6055 @ifset HPPA
6056 @ifclear GENERIC
6057 @raisesections
6058 @end ifclear
6060 @node HPPA ELF32
6061 @section @command{ld} and HPPA 32-bit ELF Support
6062 @cindex HPPA multiple sub-space stubs
6063 @kindex --multi-subspace
6064 When generating a shared library, @command{ld} will by default generate
6065 import stubs suitable for use with a single sub-space application.
6066 The @samp{--multi-subspace} switch causes @command{ld} to generate export
6067 stubs, and different (larger) import stubs suitable for use with
6068 multiple sub-spaces.
6070 @cindex HPPA stub grouping
6071 @kindex --stub-group-size=@var{N}
6072 Long branch stubs and import/export stubs are placed by @command{ld} in
6073 stub sections located between groups of input sections.
6074 @samp{--stub-group-size} specifies the maximum size of a group of input
6075 sections handled by one stub section.  Since branch offsets are signed,
6076 a stub section may serve two groups of input sections, one group before
6077 the stub section, and one group after it.  However, when using
6078 conditional branches that require stubs, it may be better (for branch
6079 prediction) that stub sections only serve one group of input sections.
6080 A negative value for @samp{N} chooses this scheme, ensuring that
6081 branches to stubs always use a negative offset.  Two special values of
6082 @samp{N} are recognized, @samp{1} and @samp{-1}.  These both instruct
6083 @command{ld} to automatically size input section groups for the branch types
6084 detected, with the same behaviour regarding stub placement as other
6085 positive or negative values of @samp{N} respectively.
6087 Note that @samp{--stub-group-size} does not split input sections.  A
6088 single input section larger than the group size specified will of course
6089 create a larger group (of one section).  If input sections are too
6090 large, it may not be possible for a branch to reach its stub.
6092 @ifclear GENERIC
6093 @lowersections
6094 @end ifclear
6095 @end ifset
6097 @ifset M68K
6098 @ifclear GENERIC
6099 @raisesections
6100 @end ifclear
6102 @node M68K
6103 @section @command{ld} and the Motorola 68K family
6105 @cindex Motorola 68K GOT generation
6106 @kindex --got=@var{type}
6107 The @samp{--got=@var{type}} option lets you choose the GOT generation scheme.
6108 The choices are @samp{single}, @samp{negative}, @samp{multigot} and
6109 @samp{target}.  When @samp{target} is selected the linker chooses
6110 the default GOT generation scheme for the current target.
6111 @samp{single} tells the linker to generate a single GOT with
6112 entries only at non-negative offsets.
6113 @samp{negative} instructs the linker to generate a single GOT with
6114 entries at both negative and positive offsets.  Not all environments
6115 support such GOTs.
6116 @samp{multigot} allows the linker to generate several GOTs in the
6117 output file.  All GOT references from a single input object
6118 file access the same GOT, but references from different input object
6119 files might access different GOTs.  Not all environments support such GOTs.
6121 @ifclear GENERIC
6122 @lowersections
6123 @end ifclear
6124 @end ifset
6126 @ifset MMIX
6127 @ifclear GENERIC
6128 @raisesections
6129 @end ifclear
6131 @node MMIX
6132 @section @code{ld} and MMIX
6133 For MMIX, there is a choice of generating @code{ELF} object files or
6134 @code{mmo} object files when linking.  The simulator @code{mmix}
6135 understands the @code{mmo} format.  The binutils @code{objcopy} utility
6136 can translate between the two formats.
6138 There is one special section, the @samp{.MMIX.reg_contents} section.
6139 Contents in this section is assumed to correspond to that of global
6140 registers, and symbols referring to it are translated to special symbols,
6141 equal to registers.  In a final link, the start address of the
6142 @samp{.MMIX.reg_contents} section corresponds to the first allocated
6143 global register multiplied by 8.  Register @code{$255} is not included in
6144 this section; it is always set to the program entry, which is at the
6145 symbol @code{Main} for @code{mmo} files.
6147 Global symbols with the prefix @code{__.MMIX.start.}, for example
6148 @code{__.MMIX.start..text} and @code{__.MMIX.start..data} are special.
6149 The default linker script uses these to set the default start address
6150 of a section.
6152 Initial and trailing multiples of zero-valued 32-bit words in a section,
6153 are left out from an mmo file.
6155 @ifclear GENERIC
6156 @lowersections
6157 @end ifclear
6158 @end ifset
6160 @ifset MSP430
6161 @ifclear GENERIC
6162 @raisesections
6163 @end ifclear
6165 @node  MSP430
6166 @section @code{ld} and MSP430
6167 For the MSP430 it is possible to select the MPU architecture.  The flag @samp{-m [mpu type]}
6168 will select an appropriate linker script for selected MPU type.  (To get a list of known MPUs
6169 just pass @samp{-m help} option to the linker).
6171 @cindex MSP430 extra sections
6172 The linker will recognize some extra sections which are MSP430 specific:
6174 @table @code
6175 @item @samp{.vectors}
6176 Defines a portion of ROM where interrupt vectors located.
6178 @item @samp{.bootloader}
6179 Defines the bootloader portion of the ROM (if applicable).  Any code
6180 in this section will be uploaded to the MPU.
6182 @item @samp{.infomem}
6183 Defines an information memory section (if applicable).  Any code in
6184 this section will be uploaded to the MPU.
6186 @item @samp{.infomemnobits}
6187 This is the same as the @samp{.infomem} section except that any code
6188 in this section will not be uploaded to the MPU.
6190 @item @samp{.noinit}
6191 Denotes a portion of RAM located above @samp{.bss} section.
6193 The last two sections are used by gcc.
6194 @end table
6196 @ifclear GENERIC
6197 @lowersections
6198 @end ifclear
6199 @end ifset
6201 @ifset POWERPC
6202 @ifclear GENERIC
6203 @raisesections
6204 @end ifclear
6206 @node PowerPC ELF32
6207 @section @command{ld} and PowerPC 32-bit ELF Support
6208 @cindex PowerPC long branches
6209 @kindex --relax on PowerPC
6210 Branches on PowerPC processors are limited to a signed 26-bit
6211 displacement, which may result in @command{ld} giving
6212 @samp{relocation truncated to fit} errors with very large programs.
6213 @samp{--relax} enables the generation of trampolines that can access
6214 the entire 32-bit address space.  These trampolines are inserted at
6215 section boundaries, so may not themselves be reachable if an input
6216 section exceeds 33M in size.
6218 @cindex PowerPC ELF32 options
6219 @table @option
6220 @cindex PowerPC PLT
6221 @kindex --bss-plt
6222 @item --bss-plt
6223 Current PowerPC GCC accepts a @samp{-msecure-plt} option that
6224 generates code capable of using a newer PLT and GOT layout that has
6225 the security advantage of no executable section ever needing to be
6226 writable and no writable section ever being executable.  PowerPC
6227 @command{ld} will generate this layout, including stubs to access the
6228 PLT, if all input files (including startup and static libraries) were
6229 compiled with @samp{-msecure-plt}.  @samp{--bss-plt} forces the old
6230 BSS PLT (and GOT layout) which can give slightly better performance.
6232 @kindex --secure-plt
6233 @item --secure-plt
6234 @command{ld} will use the new PLT and GOT layout if it is linking new
6235 @samp{-fpic} or @samp{-fPIC} code, but does not do so automatically
6236 when linking non-PIC code.  This option requests the new PLT and GOT
6237 layout.  A warning will be given if some object file requires the old
6238 style BSS PLT.
6240 @cindex PowerPC GOT
6241 @kindex --sdata-got
6242 @item --sdata-got
6243 The new secure PLT and GOT are placed differently relative to other
6244 sections compared to older BSS PLT and GOT placement.  The location of
6245 @code{.plt} must change because the new secure PLT is an initialized
6246 section while the old PLT is uninitialized.  The reason for the
6247 @code{.got} change is more subtle:  The new placement allows
6248 @code{.got} to be read-only in applications linked with
6249 @samp{-z relro -z now}.  However, this placement means that
6250 @code{.sdata} cannot always be used in shared libraries, because the
6251 PowerPC ABI accesses @code{.sdata} in shared libraries from the GOT
6252 pointer.  @samp{--sdata-got} forces the old GOT placement.  PowerPC
6253 GCC doesn't use @code{.sdata} in shared libraries, so this option is
6254 really only useful for other compilers that may do so.
6256 @cindex PowerPC stub symbols
6257 @kindex --emit-stub-syms
6258 @item --emit-stub-syms
6259 This option causes @command{ld} to label linker stubs with a local
6260 symbol that encodes the stub type and destination.
6262 @cindex PowerPC TLS optimization
6263 @kindex --no-tls-optimize
6264 @item --no-tls-optimize
6265 PowerPC @command{ld} normally performs some optimization of code
6266 sequences used to access Thread-Local Storage.  Use this option to
6267 disable the optimization.
6268 @end table
6270 @ifclear GENERIC
6271 @lowersections
6272 @end ifclear
6273 @end ifset
6275 @ifset POWERPC64
6276 @ifclear GENERIC
6277 @raisesections
6278 @end ifclear
6280 @node PowerPC64 ELF64
6281 @section @command{ld} and PowerPC64 64-bit ELF Support
6283 @cindex PowerPC64 ELF64 options
6284 @table @option
6285 @cindex PowerPC64 stub grouping
6286 @kindex --stub-group-size
6287 @item --stub-group-size
6288 Long branch stubs, PLT call stubs  and TOC adjusting stubs are placed
6289 by @command{ld} in stub sections located between groups of input sections.
6290 @samp{--stub-group-size} specifies the maximum size of a group of input
6291 sections handled by one stub section.  Since branch offsets are signed,
6292 a stub section may serve two groups of input sections, one group before
6293 the stub section, and one group after it.  However, when using
6294 conditional branches that require stubs, it may be better (for branch
6295 prediction) that stub sections only serve one group of input sections.
6296 A negative value for @samp{N} chooses this scheme, ensuring that
6297 branches to stubs always use a negative offset.  Two special values of
6298 @samp{N} are recognized, @samp{1} and @samp{-1}.  These both instruct
6299 @command{ld} to automatically size input section groups for the branch types
6300 detected, with the same behaviour regarding stub placement as other
6301 positive or negative values of @samp{N} respectively.
6303 Note that @samp{--stub-group-size} does not split input sections.  A
6304 single input section larger than the group size specified will of course
6305 create a larger group (of one section).  If input sections are too
6306 large, it may not be possible for a branch to reach its stub.
6308 @cindex PowerPC64 stub symbols
6309 @kindex --emit-stub-syms
6310 @item --emit-stub-syms
6311 This option causes @command{ld} to label linker stubs with a local
6312 symbol that encodes the stub type and destination.
6314 @cindex PowerPC64 dot symbols
6315 @kindex --dotsyms
6316 @kindex --no-dotsyms
6317 @item --dotsyms, --no-dotsyms
6318 These two options control how @command{ld} interprets version patterns
6319 in a version script.  Older PowerPC64 compilers emitted both a
6320 function descriptor symbol with the same name as the function, and a
6321 code entry symbol with the name prefixed by a dot (@samp{.}).  To
6322 properly version a function @samp{foo}, the version script thus needs
6323 to control both @samp{foo} and @samp{.foo}.  The option
6324 @samp{--dotsyms}, on by default, automatically adds the required
6325 dot-prefixed patterns.  Use @samp{--no-dotsyms} to disable this
6326 feature.
6328 @cindex PowerPC64 TLS optimization
6329 @kindex --no-tls-optimize
6330 @item --no-tls-optimize
6331 PowerPC64 @command{ld} normally performs some optimization of code
6332 sequences used to access Thread-Local Storage.  Use this option to
6333 disable the optimization.
6335 @cindex PowerPC64 OPD optimization
6336 @kindex --no-opd-optimize
6337 @item --no-opd-optimize
6338 PowerPC64 @command{ld} normally removes @code{.opd} section entries
6339 corresponding to deleted link-once functions, or functions removed by
6340 the action of @samp{--gc-sections} or linker script @code{/DISCARD/}.
6341 Use this option to disable @code{.opd} optimization.
6343 @cindex PowerPC64 OPD spacing
6344 @kindex --non-overlapping-opd
6345 @item --non-overlapping-opd
6346 Some PowerPC64 compilers have an option to generate compressed
6347 @code{.opd} entries spaced 16 bytes apart, overlapping the third word,
6348 the static chain pointer (unused in C) with the first word of the next
6349 entry.  This option expands such entries to the full 24 bytes.
6351 @cindex PowerPC64 TOC optimization
6352 @kindex --no-toc-optimize
6353 @item --no-toc-optimize
6354 PowerPC64 @command{ld} normally removes unused @code{.toc} section
6355 entries.  Such entries are detected by examining relocations that
6356 reference the TOC in code sections.  A reloc in a deleted code section
6357 marks a TOC word as unneeded, while a reloc in a kept code section
6358 marks a TOC word as needed.  Since the TOC may reference itself, TOC
6359 relocs are also examined.  TOC words marked as both needed and
6360 unneeded will of course be kept.  TOC words without any referencing
6361 reloc are assumed to be part of a multi-word entry, and are kept or
6362 discarded as per the nearest marked preceding word.  This works
6363 reliably for compiler generated code, but may be incorrect if assembly
6364 code is used to insert TOC entries.  Use this option to disable the
6365 optimization.
6367 @cindex PowerPC64 multi-TOC
6368 @kindex --no-multi-toc
6369 @item --no-multi-toc
6370 By default, PowerPC64 GCC generates code for a TOC model where TOC
6371 entries are accessed with a 16-bit offset from r2.  This limits the
6372 total TOC size to 64K.  PowerPC64 @command{ld} extends this limit by
6373 grouping code sections such that each group uses less than 64K for its
6374 TOC entries, then inserts r2 adjusting stubs between inter-group
6375 calls.  @command{ld} does not split apart input sections, so cannot
6376 help if a single input file has a @code{.toc} section that exceeds
6377 64K, most likely from linking multiple files with @command{ld -r}.
6378 Use this option to turn off this feature.
6379 @end table
6381 @ifclear GENERIC
6382 @lowersections
6383 @end ifclear
6384 @end ifset
6386 @ifset SPU
6387 @ifclear GENERIC
6388 @raisesections
6389 @end ifclear
6391 @node SPU ELF
6392 @section @command{ld} and SPU ELF Support
6394 @cindex SPU ELF options
6395 @table @option
6397 @cindex SPU plugins
6398 @kindex --plugin
6399 @item --plugin
6400 This option marks an executable as a PIC plugin module.
6402 @cindex SPU overlays
6403 @kindex --no-overlays
6404 @item --no-overlays
6405 Normally, @command{ld} recognizes calls to functions within overlay
6406 regions, and redirects such calls to an overlay manager via a stub.
6407 @command{ld} also provides a built-in overlay manager.  This option
6408 turns off all this special overlay handling.
6410 @cindex SPU overlay stub symbols
6411 @kindex --emit-stub-syms
6412 @item --emit-stub-syms
6413 This option causes @command{ld} to label overlay stubs with a local
6414 symbol that encodes the stub type and destination.
6416 @cindex SPU extra overlay stubs
6417 @kindex --extra-overlay-stubs
6418 @item --extra-overlay-stubs
6419 This option causes @command{ld} to add overlay call stubs on all
6420 function calls out of overlay regions.  Normally stubs are not added
6421 on calls to non-overlay regions.
6423 @cindex SPU local store size
6424 @kindex --local-store=lo:hi
6425 @item --local-store=lo:hi
6426 @command{ld} usually checks that a final executable for SPU fits in
6427 the address range 0 to 256k.  This option may be used to change the
6428 range.  Disable the check entirely with @option{--local-store=0:0}.
6430 @cindex SPU
6431 @kindex --stack-analysis
6432 @item --stack-analysis
6433 SPU local store space is limited.  Over-allocation of stack space
6434 unnecessarily limits space available for code and data, while
6435 under-allocation results in runtime failures.  If given this option,
6436 @command{ld} will provide an estimate of maximum stack usage.
6437 @command{ld} does this by examining symbols in code sections to
6438 determine the extents of functions, and looking at function prologues
6439 for stack adjusting instructions.  A call-graph is created by looking
6440 for relocations on branch instructions.  The graph is then searched
6441 for the maximum stack usage path.  Note that this analysis does not
6442 find calls made via function pointers, and does not handle recursion
6443 and other cycles in the call graph.  Stack usage may be
6444 under-estimated if your code makes such calls.  Also, stack usage for
6445 dynamic allocation, e.g. alloca, will not be detected.  If a link map
6446 is requested, detailed information about each function's stack usage
6447 and calls will be given.
6449 @cindex SPU
6450 @kindex --emit-stack-syms
6451 @item --emit-stack-syms
6452 This option, if given along with @option{--stack-analysis} will result
6453 in @command{ld} emitting stack sizing symbols for each function.
6454 These take the form @code{__stack_<function_name>} for global
6455 functions, and @code{__stack_<number>_<function_name>} for static
6456 functions.  @code{<number>} is the section id in hex.  The value of
6457 such symbols is the stack requirement for the corresponding function.
6458 The symbol size will be zero, type @code{STT_NOTYPE}, binding
6459 @code{STB_LOCAL}, and section @code{SHN_ABS}.
6460 @end table
6462 @ifclear GENERIC
6463 @lowersections
6464 @end ifclear
6465 @end ifset
6467 @ifset TICOFF
6468 @ifclear GENERIC
6469 @raisesections
6470 @end ifclear
6472 @node TI COFF
6473 @section @command{ld}'s Support for Various TI COFF Versions
6474 @cindex TI COFF versions
6475 @kindex --format=@var{version}
6476 The @samp{--format} switch allows selection of one of the various
6477 TI COFF versions.  The latest of this writing is 2; versions 0 and 1 are
6478 also supported.  The TI COFF versions also vary in header byte-order
6479 format; @command{ld} will read any version or byte order, but the output
6480 header format depends on the default specified by the specific target.
6482 @ifclear GENERIC
6483 @lowersections
6484 @end ifclear
6485 @end ifset
6487 @ifset WIN32
6488 @ifclear GENERIC
6489 @raisesections
6490 @end ifclear
6492 @node WIN32
6493 @section @command{ld} and WIN32 (cygwin/mingw)
6495 This section describes some of the win32 specific @command{ld} issues.
6496 See @ref{Options,,Command Line Options} for detailed description of the
6497 command line options mentioned here.
6499 @table @emph
6500 @cindex import libraries
6501 @item import libraries
6502 The standard Windows linker creates and uses so-called import
6503 libraries, which contains information for linking to dll's.  They are
6504 regular static archives and are handled as any other static
6505 archive.  The cygwin and mingw ports of @command{ld} have specific
6506 support for creating such libraries provided with the
6507 @samp{--out-implib} command line option.
6509 @item   exporting DLL symbols
6510 @cindex exporting DLL symbols
6511 The cygwin/mingw @command{ld} has several ways to export symbols for dll's.
6513 @table @emph
6514 @item   using auto-export functionality
6515 @cindex using auto-export functionality
6516 By default @command{ld} exports symbols with the auto-export functionality,
6517 which is controlled by the following command line options:
6519 @itemize
6520 @item --export-all-symbols   [This is the default]
6521 @item --exclude-symbols
6522 @item --exclude-libs
6523 @item --exclude-modules-for-implib
6524 @end itemize
6526 If, however, @samp{--export-all-symbols} is not given explicitly on the
6527 command line, then the default auto-export behavior will be @emph{disabled}
6528 if either of the following are true:
6530 @itemize
6531 @item A DEF file is used.
6532 @item Any symbol in any object file was marked with the __declspec(dllexport) attribute.
6533 @end itemize
6535 @item   using a DEF file
6536 @cindex using a DEF file
6537 Another way of exporting symbols is using a DEF file.  A DEF file is
6538 an ASCII file containing definitions of symbols which should be
6539 exported when a dll is created.  Usually it is named @samp{<dll
6540 name>.def} and is added as any other object file to the linker's
6541 command line.  The file's name must end in @samp{.def} or @samp{.DEF}.
6543 @example
6544 gcc -o <output> <objectfiles> <dll name>.def
6545 @end example
6547 Using a DEF file turns off the normal auto-export behavior, unless the
6548 @samp{--export-all-symbols} option is also used.
6550 Here is an example of a DEF file for a shared library called @samp{xyz.dll}:
6552 @example
6553 LIBRARY "xyz.dll" BASE=0x20000000
6555 EXPORTS
6558 _bar = bar
6559 another_foo = abc.dll.afoo
6560 var1 DATA
6561 @end example
6563 This example defines a DLL with a non-default base address and five
6564 symbols in the export table. The third exported symbol @code{_bar} is an
6565 alias for the second. The fourth symbol, @code{another_foo} is resolved
6566 by "forwarding" to another module and treating it as an alias for
6567 @code{afoo} exported from the DLL @samp{abc.dll}. The final symbol
6568 @code{var1} is declared to be a data object.
6570 The optional @code{LIBRARY <name>} command indicates the @emph{internal}
6571 name of the output DLL. If @samp{<name>} does not include a suffix,
6572 the default library suffix, @samp{.DLL} is appended.
6574 When the .DEF file is used to build an application, rather than a
6575 library, the @code{NAME <name>} command should be used instead of
6576 @code{LIBRARY}. If @samp{<name>} does not include a suffix, the default
6577 executable suffix, @samp{.EXE} is appended.
6579 With either @code{LIBRARY <name>} or @code{NAME <name>} the optional
6580 specification @code{BASE = <number>} may be used to specify a
6581 non-default base address for the image.
6583 If neither @code{LIBRARY <name>} nor  @code{NAME <name>} is specified,
6584 or they specify an empty string, the internal name is the same as the
6585 filename specified on the command line.
6587 The complete specification of an export symbol is:
6589 @example
6590 EXPORTS
6591   ( (  ( <name1> [ = <name2> ] )
6592      | ( <name1> = <module-name> . <external-name>))
6593   [ @@ <integer> ] [NONAME] [DATA] [CONSTANT] [PRIVATE] ) *
6594 @end example
6596 Declares @samp{<name1>} as an exported symbol from the DLL, or declares
6597 @samp{<name1>} as an exported alias for @samp{<name2>}; or declares
6598 @samp{<name1>} as a "forward" alias for the symbol
6599 @samp{<external-name>} in the DLL @samp{<module-name>}.
6600 Optionally, the symbol may be exported by the specified ordinal
6601 @samp{<integer>} alias.
6603 The optional keywords that follow the declaration indicate:
6605 @code{NONAME}: Do not put the symbol name in the DLL's export table.  It
6606 will still be exported by its ordinal alias (either the value specified
6607 by the .def specification or, otherwise, the value assigned by the
6608 linker). The symbol name, however, does remain visible in the import
6609 library (if any), unless @code{PRIVATE} is also specified.
6611 @code{DATA}: The symbol is a variable or object, rather than a function.
6612 The import lib will export only an indirect reference to @code{foo} as
6613 the symbol @code{_imp__foo} (ie, @code{foo} must be resolved as
6614 @code{*_imp__foo}).
6616 @code{CONSTANT}: Like @code{DATA}, but put the undecorated @code{foo} as
6617 well as @code{_imp__foo} into the import library. Both refer to the
6618 read-only import address table's pointer to the variable, not to the
6619 variable itself. This can be dangerous. If the user code fails to add
6620 the @code{dllimport} attribute and also fails to explicitly add the
6621 extra indirection that the use of the attribute enforces, the
6622 application will behave unexpectedly.
6624 @code{PRIVATE}: Put the symbol in the DLL's export table, but do not put
6625 it into the static import library used to resolve imports at link time. The
6626 symbol can still be imported using the @code{LoadLibrary/GetProcAddress}
6627 API at runtime or by by using the GNU ld extension of linking directly to
6628 the DLL without an import library.
6630 See ld/deffilep.y in the binutils sources for the full specification of
6631 other DEF file statements
6633 @cindex creating a DEF file
6634 While linking a shared dll, @command{ld} is able to create a DEF file
6635 with the @samp{--output-def <file>} command line option.
6637 @item   Using decorations
6638 @cindex Using decorations
6639 Another way of marking symbols for export is to modify the source code
6640 itself, so that when building the DLL each symbol to be exported is
6641 declared as:
6643 @example
6644 __declspec(dllexport) int a_variable
6645 __declspec(dllexport) void a_function(int with_args)
6646 @end example
6648 All such symbols will be exported from the DLL.  If, however,
6649 any of the object files in the DLL contain symbols decorated in
6650 this way, then the normal auto-export behavior is disabled, unless
6651 the @samp{--export-all-symbols} option is also used.
6653 Note that object files that wish to access these symbols must @emph{not}
6654 decorate them with dllexport.  Instead, they should use dllimport,
6655 instead:
6657 @example
6658 __declspec(dllimport) int a_variable
6659 __declspec(dllimport) void a_function(int with_args)
6660 @end example
6662 This complicates the structure of library header files, because
6663 when included by the library itself the header must declare the
6664 variables and functions as dllexport, but when included by client
6665 code the header must declare them as dllimport.  There are a number
6666 of idioms that are typically used to do this; often client code can
6667 omit the __declspec() declaration completely.  See
6668 @samp{--enable-auto-import} and @samp{automatic data imports} for more
6669 information.
6670 @end table
6672 @cindex automatic data imports
6673 @item automatic data imports
6674 The standard Windows dll format supports data imports from dlls only
6675 by adding special decorations (dllimport/dllexport), which let the
6676 compiler produce specific assembler instructions to deal with this
6677 issue.  This increases the effort necessary to port existing Un*x
6678 code to these platforms, especially for large
6679 c++ libraries and applications.  The auto-import feature, which was
6680 initially provided by Paul Sokolovsky, allows one to omit the
6681 decorations to achieve a behavior that conforms to that on POSIX/Un*x
6682 platforms. This feature is enabled with the @samp{--enable-auto-import}
6683 command-line option, although it is enabled by default on cygwin/mingw.
6684 The @samp{--enable-auto-import} option itself now serves mainly to
6685 suppress any warnings that are ordinarily emitted when linked objects
6686 trigger the feature's use.
6688 auto-import of variables does not always work flawlessly without
6689 additional assistance.  Sometimes, you will see this message
6691 "variable '<var>' can't be auto-imported. Please read the
6692 documentation for ld's @code{--enable-auto-import} for details."
6694 The @samp{--enable-auto-import} documentation explains why this error
6695 occurs, and several methods that can be used to overcome this difficulty.
6696 One of these methods is the @emph{runtime pseudo-relocs} feature, described
6697 below.
6699 @cindex runtime pseudo-relocation
6700 For complex variables imported from DLLs (such as structs or classes),
6701 object files typically contain a base address for the variable and an
6702 offset (@emph{addend}) within the variable--to specify a particular
6703 field or public member, for instance.  Unfortunately, the runtime loader used
6704 in win32 environments is incapable of fixing these references at runtime
6705 without the additional information supplied by dllimport/dllexport decorations.
6706 The standard auto-import feature described above is unable to resolve these
6707 references.
6709 The @samp{--enable-runtime-pseudo-relocs} switch allows these references to
6710 be resolved without error, while leaving the task of adjusting the references
6711 themselves (with their non-zero addends) to specialized code provided by the
6712 runtime environment.  Recent versions of the cygwin and mingw environments and
6713 compilers provide this runtime support; older versions do not.  However, the
6714 support is only necessary on the developer's platform; the compiled result will
6715 run without error on an older system.
6717 @samp{--enable-runtime-pseudo-relocs} is not the default; it must be explicitly
6718 enabled as needed.
6720 @cindex direct linking to a dll
6721 @item direct linking to a dll
6722 The cygwin/mingw ports of @command{ld} support the direct linking,
6723 including data symbols, to a dll without the usage of any import
6724 libraries.  This is much faster and uses much less memory than does the
6725 traditional import library method, especially when linking large
6726 libraries or applications.  When @command{ld} creates an import lib, each
6727 function or variable exported from the dll is stored in its own bfd, even
6728 though a single bfd could contain many exports.  The overhead involved in
6729 storing, loading, and processing so many bfd's is quite large, and explains the
6730 tremendous time, memory, and storage needed to link against particularly
6731 large or complex libraries when using import libs.
6733 Linking directly to a dll uses no extra command-line switches other than
6734 @samp{-L} and @samp{-l}, because @command{ld} already searches for a number
6735 of names to match each library.  All that is needed from the developer's
6736 perspective is an understanding of this search, in order to force ld to
6737 select the dll instead of an import library.
6740 For instance, when ld is called with the argument @samp{-lxxx} it will attempt
6741 to find, in the first directory of its search path,
6743 @example
6744 libxxx.dll.a
6745 xxx.dll.a
6746 libxxx.a
6747 xxx.lib
6748 cygxxx.dll (*)
6749 libxxx.dll
6750 xxx.dll
6751 @end example
6753 before moving on to the next directory in the search path.
6755 (*) Actually, this is not @samp{cygxxx.dll} but in fact is @samp{<prefix>xxx.dll},
6756 where @samp{<prefix>} is set by the @command{ld} option
6757 @samp{--dll-search-prefix=<prefix>}. In the case of cygwin, the standard gcc spec
6758 file includes @samp{--dll-search-prefix=cyg}, so in effect we actually search for
6759 @samp{cygxxx.dll}.
6761 Other win32-based unix environments, such as mingw or pw32, may use other
6762 @samp{<prefix>}es, although at present only cygwin makes use of this feature.  It
6763 was originally intended to help avoid name conflicts among dll's built for the
6764 various win32/un*x environments, so that (for example) two versions of a zlib dll
6765 could coexist on the same machine.
6767 The generic cygwin/mingw path layout uses a @samp{bin} directory for
6768 applications and dll's and a @samp{lib} directory for the import
6769 libraries (using cygwin nomenclature):
6771 @example
6772 bin/
6773         cygxxx.dll
6774 lib/
6775         libxxx.dll.a   (in case of dll's)
6776         libxxx.a       (in case of static archive)
6777 @end example
6779 Linking directly to a dll without using the import library can be
6780 done two ways:
6782 1. Use the dll directly by adding the @samp{bin} path to the link line
6783 @example
6784 gcc -Wl,-verbose  -o a.exe -L../bin/ -lxxx
6785 @end example
6787 However, as the dll's often have version numbers appended to their names
6788 (@samp{cygncurses-5.dll}) this will often fail, unless one specifies
6789 @samp{-L../bin -lncurses-5} to include the version.  Import libs are generally
6790 not versioned, and do not have this difficulty.
6792 2. Create a symbolic link from the dll to a file in the @samp{lib}
6793 directory according to the above mentioned search pattern.  This
6794 should be used to avoid unwanted changes in the tools needed for
6795 making the app/dll.
6797 @example
6798 ln -s bin/cygxxx.dll lib/[cyg|lib|]xxx.dll[.a]
6799 @end example
6801 Then you can link without any make environment changes.
6803 @example
6804 gcc -Wl,-verbose  -o a.exe -L../lib/ -lxxx
6805 @end example
6807 This technique also avoids the version number problems, because the following is
6808 perfectly legal
6810 @example
6811 bin/
6812         cygxxx-5.dll
6813 lib/
6814         libxxx.dll.a -> ../bin/cygxxx-5.dll
6815 @end example
6817 Linking directly to a dll without using an import lib will work
6818 even when auto-import features are exercised, and even when
6819 @samp{--enable-runtime-pseudo-relocs} is used.
6821 Given the improvements in speed and memory usage, one might justifiably
6822 wonder why import libraries are used at all.  There are three reasons:
6824 1. Until recently, the link-directly-to-dll functionality did @emph{not}
6825 work with auto-imported data.
6827 2. Sometimes it is necessary to include pure static objects within the
6828 import library (which otherwise contains only bfd's for indirection
6829 symbols that point to the exports of a dll).  Again, the import lib
6830 for the cygwin kernel makes use of this ability, and it is not
6831 possible to do this without an import lib.
6833 3. Symbol aliases can only be resolved using an import lib.  This is
6834 critical when linking against OS-supplied dll's (eg, the win32 API)
6835 in which symbols are usually exported as undecorated aliases of their
6836 stdcall-decorated assembly names.
6838 So, import libs are not going away.  But the ability to replace
6839 true import libs with a simple symbolic link to (or a copy of)
6840 a dll, in many cases, is a useful addition to the suite of tools
6841 binutils makes available to the win32 developer.  Given the
6842 massive improvements in memory requirements during linking, storage
6843 requirements, and linking speed, we expect that many developers
6844 will soon begin to use this feature whenever possible.
6846 @item symbol aliasing
6847 @table @emph
6848 @item adding additional names
6849 Sometimes, it is useful to export symbols with additional names.
6850 A symbol @samp{foo} will be exported as @samp{foo}, but it can also be
6851 exported as @samp{_foo} by using special directives in the DEF file
6852 when creating the dll.  This will affect also the optional created
6853 import library.  Consider the following DEF file:
6855 @example
6856 LIBRARY "xyz.dll" BASE=0x61000000
6858 EXPORTS
6860 _foo = foo
6861 @end example
6863 The line @samp{_foo = foo} maps the symbol @samp{foo} to @samp{_foo}.
6865 Another method for creating a symbol alias is to create it in the
6866 source code using the "weak" attribute:
6868 @example
6869 void foo () @{ /* Do something.  */; @}
6870 void _foo () __attribute__ ((weak, alias ("foo")));
6871 @end example
6873 See the gcc manual for more information about attributes and weak
6874 symbols.
6876 @item renaming symbols
6877 Sometimes it is useful to rename exports.  For instance, the cygwin
6878 kernel does this regularly.  A symbol @samp{_foo} can be exported as
6879 @samp{foo} but not as @samp{_foo} by using special directives in the
6880 DEF file. (This will also affect the import library, if it is
6881 created).  In the following example:
6883 @example
6884 LIBRARY "xyz.dll" BASE=0x61000000
6886 EXPORTS
6887 _foo = foo
6888 @end example
6890 The line @samp{_foo = foo} maps the exported symbol @samp{foo} to
6891 @samp{_foo}.
6892 @end table
6894 Note: using a DEF file disables the default auto-export behavior,
6895 unless the @samp{--export-all-symbols} command line option is used.
6896 If, however, you are trying to rename symbols, then you should list
6897 @emph{all} desired exports in the DEF file, including the symbols
6898 that are not being renamed, and do @emph{not} use the
6899 @samp{--export-all-symbols} option.  If you list only the
6900 renamed symbols in the DEF file, and use @samp{--export-all-symbols}
6901 to handle the other symbols, then the both the new names @emph{and}
6902 the original names for the renamed symbols will be exported.
6903 In effect, you'd be aliasing those symbols, not renaming them,
6904 which is probably not what you wanted.
6906 @cindex weak externals
6907 @item weak externals
6908 The Windows object format, PE, specifies a form of weak symbols called
6909 weak externals.  When a weak symbol is linked and the symbol is not
6910 defined, the weak symbol becomes an alias for some other symbol.  There
6911 are three variants of weak externals:
6912 @itemize
6913 @item Definition is searched for in objects and libraries, historically
6914 called lazy externals.
6915 @item Definition is searched for only in other objects, not in libraries.
6916 This form is not presently implemented.
6917 @item No search; the symbol is an alias.  This form is not presently
6918 implemented.
6919 @end itemize
6920 As a GNU extension, weak symbols that do not specify an alternate symbol
6921 are supported.  If the symbol is undefined when linking, the symbol
6922 uses a default value.
6923 @end table
6925 @ifclear GENERIC
6926 @lowersections
6927 @end ifclear
6928 @end ifset
6930 @ifset XTENSA
6931 @ifclear GENERIC
6932 @raisesections
6933 @end ifclear
6935 @node Xtensa
6936 @section @code{ld} and Xtensa Processors
6938 @cindex Xtensa processors
6939 The default @command{ld} behavior for Xtensa processors is to interpret
6940 @code{SECTIONS} commands so that lists of explicitly named sections in a
6941 specification with a wildcard file will be interleaved when necessary to
6942 keep literal pools within the range of PC-relative load offsets.  For
6943 example, with the command:
6945 @smallexample
6946 SECTIONS
6948   .text : @{
6949     *(.literal .text)
6950   @}
6952 @end smallexample
6954 @noindent
6955 @command{ld} may interleave some of the @code{.literal}
6956 and @code{.text} sections from different object files to ensure that the
6957 literal pools are within the range of PC-relative load offsets.  A valid
6958 interleaving might place the @code{.literal} sections from an initial
6959 group of files followed by the @code{.text} sections of that group of
6960 files.  Then, the @code{.literal} sections from the rest of the files
6961 and the @code{.text} sections from the rest of the files would follow.
6963 @cindex @option{--relax} on Xtensa
6964 @cindex relaxing on Xtensa
6965 Relaxation is enabled by default for the Xtensa version of @command{ld} and
6966 provides two important link-time optimizations.  The first optimization
6967 is to combine identical literal values to reduce code size.  A redundant
6968 literal will be removed and all the @code{L32R} instructions that use it
6969 will be changed to reference an identical literal, as long as the
6970 location of the replacement literal is within the offset range of all
6971 the @code{L32R} instructions.  The second optimization is to remove
6972 unnecessary overhead from assembler-generated ``longcall'' sequences of
6973 @code{L32R}/@code{CALLX@var{n}} when the target functions are within
6974 range of direct @code{CALL@var{n}} instructions.
6976 For each of these cases where an indirect call sequence can be optimized
6977 to a direct call, the linker will change the @code{CALLX@var{n}}
6978 instruction to a @code{CALL@var{n}} instruction, remove the @code{L32R}
6979 instruction, and remove the literal referenced by the @code{L32R}
6980 instruction if it is not used for anything else.  Removing the
6981 @code{L32R} instruction always reduces code size but can potentially
6982 hurt performance by changing the alignment of subsequent branch targets.
6983 By default, the linker will always preserve alignments, either by
6984 switching some instructions between 24-bit encodings and the equivalent
6985 density instructions or by inserting a no-op in place of the @code{L32R}
6986 instruction that was removed.  If code size is more important than
6987 performance, the @option{--size-opt} option can be used to prevent the
6988 linker from widening density instructions or inserting no-ops, except in
6989 a few cases where no-ops are required for correctness.
6991 The following Xtensa-specific command-line options can be used to
6992 control the linker:
6994 @cindex Xtensa options
6995 @table @option
6996 @kindex --no-relax
6997 @item --no-relax
6998 Since the Xtensa version of @code{ld} enables the @option{--relax} option
6999 by default, the @option{--no-relax} option is provided to disable
7000 relaxation.
7002 @item --size-opt
7003 When optimizing indirect calls to direct calls, optimize for code size
7004 more than performance.  With this option, the linker will not insert
7005 no-ops or widen density instructions to preserve branch target
7006 alignment.  There may still be some cases where no-ops are required to
7007 preserve the correctness of the code.
7008 @end table
7010 @ifclear GENERIC
7011 @lowersections
7012 @end ifclear
7013 @end ifset
7015 @ifclear SingleFormat
7016 @node BFD
7017 @chapter BFD
7019 @cindex back end
7020 @cindex object file management
7021 @cindex object formats available
7022 @kindex objdump -i
7023 The linker accesses object and archive files using the BFD libraries.
7024 These libraries allow the linker to use the same routines to operate on
7025 object files whatever the object file format.  A different object file
7026 format can be supported simply by creating a new BFD back end and adding
7027 it to the library.  To conserve runtime memory, however, the linker and
7028 associated tools are usually configured to support only a subset of the
7029 object file formats available.  You can use @code{objdump -i}
7030 (@pxref{objdump,,objdump,binutils.info,The GNU Binary Utilities}) to
7031 list all the formats available for your configuration.
7033 @cindex BFD requirements
7034 @cindex requirements for BFD
7035 As with most implementations, BFD is a compromise between
7036 several conflicting requirements. The major factor influencing
7037 BFD design was efficiency: any time used converting between
7038 formats is time which would not have been spent had BFD not
7039 been involved. This is partly offset by abstraction payback; since
7040 BFD simplifies applications and back ends, more time and care
7041 may be spent optimizing algorithms for a greater speed.
7043 One minor artifact of the BFD solution which you should bear in
7044 mind is the potential for information loss.  There are two places where
7045 useful information can be lost using the BFD mechanism: during
7046 conversion and during output. @xref{BFD information loss}.
7048 @menu
7049 * BFD outline::                 How it works: an outline of BFD
7050 @end menu
7052 @node BFD outline
7053 @section How It Works: An Outline of BFD
7054 @cindex opening object files
7055 @include bfdsumm.texi
7056 @end ifclear
7058 @node Reporting Bugs
7059 @chapter Reporting Bugs
7060 @cindex bugs in @command{ld}
7061 @cindex reporting bugs in @command{ld}
7063 Your bug reports play an essential role in making @command{ld} reliable.
7065 Reporting a bug may help you by bringing a solution to your problem, or
7066 it may not.  But in any case the principal function of a bug report is
7067 to help the entire community by making the next version of @command{ld}
7068 work better.  Bug reports are your contribution to the maintenance of
7069 @command{ld}.
7071 In order for a bug report to serve its purpose, you must include the
7072 information that enables us to fix the bug.
7074 @menu
7075 * Bug Criteria::                Have you found a bug?
7076 * Bug Reporting::               How to report bugs
7077 @end menu
7079 @node Bug Criteria
7080 @section Have You Found a Bug?
7081 @cindex bug criteria
7083 If you are not sure whether you have found a bug, here are some guidelines:
7085 @itemize @bullet
7086 @cindex fatal signal
7087 @cindex linker crash
7088 @cindex crash of linker
7089 @item
7090 If the linker gets a fatal signal, for any input whatever, that is a
7091 @command{ld} bug.  Reliable linkers never crash.
7093 @cindex error on valid input
7094 @item
7095 If @command{ld} produces an error message for valid input, that is a bug.
7097 @cindex invalid input
7098 @item
7099 If @command{ld} does not produce an error message for invalid input, that
7100 may be a bug.  In the general case, the linker can not verify that
7101 object files are correct.
7103 @item
7104 If you are an experienced user of linkers, your suggestions for
7105 improvement of @command{ld} are welcome in any case.
7106 @end itemize
7108 @node Bug Reporting
7109 @section How to Report Bugs
7110 @cindex bug reports
7111 @cindex @command{ld} bugs, reporting
7113 A number of companies and individuals offer support for @sc{gnu}
7114 products.  If you obtained @command{ld} from a support organization, we
7115 recommend you contact that organization first.
7117 You can find contact information for many support companies and
7118 individuals in the file @file{etc/SERVICE} in the @sc{gnu} Emacs
7119 distribution.
7121 @ifset BUGURL
7122 Otherwise, send bug reports for @command{ld} to
7123 @value{BUGURL}.
7124 @end ifset
7126 The fundamental principle of reporting bugs usefully is this:
7127 @strong{report all the facts}.  If you are not sure whether to state a
7128 fact or leave it out, state it!
7130 Often people omit facts because they think they know what causes the
7131 problem and assume that some details do not matter.  Thus, you might
7132 assume that the name of a symbol you use in an example does not
7133 matter.  Well, probably it does not, but one cannot be sure.  Perhaps
7134 the bug is a stray memory reference which happens to fetch from the
7135 location where that name is stored in memory; perhaps, if the name
7136 were different, the contents of that location would fool the linker
7137 into doing the right thing despite the bug.  Play it safe and give a
7138 specific, complete example.  That is the easiest thing for you to do,
7139 and the most helpful.
7141 Keep in mind that the purpose of a bug report is to enable us to fix
7142 the bug if it is new to us.  Therefore, always write your bug reports
7143 on the assumption that the bug has not been reported previously.
7145 Sometimes people give a few sketchy facts and ask, ``Does this ring a
7146 bell?''  This cannot help us fix a bug, so it is basically useless.  We
7147 respond by asking for enough details to enable us to investigate.
7148 You might as well expedite matters by sending them to begin with.
7150 To enable us to fix the bug, you should include all these things:
7152 @itemize @bullet
7153 @item
7154 The version of @command{ld}.  @command{ld} announces it if you start it with
7155 the @samp{--version} argument.
7157 Without this, we will not know whether there is any point in looking for
7158 the bug in the current version of @command{ld}.
7160 @item
7161 Any patches you may have applied to the @command{ld} source, including any
7162 patches made to the @code{BFD} library.
7164 @item
7165 The type of machine you are using, and the operating system name and
7166 version number.
7168 @item
7169 What compiler (and its version) was used to compile @command{ld}---e.g.
7170 ``@code{gcc-2.7}''.
7172 @item
7173 The command arguments you gave the linker to link your example and
7174 observe the bug.  To guarantee you will not omit something important,
7175 list them all.  A copy of the Makefile (or the output from make) is
7176 sufficient.
7178 If we were to try to guess the arguments, we would probably guess wrong
7179 and then we might not encounter the bug.
7181 @item
7182 A complete input file, or set of input files, that will reproduce the
7183 bug.  It is generally most helpful to send the actual object files
7184 provided that they are reasonably small.  Say no more than 10K.  For
7185 bigger files you can either make them available by FTP or HTTP or else
7186 state that you are willing to send the object file(s) to whomever
7187 requests them.  (Note - your email will be going to a mailing list, so
7188 we do not want to clog it up with large attachments).  But small
7189 attachments are best.
7191 If the source files were assembled using @code{gas} or compiled using
7192 @code{gcc}, then it may be OK to send the source files rather than the
7193 object files.  In this case, be sure to say exactly what version of
7194 @code{gas} or @code{gcc} was used to produce the object files.  Also say
7195 how @code{gas} or @code{gcc} were configured.
7197 @item
7198 A description of what behavior you observe that you believe is
7199 incorrect.  For example, ``It gets a fatal signal.''
7201 Of course, if the bug is that @command{ld} gets a fatal signal, then we
7202 will certainly notice it.  But if the bug is incorrect output, we might
7203 not notice unless it is glaringly wrong.  You might as well not give us
7204 a chance to make a mistake.
7206 Even if the problem you experience is a fatal signal, you should still
7207 say so explicitly.  Suppose something strange is going on, such as, your
7208 copy of @command{ld} is out of sync, or you have encountered a bug in the
7209 C library on your system.  (This has happened!)  Your copy might crash
7210 and ours would not.  If you told us to expect a crash, then when ours
7211 fails to crash, we would know that the bug was not happening for us.  If
7212 you had not told us to expect a crash, then we would not be able to draw
7213 any conclusion from our observations.
7215 @item
7216 If you wish to suggest changes to the @command{ld} source, send us context
7217 diffs, as generated by @code{diff} with the @samp{-u}, @samp{-c}, or
7218 @samp{-p} option.  Always send diffs from the old file to the new file.
7219 If you even discuss something in the @command{ld} source, refer to it by
7220 context, not by line number.
7222 The line numbers in our development sources will not match those in your
7223 sources.  Your line numbers would convey no useful information to us.
7224 @end itemize
7226 Here are some things that are not necessary:
7228 @itemize @bullet
7229 @item
7230 A description of the envelope of the bug.
7232 Often people who encounter a bug spend a lot of time investigating
7233 which changes to the input file will make the bug go away and which
7234 changes will not affect it.
7236 This is often time consuming and not very useful, because the way we
7237 will find the bug is by running a single example under the debugger
7238 with breakpoints, not by pure deduction from a series of examples.
7239 We recommend that you save your time for something else.
7241 Of course, if you can find a simpler example to report @emph{instead}
7242 of the original one, that is a convenience for us.  Errors in the
7243 output will be easier to spot, running under the debugger will take
7244 less time, and so on.
7246 However, simplification is not vital; if you do not want to do this,
7247 report the bug anyway and send us the entire test case you used.
7249 @item
7250 A patch for the bug.
7252 A patch for the bug does help us if it is a good one.  But do not omit
7253 the necessary information, such as the test case, on the assumption that
7254 a patch is all we need.  We might see problems with your patch and decide
7255 to fix the problem another way, or we might not understand it at all.
7257 Sometimes with a program as complicated as @command{ld} it is very hard to
7258 construct an example that will make the program follow a certain path
7259 through the code.  If you do not send us the example, we will not be
7260 able to construct one, so we will not be able to verify that the bug is
7261 fixed.
7263 And if we cannot understand what bug you are trying to fix, or why your
7264 patch should be an improvement, we will not install it.  A test case will
7265 help us to understand.
7267 @item
7268 A guess about what the bug is or what it depends on.
7270 Such guesses are usually wrong.  Even we cannot guess right about such
7271 things without first using the debugger to find the facts.
7272 @end itemize
7274 @node MRI
7275 @appendix MRI Compatible Script Files
7276 @cindex MRI compatibility
7277 To aid users making the transition to @sc{gnu} @command{ld} from the MRI
7278 linker, @command{ld} can use MRI compatible linker scripts as an
7279 alternative to the more general-purpose linker scripting language
7280 described in @ref{Scripts}.  MRI compatible linker scripts have a much
7281 simpler command set than the scripting language otherwise used with
7282 @command{ld}.  @sc{gnu} @command{ld} supports the most commonly used MRI
7283 linker commands; these commands are described here.
7285 In general, MRI scripts aren't of much use with the @code{a.out} object
7286 file format, since it only has three sections and MRI scripts lack some
7287 features to make use of them.
7289 You can specify a file containing an MRI-compatible script using the
7290 @samp{-c} command-line option.
7292 Each command in an MRI-compatible script occupies its own line; each
7293 command line starts with the keyword that identifies the command (though
7294 blank lines are also allowed for punctuation).  If a line of an
7295 MRI-compatible script begins with an unrecognized keyword, @command{ld}
7296 issues a warning message, but continues processing the script.
7298 Lines beginning with @samp{*} are comments.
7300 You can write these commands using all upper-case letters, or all
7301 lower case; for example, @samp{chip} is the same as @samp{CHIP}.
7302 The following list shows only the upper-case form of each command.
7304 @table @code
7305 @cindex @code{ABSOLUTE} (MRI)
7306 @item ABSOLUTE @var{secname}
7307 @itemx ABSOLUTE @var{secname}, @var{secname}, @dots{} @var{secname}
7308 Normally, @command{ld} includes in the output file all sections from all
7309 the input files.  However, in an MRI-compatible script, you can use the
7310 @code{ABSOLUTE} command to restrict the sections that will be present in
7311 your output program.  If the @code{ABSOLUTE} command is used at all in a
7312 script, then only the sections named explicitly in @code{ABSOLUTE}
7313 commands will appear in the linker output.  You can still use other
7314 input sections (whatever you select on the command line, or using
7315 @code{LOAD}) to resolve addresses in the output file.
7317 @cindex @code{ALIAS} (MRI)
7318 @item ALIAS @var{out-secname}, @var{in-secname}
7319 Use this command to place the data from input section @var{in-secname}
7320 in a section called @var{out-secname} in the linker output file.
7322 @var{in-secname} may be an integer.
7324 @cindex @code{ALIGN} (MRI)
7325 @item ALIGN @var{secname} = @var{expression}
7326 Align the section called @var{secname} to @var{expression}.  The
7327 @var{expression} should be a power of two.
7329 @cindex @code{BASE} (MRI)
7330 @item BASE @var{expression}
7331 Use the value of @var{expression} as the lowest address (other than
7332 absolute addresses) in the output file.
7334 @cindex @code{CHIP} (MRI)
7335 @item CHIP @var{expression}
7336 @itemx CHIP @var{expression}, @var{expression}
7337 This command does nothing; it is accepted only for compatibility.
7339 @cindex @code{END} (MRI)
7340 @item END
7341 This command does nothing whatever; it's only accepted for compatibility.
7343 @cindex @code{FORMAT} (MRI)
7344 @item FORMAT @var{output-format}
7345 Similar to the @code{OUTPUT_FORMAT} command in the more general linker
7346 language, but restricted to one of these output formats:
7348 @enumerate
7349 @item
7350 S-records, if @var{output-format} is @samp{S}
7352 @item
7353 IEEE, if @var{output-format} is @samp{IEEE}
7355 @item
7356 COFF (the @samp{coff-m68k} variant in BFD), if @var{output-format} is
7357 @samp{COFF}
7358 @end enumerate
7360 @cindex @code{LIST} (MRI)
7361 @item LIST @var{anything}@dots{}
7362 Print (to the standard output file) a link map, as produced by the
7363 @command{ld} command-line option @samp{-M}.
7365 The keyword @code{LIST} may be followed by anything on the
7366 same line, with no change in its effect.
7368 @cindex @code{LOAD} (MRI)
7369 @item LOAD @var{filename}
7370 @itemx LOAD @var{filename}, @var{filename}, @dots{} @var{filename}
7371 Include one or more object file @var{filename} in the link; this has the
7372 same effect as specifying @var{filename} directly on the @command{ld}
7373 command line.
7375 @cindex @code{NAME} (MRI)
7376 @item NAME @var{output-name}
7377 @var{output-name} is the name for the program produced by @command{ld}; the
7378 MRI-compatible command @code{NAME} is equivalent to the command-line
7379 option @samp{-o} or the general script language command @code{OUTPUT}.
7381 @cindex @code{ORDER} (MRI)
7382 @item ORDER @var{secname}, @var{secname}, @dots{} @var{secname}
7383 @itemx ORDER @var{secname} @var{secname} @var{secname}
7384 Normally, @command{ld} orders the sections in its output file in the
7385 order in which they first appear in the input files.  In an MRI-compatible
7386 script, you can override this ordering with the @code{ORDER} command.  The
7387 sections you list with @code{ORDER} will appear first in your output
7388 file, in the order specified.
7390 @cindex @code{PUBLIC} (MRI)
7391 @item PUBLIC @var{name}=@var{expression}
7392 @itemx PUBLIC @var{name},@var{expression}
7393 @itemx PUBLIC @var{name} @var{expression}
7394 Supply a value (@var{expression}) for external symbol
7395 @var{name} used in the linker input files.
7397 @cindex @code{SECT} (MRI)
7398 @item SECT @var{secname}, @var{expression}
7399 @itemx SECT @var{secname}=@var{expression}
7400 @itemx SECT @var{secname} @var{expression}
7401 You can use any of these three forms of the @code{SECT} command to
7402 specify the start address (@var{expression}) for section @var{secname}.
7403 If you have more than one @code{SECT} statement for the same
7404 @var{secname}, only the @emph{first} sets the start address.
7405 @end table
7407 @node GNU Free Documentation License
7408 @appendix GNU Free Documentation License
7409 @include fdl.texi
7411 @node LD Index
7412 @unnumbered LD Index
7414 @printindex cp
7416 @tex
7417 % I think something like @colophon should be in texinfo.  In the
7418 % meantime:
7419 \long\def\colophon{\hbox to0pt{}\vfill
7420 \centerline{The body of this manual is set in}
7421 \centerline{\fontname\tenrm,}
7422 \centerline{with headings in {\bf\fontname\tenbf}}
7423 \centerline{and examples in {\tt\fontname\tentt}.}
7424 \centerline{{\it\fontname\tenit\/} and}
7425 \centerline{{\sl\fontname\tensl\/}}
7426 \centerline{are used for emphasis.}\vfill}
7427 \page\colophon
7428 % Blame: doc@cygnus.com, 28mar91.
7429 @end tex
7431 @bye