summaryrefslogtreecommitdiff
path: root/share/doc/ld.html
diff options
context:
space:
mode:
Diffstat (limited to 'share/doc/ld.html')
-rw-r--r--share/doc/ld.html11908
1 files changed, 11908 insertions, 0 deletions
diff --git a/share/doc/ld.html b/share/doc/ld.html
new file mode 100644
index 0000000..92f6b62
--- /dev/null
+++ b/share/doc/ld.html
@@ -0,0 +1,11908 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
+<html>
+<!-- This file documents the GNU linker LD
+(Arm GNU Toolchain 13.2.rel1 (Build arm-13.7))
+version 2.41.0.
+
+Copyright (C) 1991-2023 Free Software Foundation, Inc.
+
+Permission is granted to copy, distribute and/or modify this document
+under the terms of the GNU Free Documentation License, Version 1.3
+or any later version published by the Free Software Foundation;
+with no Invariant Sections, with no Front-Cover Texts, and with no
+Back-Cover Texts. A copy of the license is included in the
+section entitled "GNU Free Documentation License". -->
+<!-- Created by GNU Texinfo 5.1, http://www.gnu.org/software/texinfo/ -->
+<head>
+<title>LD</title>
+
+<meta name="description" content="LD">
+<meta name="keywords" content="LD">
+<meta name="resource-type" content="document">
+<meta name="distribution" content="global">
+<meta name="Generator" content="makeinfo">
+<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
+<link href="#Top" rel="start" title="Top">
+<link href="#LD-Index" rel="index" title="LD Index">
+<link href="#SEC_Contents" rel="contents" title="Table of Contents">
+<link href="dir.html#Top" rel="up" title="(dir)">
+<style type="text/css">
+<!--
+a.summary-letter {text-decoration: none}
+blockquote.smallquotation {font-size: smaller}
+div.display {margin-left: 3.2em}
+div.example {margin-left: 3.2em}
+div.indentedblock {margin-left: 3.2em}
+div.lisp {margin-left: 3.2em}
+div.smalldisplay {margin-left: 3.2em}
+div.smallexample {margin-left: 3.2em}
+div.smallindentedblock {margin-left: 3.2em; font-size: smaller}
+div.smalllisp {margin-left: 3.2em}
+kbd {font-style:oblique}
+pre.display {font-family: inherit}
+pre.format {font-family: inherit}
+pre.menu-comment {font-family: serif}
+pre.menu-preformatted {font-family: serif}
+pre.smalldisplay {font-family: inherit; font-size: smaller}
+pre.smallexample {font-size: smaller}
+pre.smallformat {font-family: inherit; font-size: smaller}
+pre.smalllisp {font-size: smaller}
+span.nocodebreak {white-space:nowrap}
+span.nolinebreak {white-space:nowrap}
+span.roman {font-family:serif; font-weight:normal}
+span.sansserif {font-family:sans-serif; font-weight:normal}
+ul.no-bullet {list-style: none}
+-->
+</style>
+
+
+</head>
+
+<body lang="en" bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000">
+
+
+
+
+
+
+
+
+
+<a name="SEC_Contents"></a>
+<h2 class="contents-heading">Table of Contents</h2>
+
+<div class="contents">
+
+<ul class="no-bullet">
+ <li><a name="toc-Overview-1" href="#Overview">1 Overview</a></li>
+ <li><a name="toc-Invocation-1" href="#Invocation">2 Invocation</a>
+ <ul class="no-bullet">
+ <li><a name="toc-Command_002dline-Options" href="#Options">2.1 Command-line Options</a>
+ <ul class="no-bullet">
+ <li><a name="toc-Options-Specific-to-i386-PE-Targets" href="#Options-Specific-to-i386-PE-Targets">2.1.1 Options Specific to i386 PE Targets</a></li>
+ <li><a name="toc-Options-specific-to-C6X-uClinux-targets" href="#Options-specific-to-C6X-uClinux-targets">2.1.2 Options specific to C6X uClinux targets</a></li>
+ <li><a name="toc-Options-specific-to-C_002dSKY-targets" href="#Options-specific-to-C_002dSKY-targets">2.1.3 Options specific to C-SKY targets</a></li>
+ <li><a name="toc-Options-specific-to-Motorola-68HC11-and-68HC12-targets" href="#Options-specific-to-Motorola-68HC11-and-68HC12-targets">2.1.4 Options specific to Motorola 68HC11 and 68HC12 targets</a></li>
+ <li><a name="toc-Options-specific-to-Motorola-68K-target" href="#Options-specific-to-Motorola-68K-target">2.1.5 Options specific to Motorola 68K target</a></li>
+ <li><a name="toc-Options-specific-to-MIPS-targets" href="#Options-specific-to-MIPS-targets">2.1.6 Options specific to MIPS targets</a></li>
+ <li><a name="toc-Options-specific-to-PDP11-targets" href="#Options-specific-to-PDP11-targets">2.1.7 Options specific to PDP11 targets</a></li>
+ </ul></li>
+ <li><a name="toc-Environment-Variables" href="#Environment">2.2 Environment Variables</a></li>
+ </ul></li>
+ <li><a name="toc-Linker-Scripts" href="#Scripts">3 Linker Scripts</a>
+ <ul class="no-bullet">
+ <li><a name="toc-Basic-Linker-Script-Concepts" href="#Basic-Script-Concepts">3.1 Basic Linker Script Concepts</a></li>
+ <li><a name="toc-Linker-Script-Format" href="#Script-Format">3.2 Linker Script Format</a></li>
+ <li><a name="toc-Simple-Linker-Script-Example" href="#Simple-Example">3.3 Simple Linker Script Example</a></li>
+ <li><a name="toc-Simple-Linker-Script-Commands" href="#Simple-Commands">3.4 Simple Linker Script Commands</a>
+ <ul class="no-bullet">
+ <li><a name="toc-Setting-the-Entry-Point" href="#Entry-Point">3.4.1 Setting the Entry Point</a></li>
+ <li><a name="toc-Commands-Dealing-with-Files" href="#File-Commands">3.4.2 Commands Dealing with Files</a></li>
+ <li><a name="toc-Commands-Dealing-with-Object-File-Formats" href="#Format-Commands">3.4.3 Commands Dealing with Object File Formats</a></li>
+ <li><a name="toc-Assign-alias-names-to-memory-regions" href="#REGION_005fALIAS">3.4.4 Assign alias names to memory regions</a></li>
+ <li><a name="toc-Other-Linker-Script-Commands" href="#Miscellaneous-Commands">3.4.5 Other Linker Script Commands</a></li>
+ </ul></li>
+ <li><a name="toc-Assigning-Values-to-Symbols" href="#Assignments">3.5 Assigning Values to Symbols</a>
+ <ul class="no-bullet">
+ <li><a name="toc-Simple-Assignments-1" href="#Simple-Assignments">3.5.1 Simple Assignments</a></li>
+ <li><a name="toc-HIDDEN-1" href="#HIDDEN">3.5.2 HIDDEN</a></li>
+ <li><a name="toc-PROVIDE-1" href="#PROVIDE">3.5.3 PROVIDE</a></li>
+ <li><a name="toc-PROVIDE_005fHIDDEN-1" href="#PROVIDE_005fHIDDEN">3.5.4 PROVIDE_HIDDEN</a></li>
+ <li><a name="toc-Source-Code-Reference-1" href="#Source-Code-Reference">3.5.5 Source Code Reference</a></li>
+ </ul></li>
+ <li><a name="toc-SECTIONS-Command" href="#SECTIONS">3.6 SECTIONS Command</a>
+ <ul class="no-bullet">
+ <li><a name="toc-Output-Section-Description-1" href="#Output-Section-Description">3.6.1 Output Section Description</a></li>
+ <li><a name="toc-Output-Section-Name-1" href="#Output-Section-Name">3.6.2 Output Section Name</a></li>
+ <li><a name="toc-Output-Section-Address-1" href="#Output-Section-Address">3.6.3 Output Section Address</a></li>
+ <li><a name="toc-Input-Section-Description" href="#Input-Section">3.6.4 Input Section Description</a>
+ <ul class="no-bullet">
+ <li><a name="toc-Input-Section-Basics-1" href="#Input-Section-Basics">3.6.4.1 Input Section Basics</a></li>
+ <li><a name="toc-Input-Section-Wildcard-Patterns" href="#Input-Section-Wildcards">3.6.4.2 Input Section Wildcard Patterns</a></li>
+ <li><a name="toc-Input-Section-for-Common-Symbols" href="#Input-Section-Common">3.6.4.3 Input Section for Common Symbols</a></li>
+ <li><a name="toc-Input-Section-and-Garbage-Collection" href="#Input-Section-Keep">3.6.4.4 Input Section and Garbage Collection</a></li>
+ <li><a name="toc-Input-Section-Example-1" href="#Input-Section-Example">3.6.4.5 Input Section Example</a></li>
+ </ul></li>
+ <li><a name="toc-Output-Section-Data-1" href="#Output-Section-Data">3.6.5 Output Section Data</a></li>
+ <li><a name="toc-Output-Section-Keywords-1" href="#Output-Section-Keywords">3.6.6 Output Section Keywords</a></li>
+ <li><a name="toc-Output-Section-Discarding-1" href="#Output-Section-Discarding">3.6.7 Output Section Discarding</a></li>
+ <li><a name="toc-Output-Section-Attributes-1" href="#Output-Section-Attributes">3.6.8 Output Section Attributes</a>
+ <ul class="no-bullet">
+ <li><a name="toc-Output-Section-Type-1" href="#Output-Section-Type">3.6.8.1 Output Section Type</a></li>
+ <li><a name="toc-Output-Section-LMA-1" href="#Output-Section-LMA">3.6.8.2 Output Section LMA</a></li>
+ <li><a name="toc-Forced-Output-Alignment-1" href="#Forced-Output-Alignment">3.6.8.3 Forced Output Alignment</a></li>
+ <li><a name="toc-Forced-Input-Alignment-1" href="#Forced-Input-Alignment">3.6.8.4 Forced Input Alignment</a></li>
+ <li><a name="toc-Output-Section-Constraint-1" href="#Output-Section-Constraint">3.6.8.5 Output Section Constraint</a></li>
+ <li><a name="toc-Output-Section-Region-1" href="#Output-Section-Region">3.6.8.6 Output Section Region</a></li>
+ <li><a name="toc-Output-Section-Phdr-1" href="#Output-Section-Phdr">3.6.8.7 Output Section Phdr</a></li>
+ <li><a name="toc-Output-Section-Fill-1" href="#Output-Section-Fill">3.6.8.8 Output Section Fill</a></li>
+ </ul></li>
+ <li><a name="toc-Overlay-Description-1" href="#Overlay-Description">3.6.9 Overlay Description</a></li>
+ </ul></li>
+ <li><a name="toc-MEMORY-Command" href="#MEMORY">3.7 MEMORY Command</a></li>
+ <li><a name="toc-PHDRS-Command" href="#PHDRS">3.8 PHDRS Command</a></li>
+ <li><a name="toc-VERSION-Command" href="#VERSION">3.9 VERSION Command</a></li>
+ <li><a name="toc-Expressions-in-Linker-Scripts" href="#Expressions">3.10 Expressions in Linker Scripts</a>
+ <ul class="no-bullet">
+ <li><a name="toc-Constants-1" href="#Constants">3.10.1 Constants</a></li>
+ <li><a name="toc-Symbolic-Constants-1" href="#Symbolic-Constants">3.10.2 Symbolic Constants</a></li>
+ <li><a name="toc-Symbol-Names" href="#Symbols">3.10.3 Symbol Names</a></li>
+ <li><a name="toc-Orphan-Sections-1" href="#Orphan-Sections">3.10.4 Orphan Sections</a></li>
+ <li><a name="toc-The-Location-Counter" href="#Location-Counter">3.10.5 The Location Counter</a></li>
+ <li><a name="toc-Operators-1" href="#Operators">3.10.6 Operators</a></li>
+ <li><a name="toc-Evaluation-1" href="#Evaluation">3.10.7 Evaluation</a></li>
+ <li><a name="toc-The-Section-of-an-Expression" href="#Expression-Section">3.10.8 The Section of an Expression</a></li>
+ <li><a name="toc-Builtin-Functions-1" href="#Builtin-Functions">3.10.9 Builtin Functions</a></li>
+ </ul></li>
+ <li><a name="toc-Implicit-Linker-Scripts-1" href="#Implicit-Linker-Scripts">3.11 Implicit Linker Scripts</a></li>
+ </ul></li>
+ <li><a name="toc-Linker-Plugins" href="#Plugins">4 Linker Plugins</a>
+ <ul class="no-bullet">
+ <li><a name="toc-Static-Library-Dependencies-Plugin" href="#libdep-Plugin">4.1 Static Library Dependencies Plugin</a></li>
+ </ul></li>
+ <li><a name="toc-Machine-Dependent-Features" href="#Machine-Dependent">5 Machine Dependent Features</a>
+ <ul class="no-bullet">
+ <li><a name="toc-ld-and-the-H8_002f300" href="#H8_002f300">5.1 <code>ld</code> and the H8/300</a></li>
+ <li><a name="toc-ld-and-the-Motorola-68HC11-and-68HC12-families" href="#M68HC11_002f68HC12">5.2 <code>ld</code> and the Motorola 68HC11 and 68HC12 families</a>
+ <ul class="no-bullet">
+ <li><a name="toc-Linker-Relaxation" href="#Linker-Relaxation">5.2.1 Linker Relaxation</a></li>
+ <li><a name="toc-Trampoline-Generation" href="#Trampoline-Generation">5.2.2 Trampoline Generation</a></li>
+ </ul></li>
+ <li><a name="toc-ld-and-the-ARM-family" href="#ARM">5.3 <code>ld</code> and the ARM family</a></li>
+ <li><a name="toc-ld-and-HPPA-32_002dbit-ELF-Support" href="#HPPA-ELF32">5.4 <code>ld</code> and HPPA 32-bit ELF Support</a></li>
+ <li><a name="toc-ld-and-the-Motorola-68K-family" href="#M68K">5.5 <code>ld</code> and the Motorola 68K family</a></li>
+ <li><a name="toc-ld-and-the-MIPS-family" href="#MIPS">5.6 <code>ld</code> and the MIPS family</a></li>
+ <li><a name="toc-ld-and-MMIX" href="#MMIX">5.7 <code>ld</code> and MMIX</a></li>
+ <li><a name="toc-ld-and-MSP430" href="#MSP430">5.8 <code>ld</code> and MSP430</a></li>
+ <li><a name="toc-ld-and-NDS32" href="#NDS32">5.9 <code>ld</code> and NDS32</a></li>
+ <li><a name="toc-ld-and-the-Altera-Nios-II" href="#Nios-II">5.10 <code>ld</code> and the Altera Nios II</a></li>
+ <li><a name="toc-ld-and-PowerPC-32_002dbit-ELF-Support" href="#PowerPC-ELF32">5.11 <code>ld</code> and PowerPC 32-bit ELF Support</a></li>
+ <li><a name="toc-ld-and-PowerPC64-64_002dbit-ELF-Support" href="#PowerPC64-ELF64">5.12 <code>ld</code> and PowerPC64 64-bit ELF Support</a></li>
+ <li><a name="toc-ld-and-S_002f390-ELF-Support" href="#S_002f390-ELF">5.13 <code>ld</code> and S/390 ELF Support</a></li>
+ <li><a name="toc-ld-and-SPU-ELF-Support" href="#SPU-ELF">5.14 <code>ld</code> and SPU ELF Support</a></li>
+ <li><a name="toc-ld_0027s-Support-for-Various-TI-COFF-Versions" href="#TI-COFF">5.15 <code>ld</code>&rsquo;s Support for Various TI COFF Versions</a></li>
+ <li><a name="toc-ld-and-WIN32-_0028cygwin_002fmingw_0029" href="#WIN32">5.16 <code>ld</code> and WIN32 (cygwin/mingw)</a></li>
+ <li><a name="toc-ld-and-Xtensa-Processors" href="#Xtensa">5.17 <code>ld</code> and Xtensa Processors</a></li>
+ </ul></li>
+ <li><a name="toc-BFD-1" href="#BFD">6 BFD</a>
+ <ul class="no-bullet">
+ <li><a name="toc-How-It-Works_003a-An-Outline-of-BFD" href="#BFD-outline">6.1 How It Works: An Outline of BFD</a>
+ <ul class="no-bullet">
+ <li><a name="toc-Information-Loss" href="#BFD-information-loss">6.1.1 Information Loss</a></li>
+ <li><a name="toc-The-BFD-canonical-object_002dfile-format" href="#Canonical-format">6.1.2 The BFD canonical object-file format</a></li>
+ </ul></li>
+ </ul></li>
+ <li><a name="toc-Reporting-Bugs-1" href="#Reporting-Bugs">7 Reporting Bugs</a>
+ <ul class="no-bullet">
+ <li><a name="toc-Have-You-Found-a-Bug_003f" href="#Bug-Criteria">7.1 Have You Found a Bug?</a></li>
+ <li><a name="toc-How-to-Report-Bugs" href="#Bug-Reporting">7.2 How to Report Bugs</a></li>
+ </ul></li>
+ <li><a name="toc-MRI-Compatible-Script-Files" href="#MRI">Appendix A MRI Compatible Script Files</a></li>
+ <li><a name="toc-GNU-Free-Documentation-License-1" href="#GNU-Free-Documentation-License">Appendix B GNU Free Documentation License</a></li>
+ <li><a name="toc-LD-Index-1" href="#LD-Index">LD Index</a></li>
+</ul>
+</div>
+
+
+<a name="Top"></a>
+<div class="header">
+<p>
+Next: <a href="#Overview" accesskey="n" rel="next">Overview</a>, Up: <a href="dir.html#Top" accesskey="u" rel="up">(dir)</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="LD"></a>
+<h1 class="top">LD</h1>
+<p>This file documents the <small>GNU</small> linker ld
+(Arm GNU Toolchain 13.2.rel1 (Build arm-13.7))
+version 2.41.0.
+</p>
+<p>This document is distributed under the terms of the GNU Free
+Documentation License version 1.3. A copy of the license is included
+in the section entitled &ldquo;GNU Free Documentation License&rdquo;.
+</p>
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#Overview" accesskey="1">Overview</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Overview
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Invocation" accesskey="2">Invocation</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Invocation
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Scripts" accesskey="3">Scripts</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Linker Scripts
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Plugins" accesskey="4">Plugins</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Linker Plugins
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Machine-Dependent" accesskey="5">Machine Dependent</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Machine Dependent Features
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#BFD" accesskey="6">BFD</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">BFD
+</td></tr>
+<tr><th colspan="3" align="left" valign="top"><pre class="menu-comment">
+</pre></th></tr><tr><td align="left" valign="top">&bull; <a href="#Reporting-Bugs" accesskey="7">Reporting Bugs</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Reporting Bugs
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#MRI" accesskey="8">MRI</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">MRI Compatible Script Files
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#GNU-Free-Documentation-License" accesskey="9">GNU Free Documentation License</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">GNU Free Documentation License
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#LD-Index">LD Index</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">LD Index
+</td></tr>
+</table>
+
+<hr>
+<a name="Overview"></a>
+<div class="header">
+<p>
+Next: <a href="#Invocation" accesskey="n" rel="next">Invocation</a>, Previous: <a href="#Top" accesskey="p" rel="previous">Top</a>, Up: <a href="#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Overview-1"></a>
+<h2 class="chapter">1 Overview</h2>
+
+<a name="index-GNU-linker"></a>
+<a name="index-what-is-this_003f"></a>
+
+
+
+<p><code>ld</code> combines a number of object and archive files, relocates
+their data and ties up symbol references. Usually the last step in
+compiling a program is to run <code>ld</code>.
+</p>
+<p><code>ld</code> accepts Linker Command Language files written in
+a superset of AT&amp;T&rsquo;s Link Editor Command Language syntax,
+to provide explicit and total control over the linking process.
+</p>
+
+<p>This version of <code>ld</code> uses the general purpose BFD libraries
+to operate on object files. This allows <code>ld</code> to read, combine, and
+write object files in many different formats&mdash;for example, COFF or
+<code>a.out</code>. Different formats may be linked together to produce any
+available kind of object file. See <a href="#BFD">BFD</a>, for more information.
+</p>
+<p>Aside from its flexibility, the <small>GNU</small> linker is more helpful than other
+linkers in providing diagnostic information. Many linkers abandon
+execution immediately upon encountering an error; whenever possible,
+<code>ld</code> continues executing, allowing you to identify other errors
+(or, in some cases, to get an output file in spite of the error).
+</p>
+
+<hr>
+<a name="Invocation"></a>
+<div class="header">
+<p>
+Next: <a href="#Scripts" accesskey="n" rel="next">Scripts</a>, Previous: <a href="#Overview" accesskey="p" rel="previous">Overview</a>, Up: <a href="#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Invocation-1"></a>
+<h2 class="chapter">2 Invocation</h2>
+
+
+<p>The <small>GNU</small> linker <code>ld</code> is meant to cover a broad range of situations,
+and to be as compatible as possible with other linkers. As a result,
+you have many choices to control its behavior.
+</p>
+
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#Options" accesskey="1">Options</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Command-line Options
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Environment" accesskey="2">Environment</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Environment Variables
+</td></tr>
+</table>
+
+<hr>
+<a name="Options"></a>
+<div class="header">
+<p>
+Next: <a href="#Environment" accesskey="n" rel="next">Environment</a>, Up: <a href="#Invocation" accesskey="u" rel="up">Invocation</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Command_002dline-Options"></a>
+<h3 class="section">2.1 Command-line Options</h3>
+
+<a name="index-command-line"></a>
+<a name="index-options"></a>
+
+
+<p>The linker supports a plethora of command-line options, but in actual
+practice few of them are used in any particular context.
+<a name="index-standard-Unix-system"></a>
+For instance, a frequent use of <code>ld</code> is to link standard Unix
+object files on a standard, supported Unix system. On such a system, to
+link a file <code>hello.o</code>:
+</p>
+<div class="smallexample">
+<pre class="smallexample">ld -o <var>output</var> /lib/crt0.o hello.o -lc
+</pre></div>
+
+<p>This tells <code>ld</code> to produce a file called <var>output</var> as the
+result of linking the file <code>/lib/crt0.o</code> with <code>hello.o</code> and
+the library <code>libc.a</code>, which will come from the standard search
+directories. (See the discussion of the &lsquo;<samp>-l</samp>&rsquo; option below.)
+</p>
+<p>Some of the command-line options to <code>ld</code> may be specified at any
+point in the command line. However, options which refer to files, such
+as &lsquo;<samp>-l</samp>&rsquo; or &lsquo;<samp>-T</samp>&rsquo;, cause the file to be read at the point at
+which the option appears in the command line, relative to the object
+files and other file options. Repeating non-file options with a
+different argument will either have no further effect, or override prior
+occurrences (those further to the left on the command line) of that
+option. Options which may be meaningfully specified more than once are
+noted in the descriptions below.
+</p>
+<a name="index-object-files"></a>
+<p>Non-option arguments are object files or archives which are to be linked
+together. They may follow, precede, or be mixed in with command-line
+options, except that an object file argument may not be placed between
+an option and its argument.
+</p>
+<p>Usually the linker is invoked with at least one object file, but you can
+specify other forms of binary input files using &lsquo;<samp>-l</samp>&rsquo;, &lsquo;<samp>-R</samp>&rsquo;,
+and the script command language. If <em>no</em> binary input files at all
+are specified, the linker does not produce any output, and issues the
+message &lsquo;<samp>No input files</samp>&rsquo;.
+</p>
+<p>If the linker cannot recognize the format of an object file, it will
+assume that it is a linker script. A script specified in this way
+augments the main linker script used for the link (either the default
+linker script or the one specified by using &lsquo;<samp>-T</samp>&rsquo;). This feature
+permits the linker to link against a file which appears to be an object
+or an archive, but actually merely defines some symbol values, or uses
+<code>INPUT</code> or <code>GROUP</code> to load other objects. Specifying a
+script in this way merely augments the main linker script, with the
+extra commands placed after the main script; use the &lsquo;<samp>-T</samp>&rsquo; option
+to replace the default linker script entirely, but note the effect of
+the <code>INSERT</code> command. See <a href="#Scripts">Scripts</a>.
+</p>
+<p>For options whose names are a single letter,
+option arguments must either follow the option letter without intervening
+whitespace, or be given as separate arguments immediately following the
+option that requires them.
+</p>
+<p>For options whose names are multiple letters, either one dash or two can
+precede the option name; for example, &lsquo;<samp>-trace-symbol</samp>&rsquo; and
+&lsquo;<samp>--trace-symbol</samp>&rsquo; are equivalent. Note&mdash;there is one exception to
+this rule. Multiple letter options that start with a lower case &rsquo;o&rsquo; can
+only be preceded by two dashes. This is to reduce confusion with the
+&lsquo;<samp>-o</samp>&rsquo; option. So for example &lsquo;<samp>-omagic</samp>&rsquo; sets the output file
+name to &lsquo;<samp>magic</samp>&rsquo; whereas &lsquo;<samp>--omagic</samp>&rsquo; sets the NMAGIC flag on the
+output.
+</p>
+<p>Arguments to multiple-letter options must either be separated from the
+option name by an equals sign, or be given as separate arguments
+immediately following the option that requires them. For example,
+&lsquo;<samp>--trace-symbol foo</samp>&rsquo; and &lsquo;<samp>--trace-symbol=foo</samp>&rsquo; are equivalent.
+Unique abbreviations of the names of multiple-letter options are
+accepted.
+</p>
+<p>Note&mdash;if the linker is being invoked indirectly, via a compiler driver
+(e.g. &lsquo;<samp>gcc</samp>&rsquo;) then all the linker command-line options should be
+prefixed by &lsquo;<samp>-Wl,</samp>&rsquo; (or whatever is appropriate for the particular
+compiler driver) like this:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> gcc -Wl,--start-group foo.o bar.o -Wl,--end-group
+</pre></div>
+
+<p>This is important, because otherwise the compiler driver program may
+silently drop the linker options, resulting in a bad link. Confusion
+may also arise when passing options that require values through a
+driver, as the use of a space between option and argument acts as
+a separator, and causes the driver to pass only the option to the linker
+and the argument to the compiler. In this case, it is simplest to use
+the joined forms of both single- and multiple-letter options, such as:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> gcc foo.o bar.o -Wl,-eENTRY -Wl,-Map=a.map
+</pre></div>
+
+<p>Here is a table of the generic command-line switches accepted by the GNU
+linker:
+</p>
+<dl compact="compact">
+<dt><code>@<var>file</var></code></dt>
+<dd><p>Read command-line options from <var>file</var>. The options read are
+inserted in place of the original @<var>file</var> option. If <var>file</var>
+does not exist, or cannot be read, then the option will be treated
+literally, and not removed.
+</p>
+<p>Options in <var>file</var> are separated by whitespace. A whitespace
+character may be included in an option by surrounding the entire
+option in either single or double quotes. Any character (including a
+backslash) may be included by prefixing the character to be included
+with a backslash. The <var>file</var> may itself contain additional
+@<var>file</var> options; any such options will be processed recursively.
+</p>
+<a name="index-_002da-keyword"></a>
+</dd>
+<dt><code>-a <var>keyword</var></code></dt>
+<dd><p>This option is supported for HP/UX compatibility. The <var>keyword</var>
+argument must be one of the strings &lsquo;<samp>archive</samp>&rsquo;, &lsquo;<samp>shared</samp>&rsquo;, or
+&lsquo;<samp>default</samp>&rsquo;. &lsquo;<samp>-aarchive</samp>&rsquo; is functionally equivalent to
+&lsquo;<samp>-Bstatic</samp>&rsquo;, and the other two keywords are functionally equivalent
+to &lsquo;<samp>-Bdynamic</samp>&rsquo;. This option may be used any number of times.
+</p>
+<a name="index-_002d_002daudit-AUDITLIB"></a>
+</dd>
+<dt><code>--audit <var>AUDITLIB</var></code></dt>
+<dd><p>Adds <var>AUDITLIB</var> to the <code>DT_AUDIT</code> entry of the dynamic section.
+<var>AUDITLIB</var> is not checked for existence, nor will it use the DT_SONAME
+specified in the library. If specified multiple times <code>DT_AUDIT</code>
+will contain a colon separated list of audit interfaces to use. If the linker
+finds an object with an audit entry while searching for shared libraries,
+it will add a corresponding <code>DT_DEPAUDIT</code> entry in the output file.
+This option is only meaningful on ELF platforms supporting the rtld-audit
+interface.
+</p>
+<a name="index-binary-input-format"></a>
+<a name="index-_002db-format"></a>
+<a name="index-_002d_002dformat_003dformat"></a>
+<a name="index-input-format"></a>
+<a name="index-input-format-1"></a>
+</dd>
+<dt><code>-b <var>input-format</var></code></dt>
+<dt><code>--format=<var>input-format</var></code></dt>
+<dd><p><code>ld</code> may be configured to support more than one kind of object
+file. If your <code>ld</code> is configured this way, you can use the
+&lsquo;<samp>-b</samp>&rsquo; option to specify the binary format for input object files
+that follow this option on the command line. Even when <code>ld</code> is
+configured to support alternative object formats, you don&rsquo;t usually need
+to specify this, as <code>ld</code> should be configured to expect as a
+default input format the most usual format on each machine.
+<var>input-format</var> is a text string, the name of a particular format
+supported by the BFD libraries. (You can list the available binary
+formats with &lsquo;<samp>objdump -i</samp>&rsquo;.)
+See <a href="#BFD">BFD</a>.
+</p>
+<p>You may want to use this option if you are linking files with an unusual
+binary format. You can also use &lsquo;<samp>-b</samp>&rsquo; to switch formats explicitly (when
+linking object files of different formats), by including
+&lsquo;<samp>-b <var>input-format</var></samp>&rsquo; before each group of object files in a
+particular format.
+</p>
+<p>The default format is taken from the environment variable
+<code>GNUTARGET</code>.
+See <a href="#Environment">Environment</a>.
+You can also define the input format from a script, using the command
+<code>TARGET</code>;
+see <a href="#Format-Commands">Format Commands</a>.
+</p>
+<a name="index-_002dc-MRI_002dcmdfile"></a>
+<a name="index-_002d_002dmri_002dscript_003dMRI_002dcmdfile"></a>
+<a name="index-compatibility_002c-MRI"></a>
+</dd>
+<dt><code>-c <var>MRI-commandfile</var></code></dt>
+<dt><code>--mri-script=<var>MRI-commandfile</var></code></dt>
+<dd><p>For compatibility with linkers produced by MRI, <code>ld</code> accepts script
+files written in an alternate, restricted command language, described in
+<a href="#MRI">MRI Compatible Script Files</a>.
+Introduce MRI script files with
+the option &lsquo;<samp>-c</samp>&rsquo;; use the &lsquo;<samp>-T</samp>&rsquo; option to run linker
+scripts written in the general-purpose <code>ld</code> scripting language.
+If <var>MRI-cmdfile</var> does not exist, <code>ld</code> looks for it in the directories
+specified by any &lsquo;<samp>-L</samp>&rsquo; options.
+</p>
+<a name="index-common-allocation"></a>
+<a name="index-_002dd"></a>
+<a name="index-_002ddc"></a>
+<a name="index-_002ddp"></a>
+</dd>
+<dt><code>-d</code></dt>
+<dt><code>-dc</code></dt>
+<dt><code>-dp</code></dt>
+<dd><p>These three options are equivalent; multiple forms are supported for
+compatibility with other linkers. They assign space to common symbols
+even if a relocatable output file is specified (with &lsquo;<samp>-r</samp>&rsquo;). The
+script command <code>FORCE_COMMON_ALLOCATION</code> has the same effect.
+See <a href="#Miscellaneous-Commands">Miscellaneous Commands</a>.
+</p>
+<a name="index-_002d_002ddepaudit-AUDITLIB"></a>
+<a name="index-_002dP-AUDITLIB"></a>
+</dd>
+<dt><code>--depaudit <var>AUDITLIB</var></code></dt>
+<dt><code>-P <var>AUDITLIB</var></code></dt>
+<dd><p>Adds <var>AUDITLIB</var> to the <code>DT_DEPAUDIT</code> entry of the dynamic section.
+<var>AUDITLIB</var> is not checked for existence, nor will it use the DT_SONAME
+specified in the library. If specified multiple times <code>DT_DEPAUDIT</code>
+will contain a colon separated list of audit interfaces to use. This
+option is only meaningful on ELF platforms supporting the rtld-audit interface.
+The -P option is provided for Solaris compatibility.
+</p>
+<a name="index-_002d_002denable_002dlinker_002dversion"></a>
+</dd>
+<dt><code>--enable-linker-version</code></dt>
+<dd><p>Enables the <code>LINKER_VERSION</code> linker script directive, described
+in <a href="#Output-Section-Data">Output Section Data</a>. If this directive is used in a linker
+script and this option has been enabled then a string containing the
+linker version will be inserted at the current point.
+</p>
+<p>Note - this location of this option on the linker command line is
+significant. It will only affect linker scripts that come after it on
+the command line, or which are built into the linker.
+</p>
+<a name="index-_002d_002ddisable_002dlinker_002dversion"></a>
+</dd>
+<dt><code>--disable-linker-version</code></dt>
+<dd><p>Disables the <code>LINKER_VERSION</code> linker script directive, so that it
+does not insert a version string. This is the default.
+</p>
+<a name="index-_002d_002denable_002dnon_002dcontiguous_002dregions"></a>
+</dd>
+<dt><code>--enable-non-contiguous-regions</code></dt>
+<dd><p>This option avoids generating an error if an input section does not
+fit a matching output section. The linker tries to allocate the input
+section to subseque nt matching output sections, and generates an
+error only if no output section is large enough. This is useful when
+several non-contiguous memory regions are available and the input
+section does not require a particular one. The order in which input
+sections are evaluated does not change, for instance:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> MEMORY {
+ MEM1 (rwx) : ORIGIN = 0x1000, LENGTH = 0x14
+ MEM2 (rwx) : ORIGIN = 0x1000, LENGTH = 0x40
+ MEM3 (rwx) : ORIGIN = 0x2000, LENGTH = 0x40
+ }
+ SECTIONS {
+ mem1 : { *(.data.*); } &gt; MEM1
+ mem2 : { *(.data.*); } &gt; MEM2
+ mem3 : { *(.data.*); } &gt; MEM3
+ }
+
+ with input sections:
+ .data.1: size 8
+ .data.2: size 0x10
+ .data.3: size 4
+
+ results in .data.1 affected to mem1, and .data.2 and .data.3
+ affected to mem2, even though .data.3 would fit in mem3.
+</pre></div>
+
+<p>This option is incompatible with INSERT statements because it changes
+the way input sections are mapped to output sections.
+</p>
+<a name="index-_002d_002denable_002dnon_002dcontiguous_002dregions_002dwarnings"></a>
+</dd>
+<dt><code>--enable-non-contiguous-regions-warnings</code></dt>
+<dd><p>This option enables warnings when
+<code>--enable-non-contiguous-regions</code> allows possibly unexpected
+matches in sections mapping, potentially leading to silently
+discarding a section instead of failing because it does not fit any
+output region.
+</p>
+<a name="index-entry-point_002c-from-command-line"></a>
+<a name="index-_002de-entry"></a>
+<a name="index-_002d_002dentry_003dentry"></a>
+</dd>
+<dt><code>-e <var>entry</var></code></dt>
+<dt><code>--entry=<var>entry</var></code></dt>
+<dd><p>Use <var>entry</var> as the explicit symbol for beginning execution of your
+program, rather than the default entry point. If there is no symbol
+named <var>entry</var>, the linker will try to parse <var>entry</var> as a number,
+and use that as the entry address (the number will be interpreted in
+base 10; you may use a leading &lsquo;<samp>0x</samp>&rsquo; for base 16, or a leading
+&lsquo;<samp>0</samp>&rsquo; for base 8). See <a href="#Entry-Point">Entry Point</a>, for a discussion of defaults
+and other ways of specifying the entry point.
+</p>
+<a name="index-_002d_002dexclude_002dlibs"></a>
+</dd>
+<dt><code>--exclude-libs <var>lib</var>,<var>lib</var>,...</code></dt>
+<dd><p>Specifies a list of archive libraries from which symbols should not be automatically
+exported. The library names may be delimited by commas or colons. Specifying
+<code>--exclude-libs ALL</code> excludes symbols in all archive libraries from
+automatic export. This option is available only for the i386 PE targeted
+port of the linker and for ELF targeted ports. For i386 PE, symbols
+explicitly listed in a .def file are still exported, regardless of this
+option. For ELF targeted ports, symbols affected by this option will
+be treated as hidden.
+</p>
+<a name="index-_002d_002dexclude_002dmodules_002dfor_002dimplib"></a>
+</dd>
+<dt><code>--exclude-modules-for-implib <var>module</var>,<var>module</var>,...</code></dt>
+<dd><p>Specifies a list of object files or archive members, from which symbols
+should not be automatically exported, but which should be copied wholesale
+into the import library being generated during the link. The module names
+may be delimited by commas or colons, and must match exactly the filenames
+used by <code>ld</code> to open the files; for archive members, this is simply
+the member name, but for object files the name listed must include and
+match precisely any path used to specify the input file on the linker&rsquo;s
+command-line. This option is available only for the i386 PE targeted port
+of the linker. Symbols explicitly listed in a .def file are still exported,
+regardless of this option.
+</p>
+<a name="index-dynamic-symbol-table"></a>
+<a name="index-_002dE"></a>
+<a name="index-_002d_002dexport_002ddynamic"></a>
+<a name="index-_002d_002dno_002dexport_002ddynamic"></a>
+</dd>
+<dt><code>-E</code></dt>
+<dt><code>--export-dynamic</code></dt>
+<dt><code>--no-export-dynamic</code></dt>
+<dd><p>When creating a dynamically linked executable, using the <samp>-E</samp>
+option or the <samp>--export-dynamic</samp> option causes the linker to add
+all symbols to the dynamic symbol table. The dynamic symbol table is the
+set of symbols which are visible from dynamic objects at run time.
+</p>
+<p>If you do not use either of these options (or use the
+<samp>--no-export-dynamic</samp> option to restore the default behavior), the
+dynamic symbol table will normally contain only those symbols which are
+referenced by some dynamic object mentioned in the link.
+</p>
+<p>If you use <code>dlopen</code> to load a dynamic object which needs to refer
+back to the symbols defined by the program, rather than some other
+dynamic object, then you will probably need to use this option when
+linking the program itself.
+</p>
+<p>You can also use the dynamic list to control what symbols should
+be added to the dynamic symbol table if the output format supports it.
+See the description of &lsquo;<samp>--dynamic-list</samp>&rsquo;.
+</p>
+<p>Note that this option is specific to ELF targeted ports. PE targets
+support a similar function to export all symbols from a DLL or EXE; see
+the description of &lsquo;<samp>--export-all-symbols</samp>&rsquo; below.
+</p>
+<a name="index-_002d_002dexport_002ddynamic_002dsymbol_003dglob"></a>
+<a name="index-export-dynamic-symbol"></a>
+</dd>
+<dt><code>--export-dynamic-symbol=<var>glob</var></code></dt>
+<dd><p>When creating a dynamically linked executable, symbols matching
+<var>glob</var> will be added to the dynamic symbol table. When creating a
+shared library, references to symbols matching <var>glob</var> will not be
+bound to the definitions within the shared library. This option is a
+no-op when creating a shared library and &lsquo;<samp>-Bsymbolic</samp>&rsquo; or
+&lsquo;<samp>--dynamic-list</samp>&rsquo; are not specified. This option is only meaningful
+on ELF platforms which support shared libraries.
+</p>
+<a name="index-_002d_002dexport_002ddynamic_002dsymbol_002dlist_003dfile"></a>
+<a name="index-export-dynamic-symbol-list"></a>
+</dd>
+<dt><code>--export-dynamic-symbol-list=<var>file</var></code></dt>
+<dd><p>Specify a &lsquo;<samp>--export-dynamic-symbol</samp>&rsquo; for each pattern in the file.
+The format of the file is the same as the version node without
+scope and node name. See <a href="#VERSION">VERSION</a> for more information.
+</p>
+<a name="index-big_002dendian-objects"></a>
+<a name="index-endianness"></a>
+<a name="index-_002dEB"></a>
+</dd>
+<dt><code>-EB</code></dt>
+<dd><p>Link big-endian objects. This affects the default output format.
+</p>
+<a name="index-little_002dendian-objects"></a>
+<a name="index-_002dEL"></a>
+</dd>
+<dt><code>-EL</code></dt>
+<dd><p>Link little-endian objects. This affects the default output format.
+</p>
+<a name="index-_002df-name"></a>
+<a name="index-_002d_002dauxiliary_003dname"></a>
+</dd>
+<dt><code>-f <var>name</var></code></dt>
+<dt><code>--auxiliary=<var>name</var></code></dt>
+<dd><p>When creating an ELF shared object, set the internal DT_AUXILIARY field
+to the specified name. This tells the dynamic linker that the symbol
+table of the shared object should be used as an auxiliary filter on the
+symbol table of the shared object <var>name</var>.
+</p>
+<p>If you later link a program against this filter object, then, when you
+run the program, the dynamic linker will see the DT_AUXILIARY field. If
+the dynamic linker resolves any symbols from the filter object, it will
+first check whether there is a definition in the shared object
+<var>name</var>. If there is one, it will be used instead of the definition
+in the filter object. The shared object <var>name</var> need not exist.
+Thus the shared object <var>name</var> may be used to provide an alternative
+implementation of certain functions, perhaps for debugging or for
+machine-specific performance.
+</p>
+<p>This option may be specified more than once. The DT_AUXILIARY entries
+will be created in the order in which they appear on the command line.
+</p>
+<a name="index-_002dF-name"></a>
+<a name="index-_002d_002dfilter_003dname"></a>
+</dd>
+<dt><code>-F <var>name</var></code></dt>
+<dt><code>--filter=<var>name</var></code></dt>
+<dd><p>When creating an ELF shared object, set the internal DT_FILTER field to
+the specified name. This tells the dynamic linker that the symbol table
+of the shared object which is being created should be used as a filter
+on the symbol table of the shared object <var>name</var>.
+</p>
+<p>If you later link a program against this filter object, then, when you
+run the program, the dynamic linker will see the DT_FILTER field. The
+dynamic linker will resolve symbols according to the symbol table of the
+filter object as usual, but it will actually link to the definitions
+found in the shared object <var>name</var>. Thus the filter object can be
+used to select a subset of the symbols provided by the object
+<var>name</var>.
+</p>
+<p>Some older linkers used the <samp>-F</samp> option throughout a compilation
+toolchain for specifying object-file format for both input and output
+object files.
+The <small>GNU</small> linker uses other mechanisms for this purpose: the
+<samp>-b</samp>, <samp>--format</samp>, <samp>--oformat</samp> options, the
+<code>TARGET</code> command in linker scripts, and the <code>GNUTARGET</code>
+environment variable.
+The <small>GNU</small> linker will ignore the <samp>-F</samp> option when not
+creating an ELF shared object.
+</p>
+<a name="index-finalization-function"></a>
+<a name="index-_002dfini_003dname"></a>
+</dd>
+<dt><code>-fini=<var>name</var></code></dt>
+<dd><p>When creating an ELF executable or shared object, call NAME when the
+executable or shared object is unloaded, by setting DT_FINI to the
+address of the function. By default, the linker uses <code>_fini</code> as
+the function to call.
+</p>
+<a name="index-_002dg"></a>
+</dd>
+<dt><code>-g</code></dt>
+<dd><p>Ignored. Provided for compatibility with other tools.
+</p>
+<a name="index-_002dG-value"></a>
+<a name="index-_002d_002dgpsize_003dvalue"></a>
+<a name="index-object-size"></a>
+</dd>
+<dt><code>-G <var>value</var></code></dt>
+<dt><code>--gpsize=<var>value</var></code></dt>
+<dd><p>Set the maximum size of objects to be optimized using the GP register to
+<var>size</var>. This is only meaningful for object file formats such as
+MIPS ELF that support putting large and small objects into different
+sections. This is ignored for other object file formats.
+</p>
+<a name="index-runtime-library-name"></a>
+<a name="index-_002dh-name"></a>
+<a name="index-_002dsoname_003dname"></a>
+</dd>
+<dt><code>-h <var>name</var></code></dt>
+<dt><code>-soname=<var>name</var></code></dt>
+<dd><p>When creating an ELF shared object, set the internal DT_SONAME field to
+the specified name. When an executable is linked with a shared object
+which has a DT_SONAME field, then when the executable is run the dynamic
+linker will attempt to load the shared object specified by the DT_SONAME
+field rather than using the file name given to the linker.
+</p>
+<a name="index-_002di"></a>
+<a name="index-incremental-link"></a>
+</dd>
+<dt><code>-i</code></dt>
+<dd><p>Perform an incremental link (same as option &lsquo;<samp>-r</samp>&rsquo;).
+</p>
+<a name="index-initialization-function"></a>
+<a name="index-_002dinit_003dname"></a>
+</dd>
+<dt><code>-init=<var>name</var></code></dt>
+<dd><p>When creating an ELF executable or shared object, call NAME when the
+executable or shared object is loaded, by setting DT_INIT to the address
+of the function. By default, the linker uses <code>_init</code> as the
+function to call.
+</p>
+<a name="index-archive-files_002c-from-cmd-line"></a>
+<a name="index-_002dl-namespec"></a>
+<a name="index-_002d_002dlibrary_003dnamespec"></a>
+</dd>
+<dt><code>-l <var>namespec</var></code></dt>
+<dt><code>--library=<var>namespec</var></code></dt>
+<dd><p>Add the archive or object file specified by <var>namespec</var> to the
+list of files to link. This option may be used any number of times.
+If <var>namespec</var> is of the form <samp>:<var>filename</var></samp>, <code>ld</code>
+will search the library path for a file called <var>filename</var>, otherwise it
+will search the library path for a file called <samp>lib<var>namespec</var>.a</samp>.
+</p>
+<p>On systems which support shared libraries, <code>ld</code> may also search for
+files other than <samp>lib<var>namespec</var>.a</samp>. Specifically, on ELF
+and SunOS systems, <code>ld</code> will search a directory for a library
+called <samp>lib<var>namespec</var>.so</samp> before searching for one called
+<samp>lib<var>namespec</var>.a</samp>. (By convention, a <code>.so</code> extension
+indicates a shared library.) Note that this behavior does not apply
+to <samp>:<var>filename</var></samp>, which always specifies a file called
+<var>filename</var>.
+</p>
+<p>The linker will search an archive only once, at the location where it is
+specified on the command line. If the archive defines a symbol which
+was undefined in some object which appeared before the archive on the
+command line, the linker will include the appropriate file(s) from the
+archive. However, an undefined symbol in an object appearing later on
+the command line will not cause the linker to search the archive again.
+</p>
+<p>See the <samp>-(</samp> option for a way to force the linker to search
+archives multiple times.
+</p>
+<p>You may list the same archive multiple times on the command line.
+</p>
+<p>This type of archive searching is standard for Unix linkers. However,
+if you are using <code>ld</code> on AIX, note that it is different from the
+behaviour of the AIX linker.
+</p>
+<a name="index-search-directory_002c-from-cmd-line"></a>
+<a name="index-_002dL-dir"></a>
+<a name="index-_002d_002dlibrary_002dpath_003ddir"></a>
+</dd>
+<dt><code>-L <var>searchdir</var></code></dt>
+<dt><code>--library-path=<var>searchdir</var></code></dt>
+<dd><p>Add path <var>searchdir</var> to the list of paths that <code>ld</code> will search
+for archive libraries and <code>ld</code> control scripts. You may use this
+option any number of times. The directories are searched in the order
+in which they are specified on the command line. Directories specified
+on the command line are searched before the default directories. All
+<samp>-L</samp> options apply to all <samp>-l</samp> options, regardless of the
+order in which the options appear. <samp>-L</samp> options do not affect
+how <code>ld</code> searches for a linker script unless <samp>-T</samp>
+option is specified.
+</p>
+<p>If <var>searchdir</var> begins with <code>=</code> or <code>$SYSROOT</code>, then this
+prefix will be replaced by the <em>sysroot prefix</em>, controlled by the
+&lsquo;<samp>--sysroot</samp>&rsquo; option, or specified when the linker is configured.
+</p>
+<p>The default set of paths searched (without being specified with
+&lsquo;<samp>-L</samp>&rsquo;) depends on which emulation mode <code>ld</code> is using, and in
+some cases also on how it was configured. See <a href="#Environment">Environment</a>.
+</p>
+<p>The paths can also be specified in a link script with the
+<code>SEARCH_DIR</code> command. Directories specified this way are searched
+at the point in which the linker script appears in the command line.
+</p>
+<a name="index-emulation"></a>
+<a name="index-_002dm-emulation"></a>
+</dd>
+<dt><code>-m <var>emulation</var></code></dt>
+<dd><p>Emulate the <var>emulation</var> linker. You can list the available
+emulations with the &lsquo;<samp>--verbose</samp>&rsquo; or &lsquo;<samp>-V</samp>&rsquo; options.
+</p>
+<p>If the &lsquo;<samp>-m</samp>&rsquo; option is not used, the emulation is taken from the
+<code>LDEMULATION</code> environment variable, if that is defined.
+</p>
+<p>Otherwise, the default emulation depends upon how the linker was
+configured.
+</p>
+<a name="index-remapping-inputs"></a>
+<a name="index-_002d_002dremap_002dinputs_003dpattern_003dfilename"></a>
+<a name="index-_002d_002dremap_002dinputs_002dfile_003dfile"></a>
+</dd>
+<dt><code>--remap-inputs=<samp>pattern</samp>=<samp>filename</samp></code></dt>
+<dt><code>--remap-inputs-file=<samp>file</samp></code></dt>
+<dd><p>These options allow the names of input files to be changed before the
+linker attempts to open them. The option
+<samp>--remap-inputs=foo.o=bar.o</samp> will cause any attempt to load a
+file called <samp>foo.o</samp> to instead try to load a file called
+<samp>bar.o</samp>. Wildcard patterns are permitted in the first filename,
+so <samp>--remap-inputs=foo*.o=bar.o</samp> will rename any input file that
+matches <samp>foo*.o</samp> to <samp>bar.o</samp>.
+</p>
+<p>An alternative form of the option
+<samp>--remap-inputs-file=filename</samp> allows the remappings to be read
+from a file. Each line in the file can contain a single remapping.
+Blank lines are ignored. Anything from a hash character (&lsquo;<samp>#</samp>&rsquo;) to
+the end of a line is considered to be a comment and is also ignored.
+The mapping pattern can be separated from the filename by whitespace
+or an equals (&lsquo;<samp>=</samp>&rsquo;) character.
+</p>
+<p>The options can be specified multiple times. Their contents
+accumulate. The remappings will be processed in the order in which
+they occur on the command line, and if they come from a file, in the
+order in which they occur in the file. If a match is made, no further
+checking for that filename will be performed.
+</p>
+<p>If the replacement filename is <samp>/dev/null</samp> or just <samp>NUL</samp>
+then the remapping will actually cause the input file to be ignored.
+This can be a convenient way to experiment with removing input files
+from a complicated build environment.
+</p>
+<p>Note that this option is position dependent and only affects filenames
+that come after it on the command line. Thus:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> ld foo.o --remap-inputs=foo.o=bar.o
+</pre></div>
+
+<p>Will have no effect, whereas:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> ld --remap-inputs=foo.o=bar.o foo.o
+</pre></div>
+
+<p>Will rename the input file <samp>foo.o</samp> to <samp>bar.o</samp>.
+</p>
+<p>Note - these options also affect files referenced by <em>INPUT</em>
+statements in linker scripts. But since linker scripts are processed
+after the entire command line is read, the position of the remap
+options on the command line is not significant.
+</p>
+<p>If the <samp>verbose</samp> option is enabled then any mappings that match
+will be reported, although again the <samp>verbose</samp> option needs to
+be enabled on the command line <em>before</em> the remaped filenames
+appear.
+</p>
+<p>If the <samp>-Map</samp> or <samp>--print-map</samp> options are enabled then
+the remapping list will be included in the map output.
+</p>
+<a name="index-link-map"></a>
+<a name="index-_002dM"></a>
+<a name="index-_002d_002dprint_002dmap"></a>
+</dd>
+<dt><code>-M</code></dt>
+<dt><code>--print-map</code></dt>
+<dd><p>Print a link map to the standard output. A link map provides
+information about the link, including the following:
+</p>
+<ul>
+<li> Where object files are mapped into memory.
+</li><li> How common symbols are allocated.
+</li><li> All archive members included in the link, with a mention of the symbol
+which caused the archive member to be brought in.
+</li><li> The values assigned to symbols.
+
+<p>Note - symbols whose values are computed by an expression which
+involves a reference to a previous value of the same symbol may not
+have correct result displayed in the link map. This is because the
+linker discards intermediate results and only retains the final value
+of an expression. Under such circumstances the linker will display
+the final value enclosed by square brackets. Thus for example a
+linker script containing:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> foo = 1
+ foo = foo * 4
+ foo = foo + 8
+</pre></div>
+
+<p>will produce the following output in the link map if the <samp>-M</samp>
+option is used:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> 0x00000001 foo = 0x1
+ [0x0000000c] foo = (foo * 0x4)
+ [0x0000000c] foo = (foo + 0x8)
+</pre></div>
+
+<p>See <a href="#Expressions">Expressions</a> for more information about expressions in linker
+scripts.
+</p>
+</li><li> How GNU properties are merged.
+
+<p>When the linker merges input .note.gnu.property sections into one output
+.note.gnu.property section, some properties are removed or updated.
+These actions are reported in the link map. For example:
+</p>
+<div class="smallexample">
+<pre class="smallexample">Removed property 0xc0000002 to merge foo.o (0x1) and bar.o (not found)
+</pre></div>
+
+<p>This indicates that property 0xc0000002 is removed from output when
+merging properties in <samp>foo.o</samp>, whose property 0xc0000002 value
+is 0x1, and <samp>bar.o</samp>, which doesn&rsquo;t have property 0xc0000002.
+</p>
+<div class="smallexample">
+<pre class="smallexample">Updated property 0xc0010001 (0x1) to merge foo.o (0x1) and bar.o (0x1)
+</pre></div>
+
+<p>This indicates that property 0xc0010001 value is updated to 0x1 in output
+when merging properties in <samp>foo.o</samp>, whose 0xc0010001 property value
+is 0x1, and <samp>bar.o</samp>, whose 0xc0010001 property value is 0x1.
+</p></li></ul>
+
+<a name="index-link-map-discarded"></a>
+<a name="index-_002d_002dprint_002dmap_002ddiscarded"></a>
+<a name="index-_002d_002dno_002dprint_002dmap_002ddiscarded"></a>
+</dd>
+<dt><code>--print-map-discarded</code></dt>
+<dt><code>--no-print-map-discarded</code></dt>
+<dd><p>Print (or do not print) the list of discarded and garbage collected sections
+in the link map. Enabled by default.
+</p>
+<a name="index-_002d_002dprint_002dmap_002dlocals"></a>
+<a name="index-_002d_002dno_002dprint_002dmap_002dlocals"></a>
+</dd>
+<dt><code>--print-map-locals</code></dt>
+<dt><code>--no-print-map-locals</code></dt>
+<dd><p>Print (or do not print) local symbols in the link map. Local symbols
+will have the text &lsquo;<samp>(local)</samp>&rsquo; printed before their name, and will
+be listed after all of the global symbols in a given section.
+Temporary local symbols (typically those that start with &lsquo;<samp>.L</samp>&rsquo;)
+will not be included in the output. Disabled by default.
+</p>
+<a name="index-_002dn"></a>
+<a name="index-read_002donly-text"></a>
+<a name="index-NMAGIC"></a>
+<a name="index-_002d_002dnmagic"></a>
+</dd>
+<dt><code>-n</code></dt>
+<dt><code>--nmagic</code></dt>
+<dd><p>Turn off page alignment of sections, and disable linking against shared
+libraries. If the output format supports Unix style magic numbers,
+mark the output as <code>NMAGIC</code>.
+</p>
+<a name="index-_002dN"></a>
+<a name="index-_002d_002domagic"></a>
+<a name="index-read_002fwrite-from-cmd-line"></a>
+<a name="index-OMAGIC"></a>
+</dd>
+<dt><code>-N</code></dt>
+<dt><code>--omagic</code></dt>
+<dd><p>Set the text and data sections to be readable and writable. Also, do
+not page-align the data segment, and disable linking against shared
+libraries. If the output format supports Unix style magic numbers,
+mark the output as <code>OMAGIC</code>. Note: Although a writable text section
+is allowed for PE-COFF targets, it does not conform to the format
+specification published by Microsoft.
+</p>
+<a name="index-_002d_002dno_002domagic"></a>
+<a name="index-OMAGIC-1"></a>
+</dd>
+<dt><code>--no-omagic</code></dt>
+<dd><p>This option negates most of the effects of the <samp>-N</samp> option. It
+sets the text section to be read-only, and forces the data segment to
+be page-aligned. Note - this option does not enable linking against
+shared libraries. Use <samp>-Bdynamic</samp> for this.
+</p>
+<a name="index-_002do-output"></a>
+<a name="index-_002d_002doutput_003doutput"></a>
+<a name="index-naming-the-output-file"></a>
+</dd>
+<dt><code>-o <var>output</var></code></dt>
+<dt><code>--output=<var>output</var></code></dt>
+<dd><p>Use <var>output</var> as the name for the program produced by <code>ld</code>; if this
+option is not specified, the name <samp>a.out</samp> is used by default. The
+script command <code>OUTPUT</code> can also specify the output file name.
+</p>
+<a name="index-_002d_002ddependency_002dfile_003ddepfile"></a>
+<a name="index-dependency-file"></a>
+</dd>
+<dt><code>--dependency-file=<var>depfile</var></code></dt>
+<dd><p>Write a <em>dependency file</em> to <var>depfile</var>. This file contains a rule
+suitable for <code>make</code> describing the output file and all the input files
+that were read to produce it. The output is similar to the compiler&rsquo;s
+output with &lsquo;<samp>-M -MP</samp>&rsquo; (see <a href="http://gcc.gnu.org/onlinedocs/gcc/Preprocessor-Options.html#Preprocessor-Options">Options
+Controlling the Preprocessor</a> in <cite>Using the GNU Compiler
+Collection</cite>). Note that there is no option like the compiler&rsquo;s &lsquo;<samp>-MM</samp>&rsquo;,
+to exclude &ldquo;system files&rdquo; (which is not a well-specified concept in the
+linker, unlike &ldquo;system headers&rdquo; in the compiler). So the output from
+&lsquo;<samp>--dependency-file</samp>&rsquo; is always specific to the exact state of the
+installation where it was produced, and should not be copied into
+distributed makefiles without careful editing.
+</p>
+<a name="index-_002dO-level"></a>
+<a name="index-generating-optimized-output"></a>
+</dd>
+<dt><code>-O <var>level</var></code></dt>
+<dd><p>If <var>level</var> is a numeric values greater than zero <code>ld</code> optimizes
+the output. This might take significantly longer and therefore probably
+should only be enabled for the final binary. At the moment this
+option only affects ELF shared library generation. Future releases of
+the linker may make more use of this option. Also currently there is
+no difference in the linker&rsquo;s behaviour for different non-zero values
+of this option. Again this may change with future releases.
+</p>
+<a name="index-_002dplugin-name"></a>
+</dd>
+<dt><code>-plugin <var>name</var></code></dt>
+<dd><p>Involve a plugin in the linking process. The <var>name</var> parameter is
+the absolute filename of the plugin. Usually this parameter is
+automatically added by the complier, when using link time
+optimization, but users can also add their own plugins if they so
+wish.
+</p>
+<p>Note that the location of the compiler originated plugins is different
+from the place where the <code>ar</code>, <code>nm</code> and
+<code>ranlib</code> programs search for their plugins. In order for
+those commands to make use of a compiler based plugin it must first be
+copied into the <samp>${libdir}/bfd-plugins</samp> directory. All gcc
+based linker plugins are backward compatible, so it is sufficient to
+just copy in the newest one.
+</p>
+<a name="index-_002d_002dpush_002dstate"></a>
+<a name="index-push-state-governing-input-file-handling"></a>
+</dd>
+<dt><code>--push-state</code></dt>
+<dd><p>The <samp>--push-state</samp> allows one to preserve the current state of the
+flags which govern the input file handling so that they can all be
+restored with one corresponding <samp>--pop-state</samp> option.
+</p>
+<p>The option which are covered are: <samp>-Bdynamic</samp>, <samp>-Bstatic</samp>,
+<samp>-dn</samp>, <samp>-dy</samp>, <samp>-call_shared</samp>, <samp>-non_shared</samp>,
+<samp>-static</samp>, <samp>-N</samp>, <samp>-n</samp>, <samp>--whole-archive</samp>,
+<samp>--no-whole-archive</samp>, <samp>-r</samp>, <samp>-Ur</samp>,
+<samp>--copy-dt-needed-entries</samp>, <samp>--no-copy-dt-needed-entries</samp>,
+<samp>--as-needed</samp>, <samp>--no-as-needed</samp>, and <samp>-a</samp>.
+</p>
+<p>One target for this option are specifications for <samp>pkg-config</samp>. When
+used with the <samp>--libs</samp> option all possibly needed libraries are
+listed and then possibly linked with all the time. It is better to return
+something as follows:
+</p>
+<div class="smallexample">
+<pre class="smallexample">-Wl,--push-state,--as-needed -libone -libtwo -Wl,--pop-state
+</pre></div>
+
+<a name="index-_002d_002dpop_002dstate"></a>
+<a name="index-pop-state-governing-input-file-handling"></a>
+</dd>
+<dt><code>--pop-state</code></dt>
+<dd><p>Undoes the effect of &ndash;push-state, restores the previous values of the
+flags governing input file handling.
+</p>
+<a name="index-_002dq"></a>
+<a name="index-_002d_002demit_002drelocs"></a>
+<a name="index-retain-relocations-in-final-executable"></a>
+</dd>
+<dt><code>-q</code></dt>
+<dt><code>--emit-relocs</code></dt>
+<dd><p>Leave relocation sections and contents in fully linked executables.
+Post link analysis and optimization tools may need this information in
+order to perform correct modifications of executables. This results
+in larger executables.
+</p>
+<p>This option is currently only supported on ELF platforms.
+</p>
+<a name="index-_002d_002dforce_002ddynamic"></a>
+<a name="index-forcing-the-creation-of-dynamic-sections"></a>
+</dd>
+<dt><code>--force-dynamic</code></dt>
+<dd><p>Force the output file to have dynamic sections. This option is specific
+to VxWorks targets.
+</p>
+<a name="index-partial-link"></a>
+<a name="index-relocatable-output"></a>
+<a name="index-_002dr"></a>
+<a name="index-_002d_002drelocatable"></a>
+</dd>
+<dt><code>-r</code></dt>
+<dt><code>--relocatable</code></dt>
+<dd><p>Generate relocatable output&mdash;i.e., generate an output file that can in
+turn serve as input to <code>ld</code>. This is often called <em>partial
+linking</em>. As a side effect, in environments that support standard Unix
+magic numbers, this option also sets the output file&rsquo;s magic number to
+<code>OMAGIC</code>.
+If this option is not specified, an absolute file is produced. When
+linking C++ programs, this option <em>will not</em> resolve references to
+constructors; to do that, use &lsquo;<samp>-Ur</samp>&rsquo;.
+</p>
+<p>When an input file does not have the same format as the output file,
+partial linking is only supported if that input file does not contain any
+relocations. Different output formats can have further restrictions; for
+example some <code>a.out</code>-based formats do not support partial linking
+with input files in other formats at all.
+</p>
+<p>This option does the same thing as &lsquo;<samp>-i</samp>&rsquo;.
+</p>
+<a name="index-_002dR-file"></a>
+<a name="index-_002d_002djust_002dsymbols_003dfile"></a>
+<a name="index-symbol_002donly-input"></a>
+</dd>
+<dt><code>-R <var>filename</var></code></dt>
+<dt><code>--just-symbols=<var>filename</var></code></dt>
+<dd><p>Read symbol names and their addresses from <var>filename</var>, but do not
+relocate it or include it in the output. This allows your output file
+to refer symbolically to absolute locations of memory defined in other
+programs. You may use this option more than once.
+</p>
+<p>For compatibility with other ELF linkers, if the <samp>-R</samp> option is
+followed by a directory name, rather than a file name, it is treated as
+the <samp>-rpath</samp> option.
+</p>
+<a name="index-_002ds"></a>
+<a name="index-_002d_002dstrip_002dall"></a>
+<a name="index-strip-all-symbols"></a>
+</dd>
+<dt><code>-s</code></dt>
+<dt><code>--strip-all</code></dt>
+<dd><p>Omit all symbol information from the output file.
+</p>
+<a name="index-_002dS"></a>
+<a name="index-_002d_002dstrip_002ddebug"></a>
+<a name="index-strip-debugger-symbols"></a>
+</dd>
+<dt><code>-S</code></dt>
+<dt><code>--strip-debug</code></dt>
+<dd><p>Omit debugger symbol information (but not all symbols) from the output file.
+</p>
+<a name="index-_002d_002dstrip_002ddiscarded"></a>
+<a name="index-_002d_002dno_002dstrip_002ddiscarded"></a>
+</dd>
+<dt><code>--strip-discarded</code></dt>
+<dt><code>--no-strip-discarded</code></dt>
+<dd><p>Omit (or do not omit) global symbols defined in discarded sections.
+Enabled by default.
+</p>
+<a name="index-_002dt"></a>
+<a name="index-_002d_002dtrace"></a>
+<a name="index-input-files_002c-displaying"></a>
+</dd>
+<dt><code>-t</code></dt>
+<dt><code>--trace</code></dt>
+<dd><p>Print the names of the input files as <code>ld</code> processes them. If
+&lsquo;<samp>-t</samp>&rsquo; is given twice then members within archives are also printed.
+&lsquo;<samp>-t</samp>&rsquo; output is useful to generate a list of all the object files
+and scripts involved in linking, for example, when packaging files for
+a linker bug report.
+</p>
+<a name="index-_002dT-script"></a>
+<a name="index-_002d_002dscript_003dscript"></a>
+<a name="index-script-files"></a>
+</dd>
+<dt><code>-T <var>scriptfile</var></code></dt>
+<dt><code>--script=<var>scriptfile</var></code></dt>
+<dd><p>Use <var>scriptfile</var> as the linker script. This script replaces
+<code>ld</code>&rsquo;s default linker script (rather than adding to it),
+unless the script contains <code>INSERT</code>, so
+<var>commandfile</var> must specify everything necessary to describe the
+output file. See <a href="#Scripts">Scripts</a>. If <var>scriptfile</var> does not exist in
+the current directory, <code>ld</code> looks for it in the directories
+specified by any preceding &lsquo;<samp>-L</samp>&rsquo; options. Multiple &lsquo;<samp>-T</samp>&rsquo;
+options accumulate.
+</p>
+<a name="index-_002ddT-script"></a>
+<a name="index-_002d_002ddefault_002dscript_003dscript"></a>
+<a name="index-script-files-1"></a>
+</dd>
+<dt><code>-dT <var>scriptfile</var></code></dt>
+<dt><code>--default-script=<var>scriptfile</var></code></dt>
+<dd><p>Use <var>scriptfile</var> as the default linker script. See <a href="#Scripts">Scripts</a>.
+</p>
+<p>This option is similar to the <samp>--script</samp> option except that
+processing of the script is delayed until after the rest of the
+command line has been processed. This allows options placed after the
+<samp>--default-script</samp> option on the command line to affect the
+behaviour of the linker script, which can be important when the linker
+command line cannot be directly controlled by the user. (eg because
+the command line is being constructed by another tool, such as
+&lsquo;<samp>gcc</samp>&rsquo;).
+</p>
+<a name="index-_002du-symbol"></a>
+<a name="index-_002d_002dundefined_003dsymbol"></a>
+<a name="index-undefined-symbol"></a>
+</dd>
+<dt><code>-u <var>symbol</var></code></dt>
+<dt><code>--undefined=<var>symbol</var></code></dt>
+<dd><p>Force <var>symbol</var> to be entered in the output file as an undefined
+symbol. Doing this may, for example, trigger linking of additional
+modules from standard libraries. &lsquo;<samp>-u</samp>&rsquo; may be repeated with
+different option arguments to enter additional undefined symbols. This
+option is equivalent to the <code>EXTERN</code> linker script command.
+</p>
+<p>If this option is being used to force additional modules to be pulled
+into the link, and if it is an error for the symbol to remain
+undefined, then the option <samp>--require-defined</samp> should be used
+instead.
+</p>
+<a name="index-_002d_002drequire_002ddefined_003dsymbol"></a>
+<a name="index-symbols_002c-require-defined"></a>
+<a name="index-defined-symbol"></a>
+</dd>
+<dt><code>--require-defined=<var>symbol</var></code></dt>
+<dd><p>Require that <var>symbol</var> is defined in the output file. This option
+is the same as option <samp>--undefined</samp> except that if <var>symbol</var>
+is not defined in the output file then the linker will issue an error
+and exit. The same effect can be achieved in a linker script by using
+<code>EXTERN</code>, <code>ASSERT</code> and <code>DEFINED</code> together. This option
+can be used multiple times to require additional symbols.
+</p>
+<a name="index-_002dUr"></a>
+<a name="index-constructors"></a>
+</dd>
+<dt><code>-Ur</code></dt>
+<dd>
+<p>For programs that do not use constructors or destructors, or for ELF
+based systems this option is equivalent to <samp>-r</samp>: it generates
+relocatable output&mdash;i.e., an output file that can in turn serve as
+input to <code>ld</code>. For other binaries however the <samp>-Ur</samp>
+option is similar to <samp>-r</samp> but it also resolves references to
+constructors and destructors.
+</p>
+<p>For those systems where <samp>-r</samp> and <samp>-Ur</samp> behave
+differently, it does not work to use <samp>-Ur</samp> on files that were
+themselves linked with <samp>-Ur</samp>; once the constructor table has
+been built, it cannot be added to. Use <samp>-Ur</samp> only for the last
+partial link, and <samp>-r</samp> for the others.
+</p>
+<a name="index-_002d_002dorphan_002dhandling_003dMODE"></a>
+<a name="index-orphan-sections"></a>
+<a name="index-sections_002c-orphan"></a>
+</dd>
+<dt><code>--orphan-handling=<var>MODE</var></code></dt>
+<dd><p>Control how orphan sections are handled. An orphan section is one not
+specifically mentioned in a linker script. See <a href="#Orphan-Sections">Orphan Sections</a>.
+</p>
+<p><var>MODE</var> can have any of the following values:
+</p>
+<dl compact="compact">
+<dt><code>place</code></dt>
+<dd><p>Orphan sections are placed into a suitable output section following
+the strategy described in <a href="#Orphan-Sections">Orphan Sections</a>. The option
+&lsquo;<samp>--unique</samp>&rsquo; also affects how sections are placed.
+</p>
+</dd>
+<dt><code>discard</code></dt>
+<dd><p>All orphan sections are discarded, by placing them in the
+&lsquo;<samp>/DISCARD/</samp>&rsquo; section (see <a href="#Output-Section-Discarding">Output Section Discarding</a>).
+</p>
+</dd>
+<dt><code>warn</code></dt>
+<dd><p>The linker will place the orphan section as for <code>place</code> and also
+issue a warning.
+</p>
+</dd>
+<dt><code>error</code></dt>
+<dd><p>The linker will exit with an error if any orphan section is found.
+</p></dd>
+</dl>
+
+<p>The default if &lsquo;<samp>--orphan-handling</samp>&rsquo; is not given is <code>place</code>.
+</p>
+<a name="index-_002d_002dunique_005b_003dSECTION_005d"></a>
+</dd>
+<dt><code>--unique[=<var>SECTION</var>]</code></dt>
+<dd><p>Creates a separate output section for every input section matching
+<var>SECTION</var>, or if the optional wildcard <var>SECTION</var> argument is
+missing, for every orphan input section. An orphan section is one not
+specifically mentioned in a linker script. You may use this option
+multiple times on the command line; It prevents the normal merging of
+input sections with the same name, overriding output section assignments
+in a linker script.
+</p>
+<a name="index-_002dv"></a>
+<a name="index-_002dV"></a>
+<a name="index-_002d_002dversion"></a>
+<a name="index-version"></a>
+</dd>
+<dt><code>-v</code></dt>
+<dt><code>--version</code></dt>
+<dt><code>-V</code></dt>
+<dd><p>Display the version number for <code>ld</code>. The <samp>-V</samp> option also
+lists the supported emulations. See also the description of the
+<samp>--enable-linker-version</samp> in <a href="#Options">Command-line Options</a>
+which can be used to insert the linker version string into a binary.
+</p>
+<a name="index-_002dx"></a>
+<a name="index-_002d_002ddiscard_002dall"></a>
+<a name="index-deleting-local-symbols"></a>
+</dd>
+<dt><code>-x</code></dt>
+<dt><code>--discard-all</code></dt>
+<dd><p>Delete all local symbols.
+</p>
+<a name="index-_002dX"></a>
+<a name="index-_002d_002ddiscard_002dlocals"></a>
+<a name="index-local-symbols_002c-deleting"></a>
+</dd>
+<dt><code>-X</code></dt>
+<dt><code>--discard-locals</code></dt>
+<dd><p>Delete all temporary local symbols. (These symbols start with
+system-specific local label prefixes, typically &lsquo;<samp>.L</samp>&rsquo; for ELF systems
+or &lsquo;<samp>L</samp>&rsquo; for traditional a.out systems.)
+</p>
+<a name="index-_002dy-symbol"></a>
+<a name="index-_002d_002dtrace_002dsymbol_003dsymbol"></a>
+<a name="index-symbol-tracing"></a>
+</dd>
+<dt><code>-y <var>symbol</var></code></dt>
+<dt><code>--trace-symbol=<var>symbol</var></code></dt>
+<dd><p>Print the name of each linked file in which <var>symbol</var> appears. This
+option may be given any number of times. On many systems it is necessary
+to prepend an underscore.
+</p>
+<p>This option is useful when you have an undefined symbol in your link but
+don&rsquo;t know where the reference is coming from.
+</p>
+<a name="index-_002dY-path"></a>
+</dd>
+<dt><code>-Y <var>path</var></code></dt>
+<dd><p>Add <var>path</var> to the default library search path. This option exists
+for Solaris compatibility.
+</p>
+<a name="index-_002dz-keyword"></a>
+</dd>
+<dt><code>-z <var>keyword</var></code></dt>
+<dd><p>The recognized keywords are:
+</p><dl compact="compact">
+<dt>&lsquo;<samp>call-nop=prefix-addr</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>call-nop=suffix-nop</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>call-nop=prefix-<var>byte</var></samp>&rsquo;</dt>
+<dt>&lsquo;<samp>call-nop=suffix-<var>byte</var></samp>&rsquo;</dt>
+<dd><p>Specify the 1-byte <code>NOP</code> padding when transforming indirect call
+to a locally defined function, foo, via its GOT slot.
+<samp>call-nop=prefix-addr</samp> generates <code>0x67 call foo</code>.
+<samp>call-nop=suffix-nop</samp> generates <code>call foo 0x90</code>.
+<samp>call-nop=prefix-<var>byte</var></samp> generates <code><var>byte</var> call foo</code>.
+<samp>call-nop=suffix-<var>byte</var></samp> generates <code>call foo <var>byte</var></code>.
+Supported for i386 and x86_64.
+</p>
+</dd>
+<dt>&lsquo;<samp>cet-report=none</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>cet-report=warning</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>cet-report=error</samp>&rsquo;</dt>
+<dd><p>Specify how to report the missing GNU_PROPERTY_X86_FEATURE_1_IBT and
+GNU_PROPERTY_X86_FEATURE_1_SHSTK properties in input .note.gnu.property
+section. <samp>cet-report=none</samp>, which is the default, will make the
+linker not report missing properties in input files.
+<samp>cet-report=warning</samp> will make the linker issue a warning for
+missing properties in input files. <samp>cet-report=error</samp> will make
+the linker issue an error for missing properties in input files.
+Note that <samp>ibt</samp> will turn off the missing
+GNU_PROPERTY_X86_FEATURE_1_IBT property report and <samp>shstk</samp> will
+turn off the missing GNU_PROPERTY_X86_FEATURE_1_SHSTK property report.
+Supported for Linux/i386 and Linux/x86_64.
+</p>
+</dd>
+<dt>&lsquo;<samp>combreloc</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>nocombreloc</samp>&rsquo;</dt>
+<dd><p>Combine multiple dynamic relocation sections and sort to improve
+dynamic symbol lookup caching. Do not do this if &lsquo;<samp>nocombreloc</samp>&rsquo;.
+</p>
+</dd>
+<dt>&lsquo;<samp>common</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>nocommon</samp>&rsquo;</dt>
+<dd><p>Generate common symbols with STT_COMMON type during a relocatable
+link. Use STT_OBJECT type if &lsquo;<samp>nocommon</samp>&rsquo;.
+</p>
+</dd>
+<dt>&lsquo;<samp>common-page-size=<var>value</var></samp>&rsquo;</dt>
+<dd><p>Set the page size most commonly used to <var>value</var>. Memory image
+layout will be optimized to minimize memory pages if the system is
+using pages of this size.
+</p>
+</dd>
+<dt>&lsquo;<samp>defs</samp>&rsquo;</dt>
+<dd><p>Report unresolved symbol references from regular object files. This
+is done even if the linker is creating a non-symbolic shared library.
+This option is the inverse of &lsquo;<samp>-z undefs</samp>&rsquo;.
+</p>
+</dd>
+<dt>&lsquo;<samp>dynamic-undefined-weak</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>nodynamic-undefined-weak</samp>&rsquo;</dt>
+<dd><p>Make undefined weak symbols dynamic when building a dynamic object,
+if they are referenced from a regular object file and not forced local
+by symbol visibility or versioning. Do not make them dynamic if
+&lsquo;<samp>nodynamic-undefined-weak</samp>&rsquo;. If neither option is given, a target
+may default to either option being in force, or make some other
+selection of undefined weak symbols dynamic. Not all targets support
+these options.
+</p>
+</dd>
+<dt>&lsquo;<samp>execstack</samp>&rsquo;</dt>
+<dd><p>Marks the object as requiring executable stack.
+</p>
+</dd>
+<dt>&lsquo;<samp>global</samp>&rsquo;</dt>
+<dd><p>This option is only meaningful when building a shared object. It makes
+the symbols defined by this shared object available for symbol resolution
+of subsequently loaded libraries.
+</p>
+</dd>
+<dt>&lsquo;<samp>globalaudit</samp>&rsquo;</dt>
+<dd><p>This option is only meaningful when building a dynamic executable.
+This option marks the executable as requiring global auditing by
+setting the <code>DF_1_GLOBAUDIT</code> bit in the <code>DT_FLAGS_1</code> dynamic
+tag. Global auditing requires that any auditing library defined via
+the <samp>--depaudit</samp> or <samp>-P</samp> command-line options be run for
+all dynamic objects loaded by the application.
+</p>
+</dd>
+<dt>&lsquo;<samp>ibtplt</samp>&rsquo;</dt>
+<dd><p>Generate Intel Indirect Branch Tracking (IBT) enabled PLT entries.
+Supported for Linux/i386 and Linux/x86_64.
+</p>
+</dd>
+<dt>&lsquo;<samp>ibt</samp>&rsquo;</dt>
+<dd><p>Generate GNU_PROPERTY_X86_FEATURE_1_IBT in .note.gnu.property section
+to indicate compatibility with IBT. This also implies <samp>ibtplt</samp>.
+Supported for Linux/i386 and Linux/x86_64.
+</p>
+</dd>
+<dt>&lsquo;<samp>indirect-extern-access</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>noindirect-extern-access</samp>&rsquo;</dt>
+<dd><p>Generate GNU_PROPERTY_1_NEEDED_INDIRECT_EXTERN_ACCESS in
+.note.gnu.property section to indicate that object file requires
+canonical function pointers and cannot be used with copy relocation.
+This option also implies <samp>noextern-protected-data</samp> and
+<samp>nocopyreloc</samp>. Supported for i386 and x86-64.
+</p>
+<p><samp>noindirect-extern-access</samp> removes
+GNU_PROPERTY_1_NEEDED_INDIRECT_EXTERN_ACCESS from .note.gnu.property
+section.
+</p>
+</dd>
+<dt>&lsquo;<samp>initfirst</samp>&rsquo;</dt>
+<dd><p>This option is only meaningful when building a shared object.
+It marks the object so that its runtime initialization will occur
+before the runtime initialization of any other objects brought into
+the process at the same time. Similarly the runtime finalization of
+the object will occur after the runtime finalization of any other
+objects.
+</p>
+</dd>
+<dt>&lsquo;<samp>interpose</samp>&rsquo;</dt>
+<dd><p>Specify that the dynamic loader should modify its symbol search order
+so that symbols in this shared library interpose all other shared
+libraries not so marked.
+</p>
+</dd>
+<dt>&lsquo;<samp>unique</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>nounique</samp>&rsquo;</dt>
+<dd><p>When generating a shared library or other dynamically loadable ELF
+object mark it as one that should (by default) only ever be loaded once,
+and only in the main namespace (when using <code>dlmopen</code>). This is
+primarily used to mark fundamental libraries such as libc, libpthread et
+al which do not usually function correctly unless they are the sole instances
+of themselves. This behaviour can be overridden by the <code>dlmopen</code> caller
+and does not apply to certain loading mechanisms (such as audit libraries).
+</p>
+</dd>
+<dt>&lsquo;<samp>lam-u48</samp>&rsquo;</dt>
+<dd><p>Generate GNU_PROPERTY_X86_FEATURE_1_LAM_U48 in .note.gnu.property section
+to indicate compatibility with Intel LAM_U48. Supported for Linux/x86_64.
+</p>
+</dd>
+<dt>&lsquo;<samp>lam-u57</samp>&rsquo;</dt>
+<dd><p>Generate GNU_PROPERTY_X86_FEATURE_1_LAM_U57 in .note.gnu.property section
+to indicate compatibility with Intel LAM_U57. Supported for Linux/x86_64.
+</p>
+</dd>
+<dt>&lsquo;<samp>lam-u48-report=none</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>lam-u48-report=warning</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>lam-u48-report=error</samp>&rsquo;</dt>
+<dd><p>Specify how to report the missing GNU_PROPERTY_X86_FEATURE_1_LAM_U48
+property in input .note.gnu.property section.
+<samp>lam-u48-report=none</samp>, which is the default, will make the
+linker not report missing properties in input files.
+<samp>lam-u48-report=warning</samp> will make the linker issue a warning for
+missing properties in input files. <samp>lam-u48-report=error</samp> will
+make the linker issue an error for missing properties in input files.
+Supported for Linux/x86_64.
+</p>
+</dd>
+<dt>&lsquo;<samp>lam-u57-report=none</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>lam-u57-report=warning</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>lam-u57-report=error</samp>&rsquo;</dt>
+<dd><p>Specify how to report the missing GNU_PROPERTY_X86_FEATURE_1_LAM_U57
+property in input .note.gnu.property section.
+<samp>lam-u57-report=none</samp>, which is the default, will make the
+linker not report missing properties in input files.
+<samp>lam-u57-report=warning</samp> will make the linker issue a warning for
+missing properties in input files. <samp>lam-u57-report=error</samp> will
+make the linker issue an error for missing properties in input files.
+Supported for Linux/x86_64.
+</p>
+</dd>
+<dt>&lsquo;<samp>lam-report=none</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>lam-report=warning</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>lam-report=error</samp>&rsquo;</dt>
+<dd><p>Specify how to report the missing GNU_PROPERTY_X86_FEATURE_1_LAM_U48 and
+GNU_PROPERTY_X86_FEATURE_1_LAM_U57 properties in input .note.gnu.property
+section. <samp>lam-report=none</samp>, which is the default, will make the
+linker not report missing properties in input files.
+<samp>lam-report=warning</samp> will make the linker issue a warning for
+missing properties in input files. <samp>lam-report=error</samp> will make
+the linker issue an error for missing properties in input files.
+Supported for Linux/x86_64.
+</p>
+</dd>
+<dt>&lsquo;<samp>lazy</samp>&rsquo;</dt>
+<dd><p>When generating an executable or shared library, mark it to tell the
+dynamic linker to defer function call resolution to the point when
+the function is called (lazy binding), rather than at load time.
+Lazy binding is the default.
+</p>
+</dd>
+<dt>&lsquo;<samp>loadfltr</samp>&rsquo;</dt>
+<dd><p>Specify that the object&rsquo;s filters be processed immediately at runtime.
+</p>
+</dd>
+<dt>&lsquo;<samp>max-page-size=<var>value</var></samp>&rsquo;</dt>
+<dd><p>Set the maximum memory page size supported to <var>value</var>.
+</p>
+</dd>
+<dt>&lsquo;<samp>muldefs</samp>&rsquo;</dt>
+<dd><p>Allow multiple definitions.
+</p>
+</dd>
+<dt>&lsquo;<samp>nocopyreloc</samp>&rsquo;</dt>
+<dd><p>Disable linker generated .dynbss variables used in place of variables
+defined in shared libraries. May result in dynamic text relocations.
+</p>
+</dd>
+<dt>&lsquo;<samp>nodefaultlib</samp>&rsquo;</dt>
+<dd><p>Specify that the dynamic loader search for dependencies of this object
+should ignore any default library search paths.
+</p>
+</dd>
+<dt>&lsquo;<samp>nodelete</samp>&rsquo;</dt>
+<dd><p>Specify that the object shouldn&rsquo;t be unloaded at runtime.
+</p>
+</dd>
+<dt>&lsquo;<samp>nodlopen</samp>&rsquo;</dt>
+<dd><p>Specify that the object is not available to <code>dlopen</code>.
+</p>
+</dd>
+<dt>&lsquo;<samp>nodump</samp>&rsquo;</dt>
+<dd><p>Specify that the object can not be dumped by <code>dldump</code>.
+</p>
+</dd>
+<dt>&lsquo;<samp>noexecstack</samp>&rsquo;</dt>
+<dd><p>Marks the object as not requiring executable stack.
+</p>
+</dd>
+<dt>&lsquo;<samp>noextern-protected-data</samp>&rsquo;</dt>
+<dd><p>Don&rsquo;t treat protected data symbols as external when building a shared
+library. This option overrides the linker backend default. It can be
+used to work around incorrect relocations against protected data symbols
+generated by compiler. Updates on protected data symbols by another
+module aren&rsquo;t visible to the resulting shared library. Supported for
+i386 and x86-64.
+</p>
+</dd>
+<dt>&lsquo;<samp>noreloc-overflow</samp>&rsquo;</dt>
+<dd><p>Disable relocation overflow check. This can be used to disable
+relocation overflow check if there will be no dynamic relocation
+overflow at run-time. Supported for x86_64.
+</p>
+</dd>
+<dt>&lsquo;<samp>now</samp>&rsquo;</dt>
+<dd><p>When generating an executable or shared library, mark it to tell the
+dynamic linker to resolve all symbols when the program is started, or
+when the shared library is loaded by dlopen, instead of deferring
+function call resolution to the point when the function is first
+called.
+</p>
+</dd>
+<dt>&lsquo;<samp>origin</samp>&rsquo;</dt>
+<dd><p>Specify that the object requires &lsquo;<samp>$ORIGIN</samp>&rsquo; handling in paths.
+</p>
+</dd>
+<dt>&lsquo;<samp>pack-relative-relocs</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>nopack-relative-relocs</samp>&rsquo;</dt>
+<dd><p>Generate compact relative relocation in position-independent executable
+and shared library. It adds <code>DT_RELR</code>, <code>DT_RELRSZ</code> and
+<code>DT_RELRENT</code> entries to the dynamic section. It is ignored when
+building position-dependent executable and relocatable output.
+<samp>nopack-relative-relocs</samp> is the default, which disables compact
+relative relocation. When linked against the GNU C Library, a
+GLIBC_ABI_DT_RELR symbol version dependency on the shared C Library is
+added to the output. Supported for i386 and x86-64.
+</p>
+</dd>
+<dt>&lsquo;<samp>relro</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>norelro</samp>&rsquo;</dt>
+<dd><p>Create an ELF <code>PT_GNU_RELRO</code> segment header in the object. This
+specifies a memory segment that should be made read-only after
+relocation, if supported. Specifying &lsquo;<samp>common-page-size</samp>&rsquo; smaller
+than the system page size will render this protection ineffective.
+Don&rsquo;t create an ELF <code>PT_GNU_RELRO</code> segment if &lsquo;<samp>norelro</samp>&rsquo;.
+</p>
+</dd>
+<dt>&lsquo;<samp>report-relative-reloc</samp>&rsquo;</dt>
+<dd><p>Report dynamic relative relocations generated by linker. Supported for
+Linux/i386 and Linux/x86_64.
+</p>
+</dd>
+<dt>&lsquo;<samp>sectionheader</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>nosectionheader</samp>&rsquo;</dt>
+<dd><p>Generate section header. Don&rsquo;t generate section header if
+&lsquo;<samp>nosectionheader</samp>&rsquo; is used. <samp>sectionheader</samp> is the default.
+</p>
+</dd>
+<dt>&lsquo;<samp>separate-code</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>noseparate-code</samp>&rsquo;</dt>
+<dd><p>Create separate code <code>PT_LOAD</code> segment header in the object. This
+specifies a memory segment that should contain only instructions and must
+be in wholly disjoint pages from any other data. Don&rsquo;t create separate
+code <code>PT_LOAD</code> segment if &lsquo;<samp>noseparate-code</samp>&rsquo; is used.
+</p>
+</dd>
+<dt>&lsquo;<samp>shstk</samp>&rsquo;</dt>
+<dd><p>Generate GNU_PROPERTY_X86_FEATURE_1_SHSTK in .note.gnu.property section
+to indicate compatibility with Intel Shadow Stack. Supported for
+Linux/i386 and Linux/x86_64.
+</p>
+</dd>
+<dt>&lsquo;<samp>stack-size=<var>value</var></samp>&rsquo;</dt>
+<dd><p>Specify a stack size for an ELF <code>PT_GNU_STACK</code> segment.
+Specifying zero will override any default non-zero sized
+<code>PT_GNU_STACK</code> segment creation.
+</p>
+</dd>
+<dt>&lsquo;<samp>start-stop-gc</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>nostart-stop-gc</samp>&rsquo;</dt>
+<dd><a name="index-start_002dstop_002dgc"></a>
+<p>When &lsquo;<samp>--gc-sections</samp>&rsquo; is in effect, a reference from a retained
+section to <code>__start_SECNAME</code> or <code>__stop_SECNAME</code> causes all
+input sections named <code>SECNAME</code> to also be retained, if
+<code>SECNAME</code> is representable as a C identifier and either
+<code>__start_SECNAME</code> or <code>__stop_SECNAME</code> is synthesized by the
+linker. &lsquo;<samp>-z start-stop-gc</samp>&rsquo; disables this effect, allowing
+sections to be garbage collected as if the special synthesized symbols
+were not defined. &lsquo;<samp>-z start-stop-gc</samp>&rsquo; has no effect on a
+definition of <code>__start_SECNAME</code> or <code>__stop_SECNAME</code> in an
+object file or linker script. Such a definition will prevent the
+linker providing a synthesized <code>__start_SECNAME</code> or
+<code>__stop_SECNAME</code> respectively, and therefore the special
+treatment by garbage collection for those references.
+</p>
+</dd>
+<dt>&lsquo;<samp>start-stop-visibility=<var>value</var></samp>&rsquo;</dt>
+<dd><a name="index-visibility"></a>
+<a name="index-ELF-symbol-visibility"></a>
+<p>Specify the ELF symbol visibility for synthesized
+<code>__start_SECNAME</code> and <code>__stop_SECNAME</code> symbols (see <a href="#Input-Section-Example">Input Section Example</a>). <var>value</var> must be exactly &lsquo;<samp>default</samp>&rsquo;,
+&lsquo;<samp>internal</samp>&rsquo;, &lsquo;<samp>hidden</samp>&rsquo;, or &lsquo;<samp>protected</samp>&rsquo;. If no &lsquo;<samp>-z
+start-stop-visibility</samp>&rsquo; option is given, &lsquo;<samp>protected</samp>&rsquo; is used for
+compatibility with historical practice. However, it&rsquo;s highly
+recommended to use &lsquo;<samp>-z start-stop-visibility=hidden</samp>&rsquo; in new
+programs and shared libraries so that these symbols are not exported
+between shared objects, which is not usually what&rsquo;s intended.
+</p>
+</dd>
+<dt>&lsquo;<samp>text</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>notext</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>textoff</samp>&rsquo;</dt>
+<dd><p>Report an error if DT_TEXTREL is set, i.e., if the position-independent
+or shared object has dynamic relocations in read-only sections. Don&rsquo;t
+report an error if &lsquo;<samp>notext</samp>&rsquo; or &lsquo;<samp>textoff</samp>&rsquo;.
+</p>
+</dd>
+<dt>&lsquo;<samp>undefs</samp>&rsquo;</dt>
+<dd><p>Do not report unresolved symbol references from regular object files,
+either when creating an executable, or when creating a shared library.
+This option is the inverse of &lsquo;<samp>-z defs</samp>&rsquo;.
+</p>
+</dd>
+<dt>&lsquo;<samp>unique-symbol</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>nounique-symbol</samp>&rsquo;</dt>
+<dd><p>Avoid duplicated local symbol names in the symbol string table. Append
+&quot;.<code>number</code>&quot; to duplicated local symbol names if &lsquo;<samp>unique-symbol</samp>&rsquo;
+is used. <samp>nounique-symbol</samp> is the default.
+</p>
+</dd>
+<dt>&lsquo;<samp>x86-64-baseline</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>x86-64-v2</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>x86-64-v3</samp>&rsquo;</dt>
+<dt>&lsquo;<samp>x86-64-v4</samp>&rsquo;</dt>
+<dd><p>Specify the x86-64 ISA level needed in .note.gnu.property section.
+<samp>x86-64-baseline</samp> generates <code>GNU_PROPERTY_X86_ISA_1_BASELINE</code>.
+<samp>x86-64-v2</samp> generates <code>GNU_PROPERTY_X86_ISA_1_V2</code>.
+<samp>x86-64-v3</samp> generates <code>GNU_PROPERTY_X86_ISA_1_V3</code>.
+<samp>x86-64-v4</samp> generates <code>GNU_PROPERTY_X86_ISA_1_V4</code>.
+Supported for Linux/i386 and Linux/x86_64.
+</p>
+</dd>
+</dl>
+
+<p>Other keywords are ignored for Solaris compatibility.
+</p>
+<a name="index-_002d_0028"></a>
+<a name="index-groups-of-archives"></a>
+</dd>
+<dt><code>-( <var>archives</var> -)</code></dt>
+<dt><code>--start-group <var>archives</var> --end-group</code></dt>
+<dd><p>The <var>archives</var> should be a list of archive files. They may be
+either explicit file names, or &lsquo;<samp>-l</samp>&rsquo; options.
+</p>
+<p>The specified archives are searched repeatedly until no new undefined
+references are created. Normally, an archive is searched only once in
+the order that it is specified on the command line. If a symbol in that
+archive is needed to resolve an undefined symbol referred to by an
+object in an archive that appears later on the command line, the linker
+would not be able to resolve that reference. By grouping the archives,
+they will all be searched repeatedly until all possible references are
+resolved.
+</p>
+<p>Using this option has a significant performance cost. It is best to use
+it only when there are unavoidable circular references between two or
+more archives.
+</p>
+<a name="index-_002d_002daccept_002dunknown_002dinput_002darch"></a>
+<a name="index-_002d_002dno_002daccept_002dunknown_002dinput_002darch"></a>
+</dd>
+<dt><code>--accept-unknown-input-arch</code></dt>
+<dt><code>--no-accept-unknown-input-arch</code></dt>
+<dd><p>Tells the linker to accept input files whose architecture cannot be
+recognised. The assumption is that the user knows what they are doing
+and deliberately wants to link in these unknown input files. This was
+the default behaviour of the linker, before release 2.14. The default
+behaviour from release 2.14 onwards is to reject such input files, and
+so the &lsquo;<samp>--accept-unknown-input-arch</samp>&rsquo; option has been added to
+restore the old behaviour.
+</p>
+<a name="index-_002d_002das_002dneeded"></a>
+<a name="index-_002d_002dno_002das_002dneeded"></a>
+</dd>
+<dt><code>--as-needed</code></dt>
+<dt><code>--no-as-needed</code></dt>
+<dd><p>This option affects ELF DT_NEEDED tags for dynamic libraries mentioned
+on the command line after the <samp>--as-needed</samp> option. Normally
+the linker will add a DT_NEEDED tag for each dynamic library mentioned
+on the command line, regardless of whether the library is actually
+needed or not. <samp>--as-needed</samp> causes a DT_NEEDED tag to only be
+emitted for a library that <em>at that point in the link</em> satisfies a
+non-weak undefined symbol reference from a regular object file or, if
+the library is not found in the DT_NEEDED lists of other needed libraries, a
+non-weak undefined symbol reference from another needed dynamic library.
+Object files or libraries appearing on the command line <em>after</em>
+the library in question do not affect whether the library is seen as
+needed. This is similar to the rules for extraction of object files
+from archives. <samp>--no-as-needed</samp> restores the default behaviour.
+</p>
+<p>Note: On Linux based systems the <samp>--as-needed</samp> option also has
+an affect on the behaviour of the <samp>--rpath</samp> and
+<samp>--rpath-link</samp> options. See the description of
+<samp>--rpath-link</samp> for more details.
+</p>
+<a name="index-_002d_002dadd_002dneeded"></a>
+<a name="index-_002d_002dno_002dadd_002dneeded"></a>
+</dd>
+<dt><code>--add-needed</code></dt>
+<dt><code>--no-add-needed</code></dt>
+<dd><p>These two options have been deprecated because of the similarity of
+their names to the <samp>--as-needed</samp> and <samp>--no-as-needed</samp>
+options. They have been replaced by <samp>--copy-dt-needed-entries</samp>
+and <samp>--no-copy-dt-needed-entries</samp>.
+</p>
+<a name="index-_002dassert-keyword"></a>
+</dd>
+<dt><code>-assert <var>keyword</var></code></dt>
+<dd><p>This option is ignored for SunOS compatibility.
+</p>
+<a name="index-_002dBdynamic"></a>
+<a name="index-_002ddy"></a>
+<a name="index-_002dcall_005fshared"></a>
+</dd>
+<dt><code>-Bdynamic</code></dt>
+<dt><code>-dy</code></dt>
+<dt><code>-call_shared</code></dt>
+<dd><p>Link against dynamic libraries. This is only meaningful on platforms
+for which shared libraries are supported. This option is normally the
+default on such platforms. The different variants of this option are
+for compatibility with various systems. You may use this option
+multiple times on the command line: it affects library searching for
+<samp>-l</samp> options which follow it.
+</p>
+<a name="index-_002dBgroup"></a>
+</dd>
+<dt><code>-Bgroup</code></dt>
+<dd><p>Set the <code>DF_1_GROUP</code> flag in the <code>DT_FLAGS_1</code> entry in the dynamic
+section. This causes the runtime linker to handle lookups in this
+object and its dependencies to be performed only inside the group.
+<samp>--unresolved-symbols=report-all</samp> is implied. This option is
+only meaningful on ELF platforms which support shared libraries.
+</p>
+<a name="index-_002dBstatic"></a>
+<a name="index-_002ddn"></a>
+<a name="index-_002dnon_005fshared"></a>
+<a name="index-_002dstatic"></a>
+</dd>
+<dt><code>-Bstatic</code></dt>
+<dt><code>-dn</code></dt>
+<dt><code>-non_shared</code></dt>
+<dt><code>-static</code></dt>
+<dd><p>Do not link against shared libraries. This is only meaningful on
+platforms for which shared libraries are supported. The different
+variants of this option are for compatibility with various systems. You
+may use this option multiple times on the command line: it affects
+library searching for <samp>-l</samp> options which follow it. This
+option also implies <samp>--unresolved-symbols=report-all</samp>. This
+option can be used with <samp>-shared</samp>. Doing so means that a
+shared library is being created but that all of the library&rsquo;s external
+references must be resolved by pulling in entries from static
+libraries.
+</p>
+<a name="index-_002dBsymbolic"></a>
+</dd>
+<dt><code>-Bsymbolic</code></dt>
+<dd><p>When creating a shared library, bind references to global symbols to the
+definition within the shared library, if any. Normally, it is possible
+for a program linked against a shared library to override the definition
+within the shared library. This option is only meaningful on ELF
+platforms which support shared libraries.
+</p>
+<a name="index-_002dBsymbolic_002dfunctions"></a>
+</dd>
+<dt><code>-Bsymbolic-functions</code></dt>
+<dd><p>When creating a shared library, bind references to global function
+symbols to the definition within the shared library, if any.
+This option is only meaningful on ELF platforms which support shared
+libraries.
+</p>
+<a name="index-_002dBno_002dsymbolic"></a>
+</dd>
+<dt><code>-Bno-symbolic</code></dt>
+<dd><p>This option can cancel previously specified &lsquo;<samp>-Bsymbolic</samp>&rsquo; and
+&lsquo;<samp>-Bsymbolic-functions</samp>&rsquo;.
+</p>
+<a name="index-_002d_002ddynamic_002dlist_003ddynamic_002dlist_002dfile"></a>
+</dd>
+<dt><code>--dynamic-list=<var>dynamic-list-file</var></code></dt>
+<dd><p>Specify the name of a dynamic list file to the linker. This is
+typically used when creating shared libraries to specify a list of
+global symbols whose references shouldn&rsquo;t be bound to the definition
+within the shared library, or creating dynamically linked executables
+to specify a list of symbols which should be added to the symbol table
+in the executable. This option is only meaningful on ELF platforms
+which support shared libraries.
+</p>
+<p>The format of the dynamic list is the same as the version node without
+scope and node name. See <a href="#VERSION">VERSION</a> for more information.
+</p>
+<a name="index-_002d_002ddynamic_002dlist_002ddata"></a>
+</dd>
+<dt><code>--dynamic-list-data</code></dt>
+<dd><p>Include all global data symbols to the dynamic list.
+</p>
+<a name="index-_002d_002ddynamic_002dlist_002dcpp_002dnew"></a>
+</dd>
+<dt><code>--dynamic-list-cpp-new</code></dt>
+<dd><p>Provide the builtin dynamic list for C++ operator new and delete. It
+is mainly useful for building shared libstdc++.
+</p>
+<a name="index-_002d_002ddynamic_002dlist_002dcpp_002dtypeinfo"></a>
+</dd>
+<dt><code>--dynamic-list-cpp-typeinfo</code></dt>
+<dd><p>Provide the builtin dynamic list for C++ runtime type identification.
+</p>
+<a name="index-_002d_002dcheck_002dsections"></a>
+<a name="index-_002d_002dno_002dcheck_002dsections"></a>
+</dd>
+<dt><code>--check-sections</code></dt>
+<dt><code>--no-check-sections</code></dt>
+<dd><p>Asks the linker <em>not</em> to check section addresses after they have
+been assigned to see if there are any overlaps. Normally the linker will
+perform this check, and if it finds any overlaps it will produce
+suitable error messages. The linker does know about, and does make
+allowances for sections in overlays. The default behaviour can be
+restored by using the command-line switch <samp>--check-sections</samp>.
+Section overlap is not usually checked for relocatable links. You can
+force checking in that case by using the <samp>--check-sections</samp>
+option.
+</p>
+<a name="index-_002d_002dcopy_002ddt_002dneeded_002dentries"></a>
+<a name="index-_002d_002dno_002dcopy_002ddt_002dneeded_002dentries"></a>
+</dd>
+<dt><code>--copy-dt-needed-entries</code></dt>
+<dt><code>--no-copy-dt-needed-entries</code></dt>
+<dd><p>This option affects the treatment of dynamic libraries referred to
+by DT_NEEDED tags <em>inside</em> ELF dynamic libraries mentioned on the
+command line. Normally the linker won&rsquo;t add a DT_NEEDED tag to the
+output binary for each library mentioned in a DT_NEEDED tag in an
+input dynamic library. With <samp>--copy-dt-needed-entries</samp>
+specified on the command line however any dynamic libraries that
+follow it will have their DT_NEEDED entries added. The default
+behaviour can be restored with <samp>--no-copy-dt-needed-entries</samp>.
+</p>
+<p>This option also has an effect on the resolution of symbols in dynamic
+libraries. With <samp>--copy-dt-needed-entries</samp> dynamic libraries
+mentioned on the command line will be recursively searched, following
+their DT_NEEDED tags to other libraries, in order to resolve symbols
+required by the output binary. With the default setting however
+the searching of dynamic libraries that follow it will stop with the
+dynamic library itself. No DT_NEEDED links will be traversed to resolve
+symbols.
+</p>
+<a name="index-cross-reference-table"></a>
+<a name="index-_002d_002dcref"></a>
+</dd>
+<dt><code>--cref</code></dt>
+<dd><p>Output a cross reference table. If a linker map file is being
+generated, the cross reference table is printed to the map file.
+Otherwise, it is printed on the standard output.
+</p>
+<p>The format of the table is intentionally simple, so that it may be
+easily processed by a script if necessary. The symbols are printed out,
+sorted by name. For each symbol, a list of file names is given. If the
+symbol is defined, the first file listed is the location of the
+definition. If the symbol is defined as a common value then any files
+where this happens appear next. Finally any files that reference the
+symbol are listed.
+</p>
+<a name="index-ctf-variables"></a>
+<a name="index-_002d_002dctf_002dvariables"></a>
+<a name="index-_002d_002dno_002dctf_002dvariables"></a>
+</dd>
+<dt><code>--ctf-variables</code></dt>
+<dt><code>--no-ctf-variables</code></dt>
+<dd><p>The CTF debuginfo format supports a section which encodes the names and
+types of variables found in the program which do not appear in any symbol
+table. These variables clearly cannot be looked up by address by
+conventional debuggers, so the space used for their types and names is
+usually wasted: the types are usually small but the names are often not.
+<samp>--ctf-variables</samp> causes the generation of such a section.
+The default behaviour can be restored with <samp>--no-ctf-variables</samp>.
+</p>
+<a name="index-ctf-type-sharing"></a>
+<a name="index-_002d_002dctf_002dshare_002dtypes"></a>
+</dd>
+<dt><code>--ctf-share-types=<var>method</var></code></dt>
+<dd><p>Adjust the method used to share types between translation units in CTF.
+</p>
+<dl compact="compact">
+<dt>&lsquo;<samp>share-unconflicted</samp>&rsquo;</dt>
+<dd><p>Put all types that do not have ambiguous definitions into the shared dictionary,
+where debuggers can easily access them, even if they only occur in one
+translation unit. This is the default.
+</p>
+</dd>
+<dt>&lsquo;<samp>share-duplicated</samp>&rsquo;</dt>
+<dd><p>Put only types that occur in multiple translation units into the shared
+dictionary: types with only one definition go into per-translation-unit
+dictionaries. Types with ambiguous definitions in multiple translation units
+always go into per-translation-unit dictionaries. This tends to make the CTF
+larger, but may reduce the amount of CTF in the shared dictionary. For very
+large projects this may speed up opening the CTF and save memory in the CTF
+consumer at runtime.
+</p></dd>
+</dl>
+
+<a name="index-common-allocation-1"></a>
+<a name="index-_002d_002dno_002ddefine_002dcommon"></a>
+</dd>
+<dt><code>--no-define-common</code></dt>
+<dd><p>This option inhibits the assignment of addresses to common symbols.
+The script command <code>INHIBIT_COMMON_ALLOCATION</code> has the same effect.
+See <a href="#Miscellaneous-Commands">Miscellaneous Commands</a>.
+</p>
+<p>The &lsquo;<samp>--no-define-common</samp>&rsquo; option allows decoupling
+the decision to assign addresses to Common symbols from the choice
+of the output file type; otherwise a non-Relocatable output type
+forces assigning addresses to Common symbols.
+Using &lsquo;<samp>--no-define-common</samp>&rsquo; allows Common symbols that are referenced
+from a shared library to be assigned addresses only in the main program.
+This eliminates the unused duplicate space in the shared library,
+and also prevents any possible confusion over resolving to the wrong
+duplicate when there are many dynamic modules with specialized search
+paths for runtime symbol resolution.
+</p>
+<a name="index-group-allocation-in-linker-script"></a>
+<a name="index-section-groups"></a>
+<a name="index-COMDAT"></a>
+<a name="index-_002d_002dforce_002dgroup_002dallocation"></a>
+</dd>
+<dt><code>--force-group-allocation</code></dt>
+<dd><p>This option causes the linker to place section group members like
+normal input sections, and to delete the section groups. This is the
+default behaviour for a final link but this option can be used to
+change the behaviour of a relocatable link (&lsquo;<samp>-r</samp>&rsquo;). The script
+command <code>FORCE_GROUP_ALLOCATION</code> has the same
+effect. See <a href="#Miscellaneous-Commands">Miscellaneous Commands</a>.
+</p>
+<a name="index-symbols_002c-from-command-line"></a>
+<a name="index-_002d_002ddefsym_003dsymbol_003dexp"></a>
+</dd>
+<dt><code>--defsym=<var>symbol</var>=<var>expression</var></code></dt>
+<dd><p>Create a global symbol in the output file, containing the absolute
+address given by <var>expression</var>. You may use this option as many
+times as necessary to define multiple symbols in the command line. A
+limited form of arithmetic is supported for the <var>expression</var> in this
+context: you may give a hexadecimal constant or the name of an existing
+symbol, or use <code>+</code> and <code>-</code> to add or subtract hexadecimal
+constants or symbols. If you need more elaborate expressions, consider
+using the linker command language from a script (see <a href="#Assignments">Assignments</a>).
+<em>Note:</em> there should be no white space between <var>symbol</var>, the
+equals sign (&ldquo;<tt class="key">=</tt>&rdquo;), and <var>expression</var>.
+</p>
+<p>The linker processes &lsquo;<samp>--defsym</samp>&rsquo; arguments and &lsquo;<samp>-T</samp>&rsquo; arguments
+in order, placing &lsquo;<samp>--defsym</samp>&rsquo; before &lsquo;<samp>-T</samp>&rsquo; will define the
+symbol before the linker script from &lsquo;<samp>-T</samp>&rsquo; is processed, while
+placing &lsquo;<samp>--defsym</samp>&rsquo; after &lsquo;<samp>-T</samp>&rsquo; will define the symbol after
+the linker script has been processed. This difference has
+consequences for expressions within the linker script that use the
+&lsquo;<samp>--defsym</samp>&rsquo; symbols, which order is correct will depend on what
+you are trying to achieve.
+</p>
+<a name="index-demangling_002c-from-command-line"></a>
+<a name="index-_002d_002ddemangle_005b_003dstyle_005d"></a>
+<a name="index-_002d_002dno_002ddemangle"></a>
+</dd>
+<dt><code>--demangle[=<var>style</var>]</code></dt>
+<dt><code>--no-demangle</code></dt>
+<dd><p>These options control whether to demangle symbol names in error messages
+and other output. When the linker is told to demangle, it tries to
+present symbol names in a readable fashion: it strips leading
+underscores if they are used by the object file format, and converts C++
+mangled symbol names into user readable names. Different compilers have
+different mangling styles. The optional demangling style argument can be used
+to choose an appropriate demangling style for your compiler. The linker will
+demangle by default unless the environment variable &lsquo;<samp>COLLECT_NO_DEMANGLE</samp>&rsquo;
+is set. These options may be used to override the default.
+</p>
+<a name="index-dynamic-linker_002c-from-command-line"></a>
+<a name="index-_002dIfile"></a>
+<a name="index-_002d_002ddynamic_002dlinker_003dfile"></a>
+</dd>
+<dt><code>-I<var>file</var></code></dt>
+<dt><code>--dynamic-linker=<var>file</var></code></dt>
+<dd><p>Set the name of the dynamic linker. This is only meaningful when
+generating dynamically linked ELF executables. The default dynamic
+linker is normally correct; don&rsquo;t use this unless you know what you are
+doing.
+</p>
+<a name="index-_002d_002dno_002ddynamic_002dlinker"></a>
+</dd>
+<dt><code>--no-dynamic-linker</code></dt>
+<dd><p>When producing an executable file, omit the request for a dynamic
+linker to be used at load-time. This is only meaningful for ELF
+executables that contain dynamic relocations, and usually requires
+entry point code that is capable of processing these relocations.
+</p>
+<a name="index-_002d_002dembedded_002drelocs"></a>
+</dd>
+<dt><code>--embedded-relocs</code></dt>
+<dd><p>This option is similar to the <samp>--emit-relocs</samp> option except
+that the relocs are stored in a target-specific section. This option
+is only supported by the &lsquo;<samp>BFIN</samp>&rsquo;, &lsquo;<samp>CR16</samp>&rsquo; and <em>M68K</em>
+targets.
+</p>
+<a name="index-_002d_002ddisable_002dmultiple_002dabs_002ddefs"></a>
+</dd>
+<dt><code>--disable-multiple-abs-defs</code></dt>
+<dd><p>Do not allow multiple definitions with symbols included
+in filename invoked by -R or &ndash;just-symbols
+</p>
+<a name="index-_002d_002dfatal_002dwarnings"></a>
+<a name="index-_002d_002dno_002dfatal_002dwarnings"></a>
+</dd>
+<dt><code>--fatal-warnings</code></dt>
+<dt><code>--no-fatal-warnings</code></dt>
+<dd><p>Treat all warnings as errors. The default behaviour can be restored
+with the option <samp>--no-fatal-warnings</samp>.
+</p>
+<a name="index-_002dw"></a>
+<a name="index-_002d_002dno_002dwarnings"></a>
+</dd>
+<dt><code>-w</code></dt>
+<dt><code>--no-warnings</code></dt>
+<dd><p>Do not display any warning or error messages. This overrides
+<samp>--fatal-warnings</samp> if it has been enabled. This option can be
+used when it is known that the output binary will not work, but there
+is still a need to create it.
+</p>
+<a name="index-_002d_002dforce_002dexe_002dsuffix"></a>
+</dd>
+<dt><code>--force-exe-suffix</code></dt>
+<dd><p>Make sure that an output file has a .exe suffix.
+</p>
+<p>If a successfully built fully linked output file does not have a
+<code>.exe</code> or <code>.dll</code> suffix, this option forces the linker to copy
+the output file to one of the same name with a <code>.exe</code> suffix. This
+option is useful when using unmodified Unix makefiles on a Microsoft
+Windows host, since some versions of Windows won&rsquo;t run an image unless
+it ends in a <code>.exe</code> suffix.
+</p>
+<a name="index-_002d_002dgc_002dsections"></a>
+<a name="index-_002d_002dno_002dgc_002dsections"></a>
+<a name="index-garbage-collection"></a>
+</dd>
+<dt><code>--gc-sections</code></dt>
+<dt><code>--no-gc-sections</code></dt>
+<dd><p>Enable garbage collection of unused input sections. It is ignored on
+targets that do not support this option. The default behaviour (of not
+performing this garbage collection) can be restored by specifying
+&lsquo;<samp>--no-gc-sections</samp>&rsquo; on the command line. Note that garbage
+collection for COFF and PE format targets is supported, but the
+implementation is currently considered to be experimental.
+</p>
+<p>&lsquo;<samp>--gc-sections</samp>&rsquo; decides which input sections are used by
+examining symbols and relocations. The section containing the entry
+symbol and all sections containing symbols undefined on the
+command-line will be kept, as will sections containing symbols
+referenced by dynamic objects. Note that when building shared
+libraries, the linker must assume that any visible symbol is
+referenced. Once this initial set of sections has been determined,
+the linker recursively marks as used any section referenced by their
+relocations. See &lsquo;<samp>--entry</samp>&rsquo;, &lsquo;<samp>--undefined</samp>&rsquo;, and
+&lsquo;<samp>--gc-keep-exported</samp>&rsquo;.
+</p>
+<p>This option can be set when doing a partial link (enabled with option
+&lsquo;<samp>-r</samp>&rsquo;). In this case the root of symbols kept must be explicitly
+specified either by one of the options &lsquo;<samp>--entry</samp>&rsquo;,
+&lsquo;<samp>--undefined</samp>&rsquo;, or &lsquo;<samp>--gc-keep-exported</samp>&rsquo; or by a <code>ENTRY</code>
+command in the linker script.
+</p>
+<p>As a GNU extension, ELF input sections marked with the
+<code>SHF_GNU_RETAIN</code> flag will not be garbage collected.
+</p>
+<a name="index-_002d_002dprint_002dgc_002dsections"></a>
+<a name="index-_002d_002dno_002dprint_002dgc_002dsections"></a>
+<a name="index-garbage-collection-1"></a>
+</dd>
+<dt><code>--print-gc-sections</code></dt>
+<dt><code>--no-print-gc-sections</code></dt>
+<dd><p>List all sections removed by garbage collection. The listing is
+printed on stderr. This option is only effective if garbage
+collection has been enabled via the &lsquo;<samp>--gc-sections</samp>&rsquo;) option. The
+default behaviour (of not listing the sections that are removed) can
+be restored by specifying &lsquo;<samp>--no-print-gc-sections</samp>&rsquo; on the command
+line.
+</p>
+<a name="index-_002d_002dgc_002dkeep_002dexported"></a>
+<a name="index-garbage-collection-2"></a>
+</dd>
+<dt><code>--gc-keep-exported</code></dt>
+<dd><p>When &lsquo;<samp>--gc-sections</samp>&rsquo; is enabled, this option prevents garbage
+collection of unused input sections that contain global symbols having
+default or protected visibility. This option is intended to be used for
+executables where unreferenced sections would otherwise be garbage
+collected regardless of the external visibility of contained symbols.
+Note that this option has no effect when linking shared objects since
+it is already the default behaviour. This option is only supported for
+ELF format targets.
+</p>
+<a name="index-_002d_002dprint_002doutput_002dformat"></a>
+<a name="index-output-format"></a>
+</dd>
+<dt><code>--print-output-format</code></dt>
+<dd><p>Print the name of the default output format (perhaps influenced by
+other command-line options). This is the string that would appear
+in an <code>OUTPUT_FORMAT</code> linker script command (see <a href="#File-Commands">File Commands</a>).
+</p>
+<a name="index-_002d_002dprint_002dmemory_002dusage"></a>
+<a name="index-memory-usage"></a>
+</dd>
+<dt><code>--print-memory-usage</code></dt>
+<dd><p>Print used size, total size and used size of memory regions created with
+the <a href="#MEMORY">MEMORY</a> command. This is useful on embedded targets to have a
+quick view of amount of free memory. The format of the output has one
+headline and one line per region. It is both human readable and easily
+parsable by tools. Here is an example of an output:
+</p>
+<div class="smallexample">
+<pre class="smallexample">Memory region Used Size Region Size %age Used
+ ROM: 256 KB 1 MB 25.00%
+ RAM: 32 B 2 GB 0.00%
+</pre></div>
+
+<a name="index-help"></a>
+<a name="index-usage"></a>
+<a name="index-_002d_002dhelp"></a>
+</dd>
+<dt><code>--help</code></dt>
+<dd><p>Print a summary of the command-line options on the standard output and exit.
+</p>
+<a name="index-_002d_002dtarget_002dhelp"></a>
+</dd>
+<dt><code>--target-help</code></dt>
+<dd><p>Print a summary of all target-specific options on the standard output and exit.
+</p>
+<a name="index-_002dMap_003dmapfile"></a>
+</dd>
+<dt><code>-Map=<var>mapfile</var></code></dt>
+<dd><p>Print a link map to the file <var>mapfile</var>. See the description of the
+<samp>-M</samp> option, above. If <var>mapfile</var> is just the character
+<code>-</code> then the map will be written to stdout.
+</p>
+<p>Specifying a directory as <var>mapfile</var> causes the linker map to be
+written as a file inside the directory. Normally name of the file
+inside the directory is computed as the basename of the <var>output</var>
+file with <code>.map</code> appended. If however the special character
+<code>%</code> is used then this will be replaced by the full path of the
+output file. Additionally if there are any characters after the
+<var>%</var> symbol then <code>.map</code> will no longer be appended.
+</p>
+<div class="smallexample">
+<pre class="smallexample"> -o foo.exe -Map=bar [Creates ./bar]
+ -o ../dir/foo.exe -Map=bar [Creates ./bar]
+ -o foo.exe -Map=../dir [Creates ../dir/foo.exe.map]
+ -o ../dir2/foo.exe -Map=../dir [Creates ../dir/foo.exe.map]
+ -o foo.exe -Map=% [Creates ./foo.exe.map]
+ -o ../dir/foo.exe -Map=% [Creates ../dir/foo.exe.map]
+ -o foo.exe -Map=%.bar [Creates ./foo.exe.bar]
+ -o ../dir/foo.exe -Map=%.bar [Creates ../dir/foo.exe.bar]
+ -o ../dir2/foo.exe -Map=../dir/% [Creates ../dir/../dir2/foo.exe.map]
+ -o ../dir2/foo.exe -Map=../dir/%.bar [Creates ../dir/../dir2/foo.exe.bar]
+</pre></div>
+
+<p>It is an error to specify more than one <code>%</code> character.
+</p>
+<p>If the map file already exists then it will be overwritten by this
+operation.
+</p>
+<a name="index-memory-usage-1"></a>
+<a name="index-_002d_002dno_002dkeep_002dmemory"></a>
+</dd>
+<dt><code>--no-keep-memory</code></dt>
+<dd><p><code>ld</code> normally optimizes for speed over memory usage by caching the
+symbol tables of input files in memory. This option tells <code>ld</code> to
+instead optimize for memory usage, by rereading the symbol tables as
+necessary. This may be required if <code>ld</code> runs out of memory space
+while linking a large executable.
+</p>
+<a name="index-_002d_002dno_002dundefined"></a>
+<a name="index-_002dz-defs"></a>
+<a name="index-_002dz-undefs"></a>
+</dd>
+<dt><code>--no-undefined</code></dt>
+<dt><code>-z defs</code></dt>
+<dd><p>Report unresolved symbol references from regular object files. This
+is done even if the linker is creating a non-symbolic shared library.
+The switch <samp>--[no-]allow-shlib-undefined</samp> controls the
+behaviour for reporting unresolved references found in shared
+libraries being linked in.
+</p>
+<p>The effects of this option can be reverted by using <code>-z undefs</code>.
+</p>
+<a name="index-_002d_002dallow_002dmultiple_002ddefinition"></a>
+<a name="index-_002dz-muldefs"></a>
+</dd>
+<dt><code>--allow-multiple-definition</code></dt>
+<dt><code>-z muldefs</code></dt>
+<dd><p>Normally when a symbol is defined multiple times, the linker will
+report a fatal error. These options allow multiple definitions and the
+first definition will be used.
+</p>
+<a name="index-_002d_002dallow_002dshlib_002dundefined"></a>
+<a name="index-_002d_002dno_002dallow_002dshlib_002dundefined"></a>
+</dd>
+<dt><code>--allow-shlib-undefined</code></dt>
+<dt><code>--no-allow-shlib-undefined</code></dt>
+<dd><p>Allows or disallows undefined symbols in shared libraries.
+This switch is similar to <samp>--no-undefined</samp> except that it
+determines the behaviour when the undefined symbols are in a
+shared library rather than a regular object file. It does not affect
+how undefined symbols in regular object files are handled.
+</p>
+<p>The default behaviour is to report errors for any undefined symbols
+referenced in shared libraries if the linker is being used to create
+an executable, but to allow them if the linker is being used to create
+a shared library.
+</p>
+<p>The reasons for allowing undefined symbol references in shared
+libraries specified at link time are that:
+</p>
+<ul>
+<li> A shared library specified at link time may not be the same as the one
+that is available at load time, so the symbol might actually be
+resolvable at load time.
+</li><li> There are some operating systems, eg BeOS and HPPA, where undefined
+symbols in shared libraries are normal.
+
+<p>The BeOS kernel for example patches shared libraries at load time to
+select whichever function is most appropriate for the current
+architecture. This is used, for example, to dynamically select an
+appropriate memset function.
+</p></li></ul>
+
+<a name="index-_002d_002derror_002dhandling_002dscript_003dscriptname"></a>
+</dd>
+<dt><code>--error-handling-script=<var>scriptname</var></code></dt>
+<dd><p>If this option is provided then the linker will invoke
+<var>scriptname</var> whenever an error is encountered. Currently however
+only two kinds of error are supported: missing symbols and missing
+libraries. Two arguments will be passed to script: the keyword
+&ldquo;undefined-symbol&rdquo; or &lsquo;missing-lib&rdquo; and the <var>name</var> of the
+undefined symbol or missing library. The intention is that the script
+will provide suggestions to the user as to where the symbol or library
+might be found. After the script has finished then the normal linker
+error message will be displayed.
+</p>
+<p>The availability of this option is controlled by a configure time
+switch, so it may not be present in specific implementations.
+</p>
+<a name="index-_002d_002dno_002dundefined_002dversion"></a>
+</dd>
+<dt><code>--no-undefined-version</code></dt>
+<dd><p>Normally when a symbol has an undefined version, the linker will ignore
+it. This option disallows symbols with undefined version and a fatal error
+will be issued instead.
+</p>
+<a name="index-_002d_002ddefault_002dsymver"></a>
+</dd>
+<dt><code>--default-symver</code></dt>
+<dd><p>Create and use a default symbol version (the soname) for unversioned
+exported symbols.
+</p>
+<a name="index-_002d_002ddefault_002dimported_002dsymver"></a>
+</dd>
+<dt><code>--default-imported-symver</code></dt>
+<dd><p>Create and use a default symbol version (the soname) for unversioned
+imported symbols.
+</p>
+<a name="index-_002d_002dno_002dwarn_002dmismatch"></a>
+</dd>
+<dt><code>--no-warn-mismatch</code></dt>
+<dd><p>Normally <code>ld</code> will give an error if you try to link together input
+files that are mismatched for some reason, perhaps because they have
+been compiled for different processors or for different endiannesses.
+This option tells <code>ld</code> that it should silently permit such possible
+errors. This option should only be used with care, in cases when you
+have taken some special action that ensures that the linker errors are
+inappropriate.
+</p>
+<a name="index-_002d_002dno_002dwarn_002dsearch_002dmismatch"></a>
+</dd>
+<dt><code>--no-warn-search-mismatch</code></dt>
+<dd><p>Normally <code>ld</code> will give a warning if it finds an incompatible
+library during a library search. This option silences the warning.
+</p>
+<a name="index-_002d_002dno_002dwhole_002darchive"></a>
+</dd>
+<dt><code>--no-whole-archive</code></dt>
+<dd><p>Turn off the effect of the <samp>--whole-archive</samp> option for subsequent
+archive files.
+</p>
+<a name="index-output-file-after-errors"></a>
+<a name="index-_002d_002dnoinhibit_002dexec"></a>
+</dd>
+<dt><code>--noinhibit-exec</code></dt>
+<dd><p>Retain the executable output file whenever it is still usable.
+Normally, the linker will not produce an output file if it encounters
+errors during the link process; it exits without writing an output file
+when it issues any error whatsoever.
+</p>
+<a name="index-_002dnostdlib"></a>
+</dd>
+<dt><code>-nostdlib</code></dt>
+<dd><p>Only search library directories explicitly specified on the
+command line. Library directories specified in linker scripts
+(including linker scripts specified on the command line) are ignored.
+</p>
+<a name="index-_002d_002doformat_003doutput_002dformat"></a>
+</dd>
+<dt><code>--oformat=<var>output-format</var></code></dt>
+<dd><p><code>ld</code> may be configured to support more than one kind of object
+file. If your <code>ld</code> is configured this way, you can use the
+&lsquo;<samp>--oformat</samp>&rsquo; option to specify the binary format for the output
+object file. Even when <code>ld</code> is configured to support alternative
+object formats, you don&rsquo;t usually need to specify this, as <code>ld</code>
+should be configured to produce as a default output format the most
+usual format on each machine. <var>output-format</var> is a text string, the
+name of a particular format supported by the BFD libraries. (You can
+list the available binary formats with &lsquo;<samp>objdump -i</samp>&rsquo;.) The script
+command <code>OUTPUT_FORMAT</code> can also specify the output format, but
+this option overrides it. See <a href="#BFD">BFD</a>.
+</p>
+<a name="index-_002d_002dout_002dimplib"></a>
+</dd>
+<dt><code>--out-implib <var>file</var></code></dt>
+<dd><p>Create an import library in <var>file</var> corresponding to the executable
+the linker is generating (eg. a DLL or ELF program). This import
+library (which should be called <code>*.dll.a</code> or <code>*.a</code> for DLLs)
+may be used to link clients against the generated executable; this
+behaviour makes it possible to skip a separate import library creation
+step (eg. <code>dlltool</code> for DLLs). This option is only available for
+the i386 PE and ELF targetted ports of the linker.
+</p>
+<a name="index-_002dpie"></a>
+<a name="index-_002d_002dpic_002dexecutable"></a>
+</dd>
+<dt><code>-pie</code></dt>
+<dt><code>--pic-executable</code></dt>
+<dd><a name="index-position-independent-executables"></a>
+<p>Create a position independent executable. This is currently only supported on
+ELF platforms. Position independent executables are similar to shared
+libraries in that they are relocated by the dynamic linker to the virtual
+address the OS chooses for them (which can vary between invocations). Like
+normal dynamically linked executables they can be executed and symbols
+defined in the executable cannot be overridden by shared libraries.
+</p>
+<a name="index-_002dno_002dpie"></a>
+</dd>
+<dt><code>-no-pie</code></dt>
+<dd><a name="index-position-dependent-executables"></a>
+<p>Create a position dependent executable. This is the default.
+</p>
+<a name="index-_002dqmagic"></a>
+</dd>
+<dt><code>-qmagic</code></dt>
+<dd><p>This option is ignored for Linux compatibility.
+</p>
+<a name="index-_002dQy"></a>
+</dd>
+<dt><code>-Qy</code></dt>
+<dd><p>This option is ignored for SVR4 compatibility.
+</p>
+<a name="index-_002d_002drelax"></a>
+<a name="index-synthesizing-linker"></a>
+<a name="index-relaxing-addressing-modes"></a>
+<a name="index-_002d_002dno_002drelax"></a>
+</dd>
+<dt><code>--relax</code></dt>
+<dt><code>--no-relax</code></dt>
+<dd><p>An option with machine dependent effects.
+This option is only supported on a few targets.
+See <a href="#H8_002f300"><code>ld</code> and the H8/300</a>.
+See <a href="#Xtensa"><code>ld</code> and Xtensa Processors</a>.
+See <a href="#M68HC11_002f68HC12"><code>ld</code> and the 68HC11 and 68HC12</a>.
+See <a href="#Nios-II"><code>ld</code> and the Altera Nios II</a>.
+See <a href="#PowerPC-ELF32"><code>ld</code> and PowerPC 32-bit ELF Support</a>.
+</p>
+<p>On some platforms the <samp>--relax</samp> option performs target specific,
+global optimizations that become possible when the linker resolves
+addressing in the program, such as relaxing address modes,
+synthesizing new instructions, selecting shorter version of current
+instructions, and combining constant values.
+</p>
+<p>On some platforms these link time global optimizations may make symbolic
+debugging of the resulting executable impossible.
+This is known to be the case for the Matsushita MN10200 and MN10300
+family of processors.
+</p>
+<p>On platforms where the feature is supported, the option
+<samp>--no-relax</samp> will disable it.
+</p>
+<p>On platforms where the feature is not supported, both <samp>--relax</samp>
+and <samp>--no-relax</samp> are accepted, but ignored.
+</p>
+<a name="index-retaining-specified-symbols"></a>
+<a name="index-stripping-all-but-some-symbols"></a>
+<a name="index-symbols_002c-retaining-selectively"></a>
+<a name="index-_002d_002dretain_002dsymbols_002dfile_003dfilename"></a>
+</dd>
+<dt><code>--retain-symbols-file=<var>filename</var></code></dt>
+<dd><p>Retain <em>only</em> the symbols listed in the file <var>filename</var>,
+discarding all others. <var>filename</var> is simply a flat file, with one
+symbol name per line. This option is especially useful in environments
+(such as VxWorks)
+where a large global symbol table is accumulated gradually, to conserve
+run-time memory.
+</p>
+<p>&lsquo;<samp>--retain-symbols-file</samp>&rsquo; does <em>not</em> discard undefined symbols,
+or symbols needed for relocations.
+</p>
+<p>You may only specify &lsquo;<samp>--retain-symbols-file</samp>&rsquo; once in the command
+line. It overrides &lsquo;<samp>-s</samp>&rsquo; and &lsquo;<samp>-S</samp>&rsquo;.
+</p>
+</dd>
+<dt><code>-rpath=<var>dir</var></code></dt>
+<dd><a name="index-runtime-library-search-path"></a>
+<a name="index-_002drpath_003ddir"></a>
+<p>Add a directory to the runtime library search path. This is used when
+linking an ELF executable with shared objects. All <samp>-rpath</samp>
+arguments are concatenated and passed to the runtime linker, which uses
+them to locate shared objects at runtime.
+</p>
+<p>The <samp>-rpath</samp> option is also used when locating shared objects which
+are needed by shared objects explicitly included in the link; see the
+description of the <samp>-rpath-link</samp> option. Searching <samp>-rpath</samp>
+in this way is only supported by native linkers and cross linkers which
+have been configured with the <samp>--with-sysroot</samp> option.
+</p>
+<p>If <samp>-rpath</samp> is not used when linking an ELF executable, the
+contents of the environment variable <code>LD_RUN_PATH</code> will be used if it
+is defined.
+</p>
+<p>The <samp>-rpath</samp> option may also be used on SunOS. By default, on
+SunOS, the linker will form a runtime search path out of all the
+<samp>-L</samp> options it is given. If a <samp>-rpath</samp> option is used, the
+runtime search path will be formed exclusively using the <samp>-rpath</samp>
+options, ignoring the <samp>-L</samp> options. This can be useful when using
+gcc, which adds many <samp>-L</samp> options which may be on NFS mounted
+file systems.
+</p>
+<p>For compatibility with other ELF linkers, if the <samp>-R</samp> option is
+followed by a directory name, rather than a file name, it is treated as
+the <samp>-rpath</samp> option.
+</p>
+<a name="index-link_002dtime-runtime-library-search-path"></a>
+<a name="index-_002drpath_002dlink_003ddir"></a>
+</dd>
+<dt><code>-rpath-link=<var>dir</var></code></dt>
+<dd><p>When using ELF or SunOS, one shared library may require another. This
+happens when an <code>ld -shared</code> link includes a shared library as one
+of the input files.
+</p>
+<p>When the linker encounters such a dependency when doing a non-shared,
+non-relocatable link, it will automatically try to locate the required
+shared library and include it in the link, if it is not included
+explicitly. In such a case, the <samp>-rpath-link</samp> option
+specifies the first set of directories to search. The
+<samp>-rpath-link</samp> option may specify a sequence of directory names
+either by specifying a list of names separated by colons, or by
+appearing multiple times.
+</p>
+<p>The tokens <var>$ORIGIN</var> and <var>$LIB</var> can appear in these search
+directories. They will be replaced by the full path to the directory
+containing the program or shared object in the case of <var>$ORIGIN</var>
+and either &lsquo;<samp>lib</samp>&rsquo; - for 32-bit binaries - or &lsquo;<samp>lib64</samp>&rsquo; - for
+64-bit binaries - in the case of <var>$LIB</var>.
+</p>
+<p>The alternative form of these tokens - <var>${ORIGIN}</var> and
+<var>${LIB}</var> can also be used. The token <var>$PLATFORM</var> is not
+supported.
+</p>
+<p>This option should be used with caution as it overrides the search path
+that may have been hard compiled into a shared library. In such a case it
+is possible to use unintentionally a different search path than the
+runtime linker would do.
+</p>
+<p>The linker uses the following search paths to locate required shared
+libraries:
+</p>
+<ol>
+<li> Any directories specified by <samp>-rpath-link</samp> options.
+</li><li> Any directories specified by <samp>-rpath</samp> options. The difference
+between <samp>-rpath</samp> and <samp>-rpath-link</samp> is that directories
+specified by <samp>-rpath</samp> options are included in the executable and
+used at runtime, whereas the <samp>-rpath-link</samp> option is only effective
+at link time. Searching <samp>-rpath</samp> in this way is only supported
+by native linkers and cross linkers which have been configured with
+the <samp>--with-sysroot</samp> option.
+</li><li> On an ELF system, for native linkers, if the <samp>-rpath</samp> and
+<samp>-rpath-link</samp> options were not used, search the contents of the
+environment variable <code>LD_RUN_PATH</code>.
+</li><li> On SunOS, if the <samp>-rpath</samp> option was not used, search any
+directories specified using <samp>-L</samp> options.
+</li><li> For a native linker, search the contents of the environment
+variable <code>LD_LIBRARY_PATH</code>.
+</li><li> For a native ELF linker, the directories in <code>DT_RUNPATH</code> or
+<code>DT_RPATH</code> of a shared library are searched for shared
+libraries needed by it. The <code>DT_RPATH</code> entries are ignored if
+<code>DT_RUNPATH</code> entries exist.
+</li><li> For a linker for a Linux system, if the file <samp>/etc/ld.so.conf</samp>
+exists, the list of directories found in that file. Note: the path
+to this file is prefixed with the <code>sysroot</code> value, if that is
+defined, and then any <code>prefix</code> string if the linker was
+configured with the <code>--prefix=&lt;path&gt;</code> option.
+</li><li> For a native linker on a FreeBSD system, any directories specified by
+the <code>_PATH_ELF_HINTS</code> macro defined in the <samp>elf-hints.h</samp>
+header file.
+</li><li> Any directories specified by a <code>SEARCH_DIR</code> command in a
+linker script given on the command line, including scripts specified
+by <samp>-T</samp> (but not <samp>-dT</samp>).
+</li><li> The default directories, normally <samp>/lib</samp> and <samp>/usr/lib</samp>.
+</li><li> Any directories specified by a plugin LDPT_SET_EXTRA_LIBRARY_PATH.
+</li><li> Any directories specified by a <code>SEARCH_DIR</code> command in a default
+linker script.
+</li></ol>
+
+<p>Note however on Linux based systems there is an additional caveat: If
+the <samp>--as-needed</samp> option is active <em>and</em> a shared library
+is located which would normally satisfy the search <em>and</em> this
+library does not have DT_NEEDED tag for <samp>libc.so</samp>
+<em>and</em> there is a shared library later on in the set of search
+directories which also satisfies the search <em>and</em>
+this second shared library does have a DT_NEEDED tag for
+<samp>libc.so</samp> <em>then</em> the second library will be selected instead
+of the first.
+</p>
+<p>If the required shared library is not found, the linker will issue a
+warning and continue with the link.
+</p>
+
+<a name="index-_002dshared"></a>
+<a name="index-_002dBshareable"></a>
+</dd>
+<dt><code>-shared</code></dt>
+<dt><code>-Bshareable</code></dt>
+<dd><a name="index-shared-libraries"></a>
+<p>Create a shared library. This is currently only supported on ELF, XCOFF
+and SunOS platforms. On SunOS, the linker will automatically create a
+shared library if the <samp>-e</samp> option is not used and there are
+undefined symbols in the link.
+</p>
+<a name="index-_002d_002dsort_002dcommon"></a>
+</dd>
+<dt><code>--sort-common</code></dt>
+<dt><code>--sort-common=ascending</code></dt>
+<dt><code>--sort-common=descending</code></dt>
+<dd><p>This option tells <code>ld</code> to sort the common symbols by alignment in
+ascending or descending order when it places them in the appropriate output
+sections. The symbol alignments considered are sixteen-byte or larger,
+eight-byte, four-byte, two-byte, and one-byte. This is to prevent gaps
+between symbols due to alignment constraints. If no sorting order is
+specified, then descending order is assumed.
+</p>
+<a name="index-_002d_002dsort_002dsection_003dname"></a>
+</dd>
+<dt><code>--sort-section=name</code></dt>
+<dd><p>This option will apply <code>SORT_BY_NAME</code> to all wildcard section
+patterns in the linker script.
+</p>
+<a name="index-_002d_002dsort_002dsection_003dalignment"></a>
+</dd>
+<dt><code>--sort-section=alignment</code></dt>
+<dd><p>This option will apply <code>SORT_BY_ALIGNMENT</code> to all wildcard section
+patterns in the linker script.
+</p>
+<a name="index-_002d_002dspare_002ddynamic_002dtags"></a>
+</dd>
+<dt><code>--spare-dynamic-tags=<var>count</var></code></dt>
+<dd><p>This option specifies the number of empty slots to leave in the
+.dynamic section of ELF shared objects. Empty slots may be needed by
+post processing tools, such as the prelinker. The default is 5.
+</p>
+<a name="index-_002d_002dsplit_002dby_002dfile"></a>
+</dd>
+<dt><code>--split-by-file[=<var>size</var>]</code></dt>
+<dd><p>Similar to <samp>--split-by-reloc</samp> but creates a new output section for
+each input file when <var>size</var> is reached. <var>size</var> defaults to a
+size of 1 if not given.
+</p>
+<a name="index-_002d_002dsplit_002dby_002dreloc"></a>
+</dd>
+<dt><code>--split-by-reloc[=<var>count</var>]</code></dt>
+<dd><p>Tries to creates extra sections in the output file so that no single
+output section in the file contains more than <var>count</var> relocations.
+This is useful when generating huge relocatable files for downloading into
+certain real time kernels with the COFF object file format; since COFF
+cannot represent more than 65535 relocations in a single section. Note
+that this will fail to work with object file formats which do not
+support arbitrary sections. The linker will not split up individual
+input sections for redistribution, so if a single input section contains
+more than <var>count</var> relocations one output section will contain that
+many relocations. <var>count</var> defaults to a value of 32768.
+</p>
+<a name="index-_002d_002dstats"></a>
+</dd>
+<dt><code>--stats</code></dt>
+<dd><p>Compute and display statistics about the operation of the linker, such
+as execution time and memory usage.
+</p>
+<a name="index-_002d_002dsysroot_003ddirectory"></a>
+</dd>
+<dt><code>--sysroot=<var>directory</var></code></dt>
+<dd><p>Use <var>directory</var> as the location of the sysroot, overriding the
+configure-time default. This option is only supported by linkers
+that were configured using <samp>--with-sysroot</samp>.
+</p>
+<a name="index-_002d_002dtask_002dlink"></a>
+</dd>
+<dt><code>--task-link</code></dt>
+<dd><p>This is used by COFF/PE based targets to create a task-linked object
+file where all of the global symbols have been converted to statics.
+</p>
+<a name="index-_002d_002dtraditional_002dformat"></a>
+<a name="index-traditional-format"></a>
+</dd>
+<dt><code>--traditional-format</code></dt>
+<dd><p>For some targets, the output of <code>ld</code> is different in some ways from
+the output of some existing linker. This switch requests <code>ld</code> to
+use the traditional format instead.
+</p>
+<a name="index-dbx"></a>
+<p>For example, on SunOS, <code>ld</code> combines duplicate entries in the
+symbol string table. This can reduce the size of an output file with
+full debugging information by over 30 percent. Unfortunately, the SunOS
+<code>dbx</code> program can not read the resulting program (<code>gdb</code> has no
+trouble). The &lsquo;<samp>--traditional-format</samp>&rsquo; switch tells <code>ld</code> to not
+combine duplicate entries.
+</p>
+<a name="index-_002d_002dsection_002dstart_003dsectionname_003dorg"></a>
+</dd>
+<dt><code>--section-start=<var>sectionname</var>=<var>org</var></code></dt>
+<dd><p>Locate a section in the output file at the absolute
+address given by <var>org</var>. You may use this option as many
+times as necessary to locate multiple sections in the command
+line.
+<var>org</var> must be a single hexadecimal integer;
+for compatibility with other linkers, you may omit the leading
+&lsquo;<samp>0x</samp>&rsquo; usually associated with hexadecimal values. <em>Note:</em> there
+should be no white space between <var>sectionname</var>, the equals
+sign (&ldquo;<tt class="key">=</tt>&rdquo;), and <var>org</var>.
+</p>
+<a name="index-_002dTbss_003dorg"></a>
+<a name="index-_002dTdata_003dorg"></a>
+<a name="index-_002dTtext_003dorg"></a>
+<a name="index-segment-origins_002c-cmd-line"></a>
+</dd>
+<dt><code>-Tbss=<var>org</var></code></dt>
+<dt><code>-Tdata=<var>org</var></code></dt>
+<dt><code>-Ttext=<var>org</var></code></dt>
+<dd><p>Same as <samp>--section-start</samp>, with <code>.bss</code>, <code>.data</code> or
+<code>.text</code> as the <var>sectionname</var>.
+</p>
+<a name="index-_002dTtext_002dsegment_003dorg"></a>
+</dd>
+<dt><code>-Ttext-segment=<var>org</var></code></dt>
+<dd><a name="index-text-segment-origin_002c-cmd-line"></a>
+<p>When creating an ELF executable, it will set the address of the first
+byte of the text segment.
+</p>
+<a name="index-_002dTrodata_002dsegment_003dorg"></a>
+</dd>
+<dt><code>-Trodata-segment=<var>org</var></code></dt>
+<dd><a name="index-rodata-segment-origin_002c-cmd-line"></a>
+<p>When creating an ELF executable or shared object for a target where
+the read-only data is in its own segment separate from the executable
+text, it will set the address of the first byte of the read-only data segment.
+</p>
+<a name="index-_002dTldata_002dsegment_003dorg"></a>
+</dd>
+<dt><code>-Tldata-segment=<var>org</var></code></dt>
+<dd><a name="index-ldata-segment-origin_002c-cmd-line"></a>
+<p>When creating an ELF executable or shared object for x86-64 medium memory
+model, it will set the address of the first byte of the ldata segment.
+</p>
+<a name="index-_002d_002dunresolved_002dsymbols"></a>
+</dd>
+<dt><code>--unresolved-symbols=<var>method</var></code></dt>
+<dd><p>Determine how to handle unresolved symbols. There are four possible
+values for &lsquo;<samp>method</samp>&rsquo;:
+</p>
+<dl compact="compact">
+<dt>&lsquo;<samp>ignore-all</samp>&rsquo;</dt>
+<dd><p>Do not report any unresolved symbols.
+</p>
+</dd>
+<dt>&lsquo;<samp>report-all</samp>&rsquo;</dt>
+<dd><p>Report all unresolved symbols. This is the default.
+</p>
+</dd>
+<dt>&lsquo;<samp>ignore-in-object-files</samp>&rsquo;</dt>
+<dd><p>Report unresolved symbols that are contained in shared libraries, but
+ignore them if they come from regular object files.
+</p>
+</dd>
+<dt>&lsquo;<samp>ignore-in-shared-libs</samp>&rsquo;</dt>
+<dd><p>Report unresolved symbols that come from regular object files, but
+ignore them if they come from shared libraries. This can be useful
+when creating a dynamic binary and it is known that all the shared
+libraries that it should be referencing are included on the linker&rsquo;s
+command line.
+</p></dd>
+</dl>
+
+<p>The behaviour for shared libraries on their own can also be controlled
+by the <samp>--[no-]allow-shlib-undefined</samp> option.
+</p>
+<p>Normally the linker will generate an error message for each reported
+unresolved symbol but the option <samp>--warn-unresolved-symbols</samp>
+can change this to a warning.
+</p>
+<a name="index-_002d_002dverbose_005b_003dNUMBER_005d"></a>
+<a name="index-verbose_005b_003dNUMBER_005d"></a>
+</dd>
+<dt><code>--dll-verbose</code></dt>
+<dt><code>--verbose[=<var>NUMBER</var>]</code></dt>
+<dd><p>Display the version number for <code>ld</code> and list the linker emulations
+supported. Display which input files can and cannot be opened. Display
+the linker script being used by the linker. If the optional <var>NUMBER</var>
+argument &gt; 1, plugin symbol status will also be displayed.
+</p>
+<a name="index-_002d_002dversion_002dscript_003dversion_002dscriptfile"></a>
+<a name="index-version-script_002c-symbol-versions"></a>
+</dd>
+<dt><code>--version-script=<var>version-scriptfile</var></code></dt>
+<dd><p>Specify the name of a version script to the linker. This is typically
+used when creating shared libraries to specify additional information
+about the version hierarchy for the library being created. This option
+is only fully supported on ELF platforms which support shared libraries;
+see <a href="#VERSION">VERSION</a>. It is partially supported on PE platforms, which can
+use version scripts to filter symbol visibility in auto-export mode: any
+symbols marked &lsquo;<samp>local</samp>&rsquo; in the version script will not be exported.
+See <a href="#WIN32">WIN32</a>.
+</p>
+<a name="index-_002d_002dwarn_002dcommon"></a>
+<a name="index-warnings_002c-on-combining-symbols"></a>
+<a name="index-combining-symbols_002c-warnings-on"></a>
+</dd>
+<dt><code>--warn-common</code></dt>
+<dd><p>Warn when a common symbol is combined with another common symbol or with
+a symbol definition. Unix linkers allow this somewhat sloppy practice,
+but linkers on some other operating systems do not. This option allows
+you to find potential problems from combining global symbols.
+Unfortunately, some C libraries use this practice, so you may get some
+warnings about symbols in the libraries as well as in your programs.
+</p>
+<p>There are three kinds of global symbols, illustrated here by C examples:
+</p>
+<dl compact="compact">
+<dt>&lsquo;<samp>int i = 1;</samp>&rsquo;</dt>
+<dd><p>A definition, which goes in the initialized data section of the output
+file.
+</p>
+</dd>
+<dt>&lsquo;<samp>extern int i;</samp>&rsquo;</dt>
+<dd><p>An undefined reference, which does not allocate space.
+There must be either a definition or a common symbol for the
+variable somewhere.
+</p>
+</dd>
+<dt>&lsquo;<samp>int i;</samp>&rsquo;</dt>
+<dd><p>A common symbol. If there are only (one or more) common symbols for a
+variable, it goes in the uninitialized data area of the output file.
+The linker merges multiple common symbols for the same variable into a
+single symbol. If they are of different sizes, it picks the largest
+size. The linker turns a common symbol into a declaration, if there is
+a definition of the same variable.
+</p></dd>
+</dl>
+
+<p>The &lsquo;<samp>--warn-common</samp>&rsquo; option can produce five kinds of warnings.
+Each warning consists of a pair of lines: the first describes the symbol
+just encountered, and the second describes the previous symbol
+encountered with the same name. One or both of the two symbols will be
+a common symbol.
+</p>
+<ol>
+<li> Turning a common symbol into a reference, because there is already a
+definition for the symbol.
+<div class="smallexample">
+<pre class="smallexample"><var>file</var>(<var>section</var>): warning: common of `<var>symbol</var>'
+ overridden by definition
+<var>file</var>(<var>section</var>): warning: defined here
+</pre></div>
+
+</li><li> Turning a common symbol into a reference, because a later definition for
+the symbol is encountered. This is the same as the previous case,
+except that the symbols are encountered in a different order.
+<div class="smallexample">
+<pre class="smallexample"><var>file</var>(<var>section</var>): warning: definition of `<var>symbol</var>'
+ overriding common
+<var>file</var>(<var>section</var>): warning: common is here
+</pre></div>
+
+</li><li> Merging a common symbol with a previous same-sized common symbol.
+<div class="smallexample">
+<pre class="smallexample"><var>file</var>(<var>section</var>): warning: multiple common
+ of `<var>symbol</var>'
+<var>file</var>(<var>section</var>): warning: previous common is here
+</pre></div>
+
+</li><li> Merging a common symbol with a previous larger common symbol.
+<div class="smallexample">
+<pre class="smallexample"><var>file</var>(<var>section</var>): warning: common of `<var>symbol</var>'
+ overridden by larger common
+<var>file</var>(<var>section</var>): warning: larger common is here
+</pre></div>
+
+</li><li> Merging a common symbol with a previous smaller common symbol. This is
+the same as the previous case, except that the symbols are
+encountered in a different order.
+<div class="smallexample">
+<pre class="smallexample"><var>file</var>(<var>section</var>): warning: common of `<var>symbol</var>'
+ overriding smaller common
+<var>file</var>(<var>section</var>): warning: smaller common is here
+</pre></div>
+</li></ol>
+
+<a name="index-_002d_002dwarn_002dconstructors"></a>
+</dd>
+<dt><code>--warn-constructors</code></dt>
+<dd><p>Warn if any global constructors are used. This is only useful for a few
+object file formats. For formats like COFF or ELF, the linker can not
+detect the use of global constructors.
+</p>
+<a name="index-_002d_002dwarn_002dexecstack"></a>
+<a name="index-warnings_002c-on-executable-stack"></a>
+<a name="index-executable-stack_002c-warnings-on"></a>
+</dd>
+<dt><code>--warn-execstack</code></dt>
+<dt><code>--no-warn-execstack</code></dt>
+<dd><p>On ELF platforms this option controls how the linker generates warning
+messages when it creates an output file with an executable stack. By
+default the linker will not warn if the <code>-z execstack</code> command
+line option has been used, but this behaviour can be overridden by the
+<samp>--warn-execstack</samp> option.
+</p>
+<p>On the other hand the linker will normally warn if the stack is made
+executable because one or more of the input files need an execuable
+stack and neither of the <code>-z execstack</code> or <code>-z
+noexecstack</code> command line options have been specified. This warning
+can be disabled via the <code>--no-warn-execstack</code> option.
+</p>
+<p>Note: ELF format input files specify that they need an executable
+stack by having a <var>.note.GNU-stack</var> section with the executable
+bit set in its section flags. They can specify that they do not need
+an executable stack by having that section, but without the executable
+flag bit set. If an input file does not have a <var>.note.GNU-stack</var>
+section present then the default behaviour is target specific. For
+some targets, then absence of such a section implies that an
+executable stack <em>is</em> required. This is often a problem for hand
+crafted assembler files.
+</p>
+<a name="index-_002d_002dwarn_002dmultiple_002dgp"></a>
+</dd>
+<dt><code>--warn-multiple-gp</code></dt>
+<dd><p>Warn if multiple global pointer values are required in the output file.
+This is only meaningful for certain processors, such as the Alpha.
+Specifically, some processors put large-valued constants in a special
+section. A special register (the global pointer) points into the middle
+of this section, so that constants can be loaded efficiently via a
+base-register relative addressing mode. Since the offset in
+base-register relative mode is fixed and relatively small (e.g., 16
+bits), this limits the maximum size of the constant pool. Thus, in
+large programs, it is often necessary to use multiple global pointer
+values in order to be able to address all possible constants. This
+option causes a warning to be issued whenever this case occurs.
+</p>
+<a name="index-_002d_002dwarn_002donce"></a>
+<a name="index-warnings_002c-on-undefined-symbols"></a>
+<a name="index-undefined-symbols_002c-warnings-on"></a>
+</dd>
+<dt><code>--warn-once</code></dt>
+<dd><p>Only warn once for each undefined symbol, rather than once per module
+which refers to it.
+</p>
+<a name="index-_002d_002dwarn_002drwx_002dsegments"></a>
+<a name="index-warnings_002c-on-writeable-and-exectuable-segments"></a>
+<a name="index-executable-segments_002c-warnings-on"></a>
+</dd>
+<dt><code>--warn-rwx-segments</code></dt>
+<dt><code>--no-warn-rwx-segments</code></dt>
+<dd><p>Warn if the linker creates a loadable, non-zero sized segment that has
+all three of the read, write and execute permission flags set. Such a
+segment represents a potential security vulnerability. In addition
+warnings will be generated if a thread local storage segment is
+created with the execute permission flag set, regardless of whether or
+not it has the read and/or write flags set.
+</p>
+<p>These warnings are enabled by default. They can be disabled via the
+<samp>--no-warn-rwx-segments</samp> option and re-enabled via the
+<samp>--warn-rwx-segments</samp> option.
+</p>
+<a name="index-_002d_002dwarn_002dsection_002dalign"></a>
+<a name="index-warnings_002c-on-section-alignment"></a>
+<a name="index-section-alignment_002c-warnings-on"></a>
+</dd>
+<dt><code>--warn-section-align</code></dt>
+<dd><p>Warn if the address of an output section is changed because of
+alignment. Typically, the alignment will be set by an input section.
+The address will only be changed if it not explicitly specified; that
+is, if the <code>SECTIONS</code> command does not specify a start address for
+the section (see <a href="#SECTIONS">SECTIONS</a>).
+</p>
+<a name="index-_002d_002dwarn_002dtextrel"></a>
+</dd>
+<dt><code>--warn-textrel</code></dt>
+<dd><p>Warn if the linker adds DT_TEXTREL to a position-independent executable
+or shared object.
+</p>
+<a name="index-_002d_002dwarn_002dalternate_002dem"></a>
+</dd>
+<dt><code>--warn-alternate-em</code></dt>
+<dd><p>Warn if an object has alternate ELF machine code.
+</p>
+<a name="index-_002d_002dwarn_002dunresolved_002dsymbols"></a>
+</dd>
+<dt><code>--warn-unresolved-symbols</code></dt>
+<dd><p>If the linker is going to report an unresolved symbol (see the option
+<samp>--unresolved-symbols</samp>) it will normally generate an error.
+This option makes it generate a warning instead.
+</p>
+<a name="index-_002d_002derror_002dunresolved_002dsymbols"></a>
+</dd>
+<dt><code>--error-unresolved-symbols</code></dt>
+<dd><p>This restores the linker&rsquo;s default behaviour of generating errors when
+it is reporting unresolved symbols.
+</p>
+<a name="index-_002d_002dwhole_002darchive"></a>
+<a name="index-including-an-entire-archive"></a>
+</dd>
+<dt><code>--whole-archive</code></dt>
+<dd><p>For each archive mentioned on the command line after the
+<samp>--whole-archive</samp> option, include every object file in the archive
+in the link, rather than searching the archive for the required object
+files. This is normally used to turn an archive file into a shared
+library, forcing every object to be included in the resulting shared
+library. This option may be used more than once.
+</p>
+<p>Two notes when using this option from gcc: First, gcc doesn&rsquo;t know
+about this option, so you have to use <samp>-Wl,-whole-archive</samp>.
+Second, don&rsquo;t forget to use <samp>-Wl,-no-whole-archive</samp> after your
+list of archives, because gcc will add its own list of archives to
+your link and you may not want this flag to affect those as well.
+</p>
+<a name="index-_002d_002dwrap_003dsymbol"></a>
+</dd>
+<dt><code>--wrap=<var>symbol</var></code></dt>
+<dd><p>Use a wrapper function for <var>symbol</var>. Any undefined reference to
+<var>symbol</var> will be resolved to <code>__wrap_<var>symbol</var></code>. Any
+undefined reference to <code>__real_<var>symbol</var></code> will be resolved to
+<var>symbol</var>.
+</p>
+<p>This can be used to provide a wrapper for a system function. The
+wrapper function should be called <code>__wrap_<var>symbol</var></code>. If it
+wishes to call the system function, it should call
+<code>__real_<var>symbol</var></code>.
+</p>
+<p>Here is a trivial example:
+</p>
+<div class="smallexample">
+<pre class="smallexample">void *
+__wrap_malloc (size_t c)
+{
+ printf (&quot;malloc called with %zu\n&quot;, c);
+ return __real_malloc (c);
+}
+</pre></div>
+
+<p>If you link other code with this file using <samp>--wrap malloc</samp>, then
+all calls to <code>malloc</code> will call the function <code>__wrap_malloc</code>
+instead. The call to <code>__real_malloc</code> in <code>__wrap_malloc</code> will
+call the real <code>malloc</code> function.
+</p>
+<p>You may wish to provide a <code>__real_malloc</code> function as well, so that
+links without the <samp>--wrap</samp> option will succeed. If you do this,
+you should not put the definition of <code>__real_malloc</code> in the same
+file as <code>__wrap_malloc</code>; if you do, the assembler may resolve the
+call before the linker has a chance to wrap it to <code>malloc</code>.
+</p>
+<p>Only undefined references are replaced by the linker. So, translation unit
+internal references to <var>symbol</var> are not resolved to
+<code>__wrap_<var>symbol</var></code>. In the next example, the call to <code>f</code> in
+<code>g</code> is not resolved to <code>__wrap_f</code>.
+</p>
+<div class="smallexample">
+<pre class="smallexample">int
+f (void)
+{
+ return 123;
+}
+
+int
+g (void)
+{
+ return f();
+}
+</pre></div>
+
+<a name="index-_002d_002deh_002dframe_002dhdr"></a>
+<a name="index-_002d_002dno_002deh_002dframe_002dhdr"></a>
+</dd>
+<dt><code>--eh-frame-hdr</code></dt>
+<dt><code>--no-eh-frame-hdr</code></dt>
+<dd><p>Request (<samp>--eh-frame-hdr</samp>) or suppress
+(<samp>--no-eh-frame-hdr</samp>) the creation of <code>.eh_frame_hdr</code>
+section and ELF <code>PT_GNU_EH_FRAME</code> segment header.
+</p>
+<a name="index-_002d_002dld_002dgenerated_002dunwind_002dinfo"></a>
+</dd>
+<dt><code>--no-ld-generated-unwind-info</code></dt>
+<dd><p>Request creation of <code>.eh_frame</code> unwind info for linker
+generated code sections like PLT. This option is on by default
+if linker generated unwind info is supported. This option also
+controls the generation of <code>.sframe</code> stack trace info for linker
+generated code sections like PLT.
+</p>
+<a name="index-_002d_002denable_002dnew_002ddtags"></a>
+<a name="index-_002d_002ddisable_002dnew_002ddtags"></a>
+</dd>
+<dt><code>--enable-new-dtags</code></dt>
+<dt><code>--disable-new-dtags</code></dt>
+<dd><p>This linker can create the new dynamic tags in ELF. But the older ELF
+systems may not understand them. If you specify
+<samp>--enable-new-dtags</samp>, the new dynamic tags will be created as needed
+and older dynamic tags will be omitted.
+If you specify <samp>--disable-new-dtags</samp>, no new dynamic tags will be
+created. By default, the new dynamic tags are not created. Note that
+those options are only available for ELF systems.
+</p>
+<a name="index-_002d_002dhash_002dsize_003dnumber"></a>
+</dd>
+<dt><code>--hash-size=<var>number</var></code></dt>
+<dd><p>Set the default size of the linker&rsquo;s hash tables to a prime number
+close to <var>number</var>. Increasing this value can reduce the length of
+time it takes the linker to perform its tasks, at the expense of
+increasing the linker&rsquo;s memory requirements. Similarly reducing this
+value can reduce the memory requirements at the expense of speed.
+</p>
+<a name="index-_002d_002dhash_002dstyle_003dstyle"></a>
+</dd>
+<dt><code>--hash-style=<var>style</var></code></dt>
+<dd><p>Set the type of linker&rsquo;s hash table(s). <var>style</var> can be either
+<code>sysv</code> for classic ELF <code>.hash</code> section, <code>gnu</code> for
+new style GNU <code>.gnu.hash</code> section or <code>both</code> for both
+the classic ELF <code>.hash</code> and new style GNU <code>.gnu.hash</code>
+hash tables. The default depends upon how the linker was configured,
+but for most Linux based systems it will be <code>both</code>.
+</p>
+<a name="index-_002d_002dcompress_002ddebug_002dsections_003dnone"></a>
+<a name="index-_002d_002dcompress_002ddebug_002dsections_003dzlib"></a>
+<a name="index-_002d_002dcompress_002ddebug_002dsections_003dzlib_002dgnu"></a>
+<a name="index-_002d_002dcompress_002ddebug_002dsections_003dzlib_002dgabi"></a>
+<a name="index-_002d_002dcompress_002ddebug_002dsections_003dzstd"></a>
+</dd>
+<dt><code>--compress-debug-sections=none</code></dt>
+<dt><code>--compress-debug-sections=zlib</code></dt>
+<dt><code>--compress-debug-sections=zlib-gnu</code></dt>
+<dt><code>--compress-debug-sections=zlib-gabi</code></dt>
+<dt><code>--compress-debug-sections=zstd</code></dt>
+<dd><p>On ELF platforms, these options control how DWARF debug sections are
+compressed using zlib.
+</p>
+<p><samp>--compress-debug-sections=none</samp> doesn&rsquo;t compress DWARF debug
+sections. <samp>--compress-debug-sections=zlib-gnu</samp> compresses
+DWARF debug sections and renames them to begin with &lsquo;<samp>.zdebug</samp>&rsquo;
+instead of &lsquo;<samp>.debug</samp>&rsquo;. <samp>--compress-debug-sections=zlib-gabi</samp>
+also compresses DWARF debug sections, but rather than renaming them it
+sets the SHF_COMPRESSED flag in the sections&rsquo; headers.
+</p>
+<p>The <samp>--compress-debug-sections=zlib</samp> option is an alias for
+<samp>--compress-debug-sections=zlib-gabi</samp>.
+</p>
+<p><samp>--compress-debug-sections=zstd</samp> compresses DWARF debug sections using
+zstd.
+</p>
+<p>Note that this option overrides any compression in input debug
+sections, so if a binary is linked with <samp>--compress-debug-sections=none</samp>
+for example, then any compressed debug sections in input files will be
+uncompressed before they are copied into the output binary.
+</p>
+<p>The default compression behaviour varies depending upon the target
+involved and the configure options used to build the toolchain. The
+default can be determined by examining the output from the linker&rsquo;s
+<samp>--help</samp> option.
+</p>
+<a name="index-_002d_002dreduce_002dmemory_002doverheads"></a>
+</dd>
+<dt><code>--reduce-memory-overheads</code></dt>
+<dd><p>This option reduces memory requirements at ld runtime, at the expense of
+linking speed. This was introduced to select the old O(n^2) algorithm
+for link map file generation, rather than the new O(n) algorithm which uses
+about 40% more memory for symbol storage.
+</p>
+<p>Another effect of the switch is to set the default hash table size to
+1021, which again saves memory at the cost of lengthening the linker&rsquo;s
+run time. This is not done however if the <samp>--hash-size</samp> switch
+has been used.
+</p>
+<p>The <samp>--reduce-memory-overheads</samp> switch may be also be used to
+enable other tradeoffs in future versions of the linker.
+</p>
+<a name="index-_002d_002dmax_002dcache_002dsize_003dsize"></a>
+</dd>
+<dt><code>--max-cache-size=<var>size</var></code></dt>
+<dd><p><code>ld</code> normally caches the relocation information and symbol tables
+of input files in memory with the unlimited size. This option sets the
+maximum cache size to <var>size</var>.
+</p>
+<a name="index-_002d_002dbuild_002did"></a>
+<a name="index-_002d_002dbuild_002did_003dstyle"></a>
+</dd>
+<dt><code>--build-id</code></dt>
+<dt><code>--build-id=<var>style</var></code></dt>
+<dd><p>Request the creation of a <code>.note.gnu.build-id</code> ELF note section
+or a <code>.buildid</code> COFF section. The contents of the note are
+unique bits identifying this linked file. <var>style</var> can be
+<code>uuid</code> to use 128 random bits, <code>sha1</code> to use a 160-bit
+<small>SHA1</small> hash on the normative parts of the output contents,
+<code>md5</code> to use a 128-bit <small>MD5</small> hash on the normative parts of
+the output contents, or <code>0x<var>hexstring</var></code> to use a chosen bit
+string specified as an even number of hexadecimal digits (<code>-</code> and
+<code>:</code> characters between digit pairs are ignored). If <var>style</var>
+is omitted, <code>sha1</code> is used.
+</p>
+<p>The <code>md5</code> and <code>sha1</code> styles produces an identifier
+that is always the same in an identical output file, but will be
+unique among all nonidentical output files. It is not intended
+to be compared as a checksum for the file&rsquo;s contents. A linked
+file may be changed later by other tools, but the build ID bit
+string identifying the original linked file does not change.
+</p>
+<p>Passing <code>none</code> for <var>style</var> disables the setting from any
+<code>--build-id</code> options earlier on the command line.
+</p>
+<a name="index-_002d_002dpackage_002dmetadata_003dJSON"></a>
+</dd>
+<dt><code>--package-metadata=<var>JSON</var></code></dt>
+<dd><p>Request the creation of a <code>.note.package</code> ELF note section. The
+contents of the note are in JSON format, as per the package metadata
+specification. For more information see:
+https://systemd.io/ELF_PACKAGE_METADATA/
+If the JSON argument is missing/empty then this will disable the
+creation of the metadata note, if one had been enabled by an earlier
+occurrence of the &ndash;package-metdata option.
+If the linker has been built with libjansson, then the JSON string
+will be validated.
+</p></dd>
+</dl>
+
+
+<a name="Options-Specific-to-i386-PE-Targets"></a>
+<h4 class="subsection">2.1.1 Options Specific to i386 PE Targets</h4>
+
+
+<p>The i386 PE linker supports the <samp>-shared</samp> option, which causes
+the output to be a dynamically linked library (DLL) instead of a
+normal executable. You should name the output <code>*.dll</code> when you
+use this option. In addition, the linker fully supports the standard
+<code>*.def</code> files, which may be specified on the linker command line
+like an object file (in fact, it should precede archives it exports
+symbols from, to ensure that they get linked in, just like a normal
+object file).
+</p>
+<p>In addition to the options common to all targets, the i386 PE linker
+support additional command-line options that are specific to the i386
+PE target. Options that take values may be separated from their
+values by either a space or an equals sign.
+</p>
+<dl compact="compact">
+<dd>
+<a name="index-_002d_002dadd_002dstdcall_002dalias"></a>
+</dd>
+<dt><code>--add-stdcall-alias</code></dt>
+<dd><p>If given, symbols with a stdcall suffix (@<var>nn</var>) will be exported
+as-is and also with the suffix stripped.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dbase_002dfile"></a>
+</dd>
+<dt><code>--base-file <var>file</var></code></dt>
+<dd><p>Use <var>file</var> as the name of a file in which to save the base
+addresses of all the relocations needed for generating DLLs with
+<samp>dlltool</samp>.
+[This is an i386 PE specific option]
+</p>
+<a name="index-_002d_002ddll"></a>
+</dd>
+<dt><code>--dll</code></dt>
+<dd><p>Create a DLL instead of a regular executable. You may also use
+<samp>-shared</samp> or specify a <code>LIBRARY</code> in a given <code>.def</code>
+file.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002denable_002dlong_002dsection_002dnames"></a>
+<a name="index-_002d_002ddisable_002dlong_002dsection_002dnames"></a>
+</dd>
+<dt><code>--enable-long-section-names</code></dt>
+<dt><code>--disable-long-section-names</code></dt>
+<dd><p>The PE variants of the COFF object format add an extension that permits
+the use of section names longer than eight characters, the normal limit
+for COFF. By default, these names are only allowed in object files, as
+fully-linked executable images do not carry the COFF string table required
+to support the longer names. As a GNU extension, it is possible to
+allow their use in executable images as well, or to (probably pointlessly!)
+disallow it in object files, by using these two options. Executable images
+generated with these long section names are slightly non-standard, carrying
+as they do a string table, and may generate confusing output when examined
+with non-GNU PE-aware tools, such as file viewers and dumpers. However,
+GDB relies on the use of PE long section names to find Dwarf-2 debug
+information sections in an executable image at runtime, and so if neither
+option is specified on the command-line, <code>ld</code> will enable long
+section names, overriding the default and technically correct behaviour,
+when it finds the presence of debug information while linking an executable
+image and not stripping symbols.
+[This option is valid for all PE targeted ports of the linker]
+</p>
+<a name="index-_002d_002denable_002dstdcall_002dfixup"></a>
+<a name="index-_002d_002ddisable_002dstdcall_002dfixup"></a>
+</dd>
+<dt><code>--enable-stdcall-fixup</code></dt>
+<dt><code>--disable-stdcall-fixup</code></dt>
+<dd><p>If the link finds a symbol that it cannot resolve, it will attempt to
+do &ldquo;fuzzy linking&rdquo; by looking for another defined symbol that differs
+only in the format of the symbol name (cdecl vs stdcall) and will
+resolve that symbol by linking to the match. For example, the
+undefined symbol <code>_foo</code> might be linked to the function
+<code>_foo@12</code>, or the undefined symbol <code>_bar@16</code> might be linked
+to the function <code>_bar</code>. When the linker does this, it prints a
+warning, since it normally should have failed to link, but sometimes
+import libraries generated from third-party dlls may need this feature
+to be usable. If you specify <samp>--enable-stdcall-fixup</samp>, this
+feature is fully enabled and warnings are not printed. If you specify
+<samp>--disable-stdcall-fixup</samp>, this feature is disabled and such
+mismatches are considered to be errors.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dleading_002dunderscore"></a>
+<a name="index-_002d_002dno_002dleading_002dunderscore"></a>
+</dd>
+<dt><code>--leading-underscore</code></dt>
+<dt><code>--no-leading-underscore</code></dt>
+<dd><p>For most targets default symbol-prefix is an underscore and is defined
+in target&rsquo;s description. By this option it is possible to
+disable/enable the default underscore symbol-prefix.
+</p>
+<a name="index-DLLs_002c-creating"></a>
+<a name="index-_002d_002dexport_002dall_002dsymbols"></a>
+</dd>
+<dt><code>--export-all-symbols</code></dt>
+<dd><p>If given, all global symbols in the objects used to build a DLL will
+be exported by the DLL. Note that this is the default if there
+otherwise wouldn&rsquo;t be any exported symbols. When symbols are
+explicitly exported via DEF files or implicitly exported via function
+attributes, the default is to not export anything else unless this
+option is given. Note that the symbols <code>DllMain@12</code>,
+<code>DllEntryPoint@0</code>, <code>DllMainCRTStartup@12</code>, and
+<code>impure_ptr</code> will not be automatically
+exported. Also, symbols imported from other DLLs will not be
+re-exported, nor will symbols specifying the DLL&rsquo;s internal layout
+such as those beginning with <code>_head_</code> or ending with
+<code>_iname</code>. In addition, no symbols from <code>libgcc</code>,
+<code>libstd++</code>, <code>libmingw32</code>, or <code>crtX.o</code> will be exported.
+Symbols whose names begin with <code>__rtti_</code> or <code>__builtin_</code> will
+not be exported, to help with C++ DLLs. Finally, there is an
+extensive list of cygwin-private symbols that are not exported
+(obviously, this applies on when building DLLs for cygwin targets).
+These cygwin-excludes are: <code>_cygwin_dll_entry@12</code>,
+<code>_cygwin_crt0_common@8</code>, <code>_cygwin_noncygwin_dll_entry@12</code>,
+<code>_fmode</code>, <code>_impure_ptr</code>, <code>cygwin_attach_dll</code>,
+<code>cygwin_premain0</code>, <code>cygwin_premain1</code>, <code>cygwin_premain2</code>,
+<code>cygwin_premain3</code>, and <code>environ</code>.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dexclude_002dsymbols"></a>
+</dd>
+<dt><code>--exclude-symbols <var>symbol</var>,<var>symbol</var>,...</code></dt>
+<dd><p>Specifies a list of symbols which should not be automatically
+exported. The symbol names may be delimited by commas or colons.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dexclude_002dall_002dsymbols"></a>
+</dd>
+<dt><code>--exclude-all-symbols</code></dt>
+<dd><p>Specifies no symbols should be automatically exported.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dfile_002dalignment"></a>
+</dd>
+<dt><code>--file-alignment</code></dt>
+<dd><p>Specify the file alignment. Sections in the file will always begin at
+file offsets which are multiples of this number. This defaults to
+512.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-heap-size"></a>
+<a name="index-_002d_002dheap"></a>
+</dd>
+<dt><code>--heap <var>reserve</var></code></dt>
+<dt><code>--heap <var>reserve</var>,<var>commit</var></code></dt>
+<dd><p>Specify the number of bytes of memory to reserve (and optionally commit)
+to be used as heap for this program. The default is 1MB reserved, 4K
+committed.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-image-base"></a>
+<a name="index-_002d_002dimage_002dbase"></a>
+</dd>
+<dt><code>--image-base <var>value</var></code></dt>
+<dd><p>Use <var>value</var> as the base address of your program or dll. This is
+the lowest memory location that will be used when your program or dll
+is loaded. To reduce the need to relocate and improve performance of
+your dlls, each should have a unique base address and not overlap any
+other dlls. The default is 0x400000 for executables, and 0x10000000
+for dlls.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dkill_002dat"></a>
+</dd>
+<dt><code>--kill-at</code></dt>
+<dd><p>If given, the stdcall suffixes (@<var>nn</var>) will be stripped from
+symbols before they are exported.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dlarge_002daddress_002daware"></a>
+</dd>
+<dt><code>--large-address-aware</code></dt>
+<dd><p>If given, the appropriate bit in the &ldquo;Characteristics&rdquo; field of the COFF
+header is set to indicate that this executable supports virtual addresses
+greater than 2 gigabytes. This should be used in conjunction with the /3GB
+or /USERVA=<var>value</var> megabytes switch in the &ldquo;[operating systems]&rdquo;
+section of the BOOT.INI. Otherwise, this bit has no effect.
+[This option is specific to PE targeted ports of the linker]
+</p>
+<a name="index-_002d_002ddisable_002dlarge_002daddress_002daware"></a>
+</dd>
+<dt><code>--disable-large-address-aware</code></dt>
+<dd><p>Reverts the effect of a previous &lsquo;<samp>--large-address-aware</samp>&rsquo; option.
+This is useful if &lsquo;<samp>--large-address-aware</samp>&rsquo; is always set by the compiler
+driver (e.g. Cygwin gcc) and the executable does not support virtual
+addresses greater than 2 gigabytes.
+[This option is specific to PE targeted ports of the linker]
+</p>
+<a name="index-_002d_002dmajor_002dimage_002dversion"></a>
+</dd>
+<dt><code>--major-image-version <var>value</var></code></dt>
+<dd><p>Sets the major number of the &ldquo;image version&rdquo;. Defaults to 1.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dmajor_002dos_002dversion"></a>
+</dd>
+<dt><code>--major-os-version <var>value</var></code></dt>
+<dd><p>Sets the major number of the &ldquo;os version&rdquo;. Defaults to 4.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dmajor_002dsubsystem_002dversion"></a>
+</dd>
+<dt><code>--major-subsystem-version <var>value</var></code></dt>
+<dd><p>Sets the major number of the &ldquo;subsystem version&rdquo;. Defaults to 4.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dminor_002dimage_002dversion"></a>
+</dd>
+<dt><code>--minor-image-version <var>value</var></code></dt>
+<dd><p>Sets the minor number of the &ldquo;image version&rdquo;. Defaults to 0.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dminor_002dos_002dversion"></a>
+</dd>
+<dt><code>--minor-os-version <var>value</var></code></dt>
+<dd><p>Sets the minor number of the &ldquo;os version&rdquo;. Defaults to 0.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dminor_002dsubsystem_002dversion"></a>
+</dd>
+<dt><code>--minor-subsystem-version <var>value</var></code></dt>
+<dd><p>Sets the minor number of the &ldquo;subsystem version&rdquo;. Defaults to 0.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-DEF-files_002c-creating"></a>
+<a name="index-DLLs_002c-creating-1"></a>
+<a name="index-_002d_002doutput_002ddef"></a>
+</dd>
+<dt><code>--output-def <var>file</var></code></dt>
+<dd><p>The linker will create the file <var>file</var> which will contain a DEF
+file corresponding to the DLL the linker is generating. This DEF file
+(which should be called <code>*.def</code>) may be used to create an import
+library with <code>dlltool</code> or may be used as a reference to
+automatically or implicitly exported symbols.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-DLLs_002c-creating-2"></a>
+<a name="index-_002d_002denable_002dauto_002dimage_002dbase"></a>
+</dd>
+<dt><code>--enable-auto-image-base</code></dt>
+<dt><code>--enable-auto-image-base=<var>value</var></code></dt>
+<dd><p>Automatically choose the image base for DLLs, optionally starting with base
+<var>value</var>, unless one is specified using the <code>--image-base</code> argument.
+By using a hash generated from the dllname to create unique image bases
+for each DLL, in-memory collisions and relocations which can delay program
+execution are avoided.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002ddisable_002dauto_002dimage_002dbase"></a>
+</dd>
+<dt><code>--disable-auto-image-base</code></dt>
+<dd><p>Do not automatically generate a unique image base. If there is no
+user-specified image base (<code>--image-base</code>) then use the platform
+default.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-DLLs_002c-linking-to"></a>
+<a name="index-_002d_002ddll_002dsearch_002dprefix"></a>
+</dd>
+<dt><code>--dll-search-prefix <var>string</var></code></dt>
+<dd><p>When linking dynamically to a dll without an import library,
+search for <code>&lt;string&gt;&lt;basename&gt;.dll</code> in preference to
+<code>lib&lt;basename&gt;.dll</code>. This behaviour allows easy distinction
+between DLLs built for the various &quot;subplatforms&quot;: native, cygwin,
+uwin, pw, etc. For instance, cygwin DLLs typically use
+<code>--dll-search-prefix=cyg</code>.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002denable_002dauto_002dimport"></a>
+</dd>
+<dt><code>--enable-auto-import</code></dt>
+<dd><p>Do sophisticated linking of <code>_symbol</code> to <code>__imp__symbol</code> for
+DATA imports from DLLs, thus making it possible to bypass the dllimport
+mechanism on the user side and to reference unmangled symbol names.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<p>The following remarks pertain to the original implementation of the
+feature and are obsolete nowadays for Cygwin and MinGW targets.
+</p>
+<p>Note: Use of the &rsquo;auto-import&rsquo; extension will cause the text section
+of the image file to be made writable. This does not conform to the
+PE-COFF format specification published by Microsoft.
+</p>
+<p>Note - use of the &rsquo;auto-import&rsquo; extension will also cause read only
+data which would normally be placed into the .rdata section to be
+placed into the .data section instead. This is in order to work
+around a problem with consts that is described here:
+http://www.cygwin.com/ml/cygwin/2004-09/msg01101.html
+</p>
+<p>Using &rsquo;auto-import&rsquo; generally will &rsquo;just work&rsquo; &ndash; but sometimes you may
+see this message:
+</p>
+<p>&quot;variable &rsquo;&lt;var&gt;&rsquo; can&rsquo;t be auto-imported. Please read the
+documentation for ld&rsquo;s <code>--enable-auto-import</code> for details.&quot;
+</p>
+<p>This message occurs when some (sub)expression accesses an address
+ultimately given by the sum of two constants (Win32 import tables only
+allow one). Instances where this may occur include accesses to member
+fields of struct variables imported from a DLL, as well as using a
+constant index into an array variable imported from a DLL. Any
+multiword variable (arrays, structs, long long, etc) may trigger
+this error condition. However, regardless of the exact data type
+of the offending exported variable, ld will always detect it, issue
+the warning, and exit.
+</p>
+<p>There are several ways to address this difficulty, regardless of the
+data type of the exported variable:
+</p>
+<p>One way is to use &ndash;enable-runtime-pseudo-reloc switch. This leaves the task
+of adjusting references in your client code for runtime environment, so
+this method works only when runtime environment supports this feature.
+</p>
+<p>A second solution is to force one of the &rsquo;constants&rsquo; to be a variable &ndash;
+that is, unknown and un-optimizable at compile time. For arrays,
+there are two possibilities: a) make the indexee (the array&rsquo;s address)
+a variable, or b) make the &rsquo;constant&rsquo; index a variable. Thus:
+</p>
+<div class="example">
+<pre class="example">extern type extern_array[];
+extern_array[1] --&gt;
+ { volatile type *t=extern_array; t[1] }
+</pre></div>
+
+<p>or
+</p>
+<div class="example">
+<pre class="example">extern type extern_array[];
+extern_array[1] --&gt;
+ { volatile int t=1; extern_array[t] }
+</pre></div>
+
+<p>For structs (and most other multiword data types) the only option
+is to make the struct itself (or the long long, or the ...) variable:
+</p>
+<div class="example">
+<pre class="example">extern struct s extern_struct;
+extern_struct.field --&gt;
+ { volatile struct s *t=&amp;extern_struct; t-&gt;field }
+</pre></div>
+
+<p>or
+</p>
+<div class="example">
+<pre class="example">extern long long extern_ll;
+extern_ll --&gt;
+ { volatile long long * local_ll=&amp;extern_ll; *local_ll }
+</pre></div>
+
+<p>A third method of dealing with this difficulty is to abandon
+&rsquo;auto-import&rsquo; for the offending symbol and mark it with
+<code>__declspec(dllimport)</code>. However, in practice that
+requires using compile-time #defines to indicate whether you are
+building a DLL, building client code that will link to the DLL, or
+merely building/linking to a static library. In making the choice
+between the various methods of resolving the &rsquo;direct address with
+constant offset&rsquo; problem, you should consider typical real-world usage:
+</p>
+<p>Original:
+</p><div class="example">
+<pre class="example">--foo.h
+extern int arr[];
+--foo.c
+#include &quot;foo.h&quot;
+void main(int argc, char **argv){
+ printf(&quot;%d\n&quot;,arr[1]);
+}
+</pre></div>
+
+<p>Solution 1:
+</p><div class="example">
+<pre class="example">--foo.h
+extern int arr[];
+--foo.c
+#include &quot;foo.h&quot;
+void main(int argc, char **argv){
+ /* This workaround is for win32 and cygwin; do not &quot;optimize&quot; */
+ volatile int *parr = arr;
+ printf(&quot;%d\n&quot;,parr[1]);
+}
+</pre></div>
+
+<p>Solution 2:
+</p><div class="example">
+<pre class="example">--foo.h
+/* Note: auto-export is assumed (no __declspec(dllexport)) */
+#if (defined(_WIN32) || defined(__CYGWIN__)) &amp;&amp; \
+ !(defined(FOO_BUILD_DLL) || defined(FOO_STATIC))
+#define FOO_IMPORT __declspec(dllimport)
+#else
+#define FOO_IMPORT
+#endif
+extern FOO_IMPORT int arr[];
+--foo.c
+#include &quot;foo.h&quot;
+void main(int argc, char **argv){
+ printf(&quot;%d\n&quot;,arr[1]);
+}
+</pre></div>
+
+<p>A fourth way to avoid this problem is to re-code your
+library to use a functional interface rather than a data interface
+for the offending variables (e.g. set_foo() and get_foo() accessor
+functions).
+</p>
+<a name="index-_002d_002ddisable_002dauto_002dimport"></a>
+</dd>
+<dt><code>--disable-auto-import</code></dt>
+<dd><p>Do not attempt to do sophisticated linking of <code>_symbol</code> to
+<code>__imp__symbol</code> for DATA imports from DLLs.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002denable_002druntime_002dpseudo_002dreloc"></a>
+</dd>
+<dt><code>--enable-runtime-pseudo-reloc</code></dt>
+<dd><p>If your code contains expressions described in &ndash;enable-auto-import section,
+that is, DATA imports from DLL with non-zero offset, this switch will create
+a vector of &rsquo;runtime pseudo relocations&rsquo; which can be used by runtime
+environment to adjust references to such data in your client code.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002ddisable_002druntime_002dpseudo_002dreloc"></a>
+</dd>
+<dt><code>--disable-runtime-pseudo-reloc</code></dt>
+<dd><p>Do not create pseudo relocations for non-zero offset DATA imports from DLLs.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002denable_002dextra_002dpe_002ddebug"></a>
+</dd>
+<dt><code>--enable-extra-pe-debug</code></dt>
+<dd><p>Show additional debug info related to auto-import symbol thunking.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dsection_002dalignment"></a>
+</dd>
+<dt><code>--section-alignment</code></dt>
+<dd><p>Sets the section alignment. Sections in memory will always begin at
+addresses which are a multiple of this number. Defaults to 0x1000.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-stack-size"></a>
+<a name="index-_002d_002dstack"></a>
+</dd>
+<dt><code>--stack <var>reserve</var></code></dt>
+<dt><code>--stack <var>reserve</var>,<var>commit</var></code></dt>
+<dd><p>Specify the number of bytes of memory to reserve (and optionally commit)
+to be used as stack for this program. The default is 2MB reserved, 4K
+committed.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<a name="index-_002d_002dsubsystem"></a>
+</dd>
+<dt><code>--subsystem <var>which</var></code></dt>
+<dt><code>--subsystem <var>which</var>:<var>major</var></code></dt>
+<dt><code>--subsystem <var>which</var>:<var>major</var>.<var>minor</var></code></dt>
+<dd><p>Specifies the subsystem under which your program will execute. The
+legal values for <var>which</var> are <code>native</code>, <code>windows</code>,
+<code>console</code>, <code>posix</code>, and <code>xbox</code>. You may optionally set
+the subsystem version also. Numeric values are also accepted for
+<var>which</var>.
+[This option is specific to the i386 PE targeted port of the linker]
+</p>
+<p>The following options set flags in the <code>DllCharacteristics</code> field
+of the PE file header:
+[These options are specific to PE targeted ports of the linker]
+</p>
+<a name="index-_002d_002dhigh_002dentropy_002dva"></a>
+</dd>
+<dt><code>--high-entropy-va</code></dt>
+<dt><code>--disable-high-entropy-va</code></dt>
+<dd><p>Image is compatible with 64-bit address space layout randomization
+(ASLR). This option is enabled by default for 64-bit PE images.
+</p>
+<p>This option also implies <samp>--dynamicbase</samp> and
+<samp>--enable-reloc-section</samp>.
+</p>
+<a name="index-_002d_002ddynamicbase"></a>
+</dd>
+<dt><code>--dynamicbase</code></dt>
+<dt><code>--disable-dynamicbase</code></dt>
+<dd><p>The image base address may be relocated using address space layout
+randomization (ASLR). This feature was introduced with MS Windows
+Vista for i386 PE targets. This option is enabled by default but
+can be disabled via the <samp>--disable-dynamicbase</samp> option.
+This option also implies <samp>--enable-reloc-section</samp>.
+</p>
+<a name="index-_002d_002dforceinteg"></a>
+</dd>
+<dt><code>--forceinteg</code></dt>
+<dt><code>--disable-forceinteg</code></dt>
+<dd><p>Code integrity checks are enforced. This option is disabled by
+default.
+</p>
+<a name="index-_002d_002dnxcompat"></a>
+</dd>
+<dt><code>--nxcompat</code></dt>
+<dt><code>--disable-nxcompat</code></dt>
+<dd><p>The image is compatible with the Data Execution Prevention.
+This feature was introduced with MS Windows XP SP2 for i386 PE
+targets. The option is enabled by default.
+</p>
+<a name="index-_002d_002dno_002disolation"></a>
+</dd>
+<dt><code>--no-isolation</code></dt>
+<dt><code>--disable-no-isolation</code></dt>
+<dd><p>Although the image understands isolation, do not isolate the image.
+This option is disabled by default.
+</p>
+<a name="index-_002d_002dno_002dseh"></a>
+</dd>
+<dt><code>--no-seh</code></dt>
+<dt><code>--disable-no-seh</code></dt>
+<dd><p>The image does not use SEH. No SE handler may be called from
+this image. This option is disabled by default.
+</p>
+<a name="index-_002d_002dno_002dbind"></a>
+</dd>
+<dt><code>--no-bind</code></dt>
+<dt><code>--disable-no-bind</code></dt>
+<dd><p>Do not bind this image. This option is disabled by default.
+</p>
+<a name="index-_002d_002dwdmdriver"></a>
+</dd>
+<dt><code>--wdmdriver</code></dt>
+<dt><code>--disable-wdmdriver</code></dt>
+<dd><p>The driver uses the MS Windows Driver Model. This option is disabled
+by default.
+</p>
+<a name="index-_002d_002dtsaware"></a>
+</dd>
+<dt><code>--tsaware</code></dt>
+<dt><code>--disable-tsaware</code></dt>
+<dd><p>The image is Terminal Server aware. This option is disabled by
+default.
+</p>
+<a name="index-_002d_002dinsert_002dtimestamp"></a>
+</dd>
+<dt><code>--insert-timestamp</code></dt>
+<dt><code>--no-insert-timestamp</code></dt>
+<dd><p>Insert a real timestamp into the image. This is the default behaviour
+as it matches legacy code and it means that the image will work with
+other, proprietary tools. The problem with this default is that it
+will result in slightly different images being produced each time the
+same sources are linked. The option <samp>--no-insert-timestamp</samp>
+can be used to insert a zero value for the timestamp, this ensuring
+that binaries produced from identical sources will compare
+identically.
+</p>
+<a name="index-_002d_002denable_002dreloc_002dsection"></a>
+</dd>
+<dt><code>--enable-reloc-section</code></dt>
+<dt><code>--disable-reloc-section</code></dt>
+<dd><p>Create the base relocation table, which is necessary if the image
+is loaded at a different image base than specified in the PE header.
+This option is enabled by default.
+</p></dd>
+</dl>
+
+
+<a name="Options-specific-to-C6X-uClinux-targets"></a>
+<h4 class="subsection">2.1.2 Options specific to C6X uClinux targets</h4>
+
+
+<p>The C6X uClinux target uses a binary format called DSBT to support shared
+libraries. Each shared library in the system needs to have a unique index;
+all executables use an index of 0.
+</p>
+<dl compact="compact">
+<dd>
+<a name="index-_002d_002ddsbt_002dsize"></a>
+</dd>
+<dt><code>--dsbt-size <var>size</var></code></dt>
+<dd><p>This option sets the number of entries in the DSBT of the current executable
+or shared library to <var>size</var>. The default is to create a table with 64
+entries.
+</p>
+<a name="index-_002d_002ddsbt_002dindex"></a>
+</dd>
+<dt><code>--dsbt-index <var>index</var></code></dt>
+<dd><p>This option sets the DSBT index of the current executable or shared library
+to <var>index</var>. The default is 0, which is appropriate for generating
+executables. If a shared library is generated with a DSBT index of 0, the
+<code>R_C6000_DSBT_INDEX</code> relocs are copied into the output file.
+</p>
+<a name="index-_002d_002dno_002dmerge_002dexidx_002dentries"></a>
+<p>The &lsquo;<samp>--no-merge-exidx-entries</samp>&rsquo; switch disables the merging of adjacent
+exidx entries in frame unwind info.
+</p>
+</dd>
+</dl>
+
+
+<a name="Options-specific-to-C_002dSKY-targets"></a>
+<h4 class="subsection">2.1.3 Options specific to C-SKY targets</h4>
+
+
+<dl compact="compact">
+<dd>
+<a name="index-_002d_002dbranch_002dstub-on-C_002dSKY"></a>
+</dd>
+<dt><code>--branch-stub</code></dt>
+<dd><p>This option enables linker branch relaxation by inserting branch stub
+sections when needed to extend the range of branches. This option is
+usually not required since C-SKY supports branch and call instructions that
+can access the full memory range and branch relaxation is normally handled by
+the compiler or assembler.
+</p>
+<a name="index-_002d_002dstub_002dgroup_002dsize-on-C_002dSKY"></a>
+</dd>
+<dt><code>--stub-group-size=<var>N</var></code></dt>
+<dd><p>This option allows finer control of linker branch stub creation.
+It sets the maximum size of a group of input sections that can
+be handled by one stub section. A negative value of <var>N</var> locates
+stub sections after their branches, while a positive value allows stub
+sections to appear either before or after the branches. Values of
+&lsquo;<samp>1</samp>&rsquo; or &lsquo;<samp>-1</samp>&rsquo; indicate that the
+linker should choose suitable defaults.
+</p>
+</dd>
+</dl>
+
+
+<a name="Options-specific-to-Motorola-68HC11-and-68HC12-targets"></a>
+<h4 class="subsection">2.1.4 Options specific to Motorola 68HC11 and 68HC12 targets</h4>
+
+
+<p>The 68HC11 and 68HC12 linkers support specific options to control the
+memory bank switching mapping and trampoline code generation.
+</p>
+<dl compact="compact">
+<dd>
+<a name="index-_002d_002dno_002dtrampoline"></a>
+</dd>
+<dt><code>--no-trampoline</code></dt>
+<dd><p>This option disables the generation of trampoline. By default a trampoline
+is generated for each far function which is called using a <code>jsr</code>
+instruction (this happens when a pointer to a far function is taken).
+</p>
+<a name="index-_002d_002dbank_002dwindow"></a>
+</dd>
+<dt><code>--bank-window <var>name</var></code></dt>
+<dd><p>This option indicates to the linker the name of the memory region in
+the &lsquo;<samp>MEMORY</samp>&rsquo; specification that describes the memory bank window.
+The definition of such region is then used by the linker to compute
+paging and addresses within the memory window.
+</p>
+</dd>
+</dl>
+
+
+<a name="Options-specific-to-Motorola-68K-target"></a>
+<h4 class="subsection">2.1.5 Options specific to Motorola 68K target</h4>
+
+
+<p>The following options are supported to control handling of GOT generation
+when linking for 68K targets.
+</p>
+<dl compact="compact">
+<dd>
+<a name="index-_002d_002dgot"></a>
+</dd>
+<dt><code>--got=<var>type</var></code></dt>
+<dd><p>This option tells the linker which GOT generation scheme to use.
+<var>type</var> should be one of &lsquo;<samp>single</samp>&rsquo;, &lsquo;<samp>negative</samp>&rsquo;,
+&lsquo;<samp>multigot</samp>&rsquo; or &lsquo;<samp>target</samp>&rsquo;. For more information refer to the
+Info entry for <samp>ld</samp>.
+</p>
+</dd>
+</dl>
+
+
+<a name="Options-specific-to-MIPS-targets"></a>
+<h4 class="subsection">2.1.6 Options specific to MIPS targets</h4>
+
+
+<p>The following options are supported to control microMIPS instruction
+generation and branch relocation checks for ISA mode transitions when
+linking for MIPS targets.
+</p>
+<dl compact="compact">
+<dd>
+<a name="index-_002d_002dinsn32"></a>
+</dd>
+<dt><code>--insn32</code></dt>
+<dd><a name="index-_002d_002dno_002dinsn32"></a>
+</dd>
+<dt><code>--no-insn32</code></dt>
+<dd><p>These options control the choice of microMIPS instructions used in code
+generated by the linker, such as that in the PLT or lazy binding stubs,
+or in relaxation. If &lsquo;<samp>--insn32</samp>&rsquo; is used, then the linker only uses
+32-bit instruction encodings. By default or if &lsquo;<samp>--no-insn32</samp>&rsquo; is
+used, all instruction encodings are used, including 16-bit ones where
+possible.
+</p>
+<a name="index-_002d_002dignore_002dbranch_002disa"></a>
+</dd>
+<dt><code>--ignore-branch-isa</code></dt>
+<dd><a name="index-_002d_002dno_002dignore_002dbranch_002disa"></a>
+</dd>
+<dt><code>--no-ignore-branch-isa</code></dt>
+<dd><p>These options control branch relocation checks for invalid ISA mode
+transitions. If &lsquo;<samp>--ignore-branch-isa</samp>&rsquo; is used, then the linker
+accepts any branch relocations and any ISA mode transition required
+is lost in relocation calculation, except for some cases of <code>BAL</code>
+instructions which meet relaxation conditions and are converted to
+equivalent <code>JALX</code> instructions as the associated relocation is
+calculated. By default or if &lsquo;<samp>--no-ignore-branch-isa</samp>&rsquo; is used
+a check is made causing the loss of an ISA mode transition to produce
+an error.
+</p>
+<a name="index-_002d_002dcompact_002dbranches"></a>
+</dd>
+<dt><code>--compact-branches</code></dt>
+<dd><a name="index-_002d_002dno_002dcompact_002dbranches"></a>
+</dd>
+<dt><code>--no-compact-branches</code></dt>
+<dd><p>These options control the generation of compact instructions by the linker
+in the PLT entries for MIPS R6.
+</p>
+</dd>
+</dl>
+
+
+
+<a name="Options-specific-to-PDP11-targets"></a>
+<h4 class="subsection">2.1.7 Options specific to PDP11 targets</h4>
+
+
+<p>For the pdp11-aout target, three variants of the output format can be
+produced as selected by the following options. The default variant
+for pdp11-aout is the &lsquo;<samp>--omagic</samp>&rsquo; option, whereas for other
+targets &lsquo;<samp>--nmagic</samp>&rsquo; is the default. The &lsquo;<samp>--imagic</samp>&rsquo; option is
+defined only for the pdp11-aout target, while the others are described
+here as they apply to the pdp11-aout target.
+</p>
+<dl compact="compact">
+<dd>
+<a name="index-_002dN-1"></a>
+</dd>
+<dt><code>-N</code></dt>
+<dd><a name="index-_002d_002domagic-1"></a>
+</dd>
+<dt><code>--omagic</code></dt>
+<dd>
+<p>Mark the output as <code>OMAGIC</code> (0407) in the <samp>a.out</samp> header to
+indicate that the text segment is not to be write-protected and
+shared. Since the text and data sections are both readable and
+writable, the data section is allocated immediately contiguous after
+the text segment. This is the oldest format for PDP11 executable
+programs and is the default for <code>ld</code> on PDP11 Unix systems
+from the beginning through 2.11BSD.
+</p>
+<a name="index-_002dn-1"></a>
+</dd>
+<dt><code>-n</code></dt>
+<dd><a name="index-_002d_002dnmagic-1"></a>
+</dd>
+<dt><code>--nmagic</code></dt>
+<dd>
+<p>Mark the output as <code>NMAGIC</code> (0410) in the <samp>a.out</samp> header to
+indicate that when the output file is executed, the text portion will
+be read-only and shareable among all processes executing the same
+file. This involves moving the data areas up to the first possible 8K
+byte page boundary following the end of the text. This option creates
+a <em>pure executable</em> format.
+</p>
+<a name="index-_002dz"></a>
+</dd>
+<dt><code>-z</code></dt>
+<dd><a name="index-_002d_002dimagic"></a>
+</dd>
+<dt><code>--imagic</code></dt>
+<dd>
+<p>Mark the output as <code>IMAGIC</code> (0411) in the <samp>a.out</samp> header to
+indicate that when the output file is executed, the program text and
+data areas will be loaded into separate address spaces using the split
+instruction and data space feature of the memory management unit in
+larger models of the PDP11. This doubles the address space available
+to the program. The text segment is again pure, write-protected, and
+shareable. The only difference in the output format between this
+option and the others, besides the magic number, is that both the text
+and data sections start at location 0. The &lsquo;<samp>-z</samp>&rsquo; option selected
+this format in 2.11BSD. This option creates a <em>separate
+executable</em> format.
+</p>
+<a name="index-_002d_002dno_002domagic-1"></a>
+</dd>
+<dt><code>--no-omagic</code></dt>
+<dd>
+<p>Equivalent to &lsquo;<samp>--nmagic</samp>&rsquo; for pdp11-aout.
+</p>
+</dd>
+</dl>
+
+
+<hr>
+<a name="Environment"></a>
+<div class="header">
+<p>
+Previous: <a href="#Options" accesskey="p" rel="previous">Options</a>, Up: <a href="#Invocation" accesskey="u" rel="up">Invocation</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Environment-Variables"></a>
+<h3 class="section">2.2 Environment Variables</h3>
+
+
+<p>You can change the behaviour of <code>ld</code> with the environment variables
+<code>GNUTARGET</code>,
+<code>LDEMULATION</code> and <code>COLLECT_NO_DEMANGLE</code>.
+</p>
+<a name="index-GNUTARGET"></a>
+<a name="index-default-input-format"></a>
+<p><code>GNUTARGET</code> determines the input-file object format if you don&rsquo;t
+use &lsquo;<samp>-b</samp>&rsquo; (or its synonym &lsquo;<samp>--format</samp>&rsquo;). Its value should be one
+of the BFD names for an input format (see <a href="#BFD">BFD</a>). If there is no
+<code>GNUTARGET</code> in the environment, <code>ld</code> uses the natural format
+of the target. If <code>GNUTARGET</code> is set to <code>default</code> then BFD
+attempts to discover the input format by examining binary input files;
+this method often succeeds, but there are potential ambiguities, since
+there is no method of ensuring that the magic number used to specify
+object-file formats is unique. However, the configuration procedure for
+BFD on each system places the conventional format for that system first
+in the search-list, so ambiguities are resolved in favor of convention.
+</p>
+<a name="index-LDEMULATION"></a>
+<a name="index-default-emulation"></a>
+<a name="index-emulation_002c-default"></a>
+<p><code>LDEMULATION</code> determines the default emulation if you don&rsquo;t use the
+&lsquo;<samp>-m</samp>&rsquo; option. The emulation can affect various aspects of linker
+behaviour, particularly the default linker script. You can list the
+available emulations with the &lsquo;<samp>--verbose</samp>&rsquo; or &lsquo;<samp>-V</samp>&rsquo; options. If
+the &lsquo;<samp>-m</samp>&rsquo; option is not used, and the <code>LDEMULATION</code> environment
+variable is not defined, the default emulation depends upon how the
+linker was configured.
+</p>
+<a name="index-COLLECT_005fNO_005fDEMANGLE"></a>
+<a name="index-demangling_002c-default"></a>
+<p>Normally, the linker will default to demangling symbols. However, if
+<code>COLLECT_NO_DEMANGLE</code> is set in the environment, then it will
+default to not demangling symbols. This environment variable is used in
+a similar fashion by the <code>gcc</code> linker wrapper program. The default
+may be overridden by the &lsquo;<samp>--demangle</samp>&rsquo; and &lsquo;<samp>--no-demangle</samp>&rsquo;
+options.
+</p>
+
+<hr>
+<a name="Scripts"></a>
+<div class="header">
+<p>
+Next: <a href="#Plugins" accesskey="n" rel="next">Plugins</a>, Previous: <a href="#Invocation" accesskey="p" rel="previous">Invocation</a>, Up: <a href="#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Linker-Scripts"></a>
+<h2 class="chapter">3 Linker Scripts</h2>
+
+<a name="index-scripts"></a>
+<a name="index-linker-scripts"></a>
+<a name="index-command-files"></a>
+<p>Every link is controlled by a <em>linker script</em>. This script is
+written in the linker command language.
+</p>
+<p>The main purpose of the linker script is to describe how the sections in
+the input files should be mapped into the output file, and to control
+the memory layout of the output file. Most linker scripts do nothing
+more than this. However, when necessary, the linker script can also
+direct the linker to perform many other operations, using the commands
+described below.
+</p>
+<p>The linker always uses a linker script. If you do not supply one
+yourself, the linker will use a default script that is compiled into the
+linker executable. You can use the &lsquo;<samp>--verbose</samp>&rsquo; command-line option
+to display the default linker script. Certain command-line options,
+such as &lsquo;<samp>-r</samp>&rsquo; or &lsquo;<samp>-N</samp>&rsquo;, will affect the default linker script.
+</p>
+<p>You may supply your own linker script by using the &lsquo;<samp>-T</samp>&rsquo; command
+line option. When you do this, your linker script will replace the
+default linker script.
+</p>
+<p>You may also use linker scripts implicitly by naming them as input files
+to the linker, as though they were files to be linked. See <a href="#Implicit-Linker-Scripts">Implicit Linker Scripts</a>.
+</p>
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#Basic-Script-Concepts" accesskey="1">Basic Script Concepts</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Basic Linker Script Concepts
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Script-Format" accesskey="2">Script Format</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Linker Script Format
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Simple-Example" accesskey="3">Simple Example</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Simple Linker Script Example
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Simple-Commands" accesskey="4">Simple Commands</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Simple Linker Script Commands
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Assignments" accesskey="5">Assignments</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Assigning Values to Symbols
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#SECTIONS" accesskey="6">SECTIONS</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">SECTIONS Command
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#MEMORY" accesskey="7">MEMORY</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">MEMORY Command
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#PHDRS" accesskey="8">PHDRS</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">PHDRS Command
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#VERSION" accesskey="9">VERSION</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">VERSION Command
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Expressions">Expressions</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Expressions in Linker Scripts
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Implicit-Linker-Scripts">Implicit Linker Scripts</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Implicit Linker Scripts
+</td></tr>
+</table>
+
+<hr>
+<a name="Basic-Script-Concepts"></a>
+<div class="header">
+<p>
+Next: <a href="#Script-Format" accesskey="n" rel="next">Script Format</a>, Up: <a href="#Scripts" accesskey="u" rel="up">Scripts</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Basic-Linker-Script-Concepts"></a>
+<h3 class="section">3.1 Basic Linker Script Concepts</h3>
+<a name="index-linker-script-concepts"></a>
+<p>We need to define some basic concepts and vocabulary in order to
+describe the linker script language.
+</p>
+<p>The linker combines input files into a single output file. The output
+file and each input file are in a special data format known as an
+<em>object file format</em>. Each file is called an <em>object file</em>.
+The output file is often called an <em>executable</em>, but for our
+purposes we will also call it an object file. Each object file has,
+among other things, a list of <em>sections</em>. We sometimes refer to a
+section in an input file as an <em>input section</em>; similarly, a section
+in the output file is an <em>output section</em>.
+</p>
+<p>Each section in an object file has a name and a size. Most sections
+also have an associated block of data, known as the <em>section
+contents</em>. A section may be marked as <em>loadable</em>, which means that
+the contents should be loaded into memory when the output file is run.
+A section with no contents may be <em>allocatable</em>, which means that an
+area in memory should be set aside, but nothing in particular should be
+loaded there (in some cases this memory must be zeroed out). A section
+which is neither loadable nor allocatable typically contains some sort
+of debugging information.
+</p>
+<p>Every loadable or allocatable output section has two addresses. The
+first is the <em>VMA</em>, or virtual memory address. This is the address
+the section will have when the output file is run. The second is the
+<em>LMA</em>, or load memory address. This is the address at which the
+section will be loaded. In most cases the two addresses will be the
+same. An example of when they might be different is when a data section
+is loaded into ROM, and then copied into RAM when the program starts up
+(this technique is often used to initialize global variables in a ROM
+based system). In this case the ROM address would be the LMA, and the
+RAM address would be the VMA.
+</p>
+<p>You can see the sections in an object file by using the <code>objdump</code>
+program with the &lsquo;<samp>-h</samp>&rsquo; option.
+</p>
+<p>Every object file also has a list of <em>symbols</em>, known as the
+<em>symbol table</em>. A symbol may be defined or undefined. Each symbol
+has a name, and each defined symbol has an address, among other
+information. If you compile a C or C++ program into an object file, you
+will get a defined symbol for every defined function and global or
+static variable. Every undefined function or global variable which is
+referenced in the input file will become an undefined symbol.
+</p>
+<p>You can see the symbols in an object file by using the <code>nm</code>
+program, or by using the <code>objdump</code> program with the &lsquo;<samp>-t</samp>&rsquo;
+option.
+</p>
+<hr>
+<a name="Script-Format"></a>
+<div class="header">
+<p>
+Next: <a href="#Simple-Example" accesskey="n" rel="next">Simple Example</a>, Previous: <a href="#Basic-Script-Concepts" accesskey="p" rel="previous">Basic Script Concepts</a>, Up: <a href="#Scripts" accesskey="u" rel="up">Scripts</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Linker-Script-Format"></a>
+<h3 class="section">3.2 Linker Script Format</h3>
+<a name="index-linker-script-format"></a>
+<p>Linker scripts are text files.
+</p>
+<p>You write a linker script as a series of commands. Each command is
+either a keyword, possibly followed by arguments, or an assignment to a
+symbol. You may separate commands using semicolons. Whitespace is
+generally ignored.
+</p>
+<p>Strings such as file or format names can normally be entered directly.
+If the file name contains a character such as a comma which would
+otherwise serve to separate file names, you may put the file name in
+double quotes. There is no way to use a double quote character in a
+file name.
+</p>
+<p>You may include comments in linker scripts just as in C, delimited by
+&lsquo;<samp>/*</samp>&rsquo; and &lsquo;<samp>*/</samp>&rsquo;. As in C, comments are syntactically equivalent
+to whitespace.
+</p>
+<hr>
+<a name="Simple-Example"></a>
+<div class="header">
+<p>
+Next: <a href="#Simple-Commands" accesskey="n" rel="next">Simple Commands</a>, Previous: <a href="#Script-Format" accesskey="p" rel="previous">Script Format</a>, Up: <a href="#Scripts" accesskey="u" rel="up">Scripts</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Simple-Linker-Script-Example"></a>
+<h3 class="section">3.3 Simple Linker Script Example</h3>
+<a name="index-linker-script-example"></a>
+<a name="index-example-of-linker-script"></a>
+<p>Many linker scripts are fairly simple.
+</p>
+<p>The simplest possible linker script has just one command:
+&lsquo;<samp>SECTIONS</samp>&rsquo;. You use the &lsquo;<samp>SECTIONS</samp>&rsquo; command to describe the
+memory layout of the output file.
+</p>
+<p>The &lsquo;<samp>SECTIONS</samp>&rsquo; command is a powerful command. Here we will
+describe a simple use of it. Let&rsquo;s assume your program consists only of
+code, initialized data, and uninitialized data. These will be in the
+&lsquo;<samp>.text</samp>&rsquo;, &lsquo;<samp>.data</samp>&rsquo;, and &lsquo;<samp>.bss</samp>&rsquo; sections, respectively.
+Let&rsquo;s assume further that these are the only sections which appear in
+your input files.
+</p>
+<p>For this example, let&rsquo;s say that the code should be loaded at address
+0x10000, and that the data should start at address 0x8000000. Here is a
+linker script which will do that:
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS
+{
+ . = 0x10000;
+ .text : { *(.text) }
+ . = 0x8000000;
+ .data : { *(.data) }
+ .bss : { *(.bss) }
+}
+</pre></div>
+
+<p>You write the &lsquo;<samp>SECTIONS</samp>&rsquo; command as the keyword &lsquo;<samp>SECTIONS</samp>&rsquo;,
+followed by a series of symbol assignments and output section
+descriptions enclosed in curly braces.
+</p>
+<p>The first line inside the &lsquo;<samp>SECTIONS</samp>&rsquo; command of the above example
+sets the value of the special symbol &lsquo;<samp>.</samp>&rsquo;, which is the location
+counter. If you do not specify the address of an output section in some
+other way (other ways are described later), the address is set from the
+current value of the location counter. The location counter is then
+incremented by the size of the output section. At the start of the
+&lsquo;<samp>SECTIONS</samp>&rsquo; command, the location counter has the value &lsquo;<samp>0</samp>&rsquo;.
+</p>
+<p>The second line defines an output section, &lsquo;<samp>.text</samp>&rsquo;. The colon is
+required syntax which may be ignored for now. Within the curly braces
+after the output section name, you list the names of the input sections
+which should be placed into this output section. The &lsquo;<samp>*</samp>&rsquo; is a
+wildcard which matches any file name. The expression &lsquo;<samp>*(.text)</samp>&rsquo;
+means all &lsquo;<samp>.text</samp>&rsquo; input sections in all input files.
+</p>
+<p>Since the location counter is &lsquo;<samp>0x10000</samp>&rsquo; when the output section
+&lsquo;<samp>.text</samp>&rsquo; is defined, the linker will set the address of the
+&lsquo;<samp>.text</samp>&rsquo; section in the output file to be &lsquo;<samp>0x10000</samp>&rsquo;.
+</p>
+<p>The remaining lines define the &lsquo;<samp>.data</samp>&rsquo; and &lsquo;<samp>.bss</samp>&rsquo; sections in
+the output file. The linker will place the &lsquo;<samp>.data</samp>&rsquo; output section
+at address &lsquo;<samp>0x8000000</samp>&rsquo;. After the linker places the &lsquo;<samp>.data</samp>&rsquo;
+output section, the value of the location counter will be
+&lsquo;<samp>0x8000000</samp>&rsquo; plus the size of the &lsquo;<samp>.data</samp>&rsquo; output section. The
+effect is that the linker will place the &lsquo;<samp>.bss</samp>&rsquo; output section
+immediately after the &lsquo;<samp>.data</samp>&rsquo; output section in memory.
+</p>
+<p>The linker will ensure that each output section has the required
+alignment, by increasing the location counter if necessary. In this
+example, the specified addresses for the &lsquo;<samp>.text</samp>&rsquo; and &lsquo;<samp>.data</samp>&rsquo;
+sections will probably satisfy any alignment constraints, but the linker
+may have to create a small gap between the &lsquo;<samp>.data</samp>&rsquo; and &lsquo;<samp>.bss</samp>&rsquo;
+sections.
+</p>
+<p>That&rsquo;s it! That&rsquo;s a simple and complete linker script.
+</p>
+<hr>
+<a name="Simple-Commands"></a>
+<div class="header">
+<p>
+Next: <a href="#Assignments" accesskey="n" rel="next">Assignments</a>, Previous: <a href="#Simple-Example" accesskey="p" rel="previous">Simple Example</a>, Up: <a href="#Scripts" accesskey="u" rel="up">Scripts</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Simple-Linker-Script-Commands"></a>
+<h3 class="section">3.4 Simple Linker Script Commands</h3>
+<a name="index-linker-script-simple-commands"></a>
+<p>In this section we describe the simple linker script commands.
+</p>
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#Entry-Point" accesskey="1">Entry Point</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Setting the entry point
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#File-Commands" accesskey="2">File Commands</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Commands dealing with files
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Format-Commands" accesskey="3">Format Commands</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Commands dealing with object file formats
+</td></tr>
+<tr><th colspan="3" align="left" valign="top"><pre class="menu-comment">
+</pre></th></tr><tr><td align="left" valign="top">&bull; <a href="#REGION_005fALIAS" accesskey="4">REGION_ALIAS</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Assign alias names to memory regions
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Miscellaneous-Commands" accesskey="5">Miscellaneous Commands</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Other linker script commands
+</td></tr>
+</table>
+
+<hr>
+<a name="Entry-Point"></a>
+<div class="header">
+<p>
+Next: <a href="#File-Commands" accesskey="n" rel="next">File Commands</a>, Up: <a href="#Simple-Commands" accesskey="u" rel="up">Simple Commands</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Setting-the-Entry-Point"></a>
+<h4 class="subsection">3.4.1 Setting the Entry Point</h4>
+<a name="index-ENTRY_0028symbol_0029"></a>
+<a name="index-start-of-execution"></a>
+<a name="index-first-instruction"></a>
+<a name="index-entry-point"></a>
+<p>The first instruction to execute in a program is called the <em>entry
+point</em>. You can use the <code>ENTRY</code> linker script command to set the
+entry point. The argument is a symbol name:
+</p><div class="smallexample">
+<pre class="smallexample">ENTRY(<var>symbol</var>)
+</pre></div>
+
+<p>There are several ways to set the entry point. The linker will set the
+entry point by trying each of the following methods in order, and
+stopping when one of them succeeds:
+</p><ul>
+<li> the &lsquo;<samp>-e</samp>&rsquo; <var>entry</var> command-line option;
+</li><li> the <code>ENTRY(<var>symbol</var>)</code> command in a linker script;
+</li><li> the value of a target-specific symbol, if it is defined; For many
+targets this is <code>start</code>, but PE- and BeOS-based systems for example
+check a list of possible entry symbols, matching the first one found.
+</li><li> the address of the first byte of the code section, if present and an
+executable is being created - the code section is usually
+&lsquo;<samp>.text</samp>&rsquo;, but can be something else;
+</li><li> The address <code>0</code>.
+</li></ul>
+
+<hr>
+<a name="File-Commands"></a>
+<div class="header">
+<p>
+Next: <a href="#Format-Commands" accesskey="n" rel="next">Format Commands</a>, Previous: <a href="#Entry-Point" accesskey="p" rel="previous">Entry Point</a>, Up: <a href="#Simple-Commands" accesskey="u" rel="up">Simple Commands</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Commands-Dealing-with-Files"></a>
+<h4 class="subsection">3.4.2 Commands Dealing with Files</h4>
+<a name="index-linker-script-file-commands"></a>
+<p>Several linker script commands deal with files.
+</p>
+<dl compact="compact">
+<dt><code>INCLUDE <var>filename</var></code></dt>
+<dd><a name="index-INCLUDE-filename"></a>
+<a name="index-including-a-linker-script"></a>
+<p>Include the linker script <var>filename</var> at this point. The file will
+be searched for in the current directory, and in any directory specified
+with the <samp>-L</samp> option. You can nest calls to <code>INCLUDE</code> up to
+10 levels deep.
+</p>
+<p>You can place <code>INCLUDE</code> directives at the top level, in <code>MEMORY</code> or
+<code>SECTIONS</code> commands, or in output section descriptions.
+</p>
+</dd>
+<dt><code>INPUT(<var>file</var>, <var>file</var>, &hellip;)</code></dt>
+<dt><code>INPUT(<var>file</var> <var>file</var> &hellip;)</code></dt>
+<dd><a name="index-INPUT_0028files_0029"></a>
+<a name="index-input-files-in-linker-scripts"></a>
+<a name="index-input-object-files-in-linker-scripts"></a>
+<a name="index-linker-script-input-object-files"></a>
+<p>The <code>INPUT</code> command directs the linker to include the named files
+in the link, as though they were named on the command line.
+</p>
+<p>For example, if you always want to include <samp>subr.o</samp> any time you do
+a link, but you can&rsquo;t be bothered to put it on every link command line,
+then you can put &lsquo;<samp>INPUT (subr.o)</samp>&rsquo; in your linker script.
+</p>
+<p>In fact, if you like, you can list all of your input files in the linker
+script, and then invoke the linker with nothing but a &lsquo;<samp>-T</samp>&rsquo; option.
+</p>
+<p>In case a <em>sysroot prefix</em> is configured, and the filename starts
+with the &lsquo;<samp>/</samp>&rsquo; character, and the script being processed was
+located inside the <em>sysroot prefix</em>, the filename will be looked
+for in the <em>sysroot prefix</em>. The <em>sysroot prefix</em> can also be forced by specifying
+<code>=</code> as the first character in the filename path, or prefixing the
+filename path with <code>$SYSROOT</code>. See also the description of
+&lsquo;<samp>-L</samp>&rsquo; in <a href="#Options">Command-line Options</a>.
+</p>
+<p>If a <em>sysroot prefix</em> is not used then the linker will try to open
+the file in the directory containing the linker script. If it is not
+found the linker will then search the current directory. If it is still
+not found the linker will search through the archive library search
+path.
+</p>
+<p>If you use &lsquo;<samp>INPUT (-l<var>file</var>)</samp>&rsquo;, <code>ld</code> will transform the
+name to <code>lib<var>file</var>.a</code>, as with the command-line argument
+&lsquo;<samp>-l</samp>&rsquo;.
+</p>
+<p>When you use the <code>INPUT</code> command in an implicit linker script, the
+files will be included in the link at the point at which the linker
+script file is included. This can affect archive searching.
+</p>
+</dd>
+<dt><code>GROUP(<var>file</var>, <var>file</var>, &hellip;)</code></dt>
+<dt><code>GROUP(<var>file</var> <var>file</var> &hellip;)</code></dt>
+<dd><a name="index-GROUP_0028files_0029"></a>
+<a name="index-grouping-input-files"></a>
+<p>The <code>GROUP</code> command is like <code>INPUT</code>, except that the named
+files should all be archives, and they are searched repeatedly until no
+new undefined references are created. See the description of &lsquo;<samp>-(</samp>&rsquo;
+in <a href="#Options">Command-line Options</a>.
+</p>
+</dd>
+<dt><code>AS_NEEDED(<var>file</var>, <var>file</var>, &hellip;)</code></dt>
+<dt><code>AS_NEEDED(<var>file</var> <var>file</var> &hellip;)</code></dt>
+<dd><a name="index-AS_005fNEEDED_0028files_0029"></a>
+<p>This construct can appear only inside of the <code>INPUT</code> or <code>GROUP</code>
+commands, among other filenames. The files listed will be handled
+as if they appear directly in the <code>INPUT</code> or <code>GROUP</code> commands,
+with the exception of ELF shared libraries, that will be added only
+when they are actually needed. This construct essentially enables
+<samp>--as-needed</samp> option for all the files listed inside of it
+and restores previous <samp>--as-needed</samp> resp. <samp>--no-as-needed</samp>
+setting afterwards.
+</p>
+</dd>
+<dt><code>OUTPUT(<var>filename</var>)</code></dt>
+<dd><a name="index-OUTPUT_0028filename_0029"></a>
+<a name="index-output-file-name-in-linker-script"></a>
+<p>The <code>OUTPUT</code> command names the output file. Using
+<code>OUTPUT(<var>filename</var>)</code> in the linker script is exactly like using
+&lsquo;<samp>-o <var>filename</var></samp>&rsquo; on the command line (see <a href="#Options">Command
+Line Options</a>). If both are used, the command-line option takes
+precedence.
+</p>
+<p>You can use the <code>OUTPUT</code> command to define a default name for the
+output file other than the usual default of <samp>a.out</samp>.
+</p>
+</dd>
+<dt><code>SEARCH_DIR(<var>path</var>)</code></dt>
+<dd><a name="index-SEARCH_005fDIR_0028path_0029"></a>
+<a name="index-library-search-path-in-linker-script"></a>
+<a name="index-archive-search-path-in-linker-script"></a>
+<a name="index-search-path-in-linker-script"></a>
+<p>The <code>SEARCH_DIR</code> command adds <var>path</var> to the list of paths where
+<code>ld</code> looks for archive libraries. Using
+<code>SEARCH_DIR(<var>path</var>)</code> is exactly like using &lsquo;<samp>-L <var>path</var></samp>&rsquo;
+on the command line (see <a href="#Options">Command-line Options</a>). If both
+are used, then the linker will search both paths. Paths specified using
+the command-line option are searched first.
+</p>
+</dd>
+<dt><code>STARTUP(<var>filename</var>)</code></dt>
+<dd><a name="index-STARTUP_0028filename_0029"></a>
+<a name="index-first-input-file"></a>
+<p>The <code>STARTUP</code> command is just like the <code>INPUT</code> command, except
+that <var>filename</var> will become the first input file to be linked, as
+though it were specified first on the command line. This may be useful
+when using a system in which the entry point is always the start of the
+first file.
+</p></dd>
+</dl>
+
+<hr>
+<a name="Format-Commands"></a>
+<div class="header">
+<p>
+Next: <a href="#REGION_005fALIAS" accesskey="n" rel="next">REGION_ALIAS</a>, Previous: <a href="#File-Commands" accesskey="p" rel="previous">File Commands</a>, Up: <a href="#Simple-Commands" accesskey="u" rel="up">Simple Commands</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Commands-Dealing-with-Object-File-Formats"></a>
+<h4 class="subsection">3.4.3 Commands Dealing with Object File Formats</h4>
+<p>A couple of linker script commands deal with object file formats.
+</p>
+<dl compact="compact">
+<dt><code>OUTPUT_FORMAT(<var>bfdname</var>)</code></dt>
+<dt><code>OUTPUT_FORMAT(<var>default</var>, <var>big</var>, <var>little</var>)</code></dt>
+<dd><a name="index-OUTPUT_005fFORMAT_0028bfdname_0029"></a>
+<a name="index-output-file-format-in-linker-script"></a>
+<p>The <code>OUTPUT_FORMAT</code> command names the BFD format to use for the
+output file (see <a href="#BFD">BFD</a>). Using <code>OUTPUT_FORMAT(<var>bfdname</var>)</code> is
+exactly like using &lsquo;<samp>--oformat <var>bfdname</var></samp>&rsquo; on the command line
+(see <a href="#Options">Command-line Options</a>). If both are used, the command
+line option takes precedence.
+</p>
+<p>You can use <code>OUTPUT_FORMAT</code> with three arguments to use different
+formats based on the &lsquo;<samp>-EB</samp>&rsquo; and &lsquo;<samp>-EL</samp>&rsquo; command-line options.
+This permits the linker script to set the output format based on the
+desired endianness.
+</p>
+<p>If neither &lsquo;<samp>-EB</samp>&rsquo; nor &lsquo;<samp>-EL</samp>&rsquo; are used, then the output format
+will be the first argument, <var>default</var>. If &lsquo;<samp>-EB</samp>&rsquo; is used, the
+output format will be the second argument, <var>big</var>. If &lsquo;<samp>-EL</samp>&rsquo; is
+used, the output format will be the third argument, <var>little</var>.
+</p>
+<p>For example, the default linker script for the MIPS ELF target uses this
+command:
+</p><div class="smallexample">
+<pre class="smallexample">OUTPUT_FORMAT(elf32-bigmips, elf32-bigmips, elf32-littlemips)
+</pre></div>
+<p>This says that the default format for the output file is
+&lsquo;<samp>elf32-bigmips</samp>&rsquo;, but if the user uses the &lsquo;<samp>-EL</samp>&rsquo; command-line
+option, the output file will be created in the &lsquo;<samp>elf32-littlemips</samp>&rsquo;
+format.
+</p>
+</dd>
+<dt><code>TARGET(<var>bfdname</var>)</code></dt>
+<dd><a name="index-TARGET_0028bfdname_0029"></a>
+<a name="index-input-file-format-in-linker-script"></a>
+<p>The <code>TARGET</code> command names the BFD format to use when reading input
+files. It affects subsequent <code>INPUT</code> and <code>GROUP</code> commands.
+This command is like using &lsquo;<samp>-b <var>bfdname</var></samp>&rsquo; on the command line
+(see <a href="#Options">Command-line Options</a>). If the <code>TARGET</code> command
+is used but <code>OUTPUT_FORMAT</code> is not, then the last <code>TARGET</code>
+command is also used to set the format for the output file. See <a href="#BFD">BFD</a>.
+</p></dd>
+</dl>
+
+<hr>
+<a name="REGION_005fALIAS"></a>
+<div class="header">
+<p>
+Next: <a href="#Miscellaneous-Commands" accesskey="n" rel="next">Miscellaneous Commands</a>, Previous: <a href="#Format-Commands" accesskey="p" rel="previous">Format Commands</a>, Up: <a href="#Simple-Commands" accesskey="u" rel="up">Simple Commands</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Assign-alias-names-to-memory-regions"></a>
+<h4 class="subsection">3.4.4 Assign alias names to memory regions</h4>
+<a name="index-REGION_005fALIAS_0028alias_002c-region_0029"></a>
+<a name="index-region-alias"></a>
+<a name="index-region-names"></a>
+
+<p>Alias names can be added to existing memory regions created with the
+<a href="#MEMORY">MEMORY</a> command. Each name corresponds to at most one memory region.
+</p>
+<div class="smallexample">
+<pre class="smallexample">REGION_ALIAS(<var>alias</var>, <var>region</var>)
+</pre></div>
+
+<p>The <code>REGION_ALIAS</code> function creates an alias name <var>alias</var> for the
+memory region <var>region</var>. This allows a flexible mapping of output sections
+to memory regions. An example follows.
+</p>
+<p>Suppose we have an application for embedded systems which come with various
+memory storage devices. All have a general purpose, volatile memory <code>RAM</code>
+that allows code execution or data storage. Some may have a read-only,
+non-volatile memory <code>ROM</code> that allows code execution and read-only data
+access. The last variant is a read-only, non-volatile memory <code>ROM2</code> with
+read-only data access and no code execution capability. We have four output
+sections:
+</p>
+<ul>
+<li> <code>.text</code> program code;
+</li><li> <code>.rodata</code> read-only data;
+</li><li> <code>.data</code> read-write initialized data;
+</li><li> <code>.bss</code> read-write zero initialized data.
+</li></ul>
+
+<p>The goal is to provide a linker command file that contains a system independent
+part defining the output sections and a system dependent part mapping the
+output sections to the memory regions available on the system. Our embedded
+systems come with three different memory setups <code>A</code>, <code>B</code> and
+<code>C</code>:
+</p><table>
+<tr><td width="25%">Section</td><td width="25%">Variant A</td><td width="25%">Variant B</td><td width="25%">Variant C</td></tr>
+<tr><td width="25%">.text</td><td width="25%">RAM</td><td width="25%">ROM</td><td width="25%">ROM</td></tr>
+<tr><td width="25%">.rodata</td><td width="25%">RAM</td><td width="25%">ROM</td><td width="25%">ROM2</td></tr>
+<tr><td width="25%">.data</td><td width="25%">RAM</td><td width="25%">RAM/ROM</td><td width="25%">RAM/ROM2</td></tr>
+<tr><td width="25%">.bss</td><td width="25%">RAM</td><td width="25%">RAM</td><td width="25%">RAM</td></tr>
+</table>
+<p>The notation <code>RAM/ROM</code> or <code>RAM/ROM2</code> means that this section is
+loaded into region <code>ROM</code> or <code>ROM2</code> respectively. Please note that
+the load address of the <code>.data</code> section starts in all three variants at
+the end of the <code>.rodata</code> section.
+</p>
+<p>The base linker script that deals with the output sections follows. It
+includes the system dependent <code>linkcmds.memory</code> file that describes the
+memory layout:
+</p><div class="smallexample">
+<pre class="smallexample">INCLUDE linkcmds.memory
+
+SECTIONS
+ {
+ .text :
+ {
+ *(.text)
+ } &gt; REGION_TEXT
+ .rodata :
+ {
+ *(.rodata)
+ rodata_end = .;
+ } &gt; REGION_RODATA
+ .data : AT (rodata_end)
+ {
+ data_start = .;
+ *(.data)
+ } &gt; REGION_DATA
+ data_size = SIZEOF(.data);
+ data_load_start = LOADADDR(.data);
+ .bss :
+ {
+ *(.bss)
+ } &gt; REGION_BSS
+ }
+</pre></div>
+
+<p>Now we need three different <code>linkcmds.memory</code> files to define memory
+regions and alias names. The content of <code>linkcmds.memory</code> for the three
+variants <code>A</code>, <code>B</code> and <code>C</code>:
+</p><dl compact="compact">
+<dt><code>A</code></dt>
+<dd><p>Here everything goes into the <code>RAM</code>.
+</p><div class="smallexample">
+<pre class="smallexample">MEMORY
+ {
+ RAM : ORIGIN = 0, LENGTH = 4M
+ }
+
+REGION_ALIAS(&quot;REGION_TEXT&quot;, RAM);
+REGION_ALIAS(&quot;REGION_RODATA&quot;, RAM);
+REGION_ALIAS(&quot;REGION_DATA&quot;, RAM);
+REGION_ALIAS(&quot;REGION_BSS&quot;, RAM);
+</pre></div>
+</dd>
+<dt><code>B</code></dt>
+<dd><p>Program code and read-only data go into the <code>ROM</code>. Read-write data goes
+into the <code>RAM</code>. An image of the initialized data is loaded into the
+<code>ROM</code> and will be copied during system start into the <code>RAM</code>.
+</p><div class="smallexample">
+<pre class="smallexample">MEMORY
+ {
+ ROM : ORIGIN = 0, LENGTH = 3M
+ RAM : ORIGIN = 0x10000000, LENGTH = 1M
+ }
+
+REGION_ALIAS(&quot;REGION_TEXT&quot;, ROM);
+REGION_ALIAS(&quot;REGION_RODATA&quot;, ROM);
+REGION_ALIAS(&quot;REGION_DATA&quot;, RAM);
+REGION_ALIAS(&quot;REGION_BSS&quot;, RAM);
+</pre></div>
+</dd>
+<dt><code>C</code></dt>
+<dd><p>Program code goes into the <code>ROM</code>. Read-only data goes into the
+<code>ROM2</code>. Read-write data goes into the <code>RAM</code>. An image of the
+initialized data is loaded into the <code>ROM2</code> and will be copied during
+system start into the <code>RAM</code>.
+</p><div class="smallexample">
+<pre class="smallexample">MEMORY
+ {
+ ROM : ORIGIN = 0, LENGTH = 2M
+ ROM2 : ORIGIN = 0x10000000, LENGTH = 1M
+ RAM : ORIGIN = 0x20000000, LENGTH = 1M
+ }
+
+REGION_ALIAS(&quot;REGION_TEXT&quot;, ROM);
+REGION_ALIAS(&quot;REGION_RODATA&quot;, ROM2);
+REGION_ALIAS(&quot;REGION_DATA&quot;, RAM);
+REGION_ALIAS(&quot;REGION_BSS&quot;, RAM);
+</pre></div>
+</dd>
+</dl>
+
+<p>It is possible to write a common system initialization routine to copy the
+<code>.data</code> section from <code>ROM</code> or <code>ROM2</code> into the <code>RAM</code> if
+necessary:
+</p><div class="smallexample">
+<pre class="smallexample">#include &lt;string.h&gt;
+
+extern char data_start [];
+extern char data_size [];
+extern char data_load_start [];
+
+void copy_data(void)
+{
+ if (data_start != data_load_start)
+ {
+ memcpy(data_start, data_load_start, (size_t) data_size);
+ }
+}
+</pre></div>
+
+<hr>
+<a name="Miscellaneous-Commands"></a>
+<div class="header">
+<p>
+Previous: <a href="#REGION_005fALIAS" accesskey="p" rel="previous">REGION_ALIAS</a>, Up: <a href="#Simple-Commands" accesskey="u" rel="up">Simple Commands</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Other-Linker-Script-Commands"></a>
+<h4 class="subsection">3.4.5 Other Linker Script Commands</h4>
+<p>There are a few other linker scripts commands.
+</p>
+<dl compact="compact">
+<dt><code>ASSERT(<var>exp</var>, <var>message</var>)</code></dt>
+<dd><a name="index-ASSERT"></a>
+<a name="index-assertion-in-linker-script"></a>
+<p>Ensure that <var>exp</var> is non-zero. If it is zero, then exit the linker
+with an error code, and print <var>message</var>.
+</p>
+<p>Note that assertions are checked before the final stages of linking
+take place. This means that expressions involving symbols PROVIDEd
+inside section definitions will fail if the user has not set values
+for those symbols. The only exception to this rule is PROVIDEd
+symbols that just reference dot. Thus an assertion like this:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> .stack :
+ {
+ PROVIDE (__stack = .);
+ PROVIDE (__stack_size = 0x100);
+ ASSERT ((__stack &gt; (_end + __stack_size)), &quot;Error: No room left for the stack&quot;);
+ }
+</pre></div>
+
+<p>will fail if <code>__stack_size</code> is not defined elsewhere. Symbols
+PROVIDEd outside of section definitions are evaluated earlier, so they
+can be used inside ASSERTions. Thus:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> PROVIDE (__stack_size = 0x100);
+ .stack :
+ {
+ PROVIDE (__stack = .);
+ ASSERT ((__stack &gt; (_end + __stack_size)), &quot;Error: No room left for the stack&quot;);
+ }
+</pre></div>
+
+<p>will work.
+</p>
+</dd>
+<dt><code>EXTERN(<var>symbol</var> <var>symbol</var> &hellip;)</code></dt>
+<dd><a name="index-EXTERN"></a>
+<a name="index-undefined-symbol-in-linker-script"></a>
+<p>Force <var>symbol</var> to be entered in the output file as an undefined
+symbol. Doing this may, for example, trigger linking of additional
+modules from standard libraries. You may list several <var>symbol</var>s for
+each <code>EXTERN</code>, and you may use <code>EXTERN</code> multiple times. This
+command has the same effect as the &lsquo;<samp>-u</samp>&rsquo; command-line option.
+</p>
+</dd>
+<dt><code>FORCE_COMMON_ALLOCATION</code></dt>
+<dd><a name="index-FORCE_005fCOMMON_005fALLOCATION"></a>
+<a name="index-common-allocation-in-linker-script"></a>
+<p>This command has the same effect as the &lsquo;<samp>-d</samp>&rsquo; command-line option:
+to make <code>ld</code> assign space to common symbols even if a relocatable
+output file is specified (&lsquo;<samp>-r</samp>&rsquo;).
+</p>
+</dd>
+<dt><code>INHIBIT_COMMON_ALLOCATION</code></dt>
+<dd><a name="index-INHIBIT_005fCOMMON_005fALLOCATION"></a>
+<a name="index-common-allocation-in-linker-script-1"></a>
+<p>This command has the same effect as the &lsquo;<samp>--no-define-common</samp>&rsquo;
+command-line option: to make <code>ld</code> omit the assignment of addresses
+to common symbols even for a non-relocatable output file.
+</p>
+</dd>
+<dt><code>FORCE_GROUP_ALLOCATION</code></dt>
+<dd><a name="index-FORCE_005fGROUP_005fALLOCATION"></a>
+<a name="index-group-allocation-in-linker-script-1"></a>
+<a name="index-section-groups-1"></a>
+<a name="index-COMDAT-1"></a>
+<p>This command has the same effect as the
+&lsquo;<samp>--force-group-allocation</samp>&rsquo; command-line option: to make
+<code>ld</code> place section group members like normal input sections,
+and to delete the section groups even if a relocatable output file is
+specified (&lsquo;<samp>-r</samp>&rsquo;).
+</p>
+</dd>
+<dt><code>INSERT [ AFTER | BEFORE ] <var>output_section</var></code></dt>
+<dd><a name="index-INSERT"></a>
+<a name="index-insert-user-script-into-default-script"></a>
+<p>This command is typically used in a script specified by &lsquo;<samp>-T</samp>&rsquo; to
+augment the default <code>SECTIONS</code> with, for example, overlays. It
+inserts all prior linker script statements after (or before)
+<var>output_section</var>, and also causes &lsquo;<samp>-T</samp>&rsquo; to not override the
+default linker script. The exact insertion point is as for orphan
+sections. See <a href="#Location-Counter">Location Counter</a>. The insertion happens after the
+linker has mapped input sections to output sections. Prior to the
+insertion, since &lsquo;<samp>-T</samp>&rsquo; scripts are parsed before the default
+linker script, statements in the &lsquo;<samp>-T</samp>&rsquo; script occur before the
+default linker script statements in the internal linker representation
+of the script. In particular, input section assignments will be made
+to &lsquo;<samp>-T</samp>&rsquo; output sections before those in the default script. Here
+is an example of how a &lsquo;<samp>-T</samp>&rsquo; script using <code>INSERT</code> might look:
+</p>
+<div class="smallexample">
+<pre class="smallexample">SECTIONS
+{
+ OVERLAY :
+ {
+ .ov1 { ov1*(.text) }
+ .ov2 { ov2*(.text) }
+ }
+}
+INSERT AFTER .text;
+</pre></div>
+
+<p>Note that when &lsquo;<samp>-T</samp>&rsquo; is used twice, once to override the default
+script and once to augment that script using <code>INSERT</code> the order
+of parsing and section assignments apply as for the default script.
+The script with <code>INSERT</code> should be specified <em>first</em> on the
+command line.
+</p>
+</dd>
+<dt><code>NOCROSSREFS(<var>section</var> <var>section</var> &hellip;)</code></dt>
+<dd><a name="index-NOCROSSREFS_0028sections_0029"></a>
+<a name="index-cross-references"></a>
+<p>This command may be used to tell <code>ld</code> to issue an error about any
+references among certain output sections.
+</p>
+<p>In certain types of programs, particularly on embedded systems when
+using overlays, when one section is loaded into memory, another section
+will not be. Any direct references between the two sections would be
+errors. For example, it would be an error if code in one section called
+a function defined in the other section.
+</p>
+<p>The <code>NOCROSSREFS</code> command takes a list of output section names. If
+<code>ld</code> detects any cross references between the sections, it reports
+an error and returns a non-zero exit status. Note that the
+<code>NOCROSSREFS</code> command uses output section names, not input section
+names.
+</p>
+</dd>
+<dt><code>NOCROSSREFS_TO(<var>tosection</var> <var>fromsection</var> &hellip;)</code></dt>
+<dd><a name="index-NOCROSSREFS_005fTO_0028tosection-fromsections_0029"></a>
+<a name="index-cross-references-1"></a>
+<p>This command may be used to tell <code>ld</code> to issue an error about any
+references to one section from a list of other sections.
+</p>
+<p>The <code>NOCROSSREFS</code> command is useful when ensuring that two or more
+output sections are entirely independent but there are situations where
+a one-way dependency is needed. For example, in a multi-core application
+there may be shared code that can be called from each core but for safety
+must never call back.
+</p>
+<p>The <code>NOCROSSREFS_TO</code> command takes a list of output section names.
+The first section can not be referenced from any of the other sections.
+If <code>ld</code> detects any references to the first section from any of
+the other sections, it reports an error and returns a non-zero exit
+status. Note that the <code>NOCROSSREFS_TO</code> command uses output section
+names, not input section names.
+</p>
+</dd>
+<dt><code>OUTPUT_ARCH(<var>bfdarch</var>)</code></dt>
+<dd><a name="index-OUTPUT_005fARCH_0028bfdarch_0029"></a>
+<a name="index-machine-architecture"></a>
+<a name="index-architecture"></a>
+<p>Specify a particular output machine architecture. The argument is one
+of the names used by the BFD library (see <a href="#BFD">BFD</a>). You can see the
+architecture of an object file by using the <code>objdump</code> program with
+the &lsquo;<samp>-f</samp>&rsquo; option.
+</p>
+</dd>
+<dt><code>LD_FEATURE(<var>string</var>)</code></dt>
+<dd><a name="index-LD_005fFEATURE_0028string_0029"></a>
+<p>This command may be used to modify <code>ld</code> behavior. If
+<var>string</var> is <code>&quot;SANE_EXPR&quot;</code> then absolute symbols and numbers
+in a script are simply treated as numbers everywhere.
+See <a href="#Expression-Section">Expression Section</a>.
+</p></dd>
+</dl>
+
+<hr>
+<a name="Assignments"></a>
+<div class="header">
+<p>
+Next: <a href="#SECTIONS" accesskey="n" rel="next">SECTIONS</a>, Previous: <a href="#Simple-Commands" accesskey="p" rel="previous">Simple Commands</a>, Up: <a href="#Scripts" accesskey="u" rel="up">Scripts</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Assigning-Values-to-Symbols"></a>
+<h3 class="section">3.5 Assigning Values to Symbols</h3>
+<a name="index-assignment-in-scripts"></a>
+<a name="index-symbol-definition_002c-scripts"></a>
+<a name="index-variables_002c-defining"></a>
+<p>You may assign a value to a symbol in a linker script. This will define
+the symbol and place it into the symbol table with a global scope.
+</p>
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#Simple-Assignments" accesskey="1">Simple Assignments</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Simple Assignments
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#HIDDEN" accesskey="2">HIDDEN</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">HIDDEN
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#PROVIDE" accesskey="3">PROVIDE</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">PROVIDE
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#PROVIDE_005fHIDDEN" accesskey="4">PROVIDE_HIDDEN</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">PROVIDE_HIDDEN
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Source-Code-Reference" accesskey="5">Source Code Reference</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">How to use a linker script defined symbol in source code
+</td></tr>
+</table>
+
+<hr>
+<a name="Simple-Assignments"></a>
+<div class="header">
+<p>
+Next: <a href="#HIDDEN" accesskey="n" rel="next">HIDDEN</a>, Up: <a href="#Assignments" accesskey="u" rel="up">Assignments</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Simple-Assignments-1"></a>
+<h4 class="subsection">3.5.1 Simple Assignments</h4>
+
+<p>You may assign to a symbol using any of the C assignment operators:
+</p>
+<dl compact="compact">
+<dt><code><var>symbol</var> = <var>expression</var> ;</code></dt>
+<dt><code><var>symbol</var> += <var>expression</var> ;</code></dt>
+<dt><code><var>symbol</var> -= <var>expression</var> ;</code></dt>
+<dt><code><var>symbol</var> *= <var>expression</var> ;</code></dt>
+<dt><code><var>symbol</var> /= <var>expression</var> ;</code></dt>
+<dt><code><var>symbol</var> &lt;&lt;= <var>expression</var> ;</code></dt>
+<dt><code><var>symbol</var> &gt;&gt;= <var>expression</var> ;</code></dt>
+<dt><code><var>symbol</var> &amp;= <var>expression</var> ;</code></dt>
+<dt><code><var>symbol</var> |= <var>expression</var> ;</code></dt>
+</dl>
+
+<p>The first case will define <var>symbol</var> to the value of
+<var>expression</var>. In the other cases, <var>symbol</var> must already be
+defined, and the value will be adjusted accordingly.
+</p>
+<p>The special symbol name &lsquo;<samp>.</samp>&rsquo; indicates the location counter. You
+may only use this within a <code>SECTIONS</code> command. See <a href="#Location-Counter">Location Counter</a>.
+</p>
+<p>The semicolon after <var>expression</var> is required.
+</p>
+<p>Expressions are defined below; see <a href="#Expressions">Expressions</a>.
+</p>
+<p>You may write symbol assignments as commands in their own right, or as
+statements within a <code>SECTIONS</code> command, or as part of an output
+section description in a <code>SECTIONS</code> command.
+</p>
+<p>The section of the symbol will be set from the section of the
+expression; for more information, see <a href="#Expression-Section">Expression Section</a>.
+</p>
+<p>Here is an example showing the three different places that symbol
+assignments may be used:
+</p>
+<div class="smallexample">
+<pre class="smallexample">floating_point = 0;
+SECTIONS
+{
+ .text :
+ {
+ *(.text)
+ _etext = .;
+ }
+ _bdata = (. + 3) &amp; ~ 3;
+ .data : { *(.data) }
+}
+</pre></div>
+<p>In this example, the symbol &lsquo;<samp>floating_point</samp>&rsquo; will be defined as
+zero. The symbol &lsquo;<samp>_etext</samp>&rsquo; will be defined as the address following
+the last &lsquo;<samp>.text</samp>&rsquo; input section. The symbol &lsquo;<samp>_bdata</samp>&rsquo; will be
+defined as the address following the &lsquo;<samp>.text</samp>&rsquo; output section aligned
+upward to a 4 byte boundary.
+</p>
+<hr>
+<a name="HIDDEN"></a>
+<div class="header">
+<p>
+Next: <a href="#PROVIDE" accesskey="n" rel="next">PROVIDE</a>, Previous: <a href="#Simple-Assignments" accesskey="p" rel="previous">Simple Assignments</a>, Up: <a href="#Assignments" accesskey="u" rel="up">Assignments</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="HIDDEN-1"></a>
+<h4 class="subsection">3.5.2 HIDDEN</h4>
+<a name="index-HIDDEN"></a>
+<p>For ELF targeted ports, define a symbol that will be hidden and won&rsquo;t be
+exported. The syntax is <code>HIDDEN(<var>symbol</var> = <var>expression</var>)</code>.
+</p>
+<p>Here is the example from <a href="#Simple-Assignments">Simple Assignments</a>, rewritten to use
+<code>HIDDEN</code>:
+</p>
+<div class="smallexample">
+<pre class="smallexample">HIDDEN(floating_point = 0);
+SECTIONS
+{
+ .text :
+ {
+ *(.text)
+ HIDDEN(_etext = .);
+ }
+ HIDDEN(_bdata = (. + 3) &amp; ~ 3);
+ .data : { *(.data) }
+}
+</pre></div>
+<p>In this case none of the three symbols will be visible outside this module.
+</p>
+<hr>
+<a name="PROVIDE"></a>
+<div class="header">
+<p>
+Next: <a href="#PROVIDE_005fHIDDEN" accesskey="n" rel="next">PROVIDE_HIDDEN</a>, Previous: <a href="#HIDDEN" accesskey="p" rel="previous">HIDDEN</a>, Up: <a href="#Assignments" accesskey="u" rel="up">Assignments</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="PROVIDE-1"></a>
+<h4 class="subsection">3.5.3 PROVIDE</h4>
+<a name="index-PROVIDE"></a>
+<p>In some cases, it is desirable for a linker script to define a symbol
+only if it is referenced and is not defined by any object included in
+the link. For example, traditional linkers defined the symbol
+&lsquo;<samp>etext</samp>&rsquo;. However, ANSI C requires that the user be able to use
+&lsquo;<samp>etext</samp>&rsquo; as a function name without encountering an error. The
+<code>PROVIDE</code> keyword may be used to define a symbol, such as
+&lsquo;<samp>etext</samp>&rsquo;, only if it is referenced but not defined. The syntax is
+<code>PROVIDE(<var>symbol</var> = <var>expression</var>)</code>.
+</p>
+<p>Here is an example of using <code>PROVIDE</code> to define &lsquo;<samp>etext</samp>&rsquo;:
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS
+{
+ .text :
+ {
+ *(.text)
+ _etext = .;
+ PROVIDE(etext = .);
+ }
+}
+</pre></div>
+
+<p>In this example, if the program defines &lsquo;<samp>_etext</samp>&rsquo; (with a leading
+underscore), the linker will give a multiple definition diagnostic. If,
+on the other hand, the program defines &lsquo;<samp>etext</samp>&rsquo; (with no leading
+underscore), the linker will silently use the definition in the program.
+If the program references &lsquo;<samp>etext</samp>&rsquo; but does not define it, the
+linker will use the definition in the linker script.
+</p>
+<p>Note - the <code>PROVIDE</code> directive considers a common symbol to be
+defined, even though such a symbol could be combined with the symbol
+that the <code>PROVIDE</code> would create. This is particularly important
+when considering constructor and destructor list symbols such as
+&lsquo;<samp>__CTOR_LIST__</samp>&rsquo; as these are often defined as common symbols.
+</p>
+<hr>
+<a name="PROVIDE_005fHIDDEN"></a>
+<div class="header">
+<p>
+Next: <a href="#Source-Code-Reference" accesskey="n" rel="next">Source Code Reference</a>, Previous: <a href="#PROVIDE" accesskey="p" rel="previous">PROVIDE</a>, Up: <a href="#Assignments" accesskey="u" rel="up">Assignments</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="PROVIDE_005fHIDDEN-1"></a>
+<h4 class="subsection">3.5.4 PROVIDE_HIDDEN</h4>
+<a name="index-PROVIDE_005fHIDDEN"></a>
+<p>Similar to <code>PROVIDE</code>. For ELF targeted ports, the symbol will be
+hidden and won&rsquo;t be exported.
+</p>
+<hr>
+<a name="Source-Code-Reference"></a>
+<div class="header">
+<p>
+Previous: <a href="#PROVIDE_005fHIDDEN" accesskey="p" rel="previous">PROVIDE_HIDDEN</a>, Up: <a href="#Assignments" accesskey="u" rel="up">Assignments</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Source-Code-Reference-1"></a>
+<h4 class="subsection">3.5.5 Source Code Reference</h4>
+
+<p>Accessing a linker script defined variable from source code is not
+intuitive. In particular a linker script symbol is not equivalent to
+a variable declaration in a high level language, it is instead a
+symbol that does not have a value.
+</p>
+<p>Before going further, it is important to note that compilers often
+transform names in the source code into different names when they are
+stored in the symbol table. For example, Fortran compilers commonly
+prepend or append an underscore, and C++ performs extensive &lsquo;<samp>name
+mangling</samp>&rsquo;. Therefore there might be a discrepancy between the name
+of a variable as it is used in source code and the name of the same
+variable as it is defined in a linker script. For example in C a
+linker script variable might be referred to as:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> extern int foo;
+</pre></div>
+
+<p>But in the linker script it might be defined as:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> _foo = 1000;
+</pre></div>
+
+<p>In the remaining examples however it is assumed that no name
+transformation has taken place.
+</p>
+<p>When a symbol is declared in a high level language such as C, two
+things happen. The first is that the compiler reserves enough space
+in the program&rsquo;s memory to hold the <em>value</em> of the symbol. The
+second is that the compiler creates an entry in the program&rsquo;s symbol
+table which holds the symbol&rsquo;s <em>address</em>. ie the symbol table
+contains the address of the block of memory holding the symbol&rsquo;s
+value. So for example the following C declaration, at file scope:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> int foo = 1000;
+</pre></div>
+
+<p>creates an entry called &lsquo;<samp>foo</samp>&rsquo; in the symbol table. This entry
+holds the address of an &lsquo;<samp>int</samp>&rsquo; sized block of memory where the
+number 1000 is initially stored.
+</p>
+<p>When a program references a symbol the compiler generates code that
+first accesses the symbol table to find the address of the symbol&rsquo;s
+memory block and then code to read the value from that memory block.
+So:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> foo = 1;
+</pre></div>
+
+<p>looks up the symbol &lsquo;<samp>foo</samp>&rsquo; in the symbol table, gets the address
+associated with this symbol and then writes the value 1 into that
+address. Whereas:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> int * a = &amp; foo;
+</pre></div>
+
+<p>looks up the symbol &lsquo;<samp>foo</samp>&rsquo; in the symbol table, gets its address
+and then copies this address into the block of memory associated with
+the variable &lsquo;<samp>a</samp>&rsquo;.
+</p>
+<p>Linker scripts symbol declarations, by contrast, create an entry in
+the symbol table but do not assign any memory to them. Thus they are
+an address without a value. So for example the linker script definition:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> foo = 1000;
+</pre></div>
+
+<p>creates an entry in the symbol table called &lsquo;<samp>foo</samp>&rsquo; which holds
+the address of memory location 1000, but nothing special is stored at
+address 1000. This means that you cannot access the <em>value</em> of a
+linker script defined symbol - it has no value - all you can do is
+access the <em>address</em> of a linker script defined symbol.
+</p>
+<p>Hence when you are using a linker script defined symbol in source code
+you should always take the address of the symbol, and never attempt to
+use its value. For example suppose you want to copy the contents of a
+section of memory called .ROM into a section called .FLASH and the
+linker script contains these declarations:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> start_of_ROM = .ROM;
+ end_of_ROM = .ROM + sizeof (.ROM);
+ start_of_FLASH = .FLASH;
+</pre></div>
+
+<p>Then the C source code to perform the copy would be:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> extern char start_of_ROM, end_of_ROM, start_of_FLASH;
+
+ memcpy (&amp; start_of_FLASH, &amp; start_of_ROM, &amp; end_of_ROM - &amp; start_of_ROM);
+</pre></div>
+
+<p>Note the use of the &lsquo;<samp>&amp;</samp>&rsquo; operators. These are correct.
+Alternatively the symbols can be treated as the names of vectors or
+arrays and then the code will again work as expected:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> extern char start_of_ROM[], end_of_ROM[], start_of_FLASH[];
+
+ memcpy (start_of_FLASH, start_of_ROM, end_of_ROM - start_of_ROM);
+</pre></div>
+
+<p>Note how using this method does not require the use of &lsquo;<samp>&amp;</samp>&rsquo;
+operators.
+</p>
+<hr>
+<a name="SECTIONS"></a>
+<div class="header">
+<p>
+Next: <a href="#MEMORY" accesskey="n" rel="next">MEMORY</a>, Previous: <a href="#Assignments" accesskey="p" rel="previous">Assignments</a>, Up: <a href="#Scripts" accesskey="u" rel="up">Scripts</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="SECTIONS-Command"></a>
+<h3 class="section">3.6 SECTIONS Command</h3>
+<a name="index-SECTIONS"></a>
+<p>The <code>SECTIONS</code> command tells the linker how to map input sections
+into output sections, and how to place the output sections in memory.
+</p>
+<p>The format of the <code>SECTIONS</code> command is:
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS
+{
+ <var>sections-command</var>
+ <var>sections-command</var>
+ &hellip;
+}
+</pre></div>
+
+<p>Each <var>sections-command</var> may of be one of the following:
+</p>
+<ul>
+<li> an <code>ENTRY</code> command (see <a href="#Entry-Point">Entry command</a>)
+</li><li> a symbol assignment (see <a href="#Assignments">Assignments</a>)
+</li><li> an output section description
+</li><li> an overlay description
+</li></ul>
+
+<p>The <code>ENTRY</code> command and symbol assignments are permitted inside the
+<code>SECTIONS</code> command for convenience in using the location counter in
+those commands. This can also make the linker script easier to
+understand because you can use those commands at meaningful points in
+the layout of the output file.
+</p>
+<p>Output section descriptions and overlay descriptions are described
+below.
+</p>
+<p>If you do not use a <code>SECTIONS</code> command in your linker script, the
+linker will place each input section into an identically named output
+section in the order that the sections are first encountered in the
+input files. If all input sections are present in the first file, for
+example, the order of sections in the output file will match the order
+in the first input file. The first section will be at address zero.
+</p>
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#Output-Section-Description" accesskey="1">Output Section Description</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Output section description
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Output-Section-Name" accesskey="2">Output Section Name</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Output section name
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Output-Section-Address" accesskey="3">Output Section Address</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Output section address
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Input-Section" accesskey="4">Input Section</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Input section description
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Output-Section-Data" accesskey="5">Output Section Data</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Output section data
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Output-Section-Keywords" accesskey="6">Output Section Keywords</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Output section keywords
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Output-Section-Discarding" accesskey="7">Output Section Discarding</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Output section discarding
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Output-Section-Attributes" accesskey="8">Output Section Attributes</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Output section attributes
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Overlay-Description" accesskey="9">Overlay Description</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Overlay description
+</td></tr>
+</table>
+
+<hr>
+<a name="Output-Section-Description"></a>
+<div class="header">
+<p>
+Next: <a href="#Output-Section-Name" accesskey="n" rel="next">Output Section Name</a>, Up: <a href="#SECTIONS" accesskey="u" rel="up">SECTIONS</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Output-Section-Description-1"></a>
+<h4 class="subsection">3.6.1 Output Section Description</h4>
+<p>The full description of an output section looks like this:
+</p><div class="smallexample">
+<pre class="smallexample"><var>section</var> [<var>address</var>] [(<var>type</var>)] :
+ [AT(<var>lma</var>)]
+ [ALIGN(<var>section_align</var>) | ALIGN_WITH_INPUT]
+ [SUBALIGN(<var>subsection_align</var>)]
+ [<var>constraint</var>]
+ {
+ <var>output-section-command</var>
+ <var>output-section-command</var>
+ &hellip;
+ } [&gt;<var>region</var>] [AT&gt;<var>lma_region</var>] [:<var>phdr</var> :<var>phdr</var> &hellip;] [=<var>fillexp</var>] [,]
+</pre></div>
+
+<p>Most output sections do not use most of the optional section attributes.
+</p>
+<p>The whitespace around <var>section</var> is required, so that the section
+name is unambiguous. The colon and the curly braces are also required.
+The comma at the end may be required if a <var>fillexp</var> is used and
+the next <var>sections-command</var> looks like a continuation of the expression.
+The line breaks and other white space are optional.
+</p>
+<p>Each <var>output-section-command</var> may be one of the following:
+</p>
+<ul>
+<li> a symbol assignment (see <a href="#Assignments">Assignments</a>)
+</li><li> an input section description (see <a href="#Input-Section">Input Section</a>)
+</li><li> data values to include directly (see <a href="#Output-Section-Data">Output Section Data</a>)
+</li><li> a special output section keyword (see <a href="#Output-Section-Keywords">Output Section Keywords</a>)
+</li></ul>
+
+<hr>
+<a name="Output-Section-Name"></a>
+<div class="header">
+<p>
+Next: <a href="#Output-Section-Address" accesskey="n" rel="next">Output Section Address</a>, Previous: <a href="#Output-Section-Description" accesskey="p" rel="previous">Output Section Description</a>, Up: <a href="#SECTIONS" accesskey="u" rel="up">SECTIONS</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Output-Section-Name-1"></a>
+<h4 class="subsection">3.6.2 Output Section Name</h4>
+<a name="index-name_002c-section"></a>
+<a name="index-section-name"></a>
+<p>The name of the output section is <var>section</var>. <var>section</var> must
+meet the constraints of your output format. In formats which only
+support a limited number of sections, such as <code>a.out</code>, the name
+must be one of the names supported by the format (<code>a.out</code>, for
+example, allows only &lsquo;<samp>.text</samp>&rsquo;, &lsquo;<samp>.data</samp>&rsquo; or &lsquo;<samp>.bss</samp>&rsquo;). If the
+output format supports any number of sections, but with numbers and not
+names (as is the case for Oasys), the name should be supplied as a
+quoted numeric string. A section name may consist of any sequence of
+characters, but a name which contains any unusual characters such as
+commas must be quoted.
+</p>
+<p>The output section name &lsquo;<samp>/DISCARD/</samp>&rsquo; is special; <a href="#Output-Section-Discarding">Output Section Discarding</a>.
+</p>
+<hr>
+<a name="Output-Section-Address"></a>
+<div class="header">
+<p>
+Next: <a href="#Input-Section" accesskey="n" rel="next">Input Section</a>, Previous: <a href="#Output-Section-Name" accesskey="p" rel="previous">Output Section Name</a>, Up: <a href="#SECTIONS" accesskey="u" rel="up">SECTIONS</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Output-Section-Address-1"></a>
+<h4 class="subsection">3.6.3 Output Section Address</h4>
+<a name="index-address_002c-section"></a>
+<a name="index-section-address"></a>
+<p>The <var>address</var> is an expression for the VMA (the virtual memory
+address) of the output section. This address is optional, but if it
+is provided then the output address will be set exactly as specified.
+</p>
+<p>If the output address is not specified then one will be chosen for the
+section, based on the heuristic below. This address will be adjusted
+to fit the alignment requirement of the output section. The
+alignment requirement is the strictest alignment of any input section
+contained within the output section.
+</p>
+<p>The output section address heuristic is as follows:
+</p>
+<ul>
+<li> If an output memory <var>region</var> is set for the section then it
+is added to this region and its address will be the next free address
+in that region.
+
+</li><li> If the MEMORY command has been used to create a list of memory
+regions then the first region which has attributes compatible with the
+section is selected to contain it. The section&rsquo;s output address will
+be the next free address in that region; <a href="#MEMORY">MEMORY</a>.
+
+</li><li> If no memory regions were specified, or none match the section then
+the output address will be based on the current value of the location
+counter.
+</li></ul>
+
+<p>For example:
+</p>
+<div class="smallexample">
+<pre class="smallexample">.text . : { *(.text) }
+</pre></div>
+
+<p>and
+</p>
+<div class="smallexample">
+<pre class="smallexample">.text : { *(.text) }
+</pre></div>
+
+<p>are subtly different. The first will set the address of the
+&lsquo;<samp>.text</samp>&rsquo; output section to the current value of the location
+counter. The second will set it to the current value of the location
+counter aligned to the strictest alignment of any of the &lsquo;<samp>.text</samp>&rsquo;
+input sections.
+</p>
+<p>The <var>address</var> may be an arbitrary expression; <a href="#Expressions">Expressions</a>.
+For example, if you want to align the section on a 0x10 byte boundary,
+so that the lowest four bits of the section address are zero, you could
+do something like this:
+</p><div class="smallexample">
+<pre class="smallexample">.text ALIGN(0x10) : { *(.text) }
+</pre></div>
+<p>This works because <code>ALIGN</code> returns the current location counter
+aligned upward to the specified value.
+</p>
+<p>Specifying <var>address</var> for a section will change the value of the
+location counter, provided that the section is non-empty. (Empty
+sections are ignored).
+</p>
+<hr>
+<a name="Input-Section"></a>
+<div class="header">
+<p>
+Next: <a href="#Output-Section-Data" accesskey="n" rel="next">Output Section Data</a>, Previous: <a href="#Output-Section-Address" accesskey="p" rel="previous">Output Section Address</a>, Up: <a href="#SECTIONS" accesskey="u" rel="up">SECTIONS</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Input-Section-Description"></a>
+<h4 class="subsection">3.6.4 Input Section Description</h4>
+<a name="index-input-sections"></a>
+<a name="index-mapping-input-sections-to-output-sections"></a>
+<p>The most common output section command is an input section description.
+</p>
+<p>The input section description is the most basic linker script operation.
+You use output sections to tell the linker how to lay out your program
+in memory. You use input section descriptions to tell the linker how to
+map the input files into your memory layout.
+</p>
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#Input-Section-Basics" accesskey="1">Input Section Basics</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Input section basics
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Input-Section-Wildcards" accesskey="2">Input Section Wildcards</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Input section wildcard patterns
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Input-Section-Common" accesskey="3">Input Section Common</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Input section for common symbols
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Input-Section-Keep" accesskey="4">Input Section Keep</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Input section and garbage collection
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Input-Section-Example" accesskey="5">Input Section Example</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Input section example
+</td></tr>
+</table>
+
+<hr>
+<a name="Input-Section-Basics"></a>
+<div class="header">
+<p>
+Next: <a href="#Input-Section-Wildcards" accesskey="n" rel="next">Input Section Wildcards</a>, Up: <a href="#Input-Section" accesskey="u" rel="up">Input Section</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Input-Section-Basics-1"></a>
+<h4 class="subsubsection">3.6.4.1 Input Section Basics</h4>
+<a name="index-input-section-basics"></a>
+<p>An input section description consists of a file name optionally followed
+by a list of section names in parentheses.
+</p>
+<p>The file name and the section name may be wildcard patterns, which we
+describe further below (see <a href="#Input-Section-Wildcards">Input Section Wildcards</a>).
+</p>
+<p>The most common input section description is to include all input
+sections with a particular name in the output section. For example, to
+include all input &lsquo;<samp>.text</samp>&rsquo; sections, you would write:
+</p><div class="smallexample">
+<pre class="smallexample">*(.text)
+</pre></div>
+<p>Here the &lsquo;<samp>*</samp>&rsquo; is a wildcard which matches any file name. To exclude a list
+<a name="index-EXCLUDE_005fFILE"></a>
+of files from matching the file name wildcard, EXCLUDE_FILE may be used to
+match all files except the ones specified in the EXCLUDE_FILE list. For
+example:
+</p><div class="smallexample">
+<pre class="smallexample">EXCLUDE_FILE (*crtend.o *otherfile.o) *(.ctors)
+</pre></div>
+<p>will cause all .ctors sections from all files except <samp>crtend.o</samp>
+and <samp>otherfile.o</samp> to be included. The EXCLUDE_FILE can also be
+placed inside the section list, for example:
+</p><div class="smallexample">
+<pre class="smallexample">*(EXCLUDE_FILE (*crtend.o *otherfile.o) .ctors)
+</pre></div>
+<p>The result of this is identically to the previous example. Supporting
+two syntaxes for EXCLUDE_FILE is useful if the section list contains
+more than one section, as described below.
+</p>
+<p>There are two ways to include more than one section:
+</p><div class="smallexample">
+<pre class="smallexample">*(.text .rdata)
+*(.text) *(.rdata)
+</pre></div>
+<p>The difference between these is the order in which the &lsquo;<samp>.text</samp>&rsquo; and
+&lsquo;<samp>.rdata</samp>&rsquo; input sections will appear in the output section. In the
+first example, they will be intermingled, appearing in the same order as
+they are found in the linker input. In the second example, all
+&lsquo;<samp>.text</samp>&rsquo; input sections will appear first, followed by all
+&lsquo;<samp>.rdata</samp>&rsquo; input sections.
+</p>
+<p>When using EXCLUDE_FILE with more than one section, if the exclusion
+is within the section list then the exclusion only applies to the
+immediately following section, for example:
+</p><div class="smallexample">
+<pre class="smallexample">*(EXCLUDE_FILE (*somefile.o) .text .rdata)
+</pre></div>
+<p>will cause all &lsquo;<samp>.text</samp>&rsquo; sections from all files except
+<samp>somefile.o</samp> to be included, while all &lsquo;<samp>.rdata</samp>&rsquo; sections
+from all files, including <samp>somefile.o</samp>, will be included. To
+exclude the &lsquo;<samp>.rdata</samp>&rsquo; sections from <samp>somefile.o</samp> the example
+could be modified to:
+</p><div class="smallexample">
+<pre class="smallexample">*(EXCLUDE_FILE (*somefile.o) .text EXCLUDE_FILE (*somefile.o) .rdata)
+</pre></div>
+<p>Alternatively, placing the EXCLUDE_FILE outside of the section list,
+before the input file selection, will cause the exclusion to apply for
+all sections. Thus the previous example can be rewritten as:
+</p><div class="smallexample">
+<pre class="smallexample">EXCLUDE_FILE (*somefile.o) *(.text .rdata)
+</pre></div>
+
+<p>You can specify a file name to include sections from a particular file.
+You would do this if one or more of your files contain special data that
+needs to be at a particular location in memory. For example:
+</p><div class="smallexample">
+<pre class="smallexample">data.o(.data)
+</pre></div>
+
+<p>To refine the sections that are included based on the section flags
+of an input section, INPUT_SECTION_FLAGS may be used.
+</p>
+<p>Here is a simple example for using Section header flags for ELF sections:
+</p>
+<div class="smallexample">
+<pre class="smallexample">SECTIONS {
+ .text : { INPUT_SECTION_FLAGS (SHF_MERGE &amp; SHF_STRINGS) *(.text) }
+ .text2 : { INPUT_SECTION_FLAGS (!SHF_WRITE) *(.text) }
+}
+</pre></div>
+
+<p>In this example, the output section &lsquo;<samp>.text</samp>&rsquo; will be comprised of any
+input section matching the name *(.text) whose section header flags
+<code>SHF_MERGE</code> and <code>SHF_STRINGS</code> are set. The output section
+&lsquo;<samp>.text2</samp>&rsquo; will be comprised of any input section matching the name *(.text)
+whose section header flag <code>SHF_WRITE</code> is clear.
+</p>
+<p>You can also specify files within archives by writing a pattern
+matching the archive, a colon, then the pattern matching the file,
+with no whitespace around the colon.
+</p>
+<dl compact="compact">
+<dt>&lsquo;<samp>archive:file</samp>&rsquo;</dt>
+<dd><p>matches file within archive
+</p></dd>
+<dt>&lsquo;<samp>archive:</samp>&rsquo;</dt>
+<dd><p>matches the whole archive
+</p></dd>
+<dt>&lsquo;<samp>:file</samp>&rsquo;</dt>
+<dd><p>matches file but not one in an archive
+</p></dd>
+</dl>
+
+<p>Either one or both of &lsquo;<samp>archive</samp>&rsquo; and &lsquo;<samp>file</samp>&rsquo; can contain shell
+wildcards. On DOS based file systems, the linker will assume that a
+single letter followed by a colon is a drive specifier, so
+&lsquo;<samp>c:myfile.o</samp>&rsquo; is a simple file specification, not &lsquo;<samp>myfile.o</samp>&rsquo;
+within an archive called &lsquo;<samp>c</samp>&rsquo;. &lsquo;<samp>archive:file</samp>&rsquo; filespecs may
+also be used within an <code>EXCLUDE_FILE</code> list, but may not appear in
+other linker script contexts. For instance, you cannot extract a file
+from an archive by using &lsquo;<samp>archive:file</samp>&rsquo; in an <code>INPUT</code>
+command.
+</p>
+<p>If you use a file name without a list of sections, then all sections in
+the input file will be included in the output section. This is not
+commonly done, but it may by useful on occasion. For example:
+</p><div class="smallexample">
+<pre class="smallexample">data.o
+</pre></div>
+
+<p>When you use a file name which is not an &lsquo;<samp>archive:file</samp>&rsquo; specifier
+and does not contain any wild card
+characters, the linker will first see if you also specified the file
+name on the linker command line or in an <code>INPUT</code> command. If you
+did not, the linker will attempt to open the file as an input file, as
+though it appeared on the command line. Note that this differs from an
+<code>INPUT</code> command, because the linker will not search for the file in
+the archive search path.
+</p>
+<hr>
+<a name="Input-Section-Wildcards"></a>
+<div class="header">
+<p>
+Next: <a href="#Input-Section-Common" accesskey="n" rel="next">Input Section Common</a>, Previous: <a href="#Input-Section-Basics" accesskey="p" rel="previous">Input Section Basics</a>, Up: <a href="#Input-Section" accesskey="u" rel="up">Input Section</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Input-Section-Wildcard-Patterns"></a>
+<h4 class="subsubsection">3.6.4.2 Input Section Wildcard Patterns</h4>
+<a name="index-input-section-wildcards"></a>
+<a name="index-wildcard-file-name-patterns"></a>
+<a name="index-file-name-wildcard-patterns"></a>
+<a name="index-section-name-wildcard-patterns"></a>
+<p>In an input section description, either the file name or the section
+name or both may be wildcard patterns.
+</p>
+<p>The file name of &lsquo;<samp>*</samp>&rsquo; seen in many examples is a simple wildcard
+pattern for the file name.
+</p>
+<p>The wildcard patterns are like those used by the Unix shell.
+</p>
+<dl compact="compact">
+<dt>&lsquo;<samp>*</samp>&rsquo;</dt>
+<dd><p>matches any number of characters
+</p></dd>
+<dt>&lsquo;<samp>?</samp>&rsquo;</dt>
+<dd><p>matches any single character
+</p></dd>
+<dt>&lsquo;<samp>[<var>chars</var>]</samp>&rsquo;</dt>
+<dd><p>matches a single instance of any of the <var>chars</var>; the &lsquo;<samp>-</samp>&rsquo;
+character may be used to specify a range of characters, as in
+&lsquo;<samp>[a-z]</samp>&rsquo; to match any lower case letter
+</p></dd>
+<dt>&lsquo;<samp>\</samp>&rsquo;</dt>
+<dd><p>quotes the following character
+</p></dd>
+</dl>
+
+<p>File name wildcard patterns only match files which are explicitly
+specified on the command line or in an <code>INPUT</code> command. The linker
+does not search directories to expand wildcards.
+</p>
+<p>If a file name matches more than one wildcard pattern, or if a file name
+appears explicitly and is also matched by a wildcard pattern, the linker
+will use the first match in the linker script. For example, this
+sequence of input section descriptions is probably in error, because the
+<samp>data.o</samp> rule will not be used:
+</p><div class="smallexample">
+<pre class="smallexample">.data : { *(.data) }
+.data1 : { data.o(.data) }
+</pre></div>
+
+<a name="index-SORT_005fBY_005fNAME"></a>
+<p>Normally, the linker will place files and sections matched by wildcards
+in the order in which they are seen during the link. You can change
+this by using the <code>SORT_BY_NAME</code> keyword, which appears before a wildcard
+pattern in parentheses (e.g., <code>SORT_BY_NAME(.text*)</code>). When the
+<code>SORT_BY_NAME</code> keyword is used, the linker will sort the files or sections
+into ascending order by name before placing them in the output file.
+</p>
+<a name="index-SORT_005fBY_005fALIGNMENT"></a>
+<p><code>SORT_BY_ALIGNMENT</code> is similar to <code>SORT_BY_NAME</code>.
+<code>SORT_BY_ALIGNMENT</code> will sort sections into descending order of
+alignment before placing them in the output file. Placing larger
+alignments before smaller alignments can reduce the amount of padding
+needed.
+</p>
+<a name="index-SORT_005fBY_005fINIT_005fPRIORITY"></a>
+<p><code>SORT_BY_INIT_PRIORITY</code> is also similar to <code>SORT_BY_NAME</code>.
+<code>SORT_BY_INIT_PRIORITY</code> will sort sections into ascending
+numerical order of the GCC init_priority attribute encoded in the
+section name before placing them in the output file. In
+<code>.init_array.NNNNN</code> and <code>.fini_array.NNNNN</code>, <code>NNNNN</code> is
+the init_priority. In <code>.ctors.NNNNN</code> and <code>.dtors.NNNNN</code>,
+<code>NNNNN</code> is 65535 minus the init_priority.
+</p>
+<a name="index-SORT"></a>
+<p><code>SORT</code> is an alias for <code>SORT_BY_NAME</code>.
+</p>
+<p>When there are nested section sorting commands in linker script, there
+can be at most 1 level of nesting for section sorting commands.
+</p>
+<ol>
+<li> <code>SORT_BY_NAME</code> (<code>SORT_BY_ALIGNMENT</code> (wildcard section pattern)).
+It will sort the input sections by name first, then by alignment if two
+sections have the same name.
+</li><li> <code>SORT_BY_ALIGNMENT</code> (<code>SORT_BY_NAME</code> (wildcard section pattern)).
+It will sort the input sections by alignment first, then by name if two
+sections have the same alignment.
+</li><li> <code>SORT_BY_NAME</code> (<code>SORT_BY_NAME</code> (wildcard section pattern)) is
+treated the same as <code>SORT_BY_NAME</code> (wildcard section pattern).
+</li><li> <code>SORT_BY_ALIGNMENT</code> (<code>SORT_BY_ALIGNMENT</code> (wildcard section pattern))
+is treated the same as <code>SORT_BY_ALIGNMENT</code> (wildcard section pattern).
+</li><li> All other nested section sorting commands are invalid.
+</li></ol>
+
+<p>When both command-line section sorting option and linker script
+section sorting command are used, section sorting command always
+takes precedence over the command-line option.
+</p>
+<p>If the section sorting command in linker script isn&rsquo;t nested, the
+command-line option will make the section sorting command to be
+treated as nested sorting command.
+</p>
+<ol>
+<li> <code>SORT_BY_NAME</code> (wildcard section pattern ) with
+<samp>--sort-sections alignment</samp> is equivalent to
+<code>SORT_BY_NAME</code> (<code>SORT_BY_ALIGNMENT</code> (wildcard section pattern)).
+</li><li> <code>SORT_BY_ALIGNMENT</code> (wildcard section pattern) with
+<samp>--sort-section name</samp> is equivalent to
+<code>SORT_BY_ALIGNMENT</code> (<code>SORT_BY_NAME</code> (wildcard section pattern)).
+</li></ol>
+
+<p>If the section sorting command in linker script is nested, the
+command-line option will be ignored.
+</p>
+<a name="index-SORT_005fNONE"></a>
+<p><code>SORT_NONE</code> disables section sorting by ignoring the command-line
+section sorting option.
+</p>
+<p>If you ever get confused about where input sections are going, use the
+&lsquo;<samp>-M</samp>&rsquo; linker option to generate a map file. The map file shows
+precisely how input sections are mapped to output sections.
+</p>
+<p>This example shows how wildcard patterns might be used to partition
+files. This linker script directs the linker to place all &lsquo;<samp>.text</samp>&rsquo;
+sections in &lsquo;<samp>.text</samp>&rsquo; and all &lsquo;<samp>.bss</samp>&rsquo; sections in &lsquo;<samp>.bss</samp>&rsquo;.
+The linker will place the &lsquo;<samp>.data</samp>&rsquo; section from all files beginning
+with an upper case character in &lsquo;<samp>.DATA</samp>&rsquo;; for all other files, the
+linker will place the &lsquo;<samp>.data</samp>&rsquo; section in &lsquo;<samp>.data</samp>&rsquo;.
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS {
+ .text : { *(.text) }
+ .DATA : { [A-Z]*(.data) }
+ .data : { *(.data) }
+ .bss : { *(.bss) }
+}
+</pre></div>
+
+<hr>
+<a name="Input-Section-Common"></a>
+<div class="header">
+<p>
+Next: <a href="#Input-Section-Keep" accesskey="n" rel="next">Input Section Keep</a>, Previous: <a href="#Input-Section-Wildcards" accesskey="p" rel="previous">Input Section Wildcards</a>, Up: <a href="#Input-Section" accesskey="u" rel="up">Input Section</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Input-Section-for-Common-Symbols"></a>
+<h4 class="subsubsection">3.6.4.3 Input Section for Common Symbols</h4>
+<a name="index-common-symbol-placement"></a>
+<a name="index-uninitialized-data-placement"></a>
+<p>A special notation is needed for common symbols, because in many object
+file formats common symbols do not have a particular input section. The
+linker treats common symbols as though they are in an input section
+named &lsquo;<samp>COMMON</samp>&rsquo;.
+</p>
+<p>You may use file names with the &lsquo;<samp>COMMON</samp>&rsquo; section just as with any
+other input sections. You can use this to place common symbols from a
+particular input file in one section while common symbols from other
+input files are placed in another section.
+</p>
+<p>In most cases, common symbols in input files will be placed in the
+&lsquo;<samp>.bss</samp>&rsquo; section in the output file. For example:
+</p><div class="smallexample">
+<pre class="smallexample">.bss { *(.bss) *(COMMON) }
+</pre></div>
+
+<a name="index-scommon-section"></a>
+<a name="index-small-common-symbols"></a>
+<p>Some object file formats have more than one type of common symbol. For
+example, the MIPS ELF object file format distinguishes standard common
+symbols and small common symbols. In this case, the linker will use a
+different special section name for other types of common symbols. In
+the case of MIPS ELF, the linker uses &lsquo;<samp>COMMON</samp>&rsquo; for standard common
+symbols and &lsquo;<samp>.scommon</samp>&rsquo; for small common symbols. This permits you
+to map the different types of common symbols into memory at different
+locations.
+</p>
+<a name="index-_005bCOMMON_005d"></a>
+<p>You will sometimes see &lsquo;<samp>[COMMON]</samp>&rsquo; in old linker scripts. This
+notation is now considered obsolete. It is equivalent to
+&lsquo;<samp>*(COMMON)</samp>&rsquo;.
+</p>
+<hr>
+<a name="Input-Section-Keep"></a>
+<div class="header">
+<p>
+Next: <a href="#Input-Section-Example" accesskey="n" rel="next">Input Section Example</a>, Previous: <a href="#Input-Section-Common" accesskey="p" rel="previous">Input Section Common</a>, Up: <a href="#Input-Section" accesskey="u" rel="up">Input Section</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Input-Section-and-Garbage-Collection"></a>
+<h4 class="subsubsection">3.6.4.4 Input Section and Garbage Collection</h4>
+<a name="index-KEEP"></a>
+<a name="index-garbage-collection-3"></a>
+<p>When link-time garbage collection is in use (&lsquo;<samp>--gc-sections</samp>&rsquo;),
+it is often useful to mark sections that should not be eliminated.
+This is accomplished by surrounding an input section&rsquo;s wildcard entry
+with <code>KEEP()</code>, as in <code>KEEP(*(.init))</code> or
+<code>KEEP(SORT_BY_NAME(*)(.ctors))</code>.
+</p>
+<hr>
+<a name="Input-Section-Example"></a>
+<div class="header">
+<p>
+Previous: <a href="#Input-Section-Keep" accesskey="p" rel="previous">Input Section Keep</a>, Up: <a href="#Input-Section" accesskey="u" rel="up">Input Section</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Input-Section-Example-1"></a>
+<h4 class="subsubsection">3.6.4.5 Input Section Example</h4>
+<p>The following example is a complete linker script. It tells the linker
+to read all of the sections from file <samp>all.o</samp> and place them at the
+start of output section &lsquo;<samp>outputa</samp>&rsquo; which starts at location
+&lsquo;<samp>0x10000</samp>&rsquo;. All of section &lsquo;<samp>.input1</samp>&rsquo; from file <samp>foo.o</samp>
+follows immediately, in the same output section. All of section
+&lsquo;<samp>.input2</samp>&rsquo; from <samp>foo.o</samp> goes into output section
+&lsquo;<samp>outputb</samp>&rsquo;, followed by section &lsquo;<samp>.input1</samp>&rsquo; from <samp>foo1.o</samp>.
+All of the remaining &lsquo;<samp>.input1</samp>&rsquo; and &lsquo;<samp>.input2</samp>&rsquo; sections from any
+files are written to output section &lsquo;<samp>outputc</samp>&rsquo;.
+</p>
+<div class="smallexample">
+<pre class="smallexample">SECTIONS {
+ outputa 0x10000 :
+ {
+ all.o
+ foo.o (.input1)
+ }
+</pre><pre class="smallexample"> outputb :
+ {
+ foo.o (.input2)
+ foo1.o (.input1)
+ }
+</pre><pre class="smallexample"> outputc :
+ {
+ *(.input1)
+ *(.input2)
+ }
+}
+</pre></div>
+
+<p>If an output section&rsquo;s name is the same as the input section&rsquo;s name
+and is representable as a C identifier, then the linker will
+automatically see <a href="#PROVIDE">PROVIDE</a> two symbols: __start_SECNAME and
+__stop_SECNAME, where SECNAME is the name of the section. These
+indicate the start address and end address of the output section
+respectively. Note: most section names are not representable as
+C identifiers because they contain a &lsquo;<samp>.</samp>&rsquo; character.
+</p>
+<hr>
+<a name="Output-Section-Data"></a>
+<div class="header">
+<p>
+Next: <a href="#Output-Section-Keywords" accesskey="n" rel="next">Output Section Keywords</a>, Previous: <a href="#Input-Section" accesskey="p" rel="previous">Input Section</a>, Up: <a href="#SECTIONS" accesskey="u" rel="up">SECTIONS</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Output-Section-Data-1"></a>
+<h4 class="subsection">3.6.5 Output Section Data</h4>
+<a name="index-data"></a>
+<a name="index-section-data"></a>
+<a name="index-output-section-data"></a>
+<a name="index-ASCIZ-_0060_0060string_0027_0027"></a>
+<a name="index-BYTE_0028expression_0029"></a>
+<a name="index-SHORT_0028expression_0029"></a>
+<a name="index-LONG_0028expression_0029"></a>
+<a name="index-QUAD_0028expression_0029"></a>
+<a name="index-SQUAD_0028expression_0029"></a>
+<p>You can include explicit bytes of data in an output section by using
+<code>BYTE</code>, <code>SHORT</code>, <code>LONG</code>, <code>QUAD</code>, or <code>SQUAD</code> as
+an output section command. Each keyword is followed by an expression in
+parentheses providing the value to store (see <a href="#Expressions">Expressions</a>). The
+value of the expression is stored at the current value of the location
+counter.
+</p>
+<p>The <code>BYTE</code>, <code>SHORT</code>, <code>LONG</code>, and <code>QUAD</code> commands
+store one, two, four, and eight bytes (respectively). After storing the
+bytes, the location counter is incremented by the number of bytes
+stored.
+</p>
+<p>For example, this will store the byte 1 followed by the four byte value
+of the symbol &lsquo;<samp>addr</samp>&rsquo;:
+</p><div class="smallexample">
+<pre class="smallexample">BYTE(1)
+LONG(addr)
+</pre></div>
+
+<p>When using a 64 bit host or target, <code>QUAD</code> and <code>SQUAD</code> are the
+same; they both store an 8 byte, or 64 bit, value. When both host and
+target are 32 bits, an expression is computed as 32 bits. In this case
+<code>QUAD</code> stores a 32 bit value zero extended to 64 bits, and
+<code>SQUAD</code> stores a 32 bit value sign extended to 64 bits.
+</p>
+<p>If the object file format of the output file has an explicit endianness,
+which is the normal case, the value will be stored in that endianness.
+When the object file format does not have an explicit endianness, as is
+true of, for example, S-records, the value will be stored in the
+endianness of the first input object file.
+</p>
+<p>You can include a zero-terminated string in an output section by using
+<code>ASCIZ</code>. The keyword is followed by a string which is stored at
+the current value of the location counter adding a zero byte at the
+end. If the string includes spaces it must be enclosed in double
+quotes. The string may contain &rsquo;\n&rsquo;, &rsquo;\r&rsquo;, &rsquo;\t&rsquo; and octal numbers.
+Hex numbers are not supported.
+</p>
+<p>For example, this string of 16 characters will create a 17 byte area
+</p><div class="smallexample">
+<pre class="smallexample"> ASCIZ &quot;This is 16 bytes&quot;
+</pre></div>
+
+<p>Note&mdash;these commands only work inside a section description and not
+between them, so the following will produce an error from the linker:
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS {&nbsp;.text : {&nbsp;*(.text) }&nbsp;LONG(1) .data : {&nbsp;*(.data) }&nbsp;}&nbsp;</pre></div>
+<p>whereas this will work:
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS {&nbsp;.text : {&nbsp;*(.text) ; LONG(1) }&nbsp;.data : {&nbsp;*(.data) }&nbsp;}&nbsp;</pre></div>
+
+<a name="index-FILL_0028expression_0029"></a>
+<a name="index-holes_002c-filling"></a>
+<a name="index-unspecified-memory"></a>
+<p>You may use the <code>FILL</code> command to set the fill pattern for the
+current section. It is followed by an expression in parentheses. Any
+otherwise unspecified regions of memory within the section (for example,
+gaps left due to the required alignment of input sections) are filled
+with the value of the expression, repeated as
+necessary. A <code>FILL</code> statement covers memory locations after the
+point at which it occurs in the section definition; by including more
+than one <code>FILL</code> statement, you can have different fill patterns in
+different parts of an output section.
+</p>
+<p>This example shows how to fill unspecified regions of memory with the
+value &lsquo;<samp>0x90</samp>&rsquo;:
+</p><div class="smallexample">
+<pre class="smallexample">FILL(0x90909090)
+</pre></div>
+
+<p>The <code>FILL</code> command is similar to the &lsquo;<samp>=<var>fillexp</var></samp>&rsquo; output
+section attribute, but it only affects the
+part of the section following the <code>FILL</code> command, rather than the
+entire section. If both are used, the <code>FILL</code> command takes
+precedence. See <a href="#Output-Section-Fill">Output Section Fill</a>, for details on the fill
+expression.
+</p>
+<a name="index-LINKER_005fVERSION-1"></a>
+<a name="index-LINKER_005fVERSION"></a>
+<p>Inserts a string containing the version of the linker at the current
+point. Note - by default this directive is disabled and will do
+nothing. It only becomes active if the
+<samp>--enable-linker-version</samp> command line option is used.
+</p>
+<p>Built-in linker scripts for ELF based targets already include this
+directive in their &lsquo;<samp>.comment</samp>&rsquo; section.
+</p>
+<hr>
+<a name="Output-Section-Keywords"></a>
+<div class="header">
+<p>
+Next: <a href="#Output-Section-Discarding" accesskey="n" rel="next">Output Section Discarding</a>, Previous: <a href="#Output-Section-Data" accesskey="p" rel="previous">Output Section Data</a>, Up: <a href="#SECTIONS" accesskey="u" rel="up">SECTIONS</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Output-Section-Keywords-1"></a>
+<h4 class="subsection">3.6.6 Output Section Keywords</h4>
+<p>There are a couple of keywords which can appear as output section
+commands.
+</p>
+<dl compact="compact">
+<dd><a name="index-CREATE_005fOBJECT_005fSYMBOLS"></a>
+<a name="index-input-filename-symbols"></a>
+<a name="index-filename-symbols"></a>
+</dd>
+<dt><code>CREATE_OBJECT_SYMBOLS</code></dt>
+<dd><p>The command tells the linker to create a symbol for each input file.
+The name of each symbol will be the name of the corresponding input
+file. The section of each symbol will be the output section in which
+the <code>CREATE_OBJECT_SYMBOLS</code> command appears.
+</p>
+<p>This is conventional for the a.out object file format. It is not
+normally used for any other object file format.
+</p>
+<a name="index-CONSTRUCTORS"></a>
+<a name="index-C_002b_002b-constructors_002c-arranging-in-link"></a>
+<a name="index-constructors_002c-arranging-in-link"></a>
+</dd>
+<dt><code>CONSTRUCTORS</code></dt>
+<dd><p>When linking using the a.out object file format, the linker uses an
+unusual set construct to support C++ global constructors and
+destructors. When linking object file formats which do not support
+arbitrary sections, such as ECOFF and XCOFF, the linker will
+automatically recognize C++ global constructors and destructors by name.
+For these object file formats, the <code>CONSTRUCTORS</code> command tells the
+linker to place constructor information in the output section where the
+<code>CONSTRUCTORS</code> command appears. The <code>CONSTRUCTORS</code> command is
+ignored for other object file formats.
+</p>
+<p>The symbol <code><span class="nolinebreak">__CTOR_LIST__</span></code><!-- /@w --> marks the start of the global
+constructors, and the symbol <code><span class="nolinebreak">__CTOR_END__</span></code><!-- /@w --> marks the end.
+Similarly, <code><span class="nolinebreak">__DTOR_LIST__</span></code><!-- /@w --> and <code><span class="nolinebreak">__DTOR_END__</span></code><!-- /@w --> mark
+the start and end of the global destructors. The
+first word in the list is the number of entries, followed by the address
+of each constructor or destructor, followed by a zero word. The
+compiler must arrange to actually run the code. For these object file
+formats <small>GNU</small> C++ normally calls constructors from a subroutine
+<code>__main</code>; a call to <code>__main</code> is automatically inserted into
+the startup code for <code>main</code>. <small>GNU</small> C++ normally runs
+destructors either by using <code>atexit</code>, or directly from the function
+<code>exit</code>.
+</p>
+<p>For object file formats such as <code>COFF</code> or <code>ELF</code> which support
+arbitrary section names, <small>GNU</small> C++ will normally arrange to put the
+addresses of global constructors and destructors into the <code>.ctors</code>
+and <code>.dtors</code> sections. Placing the following sequence into your
+linker script will build the sort of table which the <small>GNU</small> C++
+runtime code expects to see.
+</p>
+<div class="smallexample">
+<pre class="smallexample"> __CTOR_LIST__ = .;
+ LONG((__CTOR_END__ - __CTOR_LIST__) / 4 - 2)
+ *(.ctors)
+ LONG(0)
+ __CTOR_END__ = .;
+ __DTOR_LIST__ = .;
+ LONG((__DTOR_END__ - __DTOR_LIST__) / 4 - 2)
+ *(.dtors)
+ LONG(0)
+ __DTOR_END__ = .;
+</pre></div>
+
+<p>If you are using the <small>GNU</small> C++ support for initialization priority,
+which provides some control over the order in which global constructors
+are run, you must sort the constructors at link time to ensure that they
+are executed in the correct order. When using the <code>CONSTRUCTORS</code>
+command, use &lsquo;<samp>SORT_BY_NAME(CONSTRUCTORS)</samp>&rsquo; instead. When using the
+<code>.ctors</code> and <code>.dtors</code> sections, use &lsquo;<samp>*(SORT_BY_NAME(.ctors))</samp>&rsquo; and
+&lsquo;<samp>*(SORT_BY_NAME(.dtors))</samp>&rsquo; instead of just &lsquo;<samp>*(.ctors)</samp>&rsquo; and
+&lsquo;<samp>*(.dtors)</samp>&rsquo;.
+</p>
+<p>Normally the compiler and linker will handle these issues automatically,
+and you will not need to concern yourself with them. However, you may
+need to consider this if you are using C++ and writing your own linker
+scripts.
+</p>
+</dd>
+</dl>
+
+<hr>
+<a name="Output-Section-Discarding"></a>
+<div class="header">
+<p>
+Next: <a href="#Output-Section-Attributes" accesskey="n" rel="next">Output Section Attributes</a>, Previous: <a href="#Output-Section-Keywords" accesskey="p" rel="previous">Output Section Keywords</a>, Up: <a href="#SECTIONS" accesskey="u" rel="up">SECTIONS</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Output-Section-Discarding-1"></a>
+<h4 class="subsection">3.6.7 Output Section Discarding</h4>
+<a name="index-discarding-sections"></a>
+<a name="index-sections_002c-discarding"></a>
+<a name="index-removing-sections"></a>
+<p>The linker will not normally create output sections with no contents.
+This is for convenience when referring to input sections that may or
+may not be present in any of the input files. For example:
+</p><div class="smallexample">
+<pre class="smallexample">.foo : { *(.foo) }
+</pre></div>
+<p>will only create a &lsquo;<samp>.foo</samp>&rsquo; section in the output file if there is a
+&lsquo;<samp>.foo</samp>&rsquo; section in at least one input file, and if the input
+sections are not all empty. Other link script directives that allocate
+space in an output section will also create the output section. So
+too will assignments to dot even if the assignment does not create
+space, except for &lsquo;<samp>. = 0</samp>&rsquo;, &lsquo;<samp>. = . + 0</samp>&rsquo;, &lsquo;<samp>. = sym</samp>&rsquo;,
+&lsquo;<samp>. = . + sym</samp>&rsquo; and &lsquo;<samp>. = ALIGN (. != 0, expr, 1)</samp>&rsquo; when
+&lsquo;<samp>sym</samp>&rsquo; is an absolute symbol of value 0 defined in the script.
+This allows you to force output of an empty section with &lsquo;<samp>. = .</samp>&rsquo;.
+</p>
+<p>The linker will ignore address assignments (see <a href="#Output-Section-Address">Output Section Address</a>)
+on discarded output sections, except when the linker script defines
+symbols in the output section. In that case the linker will obey
+the address assignments, possibly advancing dot even though the
+section is discarded.
+</p>
+<a name="index-_002fDISCARD_002f"></a>
+<p>The special output section name &lsquo;<samp>/DISCARD/</samp>&rsquo; may be used to discard
+input sections. Any input sections which are assigned to an output
+section named &lsquo;<samp>/DISCARD/</samp>&rsquo; are not included in the output file.
+</p>
+<p>This can be used to discard input sections marked with the ELF flag
+<code>SHF_GNU_RETAIN</code>, which would otherwise have been saved from linker
+garbage collection.
+</p>
+<p>Note, sections that match the &lsquo;<samp>/DISCARD/</samp>&rsquo; output section will be
+discarded even if they are in an ELF section group which has other
+members which are not being discarded. This is deliberate.
+Discarding takes precedence over grouping.
+</p>
+<hr>
+<a name="Output-Section-Attributes"></a>
+<div class="header">
+<p>
+Next: <a href="#Overlay-Description" accesskey="n" rel="next">Overlay Description</a>, Previous: <a href="#Output-Section-Discarding" accesskey="p" rel="previous">Output Section Discarding</a>, Up: <a href="#SECTIONS" accesskey="u" rel="up">SECTIONS</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Output-Section-Attributes-1"></a>
+<h4 class="subsection">3.6.8 Output Section Attributes</h4>
+<a name="index-output-section-attributes"></a>
+<p>We showed above that the full description of an output section looked
+like this:
+</p>
+<div class="smallexample">
+<pre class="smallexample"><var>section</var> [<var>address</var>] [(<var>type</var>)] :
+ [AT(<var>lma</var>)]
+ [ALIGN(<var>section_align</var>) | ALIGN_WITH_INPUT]
+ [SUBALIGN(<var>subsection_align</var>)]
+ [<var>constraint</var>]
+ {
+ <var>output-section-command</var>
+ <var>output-section-command</var>
+ &hellip;
+ } [&gt;<var>region</var>] [AT&gt;<var>lma_region</var>] [:<var>phdr</var> :<var>phdr</var> &hellip;] [=<var>fillexp</var>]
+</pre></div>
+
+<p>We&rsquo;ve already described <var>section</var>, <var>address</var>, and
+<var>output-section-command</var>. In this section we will describe the
+remaining section attributes.
+</p>
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#Output-Section-Type" accesskey="1">Output Section Type</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Output section type
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Output-Section-LMA" accesskey="2">Output Section LMA</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Output section LMA
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Forced-Output-Alignment" accesskey="3">Forced Output Alignment</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Forced Output Alignment
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Forced-Input-Alignment" accesskey="4">Forced Input Alignment</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Forced Input Alignment
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Output-Section-Constraint" accesskey="5">Output Section Constraint</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Output section constraint
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Output-Section-Region" accesskey="6">Output Section Region</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Output section region
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Output-Section-Phdr" accesskey="7">Output Section Phdr</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Output section phdr
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Output-Section-Fill" accesskey="8">Output Section Fill</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Output section fill
+</td></tr>
+</table>
+
+<hr>
+<a name="Output-Section-Type"></a>
+<div class="header">
+<p>
+Next: <a href="#Output-Section-LMA" accesskey="n" rel="next">Output Section LMA</a>, Up: <a href="#Output-Section-Attributes" accesskey="u" rel="up">Output Section Attributes</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Output-Section-Type-1"></a>
+<h4 class="subsubsection">3.6.8.1 Output Section Type</h4>
+<p>Each output section may have a type. The type is a keyword in
+parentheses. The following types are defined:
+</p>
+<dl compact="compact">
+<dt><code>NOLOAD</code></dt>
+<dd><p>The section should be marked as not loadable, so that it will not be
+loaded into memory when the program is run.
+</p>
+</dd>
+<dt><code>READONLY</code></dt>
+<dd><p>The section should be marked as read-only.
+</p>
+</dd>
+<dt><code>DSECT</code></dt>
+<dt><code>COPY</code></dt>
+<dt><code>INFO</code></dt>
+<dt><code>OVERLAY</code></dt>
+<dd><p>These type names are supported for backward compatibility, and are
+rarely used. They all have the same effect: the section should be
+marked as not allocatable, so that no memory is allocated for the
+section when the program is run.
+</p>
+</dd>
+<dt><code>TYPE = <var>type</var></code></dt>
+<dd><p>Set the section type to the integer <var>type</var>. When generating an ELF
+output file, type names <code>SHT_PROGBITS</code>, <code>SHT_STRTAB</code>,
+<code>SHT_NOTE</code>, <code>SHT_NOBITS</code>, <code>SHT_INIT_ARRAY</code>,
+<code>SHT_FINI_ARRAY</code>, and <code>SHT_PREINIT_ARRAY</code> are also allowed
+for <var>type</var>. It is the user&rsquo;s responsibility to ensure that any
+special requirements of the section type are met.
+</p>
+<p>Note - the TYPE only is used if some or all of the contents of the
+section do not have an implicit type of their own. So for example:
+</p><div class="smallexample">
+<pre class="smallexample"> .foo . TYPE = SHT_PROGBITS { *(.bar) }
+</pre></div>
+<p>will set the type of section &lsquo;<samp>.foo</samp>&rsquo; to the type of the section
+&lsquo;<samp>.bar</samp>&rsquo; in the input files, which may not be the SHT_PROGBITS
+type. Whereas:
+</p><div class="smallexample">
+<pre class="smallexample"> .foo . TYPE = SHT_PROGBITS { BYTE(1) }
+</pre></div>
+<p>will set the type of &lsquo;<samp>.foo</samp>&rsquo; to SHT_PROGBBITS. If it is necessary
+to override the type of incoming sections and force the output section
+type then an extra piece of untyped data will be needed:
+</p><div class="smallexample">
+<pre class="smallexample"> .foo . TYPE = SHT_PROGBITS { BYTE(1); *(.bar) }
+</pre></div>
+
+</dd>
+<dt><code>READONLY ( TYPE = <var>type</var> )</code></dt>
+<dd><p>This form of the syntax combines the <var>READONLY</var> type with the
+type specified by <var>type</var>.
+</p>
+</dd>
+</dl>
+
+<a name="index-NOLOAD"></a>
+<a name="index-prevent-unnecessary-loading"></a>
+<a name="index-loading_002c-preventing"></a>
+<p>The linker normally sets the attributes of an output section based on
+the input sections which map into it. You can override this by using
+the section type. For example, in the script sample below, the
+&lsquo;<samp>ROM</samp>&rsquo; section is addressed at memory location &lsquo;<samp>0</samp>&rsquo; and does not
+need to be loaded when the program is run.
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS {
+ ROM 0 (NOLOAD) : { &hellip; }
+ &hellip;
+}
+</pre></div>
+
+<hr>
+<a name="Output-Section-LMA"></a>
+<div class="header">
+<p>
+Next: <a href="#Forced-Output-Alignment" accesskey="n" rel="next">Forced Output Alignment</a>, Previous: <a href="#Output-Section-Type" accesskey="p" rel="previous">Output Section Type</a>, Up: <a href="#Output-Section-Attributes" accesskey="u" rel="up">Output Section Attributes</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Output-Section-LMA-1"></a>
+<h4 class="subsubsection">3.6.8.2 Output Section LMA</h4>
+<a name="index-AT_003elma_005fregion"></a>
+<a name="index-AT_0028lma_0029"></a>
+<a name="index-load-address"></a>
+<a name="index-section-load-address"></a>
+<p>Every section has a virtual address (VMA) and a load address (LMA); see
+<a href="#Basic-Script-Concepts">Basic Script Concepts</a>. The virtual address is specified by the
+see <a href="#Output-Section-Address">Output Section Address</a> described earlier. The load address is
+specified by the <code>AT</code> or <code>AT&gt;</code> keywords. Specifying a load
+address is optional.
+</p>
+<p>The <code>AT</code> keyword takes an expression as an argument. This
+specifies the exact load address of the section. The <code>AT&gt;</code> keyword
+takes the name of a memory region as an argument. See <a href="#MEMORY">MEMORY</a>. The
+load address of the section is set to the next free address in the
+region, aligned to the section&rsquo;s alignment requirements.
+</p>
+<p>If neither <code>AT</code> nor <code>AT&gt;</code> is specified for an allocatable
+section, the linker will use the following heuristic to determine the
+load address:
+</p>
+<ul>
+<li> If the section has a specific VMA address, then this is used as
+the LMA address as well.
+
+</li><li> If the section is not allocatable then its LMA is set to its VMA.
+
+</li><li> Otherwise if a memory region can be found that is compatible
+with the current section, and this region contains at least one
+section, then the LMA is set so the difference between the
+VMA and LMA is the same as the difference between the VMA and LMA of
+the last section in the located region.
+
+</li><li> If no memory regions have been declared then a default region
+that covers the entire address space is used in the previous step.
+
+</li><li> If no suitable region could be found, or there was no previous
+section then the LMA is set equal to the VMA.
+</li></ul>
+
+<a name="index-ROM-initialized-data"></a>
+<a name="index-initialized-data-in-ROM"></a>
+<p>This feature is designed to make it easy to build a ROM image. For
+example, the following linker script creates three output sections: one
+called &lsquo;<samp>.text</samp>&rsquo;, which starts at <code>0x1000</code>, one called
+&lsquo;<samp>.mdata</samp>&rsquo;, which is loaded at the end of the &lsquo;<samp>.text</samp>&rsquo; section
+even though its VMA is <code>0x2000</code>, and one called &lsquo;<samp>.bss</samp>&rsquo; to hold
+uninitialized data at address <code>0x3000</code>. The symbol <code>_data</code> is
+defined with the value <code>0x2000</code>, which shows that the location
+counter holds the VMA value, not the LMA value.
+</p>
+<div class="smallexample">
+<pre class="smallexample">SECTIONS
+ {
+ .text 0x1000 : { *(.text) _etext = . ; }
+ .mdata 0x2000 :
+ AT ( ADDR (.text) + SIZEOF (.text) )
+ { _data = . ; *(.data); _edata = . ; }
+ .bss 0x3000 :
+ { _bstart = . ; *(.bss) *(COMMON) ; _bend = . ;}
+}
+</pre></div>
+
+<p>The run-time initialization code for use with a program generated with
+this linker script would include something like the following, to copy
+the initialized data from the ROM image to its runtime address. Notice
+how this code takes advantage of the symbols defined by the linker
+script.
+</p>
+<div class="smallexample">
+<pre class="smallexample">extern char _etext, _data, _edata, _bstart, _bend;
+char *src = &amp;_etext;
+char *dst = &amp;_data;
+
+/* ROM has data at end of text; copy it. */
+while (dst &lt; &amp;_edata)
+ *dst++ = *src++;
+
+/* Zero bss. */
+for (dst = &amp;_bstart; dst&lt; &amp;_bend; dst++)
+ *dst = 0;
+</pre></div>
+
+<hr>
+<a name="Forced-Output-Alignment"></a>
+<div class="header">
+<p>
+Next: <a href="#Forced-Input-Alignment" accesskey="n" rel="next">Forced Input Alignment</a>, Previous: <a href="#Output-Section-LMA" accesskey="p" rel="previous">Output Section LMA</a>, Up: <a href="#Output-Section-Attributes" accesskey="u" rel="up">Output Section Attributes</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Forced-Output-Alignment-1"></a>
+<h4 class="subsubsection">3.6.8.3 Forced Output Alignment</h4>
+<a name="index-ALIGN_0028section_005falign_0029"></a>
+<a name="index-forcing-output-section-alignment"></a>
+<a name="index-output-section-alignment"></a>
+<p>You can increase an output section&rsquo;s alignment by using ALIGN. As an
+alternative you can enforce that the difference between the VMA and LMA remains
+intact throughout this output section with the ALIGN_WITH_INPUT attribute.
+</p>
+<hr>
+<a name="Forced-Input-Alignment"></a>
+<div class="header">
+<p>
+Next: <a href="#Output-Section-Constraint" accesskey="n" rel="next">Output Section Constraint</a>, Previous: <a href="#Forced-Output-Alignment" accesskey="p" rel="previous">Forced Output Alignment</a>, Up: <a href="#Output-Section-Attributes" accesskey="u" rel="up">Output Section Attributes</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Forced-Input-Alignment-1"></a>
+<h4 class="subsubsection">3.6.8.4 Forced Input Alignment</h4>
+<a name="index-SUBALIGN_0028subsection_005falign_0029"></a>
+<a name="index-forcing-input-section-alignment"></a>
+<a name="index-input-section-alignment"></a>
+<p>You can force input section alignment within an output section by using
+SUBALIGN. The value specified overrides any alignment given by input
+sections, whether larger or smaller.
+</p>
+<hr>
+<a name="Output-Section-Constraint"></a>
+<div class="header">
+<p>
+Next: <a href="#Output-Section-Region" accesskey="n" rel="next">Output Section Region</a>, Previous: <a href="#Forced-Input-Alignment" accesskey="p" rel="previous">Forced Input Alignment</a>, Up: <a href="#Output-Section-Attributes" accesskey="u" rel="up">Output Section Attributes</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Output-Section-Constraint-1"></a>
+<h4 class="subsubsection">3.6.8.5 Output Section Constraint</h4>
+<a name="index-ONLY_005fIF_005fRO"></a>
+<a name="index-ONLY_005fIF_005fRW"></a>
+<a name="index-constraints-on-output-sections"></a>
+<p>You can specify that an output section should only be created if all
+of its input sections are read-only or all of its input sections are
+read-write by using the keyword <code>ONLY_IF_RO</code> and
+<code>ONLY_IF_RW</code> respectively.
+</p>
+<hr>
+<a name="Output-Section-Region"></a>
+<div class="header">
+<p>
+Next: <a href="#Output-Section-Phdr" accesskey="n" rel="next">Output Section Phdr</a>, Previous: <a href="#Output-Section-Constraint" accesskey="p" rel="previous">Output Section Constraint</a>, Up: <a href="#Output-Section-Attributes" accesskey="u" rel="up">Output Section Attributes</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Output-Section-Region-1"></a>
+<h4 class="subsubsection">3.6.8.6 Output Section Region</h4>
+<a name="index-_003eregion"></a>
+<a name="index-section_002c-assigning-to-memory-region"></a>
+<a name="index-memory-regions-and-sections"></a>
+<p>You can assign a section to a previously defined region of memory by
+using &lsquo;<samp>&gt;<var>region</var></samp>&rsquo;. See <a href="#MEMORY">MEMORY</a>.
+</p>
+<p>Here is a simple example:
+</p><div class="smallexample">
+<pre class="smallexample">MEMORY { rom : ORIGIN = 0x1000, LENGTH = 0x1000 }
+SECTIONS { ROM : { *(.text) } &gt;rom }
+</pre></div>
+
+<hr>
+<a name="Output-Section-Phdr"></a>
+<div class="header">
+<p>
+Next: <a href="#Output-Section-Fill" accesskey="n" rel="next">Output Section Fill</a>, Previous: <a href="#Output-Section-Region" accesskey="p" rel="previous">Output Section Region</a>, Up: <a href="#Output-Section-Attributes" accesskey="u" rel="up">Output Section Attributes</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Output-Section-Phdr-1"></a>
+<h4 class="subsubsection">3.6.8.7 Output Section Phdr</h4>
+<a name="index-_003aphdr"></a>
+<a name="index-section_002c-assigning-to-program-header"></a>
+<a name="index-program-headers-and-sections"></a>
+<p>You can assign a section to a previously defined program segment by
+using &lsquo;<samp>:<var>phdr</var></samp>&rsquo;. See <a href="#PHDRS">PHDRS</a>. If a section is assigned to
+one or more segments, then all subsequent allocated sections will be
+assigned to those segments as well, unless they use an explicitly
+<code>:<var>phdr</var></code> modifier. You can use <code>:NONE</code> to tell the
+linker to not put the section in any segment at all.
+</p>
+<p>Here is a simple example:
+</p><div class="smallexample">
+<pre class="smallexample">PHDRS { text PT_LOAD ; }
+SECTIONS { .text : { *(.text) } :text }
+</pre></div>
+
+<hr>
+<a name="Output-Section-Fill"></a>
+<div class="header">
+<p>
+Previous: <a href="#Output-Section-Phdr" accesskey="p" rel="previous">Output Section Phdr</a>, Up: <a href="#Output-Section-Attributes" accesskey="u" rel="up">Output Section Attributes</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Output-Section-Fill-1"></a>
+<h4 class="subsubsection">3.6.8.8 Output Section Fill</h4>
+<a name="index-_003dfillexp"></a>
+<a name="index-section-fill-pattern"></a>
+<a name="index-fill-pattern_002c-entire-section"></a>
+<p>You can set the fill pattern for an entire section by using
+&lsquo;<samp>=<var>fillexp</var></samp>&rsquo;. <var>fillexp</var> is an expression
+(see <a href="#Expressions">Expressions</a>). Any otherwise unspecified regions of memory
+within the output section (for example, gaps left due to the required
+alignment of input sections) will be filled with the value, repeated as
+necessary. If the fill expression is a simple hex number, ie. a string
+of hex digit starting with &lsquo;<samp>0x</samp>&rsquo; and without a trailing &lsquo;<samp>k</samp>&rsquo; or &lsquo;<samp>M</samp>&rsquo;, then
+an arbitrarily long sequence of hex digits can be used to specify the
+fill pattern; Leading zeros become part of the pattern too. For all
+other cases, including extra parentheses or a unary <code>+</code>, the fill
+pattern is the four least significant bytes of the value of the
+expression. In all cases, the number is big-endian.
+</p>
+<p>You can also change the fill value with a <code>FILL</code> command in the
+output section commands; (see <a href="#Output-Section-Data">Output Section Data</a>).
+</p>
+<p>Here is a simple example:
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS { .text : { *(.text) } =0x90909090 }
+</pre></div>
+
+<hr>
+<a name="Overlay-Description"></a>
+<div class="header">
+<p>
+Previous: <a href="#Output-Section-Attributes" accesskey="p" rel="previous">Output Section Attributes</a>, Up: <a href="#SECTIONS" accesskey="u" rel="up">SECTIONS</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Overlay-Description-1"></a>
+<h4 class="subsection">3.6.9 Overlay Description</h4>
+<a name="index-OVERLAY"></a>
+<a name="index-overlays"></a>
+<p>An overlay description provides an easy way to describe sections which
+are to be loaded as part of a single memory image but are to be run at
+the same memory address. At run time, some sort of overlay manager will
+copy the overlaid sections in and out of the runtime memory address as
+required, perhaps by simply manipulating addressing bits. This approach
+can be useful, for example, when a certain region of memory is faster
+than another.
+</p>
+<p>Overlays are described using the <code>OVERLAY</code> command. The
+<code>OVERLAY</code> command is used within a <code>SECTIONS</code> command, like an
+output section description. The full syntax of the <code>OVERLAY</code>
+command is as follows:
+</p><div class="smallexample">
+<pre class="smallexample">OVERLAY [<var>start</var>] : [NOCROSSREFS] [AT ( <var>ldaddr</var> )]
+ {
+ <var>secname1</var>
+ {
+ <var>output-section-command</var>
+ <var>output-section-command</var>
+ &hellip;
+ } [:<var>phdr</var>&hellip;] [=<var>fill</var>]
+ <var>secname2</var>
+ {
+ <var>output-section-command</var>
+ <var>output-section-command</var>
+ &hellip;
+ } [:<var>phdr</var>&hellip;] [=<var>fill</var>]
+ &hellip;
+ } [&gt;<var>region</var>] [:<var>phdr</var>&hellip;] [=<var>fill</var>] [,]
+</pre></div>
+
+<p>Everything is optional except <code>OVERLAY</code> (a keyword), and each
+section must have a name (<var>secname1</var> and <var>secname2</var> above). The
+section definitions within the <code>OVERLAY</code> construct are identical to
+those within the general <code>SECTIONS</code> construct (see <a href="#SECTIONS">SECTIONS</a>),
+except that no addresses and no memory regions may be defined for
+sections within an <code>OVERLAY</code>.
+</p>
+<p>The comma at the end may be required if a <var>fill</var> is used and
+the next <var>sections-command</var> looks like a continuation of the expression.
+</p>
+<p>The sections are all defined with the same starting address. The load
+addresses of the sections are arranged such that they are consecutive in
+memory starting at the load address used for the <code>OVERLAY</code> as a
+whole (as with normal section definitions, the load address is optional,
+and defaults to the start address; the start address is also optional,
+and defaults to the current value of the location counter).
+</p>
+<p>If the <code>NOCROSSREFS</code> keyword is used, and there are any
+references among the sections, the linker will report an error. Since
+the sections all run at the same address, it normally does not make
+sense for one section to refer directly to another.
+See <a href="#Miscellaneous-Commands">NOCROSSREFS</a>.
+</p>
+<p>For each section within the <code>OVERLAY</code>, the linker automatically
+provides two symbols. The symbol <code>__load_start_<var>secname</var></code> is
+defined as the starting load address of the section. The symbol
+<code>__load_stop_<var>secname</var></code> is defined as the final load address of
+the section. Any characters within <var>secname</var> which are not legal
+within C identifiers are removed. C (or assembler) code may use these
+symbols to move the overlaid sections around as necessary.
+</p>
+<p>At the end of the overlay, the value of the location counter is set to
+the start address of the overlay plus the size of the largest section.
+</p>
+<p>Here is an example. Remember that this would appear inside a
+<code>SECTIONS</code> construct.
+</p><div class="smallexample">
+<pre class="smallexample"> OVERLAY 0x1000 : AT (0x4000)
+ {
+ .text0 { o1/*.o(.text) }
+ .text1 { o2/*.o(.text) }
+ }
+</pre></div>
+<p>This will define both &lsquo;<samp>.text0</samp>&rsquo; and &lsquo;<samp>.text1</samp>&rsquo; to start at
+address 0x1000. &lsquo;<samp>.text0</samp>&rsquo; will be loaded at address 0x4000, and
+&lsquo;<samp>.text1</samp>&rsquo; will be loaded immediately after &lsquo;<samp>.text0</samp>&rsquo;. The
+following symbols will be defined if referenced: <code>__load_start_text0</code>,
+<code>__load_stop_text0</code>, <code>__load_start_text1</code>,
+<code>__load_stop_text1</code>.
+</p>
+<p>C code to copy overlay <code>.text1</code> into the overlay area might look
+like the following.
+</p>
+<div class="smallexample">
+<pre class="smallexample"> extern char __load_start_text1, __load_stop_text1;
+ memcpy ((char *) 0x1000, &amp;__load_start_text1,
+ &amp;__load_stop_text1 - &amp;__load_start_text1);
+</pre></div>
+
+<p>Note that the <code>OVERLAY</code> command is just syntactic sugar, since
+everything it does can be done using the more basic commands. The above
+example could have been written identically as follows.
+</p>
+<div class="smallexample">
+<pre class="smallexample"> .text0 0x1000 : AT (0x4000) { o1/*.o(.text) }
+ PROVIDE (__load_start_text0 = LOADADDR (.text0));
+ PROVIDE (__load_stop_text0 = LOADADDR (.text0) + SIZEOF (.text0));
+ .text1 0x1000 : AT (0x4000 + SIZEOF (.text0)) { o2/*.o(.text) }
+ PROVIDE (__load_start_text1 = LOADADDR (.text1));
+ PROVIDE (__load_stop_text1 = LOADADDR (.text1) + SIZEOF (.text1));
+ . = 0x1000 + MAX (SIZEOF (.text0), SIZEOF (.text1));
+</pre></div>
+
+<hr>
+<a name="MEMORY"></a>
+<div class="header">
+<p>
+Next: <a href="#PHDRS" accesskey="n" rel="next">PHDRS</a>, Previous: <a href="#SECTIONS" accesskey="p" rel="previous">SECTIONS</a>, Up: <a href="#Scripts" accesskey="u" rel="up">Scripts</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="MEMORY-Command"></a>
+<h3 class="section">3.7 MEMORY Command</h3>
+<a name="index-MEMORY"></a>
+<a name="index-memory-regions"></a>
+<a name="index-regions-of-memory"></a>
+<a name="index-allocating-memory"></a>
+<a name="index-discontinuous-memory"></a>
+<p>The linker&rsquo;s default configuration permits allocation of all available
+memory. You can override this by using the <code>MEMORY</code> command.
+</p>
+<p>The <code>MEMORY</code> command describes the location and size of blocks of
+memory in the target. You can use it to describe which memory regions
+may be used by the linker, and which memory regions it must avoid. You
+can then assign sections to particular memory regions. The linker will
+set section addresses based on the memory regions, and will warn about
+regions that become too full. The linker will not shuffle sections
+around to fit into the available regions.
+</p>
+<p>A linker script may contain many uses of the <code>MEMORY</code> command,
+however, all memory blocks defined are treated as if they were
+specified inside a single <code>MEMORY</code> command. The syntax for
+<code>MEMORY</code> is:
+</p><div class="smallexample">
+<pre class="smallexample">MEMORY
+ {
+ <var>name</var> [(<var>attr</var>)] : ORIGIN = <var>origin</var>, LENGTH = <var>len</var>
+ &hellip;
+ }
+</pre></div>
+
+<p>The <var>name</var> is a name used in the linker script to refer to the
+region. The region name has no meaning outside of the linker script.
+Region names are stored in a separate name space, and will not conflict
+with symbol names, file names, or section names. Each memory region
+must have a distinct name within the <code>MEMORY</code> command. However you can
+add later alias names to existing memory regions with the <a href="#REGION_005fALIAS">REGION_ALIAS</a>
+command.
+</p>
+<a name="index-memory-region-attributes"></a>
+<p>The <var>attr</var> string is an optional list of attributes that specify
+whether to use a particular memory region for an input section which is
+not explicitly mapped in the linker script. As described in
+<a href="#SECTIONS">SECTIONS</a>, if you do not specify an output section for some input
+section, the linker will create an output section with the same name as
+the input section. If you define region attributes, the linker will use
+them to select the memory region for the output section that it creates.
+</p>
+<p>The <var>attr</var> string must consist only of the following characters:
+</p><dl compact="compact">
+<dt>&lsquo;<samp>R</samp>&rsquo;</dt>
+<dd><p>Read-only section
+</p></dd>
+<dt>&lsquo;<samp>W</samp>&rsquo;</dt>
+<dd><p>Read/write section
+</p></dd>
+<dt>&lsquo;<samp>X</samp>&rsquo;</dt>
+<dd><p>Executable section
+</p></dd>
+<dt>&lsquo;<samp>A</samp>&rsquo;</dt>
+<dd><p>Allocatable section
+</p></dd>
+<dt>&lsquo;<samp>I</samp>&rsquo;</dt>
+<dd><p>Initialized section
+</p></dd>
+<dt>&lsquo;<samp>L</samp>&rsquo;</dt>
+<dd><p>Same as &lsquo;<samp>I</samp>&rsquo;
+</p></dd>
+<dt>&lsquo;<samp>!</samp>&rsquo;</dt>
+<dd><p>Invert the sense of any of the attributes that follow
+</p></dd>
+</dl>
+
+<p>If an unmapped section matches any of the listed attributes other than
+&lsquo;<samp>!</samp>&rsquo;, it will be placed in the memory region. The &lsquo;<samp>!</samp>&rsquo;
+attribute reverses the test for the characters that follow, so that an
+unmapped section will be placed in the memory region only if it does
+not match any of the attributes listed afterwards. Thus an attribute
+string of &lsquo;<samp>RW!X</samp>&rsquo; will match any unmapped section that has either
+or both of the &lsquo;<samp>R</samp>&rsquo; and &lsquo;<samp>W</samp>&rsquo; attributes, but only as long as
+the section does not also have the &lsquo;<samp>X</samp>&rsquo; attribute.
+</p>
+<a name="index-ORIGIN-_003d"></a>
+<a name="index-o-_003d"></a>
+<a name="index-org-_003d"></a>
+<p>The <var>origin</var> is an numerical expression for the start address of
+the memory region. The expression must evaluate to a constant and it
+cannot involve any symbols. The keyword <code>ORIGIN</code> may be
+abbreviated to <code>org</code> or <code>o</code> (but not, for example,
+<code>ORG</code>).
+</p>
+<a name="index-LENGTH-_003d"></a>
+<a name="index-len-_003d"></a>
+<a name="index-l-_003d"></a>
+<p>The <var>len</var> is an expression for the size in bytes of the memory
+region. As with the <var>origin</var> expression, the expression must
+be numerical only and must evaluate to a constant. The keyword
+<code>LENGTH</code> may be abbreviated to <code>len</code> or <code>l</code>.
+</p>
+<p>In the following example, we specify that there are two memory regions
+available for allocation: one starting at &lsquo;<samp>0</samp>&rsquo; for 256 kilobytes,
+and the other starting at &lsquo;<samp>0x40000000</samp>&rsquo; for four megabytes. The
+linker will place into the &lsquo;<samp>rom</samp>&rsquo; memory region every section which
+is not explicitly mapped into a memory region, and is either read-only
+or executable. The linker will place other sections which are not
+explicitly mapped into a memory region into the &lsquo;<samp>ram</samp>&rsquo; memory
+region.
+</p>
+<div class="smallexample">
+<pre class="smallexample">MEMORY
+ {
+ rom (rx) : ORIGIN = 0, LENGTH = 256K
+ ram (!rx) : org = 0x40000000, l = 4M
+ }
+</pre></div>
+
+<p>Once you define a memory region, you can direct the linker to place
+specific output sections into that memory region by using the
+&lsquo;<samp>&gt;<var>region</var></samp>&rsquo; output section attribute. For example, if you have
+a memory region named &lsquo;<samp>mem</samp>&rsquo;, you would use &lsquo;<samp>&gt;mem</samp>&rsquo; in the
+output section definition. See <a href="#Output-Section-Region">Output Section Region</a>. If no address
+was specified for the output section, the linker will set the address to
+the next available address within the memory region. If the combined
+output sections directed to a memory region are too large for the
+region, the linker will issue an error message.
+</p>
+<p>It is possible to access the origin and length of a memory in an
+expression via the <code>ORIGIN(<var>memory</var>)</code> and
+<code>LENGTH(<var>memory</var>)</code> functions:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> _fstack = ORIGIN(ram) + LENGTH(ram) - 4;
+</pre></div>
+
+<hr>
+<a name="PHDRS"></a>
+<div class="header">
+<p>
+Next: <a href="#VERSION" accesskey="n" rel="next">VERSION</a>, Previous: <a href="#MEMORY" accesskey="p" rel="previous">MEMORY</a>, Up: <a href="#Scripts" accesskey="u" rel="up">Scripts</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="PHDRS-Command"></a>
+<h3 class="section">3.8 PHDRS Command</h3>
+<a name="index-PHDRS"></a>
+<a name="index-program-headers"></a>
+<a name="index-ELF-program-headers"></a>
+<a name="index-program-segments"></a>
+<a name="index-segments_002c-ELF"></a>
+<p>The ELF object file format uses <em>program headers</em>, also knows as
+<em>segments</em>. The program headers describe how the program should be
+loaded into memory. You can print them out by using the <code>objdump</code>
+program with the &lsquo;<samp>-p</samp>&rsquo; option.
+</p>
+<p>When you run an ELF program on a native ELF system, the system loader
+reads the program headers in order to figure out how to load the
+program. This will only work if the program headers are set correctly.
+This manual does not describe the details of how the system loader
+interprets program headers; for more information, see the ELF ABI.
+</p>
+<p>The linker will create reasonable program headers by default. However,
+in some cases, you may need to specify the program headers more
+precisely. You may use the <code>PHDRS</code> command for this purpose. When
+the linker sees the <code>PHDRS</code> command in the linker script, it will
+not create any program headers other than the ones specified.
+</p>
+<p>The linker only pays attention to the <code>PHDRS</code> command when
+generating an ELF output file. In other cases, the linker will simply
+ignore <code>PHDRS</code>.
+</p>
+<p>This is the syntax of the <code>PHDRS</code> command. The words <code>PHDRS</code>,
+<code>FILEHDR</code>, <code>AT</code>, and <code>FLAGS</code> are keywords.
+</p>
+<div class="smallexample">
+<pre class="smallexample">PHDRS
+{
+ <var>name</var> <var>type</var> [ FILEHDR ] [ PHDRS ] [ AT ( <var>address</var> ) ]
+ [ FLAGS ( <var>flags</var> ) ] ;
+}
+</pre></div>
+
+<p>The <var>name</var> is used only for reference in the <code>SECTIONS</code> command
+of the linker script. It is not put into the output file. Program
+header names are stored in a separate name space, and will not conflict
+with symbol names, file names, or section names. Each program header
+must have a distinct name. The headers are processed in order and it
+is usual for them to map to sections in ascending load address order.
+</p>
+<p>Certain program header types describe segments of memory which the
+system loader will load from the file. In the linker script, you
+specify the contents of these segments by placing allocatable output
+sections in the segments. You use the &lsquo;<samp>:<var>phdr</var></samp>&rsquo; output section
+attribute to place a section in a particular segment. See <a href="#Output-Section-Phdr">Output Section Phdr</a>.
+</p>
+<p>It is normal to put certain sections in more than one segment. This
+merely implies that one segment of memory contains another. You may
+repeat &lsquo;<samp>:<var>phdr</var></samp>&rsquo;, using it once for each segment which should
+contain the section.
+</p>
+<p>If you place a section in one or more segments using &lsquo;<samp>:<var>phdr</var></samp>&rsquo;,
+then the linker will place all subsequent allocatable sections which do
+not specify &lsquo;<samp>:<var>phdr</var></samp>&rsquo; in the same segments. This is for
+convenience, since generally a whole set of contiguous sections will be
+placed in a single segment. You can use <code>:NONE</code> to override the
+default segment and tell the linker to not put the section in any
+segment at all.
+</p>
+<a name="index-FILEHDR"></a>
+<a name="index-PHDRS-1"></a>
+<p>You may use the <code>FILEHDR</code> and <code>PHDRS</code> keywords after
+the program header type to further describe the contents of the segment.
+The <code>FILEHDR</code> keyword means that the segment should include the ELF
+file header. The <code>PHDRS</code> keyword means that the segment should
+include the ELF program headers themselves. If applied to a loadable
+segment (<code>PT_LOAD</code>), all prior loadable segments must have one of
+these keywords.
+</p>
+<p>The <var>type</var> may be one of the following. The numbers indicate the
+value of the keyword.
+</p>
+<dl compact="compact">
+<dt><code>PT_NULL</code> (0)</dt>
+<dd><p>Indicates an unused program header.
+</p>
+</dd>
+<dt><code>PT_LOAD</code> (1)</dt>
+<dd><p>Indicates that this program header describes a segment to be loaded from
+the file.
+</p>
+</dd>
+<dt><code>PT_DYNAMIC</code> (2)</dt>
+<dd><p>Indicates a segment where dynamic linking information can be found.
+</p>
+</dd>
+<dt><code>PT_INTERP</code> (3)</dt>
+<dd><p>Indicates a segment where the name of the program interpreter may be
+found.
+</p>
+</dd>
+<dt><code>PT_NOTE</code> (4)</dt>
+<dd><p>Indicates a segment holding note information.
+</p>
+</dd>
+<dt><code>PT_SHLIB</code> (5)</dt>
+<dd><p>A reserved program header type, defined but not specified by the ELF
+ABI.
+</p>
+</dd>
+<dt><code>PT_PHDR</code> (6)</dt>
+<dd><p>Indicates a segment where the program headers may be found.
+</p>
+</dd>
+<dt><code>PT_TLS</code> (7)</dt>
+<dd><p>Indicates a segment containing thread local storage.
+</p>
+</dd>
+<dt><var>expression</var></dt>
+<dd><p>An expression giving the numeric type of the program header. This may
+be used for types not defined above.
+</p></dd>
+</dl>
+
+<p>You can specify that a segment should be loaded at a particular address
+in memory by using an <code>AT</code> expression. This is identical to the
+<code>AT</code> command used as an output section attribute (see <a href="#Output-Section-LMA">Output Section LMA</a>). The <code>AT</code> command for a program header overrides the
+output section attribute.
+</p>
+<p>The linker will normally set the segment flags based on the sections
+which comprise the segment. You may use the <code>FLAGS</code> keyword to
+explicitly specify the segment flags. The value of <var>flags</var> must be
+an integer. It is used to set the <code>p_flags</code> field of the program
+header.
+</p>
+<p>Here is an example of <code>PHDRS</code>. This shows a typical set of program
+headers used on a native ELF system.
+</p>
+<div class="example">
+<pre class="example">PHDRS
+{
+ headers PT_PHDR PHDRS ;
+ interp PT_INTERP ;
+ text PT_LOAD FILEHDR PHDRS ;
+ data PT_LOAD ;
+ dynamic PT_DYNAMIC ;
+}
+
+SECTIONS
+{
+ . = SIZEOF_HEADERS;
+ .interp : { *(.interp) } :text :interp
+ .text : { *(.text) } :text
+ .rodata : { *(.rodata) } /* defaults to :text */
+ &hellip;
+ . = . + 0x1000; /* move to a new page in memory */
+ .data : { *(.data) } :data
+ .dynamic : { *(.dynamic) } :data :dynamic
+ &hellip;
+}
+</pre></div>
+
+<hr>
+<a name="VERSION"></a>
+<div class="header">
+<p>
+Next: <a href="#Expressions" accesskey="n" rel="next">Expressions</a>, Previous: <a href="#PHDRS" accesskey="p" rel="previous">PHDRS</a>, Up: <a href="#Scripts" accesskey="u" rel="up">Scripts</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="VERSION-Command"></a>
+<h3 class="section">3.9 VERSION Command</h3>
+<a name="index-VERSION-_007bscript-text_007d"></a>
+<a name="index-symbol-versions"></a>
+<a name="index-version-script"></a>
+<a name="index-versions-of-symbols"></a>
+<p>The linker supports symbol versions when using ELF. Symbol versions are
+only useful when using shared libraries. The dynamic linker can use
+symbol versions to select a specific version of a function when it runs
+a program that may have been linked against an earlier version of the
+shared library.
+</p>
+<p>You can include a version script directly in the main linker script, or
+you can supply the version script as an implicit linker script. You can
+also use the &lsquo;<samp>--version-script</samp>&rsquo; linker option.
+</p>
+<p>The syntax of the <code>VERSION</code> command is simply
+</p><div class="smallexample">
+<pre class="smallexample">VERSION { version-script-commands }
+</pre></div>
+
+<p>The format of the version script commands is identical to that used by
+Sun&rsquo;s linker in Solaris 2.5. The version script defines a tree of
+version nodes. You specify the node names and interdependencies in the
+version script. You can specify which symbols are bound to which
+version nodes, and you can reduce a specified set of symbols to local
+scope so that they are not globally visible outside of the shared
+library.
+</p>
+<p>The easiest way to demonstrate the version script language is with a few
+examples.
+</p>
+<div class="smallexample">
+<pre class="smallexample">VERS_1.1 {
+ global:
+ foo1;
+ local:
+ old*;
+ original*;
+ new*;
+};
+
+VERS_1.2 {
+ foo2;
+} VERS_1.1;
+
+VERS_2.0 {
+ bar1; bar2;
+ extern &quot;C++&quot; {
+ ns::*;
+ &quot;f(int, double)&quot;;
+ };
+} VERS_1.2;
+</pre></div>
+
+<p>This example version script defines three version nodes. The first
+version node defined is &lsquo;<samp>VERS_1.1</samp>&rsquo;; it has no other dependencies.
+The script binds the symbol &lsquo;<samp>foo1</samp>&rsquo; to &lsquo;<samp>VERS_1.1</samp>&rsquo;. It reduces
+a number of symbols to local scope so that they are not visible outside
+of the shared library; this is done using wildcard patterns, so that any
+symbol whose name begins with &lsquo;<samp>old</samp>&rsquo;, &lsquo;<samp>original</samp>&rsquo;, or &lsquo;<samp>new</samp>&rsquo;
+is matched. The wildcard patterns available are the same as those used
+in the shell when matching filenames (also known as &ldquo;globbing&rdquo;).
+However, if you specify the symbol name inside double quotes, then the
+name is treated as literal, rather than as a glob pattern.
+</p>
+<p>Next, the version script defines node &lsquo;<samp>VERS_1.2</samp>&rsquo;. This node
+depends upon &lsquo;<samp>VERS_1.1</samp>&rsquo;. The script binds the symbol &lsquo;<samp>foo2</samp>&rsquo;
+to the version node &lsquo;<samp>VERS_1.2</samp>&rsquo;.
+</p>
+<p>Finally, the version script defines node &lsquo;<samp>VERS_2.0</samp>&rsquo;. This node
+depends upon &lsquo;<samp>VERS_1.2</samp>&rsquo;. The scripts binds the symbols &lsquo;<samp>bar1</samp>&rsquo;
+and &lsquo;<samp>bar2</samp>&rsquo; are bound to the version node &lsquo;<samp>VERS_2.0</samp>&rsquo;.
+</p>
+<p>When the linker finds a symbol defined in a library which is not
+specifically bound to a version node, it will effectively bind it to an
+unspecified base version of the library. You can bind all otherwise
+unspecified symbols to a given version node by using &lsquo;<samp>global: *;</samp>&rsquo;
+somewhere in the version script. Note that it&rsquo;s slightly crazy to use
+wildcards in a global spec except on the last version node. Global
+wildcards elsewhere run the risk of accidentally adding symbols to the
+set exported for an old version. That&rsquo;s wrong since older versions
+ought to have a fixed set of symbols.
+</p>
+<p>The names of the version nodes have no specific meaning other than what
+they might suggest to the person reading them. The &lsquo;<samp>2.0</samp>&rsquo; version
+could just as well have appeared in between &lsquo;<samp>1.1</samp>&rsquo; and &lsquo;<samp>1.2</samp>&rsquo;.
+However, this would be a confusing way to write a version script.
+</p>
+<p>Node name can be omitted, provided it is the only version node
+in the version script. Such version script doesn&rsquo;t assign any versions to
+symbols, only selects which symbols will be globally visible out and which
+won&rsquo;t.
+</p>
+<div class="smallexample">
+<pre class="smallexample">{ global: foo; bar; local: *; };
+</pre></div>
+
+<p>When you link an application against a shared library that has versioned
+symbols, the application itself knows which version of each symbol it
+requires, and it also knows which version nodes it needs from each
+shared library it is linked against. Thus at runtime, the dynamic
+loader can make a quick check to make sure that the libraries you have
+linked against do in fact supply all of the version nodes that the
+application will need to resolve all of the dynamic symbols. In this
+way it is possible for the dynamic linker to know with certainty that
+all external symbols that it needs will be resolvable without having to
+search for each symbol reference.
+</p>
+<p>The symbol versioning is in effect a much more sophisticated way of
+doing minor version checking that SunOS does. The fundamental problem
+that is being addressed here is that typically references to external
+functions are bound on an as-needed basis, and are not all bound when
+the application starts up. If a shared library is out of date, a
+required interface may be missing; when the application tries to use
+that interface, it may suddenly and unexpectedly fail. With symbol
+versioning, the user will get a warning when they start their program if
+the libraries being used with the application are too old.
+</p>
+<p>There are several GNU extensions to Sun&rsquo;s versioning approach. The
+first of these is the ability to bind a symbol to a version node in the
+source file where the symbol is defined instead of in the versioning
+script. This was done mainly to reduce the burden on the library
+maintainer. You can do this by putting something like:
+</p><div class="smallexample">
+<pre class="smallexample">__asm__(&quot;.symver original_foo,foo@VERS_1.1&quot;);
+</pre></div>
+<p>in the C source file. This renames the function &lsquo;<samp>original_foo</samp>&rsquo; to
+be an alias for &lsquo;<samp>foo</samp>&rsquo; bound to the version node &lsquo;<samp>VERS_1.1</samp>&rsquo;.
+The &lsquo;<samp>local:</samp>&rsquo; directive can be used to prevent the symbol
+&lsquo;<samp>original_foo</samp>&rsquo; from being exported. A &lsquo;<samp>.symver</samp>&rsquo; directive
+takes precedence over a version script.
+</p>
+<p>The second GNU extension is to allow multiple versions of the same
+function to appear in a given shared library. In this way you can make
+an incompatible change to an interface without increasing the major
+version number of the shared library, while still allowing applications
+linked against the old interface to continue to function.
+</p>
+<p>To do this, you must use multiple &lsquo;<samp>.symver</samp>&rsquo; directives in the
+source file. Here is an example:
+</p>
+<div class="smallexample">
+<pre class="smallexample">__asm__(&quot;.symver original_foo,foo@&quot;);
+__asm__(&quot;.symver old_foo,foo@VERS_1.1&quot;);
+__asm__(&quot;.symver old_foo1,foo@VERS_1.2&quot;);
+__asm__(&quot;.symver new_foo,foo@@VERS_2.0&quot;);
+</pre></div>
+
+<p>In this example, &lsquo;<samp>foo@</samp>&rsquo; represents the symbol &lsquo;<samp>foo</samp>&rsquo; bound to the
+unspecified base version of the symbol. The source file that contains this
+example would define 4 C functions: &lsquo;<samp>original_foo</samp>&rsquo;, &lsquo;<samp>old_foo</samp>&rsquo;,
+&lsquo;<samp>old_foo1</samp>&rsquo;, and &lsquo;<samp>new_foo</samp>&rsquo;.
+</p>
+<p>When you have multiple definitions of a given symbol, there needs to be
+some way to specify a default version to which external references to
+this symbol will be bound. You can do this with the
+&lsquo;<samp>foo@@VERS_2.0</samp>&rsquo; type of &lsquo;<samp>.symver</samp>&rsquo; directive. You can only
+declare one version of a symbol as the default in this manner; otherwise
+you would effectively have multiple definitions of the same symbol.
+</p>
+<p>If you wish to bind a reference to a specific version of the symbol
+within the shared library, you can use the aliases of convenience
+(i.e., &lsquo;<samp>old_foo</samp>&rsquo;), or you can use the &lsquo;<samp>.symver</samp>&rsquo; directive to
+specifically bind to an external version of the function in question.
+</p>
+<p>You can also specify the language in the version script:
+</p>
+<div class="smallexample">
+<pre class="smallexample">VERSION extern &quot;lang&quot; { version-script-commands }
+</pre></div>
+
+<p>The supported &lsquo;<samp>lang</samp>&rsquo;s are &lsquo;<samp>C</samp>&rsquo;, &lsquo;<samp>C++</samp>&rsquo;, and &lsquo;<samp>Java</samp>&rsquo;.
+The linker will iterate over the list of symbols at the link time and
+demangle them according to &lsquo;<samp>lang</samp>&rsquo; before matching them to the
+patterns specified in &lsquo;<samp>version-script-commands</samp>&rsquo;. The default
+&lsquo;<samp>lang</samp>&rsquo; is &lsquo;<samp>C</samp>&rsquo;.
+</p>
+<p>Demangled names may contains spaces and other special characters. As
+described above, you can use a glob pattern to match demangled names,
+or you can use a double-quoted string to match the string exactly. In
+the latter case, be aware that minor differences (such as differing
+whitespace) between the version script and the demangler output will
+cause a mismatch. As the exact string generated by the demangler
+might change in the future, even if the mangled name does not, you
+should check that all of your version directives are behaving as you
+expect when you upgrade.
+</p>
+<hr>
+<a name="Expressions"></a>
+<div class="header">
+<p>
+Next: <a href="#Implicit-Linker-Scripts" accesskey="n" rel="next">Implicit Linker Scripts</a>, Previous: <a href="#VERSION" accesskey="p" rel="previous">VERSION</a>, Up: <a href="#Scripts" accesskey="u" rel="up">Scripts</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Expressions-in-Linker-Scripts"></a>
+<h3 class="section">3.10 Expressions in Linker Scripts</h3>
+<a name="index-expressions"></a>
+<a name="index-arithmetic"></a>
+<p>The syntax for expressions in the linker script language is identical to
+that of C expressions, except that whitespace is required in some
+places to resolve syntactic ambiguities. All expressions are
+evaluated as integers. All expressions are evaluated in the same
+size, which is 32 bits if both the host and target are 32 bits, and is
+otherwise 64 bits.
+</p>
+<p>You can use and set symbol values in expressions.
+</p>
+<p>The linker defines several special purpose builtin functions for use in
+expressions.
+</p>
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#Constants" accesskey="1">Constants</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Constants
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Symbolic-Constants" accesskey="2">Symbolic Constants</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Symbolic constants
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Symbols" accesskey="3">Symbols</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Symbol Names
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Orphan-Sections" accesskey="4">Orphan Sections</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Orphan Sections
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Location-Counter" accesskey="5">Location Counter</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">The Location Counter
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Operators" accesskey="6">Operators</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Operators
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Evaluation" accesskey="7">Evaluation</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Evaluation
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Expression-Section" accesskey="8">Expression Section</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">The Section of an Expression
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Builtin-Functions" accesskey="9">Builtin Functions</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Builtin Functions
+</td></tr>
+</table>
+
+<hr>
+<a name="Constants"></a>
+<div class="header">
+<p>
+Next: <a href="#Symbolic-Constants" accesskey="n" rel="next">Symbolic Constants</a>, Up: <a href="#Expressions" accesskey="u" rel="up">Expressions</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Constants-1"></a>
+<h4 class="subsection">3.10.1 Constants</h4>
+<a name="index-integer-notation"></a>
+<a name="index-constants-in-linker-scripts"></a>
+<p>All constants are integers.
+</p>
+<p>As in C, the linker considers an integer beginning with &lsquo;<samp>0</samp>&rsquo; to be
+octal, and an integer beginning with &lsquo;<samp>0x</samp>&rsquo; or &lsquo;<samp>0X</samp>&rsquo; to be
+hexadecimal. Alternatively the linker accepts suffixes of &lsquo;<samp>h</samp>&rsquo; or
+&lsquo;<samp>H</samp>&rsquo; for hexadecimal, &lsquo;<samp>o</samp>&rsquo; or &lsquo;<samp>O</samp>&rsquo; for octal, &lsquo;<samp>b</samp>&rsquo; or
+&lsquo;<samp>B</samp>&rsquo; for binary and &lsquo;<samp>d</samp>&rsquo; or &lsquo;<samp>D</samp>&rsquo; for decimal. Any integer
+value without a prefix or a suffix is considered to be decimal.
+</p>
+<a name="index-scaled-integers"></a>
+<a name="index-K-and-M-integer-suffixes"></a>
+<a name="index-M-and-K-integer-suffixes"></a>
+<a name="index-suffixes-for-integers"></a>
+<a name="index-integer-suffixes"></a>
+<p>In addition, you can use the suffixes <code>K</code> and <code>M</code> to scale a
+constant by
+<code>1024</code> or <code>1024*1024</code>
+respectively. For example, the following
+all refer to the same quantity:
+</p>
+<div class="smallexample">
+<pre class="smallexample">_fourk_1 = 4K;
+_fourk_2 = 4096;
+_fourk_3 = 0x1000;
+_fourk_4 = 10000o;
+</pre></div>
+
+<p>Note - the <code>K</code> and <code>M</code> suffixes cannot be used in
+conjunction with the base suffixes mentioned above.
+</p>
+<hr>
+<a name="Symbolic-Constants"></a>
+<div class="header">
+<p>
+Next: <a href="#Symbols" accesskey="n" rel="next">Symbols</a>, Previous: <a href="#Constants" accesskey="p" rel="previous">Constants</a>, Up: <a href="#Expressions" accesskey="u" rel="up">Expressions</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Symbolic-Constants-1"></a>
+<h4 class="subsection">3.10.2 Symbolic Constants</h4>
+<a name="index-symbolic-constants"></a>
+<a name="index-CONSTANT"></a>
+<p>It is possible to refer to target-specific constants via the use of
+the <code>CONSTANT(<var>name</var>)</code> operator, where <var>name</var> is one of:
+</p>
+<dl compact="compact">
+<dt><code>MAXPAGESIZE</code></dt>
+<dd><a name="index-MAXPAGESIZE"></a>
+<p>The target&rsquo;s maximum page size.
+</p>
+</dd>
+<dt><code>COMMONPAGESIZE</code></dt>
+<dd><a name="index-COMMONPAGESIZE"></a>
+<p>The target&rsquo;s default page size.
+</p></dd>
+</dl>
+
+<p>So for example:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> .text ALIGN (CONSTANT (MAXPAGESIZE)) : { *(.text) }
+</pre></div>
+
+<p>will create a text section aligned to the largest page boundary
+supported by the target.
+</p>
+<hr>
+<a name="Symbols"></a>
+<div class="header">
+<p>
+Next: <a href="#Orphan-Sections" accesskey="n" rel="next">Orphan Sections</a>, Previous: <a href="#Symbolic-Constants" accesskey="p" rel="previous">Symbolic Constants</a>, Up: <a href="#Expressions" accesskey="u" rel="up">Expressions</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Symbol-Names"></a>
+<h4 class="subsection">3.10.3 Symbol Names</h4>
+<a name="index-symbol-names"></a>
+<a name="index-names"></a>
+<a name="index-quoted-symbol-names"></a>
+<a name="index-_0022"></a>
+<p>Unless quoted, symbol names start with a letter, underscore, or period
+and may include letters, digits, underscores, periods, and hyphens.
+Unquoted symbol names must not conflict with any keywords. You can
+specify a symbol which contains odd characters or has the same name as a
+keyword by surrounding the symbol name in double quotes:
+</p><div class="smallexample">
+<pre class="smallexample">&quot;SECTION&quot; = 9;
+&quot;with a space&quot; = &quot;also with a space&quot; + 10;
+</pre></div>
+
+<p>Since symbols can contain many non-alphabetic characters, it is safest
+to delimit symbols with spaces. For example, &lsquo;<samp>A-B</samp>&rsquo; is one symbol,
+whereas &lsquo;<samp>A - B</samp>&rsquo; is an expression involving subtraction.
+</p>
+<hr>
+<a name="Orphan-Sections"></a>
+<div class="header">
+<p>
+Next: <a href="#Location-Counter" accesskey="n" rel="next">Location Counter</a>, Previous: <a href="#Symbols" accesskey="p" rel="previous">Symbols</a>, Up: <a href="#Expressions" accesskey="u" rel="up">Expressions</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Orphan-Sections-1"></a>
+<h4 class="subsection">3.10.4 Orphan Sections</h4>
+<a name="index-orphan"></a>
+<p>Orphan sections are sections present in the input files which
+are not explicitly placed into the output file by the linker
+script. The linker will still copy these sections into the
+output file by either finding, or creating a suitable output section
+in which to place the orphaned input section.
+</p>
+<p>If the name of an orphaned input section exactly matches the name of
+an existing output section, then the orphaned input section will be
+placed at the end of that output section.
+</p>
+<p>If there is no output section with a matching name then new output
+sections will be created. Each new output section will have the same
+name as the orphan section placed within it. If there are multiple
+orphan sections with the same name, these will all be combined into
+one new output section.
+</p>
+<p>If new output sections are created to hold orphaned input sections,
+then the linker must decide where to place these new output sections
+in relation to existing output sections. On most modern targets, the
+linker attempts to place orphan sections after sections of the same
+attribute, such as code vs data, loadable vs non-loadable, etc. If no
+sections with matching attributes are found, or your target lacks this
+support, the orphan section is placed at the end of the file.
+</p>
+<p>The command-line options &lsquo;<samp>--orphan-handling</samp>&rsquo; and &lsquo;<samp>--unique</samp>&rsquo;
+(see <a href="#Options">Command-line Options</a>) can be used to control which
+output sections an orphan is placed in.
+</p>
+<hr>
+<a name="Location-Counter"></a>
+<div class="header">
+<p>
+Next: <a href="#Operators" accesskey="n" rel="next">Operators</a>, Previous: <a href="#Orphan-Sections" accesskey="p" rel="previous">Orphan Sections</a>, Up: <a href="#Expressions" accesskey="u" rel="up">Expressions</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="The-Location-Counter"></a>
+<h4 class="subsection">3.10.5 The Location Counter</h4>
+<a name="index-_002e"></a>
+<a name="index-dot"></a>
+<a name="index-location-counter"></a>
+<a name="index-current-output-location"></a>
+<p>The special linker variable <em>dot</em> &lsquo;<samp>.</samp>&rsquo; always contains the
+current output location counter. Since the <code>.</code> always refers to a
+location in an output section, it may only appear in an expression
+within a <code>SECTIONS</code> command. The <code>.</code> symbol may appear
+anywhere that an ordinary symbol is allowed in an expression.
+</p>
+<a name="index-holes"></a>
+<p>Assigning a value to <code>.</code> will cause the location counter to be
+moved. This may be used to create holes in the output section. The
+location counter may not be moved backwards inside an output section,
+and may not be moved backwards outside of an output section if so
+doing creates areas with overlapping LMAs.
+</p>
+<div class="smallexample">
+<pre class="smallexample">SECTIONS
+{
+ output :
+ {
+ file1(.text)
+ . = . + 1000;
+ file2(.text)
+ . += 1000;
+ file3(.text)
+ } = 0x12345678;
+}
+</pre></div>
+<p>In the previous example, the &lsquo;<samp>.text</samp>&rsquo; section from <samp>file1</samp> is
+located at the beginning of the output section &lsquo;<samp>output</samp>&rsquo;. It is
+followed by a 1000 byte gap. Then the &lsquo;<samp>.text</samp>&rsquo; section from
+<samp>file2</samp> appears, also with a 1000 byte gap following before the
+&lsquo;<samp>.text</samp>&rsquo; section from <samp>file3</samp>. The notation &lsquo;<samp>= 0x12345678</samp>&rsquo;
+specifies what data to write in the gaps (see <a href="#Output-Section-Fill">Output Section Fill</a>).
+</p>
+<a name="index-dot-inside-sections"></a>
+<p>Note: <code>.</code> actually refers to the byte offset from the start of the
+current containing object. Normally this is the <code>SECTIONS</code>
+statement, whose start address is 0, hence <code>.</code> can be used as an
+absolute address. If <code>.</code> is used inside a section description
+however, it refers to the byte offset from the start of that section,
+not an absolute address. Thus in a script like this:
+</p>
+<div class="smallexample">
+<pre class="smallexample">SECTIONS
+{
+ . = 0x100
+ .text: {
+ *(.text)
+ . = 0x200
+ }
+ . = 0x500
+ .data: {
+ *(.data)
+ . += 0x600
+ }
+}
+</pre></div>
+
+<p>The &lsquo;<samp>.text</samp>&rsquo; section will be assigned a starting address of 0x100
+and a size of exactly 0x200 bytes, even if there is not enough data in
+the &lsquo;<samp>.text</samp>&rsquo; input sections to fill this area. (If there is too
+much data, an error will be produced because this would be an attempt to
+move <code>.</code> backwards). The &lsquo;<samp>.data</samp>&rsquo; section will start at 0x500
+and it will have an extra 0x600 bytes worth of space after the end of
+the values from the &lsquo;<samp>.data</samp>&rsquo; input sections and before the end of
+the &lsquo;<samp>.data</samp>&rsquo; output section itself.
+</p>
+<a name="index-dot-outside-sections"></a>
+<p>Setting symbols to the value of the location counter outside of an
+output section statement can result in unexpected values if the linker
+needs to place orphan sections. For example, given the following:
+</p>
+<div class="smallexample">
+<pre class="smallexample">SECTIONS
+{
+ start_of_text = . ;
+ .text: { *(.text) }
+ end_of_text = . ;
+
+ start_of_data = . ;
+ .data: { *(.data) }
+ end_of_data = . ;
+}
+</pre></div>
+
+<p>If the linker needs to place some input section, e.g. <code>.rodata</code>,
+not mentioned in the script, it might choose to place that section
+between <code>.text</code> and <code>.data</code>. You might think the linker
+should place <code>.rodata</code> on the blank line in the above script, but
+blank lines are of no particular significance to the linker. As well,
+the linker doesn&rsquo;t associate the above symbol names with their
+sections. Instead, it assumes that all assignments or other
+statements belong to the previous output section, except for the
+special case of an assignment to <code>.</code>. I.e., the linker will
+place the orphan <code>.rodata</code> section as if the script was written
+as follows:
+</p>
+<div class="smallexample">
+<pre class="smallexample">SECTIONS
+{
+ start_of_text = . ;
+ .text: { *(.text) }
+ end_of_text = . ;
+
+ start_of_data = . ;
+ .rodata: { *(.rodata) }
+ .data: { *(.data) }
+ end_of_data = . ;
+}
+</pre></div>
+
+<p>This may or may not be the script author&rsquo;s intention for the value of
+<code>start_of_data</code>. One way to influence the orphan section
+placement is to assign the location counter to itself, as the linker
+assumes that an assignment to <code>.</code> is setting the start address of
+a following output section and thus should be grouped with that
+section. So you could write:
+</p>
+<div class="smallexample">
+<pre class="smallexample">SECTIONS
+{
+ start_of_text = . ;
+ .text: { *(.text) }
+ end_of_text = . ;
+
+ . = . ;
+ start_of_data = . ;
+ .data: { *(.data) }
+ end_of_data = . ;
+}
+</pre></div>
+
+<p>Now, the orphan <code>.rodata</code> section will be placed between
+<code>end_of_text</code> and <code>start_of_data</code>.
+</p>
+<hr>
+<a name="Operators"></a>
+<div class="header">
+<p>
+Next: <a href="#Evaluation" accesskey="n" rel="next">Evaluation</a>, Previous: <a href="#Location-Counter" accesskey="p" rel="previous">Location Counter</a>, Up: <a href="#Expressions" accesskey="u" rel="up">Expressions</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Operators-1"></a>
+<h4 class="subsection">3.10.6 Operators</h4>
+<a name="index-operators-for-arithmetic"></a>
+<a name="index-arithmetic-operators"></a>
+<a name="index-precedence-in-expressions"></a>
+<p>The linker recognizes the standard C set of arithmetic operators, with
+the standard bindings and precedence levels:
+</p><div class="smallexample">
+<pre class="smallexample">precedence associativity Operators Notes
+(highest)
+1 left ! - ~ (1)
+2 left * / %
+3 left + -
+4 left &gt;&gt; &lt;&lt;
+5 left == != &gt; &lt; &lt;= &gt;=
+6 left &amp;
+7 left |
+8 left &amp;&amp;
+9 left ||
+10 right ? :
+11 right &amp;= += -= *= /= (2)
+(lowest)
+</pre></div>
+<p>Notes:
+(1) Prefix operators
+(2) See <a href="#Assignments">Assignments</a>.
+</p>
+<hr>
+<a name="Evaluation"></a>
+<div class="header">
+<p>
+Next: <a href="#Expression-Section" accesskey="n" rel="next">Expression Section</a>, Previous: <a href="#Operators" accesskey="p" rel="previous">Operators</a>, Up: <a href="#Expressions" accesskey="u" rel="up">Expressions</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Evaluation-1"></a>
+<h4 class="subsection">3.10.7 Evaluation</h4>
+<a name="index-lazy-evaluation"></a>
+<a name="index-expression-evaluation-order"></a>
+<p>The linker evaluates expressions lazily. It only computes the value of
+an expression when absolutely necessary.
+</p>
+<p>The linker needs some information, such as the value of the start
+address of the first section, and the origins and lengths of memory
+regions, in order to do any linking at all. These values are computed
+as soon as possible when the linker reads in the linker script.
+</p>
+<p>However, other values (such as symbol values) are not known or needed
+until after storage allocation. Such values are evaluated later, when
+other information (such as the sizes of output sections) is available
+for use in the symbol assignment expression.
+</p>
+<p>The sizes of sections cannot be known until after allocation, so
+assignments dependent upon these are not performed until after
+allocation.
+</p>
+<p>Some expressions, such as those depending upon the location counter
+&lsquo;<samp>.</samp>&rsquo;, must be evaluated during section allocation.
+</p>
+<p>If the result of an expression is required, but the value is not
+available, then an error results. For example, a script like the
+following
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS
+ {
+ .text 9+this_isnt_constant :
+ { *(.text) }
+ }
+</pre></div>
+<p>will cause the error message &lsquo;<samp>non constant expression for initial
+address</samp>&rsquo;.
+</p>
+<hr>
+<a name="Expression-Section"></a>
+<div class="header">
+<p>
+Next: <a href="#Builtin-Functions" accesskey="n" rel="next">Builtin Functions</a>, Previous: <a href="#Evaluation" accesskey="p" rel="previous">Evaluation</a>, Up: <a href="#Expressions" accesskey="u" rel="up">Expressions</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="The-Section-of-an-Expression"></a>
+<h4 class="subsection">3.10.8 The Section of an Expression</h4>
+<a name="index-expression-sections"></a>
+<a name="index-absolute-expressions"></a>
+<a name="index-relative-expressions"></a>
+<a name="index-absolute-and-relocatable-symbols"></a>
+<a name="index-relocatable-and-absolute-symbols"></a>
+<a name="index-symbols_002c-relocatable-and-absolute"></a>
+<p>Addresses and symbols may be section relative, or absolute. A section
+relative symbol is relocatable. If you request relocatable output
+using the &lsquo;<samp>-r</samp>&rsquo; option, a further link operation may change the
+value of a section relative symbol. On the other hand, an absolute
+symbol will retain the same value throughout any further link
+operations.
+</p>
+<p>Some terms in linker expressions are addresses. This is true of
+section relative symbols and for builtin functions that return an
+address, such as <code>ADDR</code>, <code>LOADADDR</code>, <code>ORIGIN</code> and
+<code>SEGMENT_START</code>. Other terms are simply numbers, or are builtin
+functions that return a non-address value, such as <code>LENGTH</code>.
+One complication is that unless you set <code>LD_FEATURE (&quot;SANE_EXPR&quot;)</code>
+(see <a href="#Miscellaneous-Commands">Miscellaneous Commands</a>), numbers and absolute symbols are treated
+differently depending on their location, for compatibility with older
+versions of <code>ld</code>. Expressions appearing outside an output
+section definition treat all numbers as absolute addresses.
+Expressions appearing inside an output section definition treat
+absolute symbols as numbers. If <code>LD_FEATURE (&quot;SANE_EXPR&quot;)</code> is
+given, then absolute symbols and numbers are simply treated as numbers
+everywhere.
+</p>
+<p>In the following simple example,
+</p>
+<div class="smallexample">
+<pre class="smallexample">SECTIONS
+ {
+ . = 0x100;
+ __executable_start = 0x100;
+ .data :
+ {
+ . = 0x10;
+ __data_start = 0x10;
+ *(.data)
+ }
+ &hellip;
+ }
+</pre></div>
+
+<p>both <code>.</code> and <code>__executable_start</code> are set to the absolute
+address 0x100 in the first two assignments, then both <code>.</code> and
+<code>__data_start</code> are set to 0x10 relative to the <code>.data</code>
+section in the second two assignments.
+</p>
+<p>For expressions involving numbers, relative addresses and absolute
+addresses, ld follows these rules to evaluate terms:
+</p>
+<ul>
+<li> Unary operations on an absolute address or number, and binary
+operations on two absolute addresses or two numbers, or between one
+absolute address and a number, apply the operator to the value(s).
+</li><li> Unary operations on a relative address, and binary operations on two
+relative addresses in the same section or between one relative address
+and a number, apply the operator to the offset part of the address(es).
+</li><li> Other binary operations, that is, between two relative addresses not
+in the same section, or between a relative address and an absolute
+address, first convert any non-absolute term to an absolute address
+before applying the operator.
+</li></ul>
+
+<p>The result section of each sub-expression is as follows:
+</p>
+<ul>
+<li> An operation involving only numbers results in a number.
+</li><li> The result of comparisons, &lsquo;<samp>&amp;&amp;</samp>&rsquo; and &lsquo;<samp>||</samp>&rsquo; is also a number.
+</li><li> The result of other binary arithmetic and logical operations on two
+relative addresses in the same section or two absolute addresses
+(after above conversions) is also a number when
+<code>LD_FEATURE (&quot;SANE_EXPR&quot;)</code> or inside an output section definition
+but an absolute address otherwise.
+</li><li> The result of other operations on relative addresses or one
+relative address and a number, is a relative address in the same
+section as the relative operand(s).
+</li><li> The result of other operations on absolute addresses (after above
+conversions) is an absolute address.
+</li></ul>
+
+<p>You can use the builtin function <code>ABSOLUTE</code> to force an expression
+to be absolute when it would otherwise be relative. For example, to
+create an absolute symbol set to the address of the end of the output
+section &lsquo;<samp>.data</samp>&rsquo;:
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS
+ {
+ .data : { *(.data) _edata = ABSOLUTE(.); }
+ }
+</pre></div>
+<p>If &lsquo;<samp>ABSOLUTE</samp>&rsquo; were not used, &lsquo;<samp>_edata</samp>&rsquo; would be relative to the
+&lsquo;<samp>.data</samp>&rsquo; section.
+</p>
+<p>Using <code>LOADADDR</code> also forces an expression absolute, since this
+particular builtin function returns an absolute address.
+</p>
+<hr>
+<a name="Builtin-Functions"></a>
+<div class="header">
+<p>
+Previous: <a href="#Expression-Section" accesskey="p" rel="previous">Expression Section</a>, Up: <a href="#Expressions" accesskey="u" rel="up">Expressions</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Builtin-Functions-1"></a>
+<h4 class="subsection">3.10.9 Builtin Functions</h4>
+<a name="index-functions-in-expressions"></a>
+<p>The linker script language includes a number of builtin functions for
+use in linker script expressions.
+</p>
+<dl compact="compact">
+<dt><code>ABSOLUTE(<var>exp</var>)</code></dt>
+<dd><a name="index-ABSOLUTE_0028exp_0029"></a>
+<a name="index-expression_002c-absolute"></a>
+<p>Return the absolute (non-relocatable, as opposed to non-negative) value
+of the expression <var>exp</var>. Primarily useful to assign an absolute
+value to a symbol within a section definition, where symbol values are
+normally section relative. See <a href="#Expression-Section">Expression Section</a>.
+</p>
+</dd>
+<dt><code>ADDR(<var>section</var>)</code></dt>
+<dd><a name="index-ADDR_0028section_0029"></a>
+<a name="index-section-address-in-expression"></a>
+<p>Return the address (VMA) of the named <var>section</var>. Your
+script must previously have defined the location of that section. In
+the following example, <code>start_of_output_1</code>, <code>symbol_1</code> and
+<code>symbol_2</code> are assigned equivalent values, except that
+<code>symbol_1</code> will be relative to the <code>.output1</code> section while
+the other two will be absolute:
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS { &hellip;
+ .output1 :
+ {
+ start_of_output_1 = ABSOLUTE(.);
+ &hellip;
+ }
+ .output :
+ {
+ symbol_1 = ADDR(.output1);
+ symbol_2 = start_of_output_1;
+ }
+&hellip; }
+</pre></div>
+
+</dd>
+<dt><code>ALIGN(<var>align</var>)</code></dt>
+<dt><code>ALIGN(<var>exp</var>,<var>align</var>)</code></dt>
+<dd><a name="index-ALIGN_0028align_0029"></a>
+<a name="index-ALIGN_0028exp_002calign_0029"></a>
+<a name="index-round-up-location-counter"></a>
+<a name="index-align-location-counter"></a>
+<a name="index-round-up-expression"></a>
+<a name="index-align-expression"></a>
+<p>Return the location counter (<code>.</code>) or arbitrary expression aligned
+to the next <var>align</var> boundary. The single operand <code>ALIGN</code>
+doesn&rsquo;t change the value of the location counter&mdash;it just does
+arithmetic on it. The two operand <code>ALIGN</code> allows an arbitrary
+expression to be aligned upwards (<code>ALIGN(<var>align</var>)</code> is
+equivalent to <code>ALIGN(ABSOLUTE(.), <var>align</var>)</code>).
+</p>
+<p>Here is an example which aligns the output <code>.data</code> section to the
+next <code>0x2000</code> byte boundary after the preceding section and sets a
+variable within the section to the next <code>0x8000</code> boundary after the
+input sections:
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS { &hellip;
+ .data ALIGN(0x2000): {
+ *(.data)
+ variable = ALIGN(0x8000);
+ }
+&hellip; }
+</pre></div>
+<p>The first use of <code>ALIGN</code> in this example specifies the location of
+a section because it is used as the optional <var>address</var> attribute of
+a section definition (see <a href="#Output-Section-Address">Output Section Address</a>). The second use
+of <code>ALIGN</code> is used to defines the value of a symbol.
+</p>
+<p>The builtin function <code>NEXT</code> is closely related to <code>ALIGN</code>.
+</p>
+</dd>
+<dt><code>ALIGNOF(<var>section</var>)</code></dt>
+<dd><a name="index-ALIGNOF_0028section_0029"></a>
+<a name="index-section-alignment"></a>
+<p>Return the alignment in bytes of the named <var>section</var>, if that section has
+been allocated. If the section has not been allocated when this is
+evaluated, the linker will report an error. In the following example,
+the alignment of the <code>.output</code> section is stored as the first
+value in that section.
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS{ &hellip;
+ .output {
+ LONG (ALIGNOF (.output))
+ &hellip;
+ }
+&hellip; }
+</pre></div>
+
+</dd>
+<dt><code>BLOCK(<var>exp</var>)</code></dt>
+<dd><a name="index-BLOCK_0028exp_0029"></a>
+<p>This is a synonym for <code>ALIGN</code>, for compatibility with older linker
+scripts. It is most often seen when setting the address of an output
+section.
+</p>
+</dd>
+<dt><code>DATA_SEGMENT_ALIGN(<var>maxpagesize</var>, <var>commonpagesize</var>)</code></dt>
+<dd><a name="index-DATA_005fSEGMENT_005fALIGN_0028maxpagesize_002c-commonpagesize_0029"></a>
+<p>This is equivalent to either
+</p><div class="smallexample">
+<pre class="smallexample">(ALIGN(<var>maxpagesize</var>) + (. &amp; (<var>maxpagesize</var> - 1)))
+</pre></div>
+<p>or
+</p><div class="smallexample">
+<pre class="smallexample">(ALIGN(<var>maxpagesize</var>)
+ + ((. + <var>commonpagesize</var> - 1) &amp; (<var>maxpagesize</var> - <var>commonpagesize</var>)))
+</pre></div>
+<p>depending on whether the latter uses fewer <var>commonpagesize</var> sized pages
+for the data segment (area between the result of this expression and
+<code>DATA_SEGMENT_END</code>) than the former or not.
+If the latter form is used, it means <var>commonpagesize</var> bytes of runtime
+memory will be saved at the expense of up to <var>commonpagesize</var> wasted
+bytes in the on-disk file.
+</p>
+<p>This expression can only be used directly in <code>SECTIONS</code> commands, not in
+any output section descriptions and only once in the linker script.
+<var>commonpagesize</var> should be less or equal to <var>maxpagesize</var> and should
+be the system page size the object wants to be optimized for while still
+running on system page sizes up to <var>maxpagesize</var>. Note however
+that &lsquo;<samp>-z relro</samp>&rsquo; protection will not be effective if the system
+page size is larger than <var>commonpagesize</var>.
+</p>
+<p>Example:
+</p><div class="smallexample">
+<pre class="smallexample"> . = DATA_SEGMENT_ALIGN(0x10000, 0x2000);
+</pre></div>
+
+</dd>
+<dt><code>DATA_SEGMENT_END(<var>exp</var>)</code></dt>
+<dd><a name="index-DATA_005fSEGMENT_005fEND_0028exp_0029"></a>
+<p>This defines the end of data segment for <code>DATA_SEGMENT_ALIGN</code>
+evaluation purposes.
+</p>
+<div class="smallexample">
+<pre class="smallexample"> . = DATA_SEGMENT_END(.);
+</pre></div>
+
+</dd>
+<dt><code>DATA_SEGMENT_RELRO_END(<var>offset</var>, <var>exp</var>)</code></dt>
+<dd><a name="index-DATA_005fSEGMENT_005fRELRO_005fEND_0028offset_002c-exp_0029"></a>
+<p>This defines the end of the <code>PT_GNU_RELRO</code> segment when
+&lsquo;<samp>-z relro</samp>&rsquo; option is used.
+When &lsquo;<samp>-z relro</samp>&rsquo; option is not present, <code>DATA_SEGMENT_RELRO_END</code>
+does nothing, otherwise <code>DATA_SEGMENT_ALIGN</code> is padded so that
+<var>exp</var> + <var>offset</var> is aligned to the <var>commonpagesize</var>
+argument given to <code>DATA_SEGMENT_ALIGN</code>. If present in the linker
+script, it must be placed between <code>DATA_SEGMENT_ALIGN</code> and
+<code>DATA_SEGMENT_END</code>. Evaluates to the second argument plus any
+padding needed at the end of the <code>PT_GNU_RELRO</code> segment due to
+section alignment.
+</p>
+<div class="smallexample">
+<pre class="smallexample"> . = DATA_SEGMENT_RELRO_END(24, .);
+</pre></div>
+
+</dd>
+<dt><code>DEFINED(<var>symbol</var>)</code></dt>
+<dd><a name="index-DEFINED_0028symbol_0029"></a>
+<a name="index-symbol-defaults"></a>
+<p>Return 1 if <var>symbol</var> is in the linker global symbol table and is
+defined before the statement using DEFINED in the script, otherwise
+return 0. You can use this function to provide
+default values for symbols. For example, the following script fragment
+shows how to set a global symbol &lsquo;<samp>begin</samp>&rsquo; to the first location in
+the &lsquo;<samp>.text</samp>&rsquo; section&mdash;but if a symbol called &lsquo;<samp>begin</samp>&rsquo; already
+existed, its value is preserved:
+</p>
+<div class="smallexample">
+<pre class="smallexample">SECTIONS { &hellip;
+ .text : {
+ begin = DEFINED(begin) ? begin : . ;
+ &hellip;
+ }
+ &hellip;
+}
+</pre></div>
+
+</dd>
+<dt><code>LENGTH(<var>memory</var>)</code></dt>
+<dd><a name="index-LENGTH_0028memory_0029"></a>
+<p>Return the length of the memory region named <var>memory</var>.
+</p>
+</dd>
+<dt><code>LOADADDR(<var>section</var>)</code></dt>
+<dd><a name="index-LOADADDR_0028section_0029"></a>
+<a name="index-section-load-address-in-expression"></a>
+<p>Return the absolute LMA of the named <var>section</var>. (see <a href="#Output-Section-LMA">Output Section LMA</a>).
+</p>
+</dd>
+<dt><code>LOG2CEIL(<var>exp</var>)</code></dt>
+<dd><a name="index-LOG2CEIL_0028exp_0029"></a>
+<p>Return the binary logarithm of <var>exp</var> rounded towards infinity.
+<code>LOG2CEIL(0)</code> returns 0.
+</p>
+<a name="index-MAX"></a>
+</dd>
+<dt><code>MAX(<var>exp1</var>, <var>exp2</var>)</code></dt>
+<dd><p>Returns the maximum of <var>exp1</var> and <var>exp2</var>.
+</p>
+<a name="index-MIN"></a>
+</dd>
+<dt><code>MIN(<var>exp1</var>, <var>exp2</var>)</code></dt>
+<dd><p>Returns the minimum of <var>exp1</var> and <var>exp2</var>.
+</p>
+</dd>
+<dt><code>NEXT(<var>exp</var>)</code></dt>
+<dd><a name="index-NEXT_0028exp_0029"></a>
+<a name="index-unallocated-address_002c-next"></a>
+<p>Return the next unallocated address that is a multiple of <var>exp</var>.
+This function is closely related to <code>ALIGN(<var>exp</var>)</code>; unless you
+use the <code>MEMORY</code> command to define discontinuous memory for the
+output file, the two functions are equivalent.
+</p>
+</dd>
+<dt><code>ORIGIN(<var>memory</var>)</code></dt>
+<dd><a name="index-ORIGIN_0028memory_0029"></a>
+<p>Return the origin of the memory region named <var>memory</var>.
+</p>
+</dd>
+<dt><code>SEGMENT_START(<var>segment</var>, <var>default</var>)</code></dt>
+<dd><a name="index-SEGMENT_005fSTART_0028segment_002c-default_0029"></a>
+<p>Return the base address of the named <var>segment</var>. If an explicit
+value has already been given for this segment (with a command-line
+&lsquo;<samp>-T</samp>&rsquo; option) then that value will be returned otherwise the value
+will be <var>default</var>. At present, the &lsquo;<samp>-T</samp>&rsquo; command-line option
+can only be used to set the base address for the &ldquo;text&rdquo;, &ldquo;data&rdquo;, and
+&ldquo;bss&rdquo; sections, but you can use <code>SEGMENT_START</code> with any segment
+name.
+</p>
+</dd>
+<dt><code>SIZEOF(<var>section</var>)</code></dt>
+<dd><a name="index-SIZEOF_0028section_0029"></a>
+<a name="index-section-size"></a>
+<p>Return the size in bytes of the named <var>section</var>, if that section has
+been allocated. If the section has not been allocated when this is
+evaluated, the linker will report an error. In the following example,
+<code>symbol_1</code> and <code>symbol_2</code> are assigned identical values:
+</p><div class="smallexample">
+<pre class="smallexample">SECTIONS{ &hellip;
+ .output {
+ .start = . ;
+ &hellip;
+ .end = . ;
+ }
+ symbol_1 = .end - .start ;
+ symbol_2 = SIZEOF(.output);
+&hellip; }
+</pre></div>
+
+</dd>
+<dt><code>SIZEOF_HEADERS</code></dt>
+<dd><a name="index-SIZEOF_005fHEADERS"></a>
+<a name="index-header-size"></a>
+<p>Return the size in bytes of the output file&rsquo;s headers. This is
+information which appears at the start of the output file. You can use
+this number when setting the start address of the first section, if you
+choose, to facilitate paging.
+</p>
+<a name="index-not-enough-room-for-program-headers"></a>
+<a name="index-program-headers_002c-not-enough-room"></a>
+<p>When producing an ELF output file, if the linker script uses the
+<code>SIZEOF_HEADERS</code> builtin function, the linker must compute the
+number of program headers before it has determined all the section
+addresses and sizes. If the linker later discovers that it needs
+additional program headers, it will report an error &lsquo;<samp>not enough
+room for program headers</samp>&rsquo;. To avoid this error, you must avoid using
+the <code>SIZEOF_HEADERS</code> function, or you must rework your linker
+script to avoid forcing the linker to use additional program headers, or
+you must define the program headers yourself using the <code>PHDRS</code>
+command (see <a href="#PHDRS">PHDRS</a>).
+</p></dd>
+</dl>
+
+<hr>
+<a name="Implicit-Linker-Scripts"></a>
+<div class="header">
+<p>
+Previous: <a href="#Expressions" accesskey="p" rel="previous">Expressions</a>, Up: <a href="#Scripts" accesskey="u" rel="up">Scripts</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Implicit-Linker-Scripts-1"></a>
+<h3 class="section">3.11 Implicit Linker Scripts</h3>
+<a name="index-implicit-linker-scripts"></a>
+<p>If you specify a linker input file which the linker can not recognize as
+an object file or an archive file, it will try to read the file as a
+linker script. If the file can not be parsed as a linker script, the
+linker will report an error.
+</p>
+<p>An implicit linker script will not replace the default linker script.
+</p>
+<p>Typically an implicit linker script would contain only symbol
+assignments, or the <code>INPUT</code>, <code>GROUP</code>, or <code>VERSION</code>
+commands.
+</p>
+<p>Any input files read because of an implicit linker script will be read
+at the position in the command line where the implicit linker script was
+read. This can affect archive searching.
+</p>
+<hr>
+<a name="Plugins"></a>
+<div class="header">
+<p>
+Next: <a href="#Machine-Dependent" accesskey="n" rel="next">Machine Dependent</a>, Previous: <a href="#Scripts" accesskey="p" rel="previous">Scripts</a>, Up: <a href="#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Linker-Plugins"></a>
+<h2 class="chapter">4 Linker Plugins</h2>
+
+<a name="index-plugins"></a>
+<a name="index-linker-plugins"></a>
+<p>The linker can use dynamically loaded plugins to modify its behavior.
+For example, the link-time optimization feature that some compilers
+support is implemented with a linker plugin.
+</p>
+<p>Currently there is only one plugin shipped by default, but more may
+be added here later.
+</p>
+<p>Plugins are enabled via the use of the <samp>-plugin <var>name</var></samp>
+command line option. See <a href="#Options">Options</a>.
+</p>
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#libdep-Plugin" accesskey="1">libdep Plugin</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Static Library Dependencies Plugin
+</td></tr>
+</table>
+
+<hr>
+<a name="libdep-Plugin"></a>
+<div class="header">
+<p>
+Up: <a href="#Plugins" accesskey="u" rel="up">Plugins</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Static-Library-Dependencies-Plugin"></a>
+<h3 class="section">4.1 Static Library Dependencies Plugin</h3>
+<a name="index-static-library-dependencies"></a>
+<p>Originally, static libraries were contained in an archive file consisting
+just of a collection of relocatable object files. Later they evolved to
+optionally include a symbol table, to assist in finding the needed objects
+within a library. There their evolution ended, and dynamic libraries
+rose to ascendance.
+</p>
+<p>One useful feature of dynamic libraries was that, more than just collecting
+multiple objects into a single file, they also included a list of their
+dependencies, such that one could specify just the name of a single dynamic
+library at link time, and all of its dependencies would be implicitly
+referenced as well. But static libraries lacked this feature, so if a
+link invocation was switched from using dynamic libraries to static
+libraries, the link command would usually fail unless it was rewritten to
+explicitly list the dependencies of the static library.
+</p>
+<p>The GNU <code>ar</code> utility now supports a <samp>--record-libdeps</samp> option
+to embed dependency lists into static libraries as well, and the <samp>libdep</samp>
+plugin may be used to read this dependency information at link time. The
+dependency information is stored as a single string, carrying <samp>-l</samp>
+and <samp>-L</samp> arguments as they would normally appear in a linker
+command line. As such, the information can be written with any text
+utility and stored into any archive, even if GNU <code>ar</code> is not
+being used to create the archive. The information is stored in an
+archive member named &lsquo;<samp>__.LIBDEP</samp>&rsquo;.
+</p>
+<p>For example, given a library <samp>libssl.a</samp> that depends on another
+library <samp>libcrypto.a</samp> which may be found in <samp>/usr/local/lib</samp>,
+the &lsquo;<samp>__.LIBDEP</samp>&rsquo; member of <samp>libssl.a</samp> would contain
+</p>
+<div class="smallexample">
+<pre class="smallexample">-L/usr/local/lib -lcrypto
+</pre></div>
+
+<hr>
+<a name="Machine-Dependent"></a>
+<div class="header">
+<p>
+Next: <a href="#BFD" accesskey="n" rel="next">BFD</a>, Previous: <a href="#Plugins" accesskey="p" rel="previous">Plugins</a>, Up: <a href="#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Machine-Dependent-Features"></a>
+<h2 class="chapter">5 Machine Dependent Features</h2>
+
+<a name="index-machine-dependencies"></a>
+<p><code>ld</code> has additional features on some platforms; the following
+sections describe them. Machines where <code>ld</code> has no additional
+functionality are not listed.
+</p>
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#H8_002f300" accesskey="1">H8/300</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and the H8/300
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#M68HC11_002f68HC12" accesskey="2">M68HC11/68HC12</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and the Motorola 68HC11 and 68HC12 families
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#ARM" accesskey="3">ARM</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and the ARM family
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#HPPA-ELF32" accesskey="4">HPPA ELF32</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and HPPA 32-bit ELF
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#M68K" accesskey="5">M68K</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and the Motorola 68K family
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#MIPS" accesskey="6">MIPS</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and the MIPS family
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#MMIX" accesskey="7">MMIX</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and MMIX
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#MSP430" accesskey="8">MSP430</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and MSP430
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#NDS32" accesskey="9">NDS32</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and NDS32
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Nios-II">Nios II</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and the Altera Nios II
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#PowerPC-ELF32">PowerPC ELF32</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and PowerPC 32-bit ELF Support
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#PowerPC64-ELF64">PowerPC64 ELF64</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and PowerPC64 64-bit ELF Support
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#S_002f390-ELF">S/390 ELF</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and S/390 ELF Support
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#SPU-ELF">SPU ELF</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and SPU ELF Support
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#TI-COFF">TI COFF</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and TI COFF
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#WIN32">WIN32</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and WIN32 (cygwin/mingw)
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Xtensa">Xtensa</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>ld</code> and Xtensa Processors
+</td></tr>
+</table>
+
+
+<hr>
+<a name="H8_002f300"></a>
+<div class="header">
+<p>
+Next: <a href="#M68HC11_002f68HC12" accesskey="n" rel="next">M68HC11/68HC12</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-the-H8_002f300"></a>
+<h3 class="section">5.1 <code>ld</code> and the H8/300</h3>
+
+<a name="index-H8_002f300-support"></a>
+<p>For the H8/300, <code>ld</code> can perform these global optimizations when
+you specify the &lsquo;<samp>--relax</samp>&rsquo; command-line option.
+</p>
+<dl compact="compact">
+<dd><a name="index-relaxing-on-H8_002f300"></a>
+</dd>
+<dt><em>relaxing address modes</em></dt>
+<dd><p><code>ld</code> finds all <code>jsr</code> and <code>jmp</code> instructions whose
+targets are within eight bits, and turns them into eight-bit
+program-counter relative <code>bsr</code> and <code>bra</code> instructions,
+respectively.
+</p>
+<a name="index-synthesizing-on-H8_002f300"></a>
+</dd>
+<dt><em>synthesizing instructions</em></dt>
+<dd><p><code>ld</code> finds all <code>mov.b</code> instructions which use the
+sixteen-bit absolute address form, but refer to the top
+page of memory, and changes them to use the eight-bit address form.
+(That is: the linker turns &lsquo;<samp>mov.b <code>@</code><var>aa</var>:16</samp>&rsquo; into
+&lsquo;<samp>mov.b <code>@</code><var>aa</var>:8</samp>&rsquo; whenever the address <var>aa</var> is in the
+top page of memory).
+</p>
+<p><code>ld</code> finds all <code>mov</code> instructions which use the register
+indirect with 32-bit displacement addressing mode, but use a small
+displacement inside 16-bit displacement range, and changes them to use
+the 16-bit displacement form. (That is: the linker turns &lsquo;<samp>mov.b
+<code>@</code><var>d</var>:32,ERx</samp>&rsquo; into &lsquo;<samp>mov.b <code>@</code><var>d</var>:16,ERx</samp>&rsquo;
+whenever the displacement <var>d</var> is in the 16 bit signed integer
+range. Only implemented in ELF-format ld).
+</p>
+</dd>
+<dt><em>bit manipulation instructions</em></dt>
+<dd><p><code>ld</code> finds all bit manipulation instructions like <code>band, bclr,
+biand, bild, bior, bist, bixor, bld, bnot, bor, bset, bst, btst, bxor</code>
+which use 32 bit and 16 bit absolute address form, but refer to the top
+page of memory, and changes them to use the 8 bit address form.
+(That is: the linker turns &lsquo;<samp>bset #xx:3,<code>@</code><var>aa</var>:32</samp>&rsquo; into
+&lsquo;<samp>bset #xx:3,<code>@</code><var>aa</var>:8</samp>&rsquo; whenever the address <var>aa</var> is in
+the top page of memory).
+</p>
+</dd>
+<dt><em>system control instructions</em></dt>
+<dd><p><code>ld</code> finds all <code>ldc.w, stc.w</code> instructions which use the
+32 bit absolute address form, but refer to the top page of memory, and
+changes them to use 16 bit address form.
+(That is: the linker turns &lsquo;<samp>ldc.w <code>@</code><var>aa</var>:32,ccr</samp>&rsquo; into
+&lsquo;<samp>ldc.w <code>@</code><var>aa</var>:16,ccr</samp>&rsquo; whenever the address <var>aa</var> is in
+the top page of memory).
+</p></dd>
+</dl>
+
+
+
+
+
+<hr>
+<a name="M68HC11_002f68HC12"></a>
+<div class="header">
+<p>
+Next: <a href="#ARM" accesskey="n" rel="next">ARM</a>, Previous: <a href="#H8_002f300" accesskey="p" rel="previous">H8/300</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-the-Motorola-68HC11-and-68HC12-families"></a>
+<h3 class="section">5.2 <code>ld</code> and the Motorola 68HC11 and 68HC12 families</h3>
+
+<a name="index-M68HC11-and-68HC12-support"></a>
+
+<a name="Linker-Relaxation"></a>
+<h4 class="subsection">5.2.1 Linker Relaxation</h4>
+
+<p>For the Motorola 68HC11, <code>ld</code> can perform these global
+optimizations when you specify the &lsquo;<samp>--relax</samp>&rsquo; command-line option.
+</p>
+<dl compact="compact">
+<dd><a name="index-relaxing-on-M68HC11"></a>
+</dd>
+<dt><em>relaxing address modes</em></dt>
+<dd><p><code>ld</code> finds all <code>jsr</code> and <code>jmp</code> instructions whose
+targets are within eight bits, and turns them into eight-bit
+program-counter relative <code>bsr</code> and <code>bra</code> instructions,
+respectively.
+</p>
+<p><code>ld</code> also looks at all 16-bit extended addressing modes and
+transforms them in a direct addressing mode when the address is in
+page 0 (between 0 and 0x0ff).
+</p>
+</dd>
+<dt><em>relaxing gcc instruction group</em></dt>
+<dd><p>When <code>gcc</code> is called with <samp>-mrelax</samp>, it can emit group
+of instructions that the linker can optimize to use a 68HC11 direct
+addressing mode. These instructions consists of <code>bclr</code> or
+<code>bset</code> instructions.
+</p>
+</dd>
+</dl>
+
+<a name="Trampoline-Generation"></a>
+<h4 class="subsection">5.2.2 Trampoline Generation</h4>
+
+<a name="index-trampoline-generation-on-M68HC11"></a>
+<a name="index-trampoline-generation-on-M68HC12"></a>
+<p>For 68HC11 and 68HC12, <code>ld</code> can generate trampoline code to
+call a far function using a normal <code>jsr</code> instruction. The linker
+will also change the relocation to some far function to use the
+trampoline address instead of the function address. This is typically the
+case when a pointer to a function is taken. The pointer will in fact
+point to the function trampoline.
+</p>
+
+<hr>
+<a name="ARM"></a>
+<div class="header">
+<p>
+Next: <a href="#HPPA-ELF32" accesskey="n" rel="next">HPPA ELF32</a>, Previous: <a href="#M68HC11_002f68HC12" accesskey="p" rel="previous">M68HC11/68HC12</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-the-ARM-family"></a>
+<h3 class="section">5.3 <code>ld</code> and the ARM family</h3>
+
+<a name="index-ARM-interworking-support"></a>
+<a name="index-_002d_002dsupport_002dold_002dcode"></a>
+<p>For the ARM, <code>ld</code> will generate code stubs to allow functions calls
+between ARM and Thumb code. These stubs only work with code that has
+been compiled and assembled with the &lsquo;<samp>-mthumb-interwork</samp>&rsquo; command
+line option. If it is necessary to link with old ARM object files or
+libraries, which have not been compiled with the -mthumb-interwork
+option then the &lsquo;<samp>--support-old-code</samp>&rsquo; command-line switch should be
+given to the linker. This will make it generate larger stub functions
+which will work with non-interworking aware ARM code. Note, however,
+the linker does not support generating stubs for function calls to
+non-interworking aware Thumb code.
+</p>
+<a name="index-thumb-entry-point"></a>
+<a name="index-entry-point_002c-thumb"></a>
+<a name="index-_002d_002dthumb_002dentry_003dentry"></a>
+<p>The &lsquo;<samp>--thumb-entry</samp>&rsquo; switch is a duplicate of the generic
+&lsquo;<samp>--entry</samp>&rsquo; switch, in that it sets the program&rsquo;s starting address.
+But it also sets the bottom bit of the address, so that it can be
+branched to using a BX instruction, and the program will start
+executing in Thumb mode straight away.
+</p>
+<a name="index-PE-import-table-prefixing"></a>
+<a name="index-_002d_002duse_002dnul_002dprefixed_002dimport_002dtables"></a>
+<p>The &lsquo;<samp>--use-nul-prefixed-import-tables</samp>&rsquo; switch is specifying, that
+the import tables idata4 and idata5 have to be generated with a zero
+element prefix for import libraries. This is the old style to generate
+import tables. By default this option is turned off.
+</p>
+<a name="index-BE8"></a>
+<a name="index-_002d_002dbe8"></a>
+<p>The &lsquo;<samp>--be8</samp>&rsquo; switch instructs <code>ld</code> to generate BE8 format
+executables. This option is only valid when linking big-endian
+objects - ie ones which have been assembled with the <samp>-EB</samp>
+option. The resulting image will contain big-endian data and
+little-endian code.
+</p>
+<a name="index-TARGET1"></a>
+<a name="index-_002d_002dtarget1_002drel"></a>
+<a name="index-_002d_002dtarget1_002dabs"></a>
+<p>The &lsquo;<samp>R_ARM_TARGET1</samp>&rsquo; relocation is typically used for entries in the
+&lsquo;<samp>.init_array</samp>&rsquo; section. It is interpreted as either &lsquo;<samp>R_ARM_REL32</samp>&rsquo;
+or &lsquo;<samp>R_ARM_ABS32</samp>&rsquo;, depending on the target. The &lsquo;<samp>--target1-rel</samp>&rsquo;
+and &lsquo;<samp>--target1-abs</samp>&rsquo; switches override the default.
+</p>
+<a name="index-TARGET2"></a>
+<a name="index-_002d_002dtarget2_003dtype"></a>
+<p>The &lsquo;<samp>--target2=type</samp>&rsquo; switch overrides the default definition of the
+&lsquo;<samp>R_ARM_TARGET2</samp>&rsquo; relocation. Valid values for &lsquo;<samp>type</samp>&rsquo;, their
+meanings, and target defaults are as follows:
+</p><dl compact="compact">
+<dt>&lsquo;<samp>rel</samp>&rsquo;</dt>
+<dd><p>&lsquo;<samp>R_ARM_REL32</samp>&rsquo; (arm*-*-elf, arm*-*-eabi)
+</p></dd>
+<dt>&lsquo;<samp>abs</samp>&rsquo;</dt>
+<dd><p>&lsquo;<samp>R_ARM_ABS32</samp>&rsquo;
+</p></dd>
+<dt>&lsquo;<samp>got-rel</samp>&rsquo;</dt>
+<dd><p>&lsquo;<samp>R_ARM_GOT_PREL</samp>&rsquo; (arm*-*-linux, arm*-*-*bsd)
+</p></dd>
+</dl>
+
+<a name="index-FIX_005fV4BX"></a>
+<a name="index-_002d_002dfix_002dv4bx"></a>
+<p>The &lsquo;<samp>R_ARM_V4BX</samp>&rsquo; relocation (defined by the ARM AAELF
+specification) enables objects compiled for the ARMv4 architecture to be
+interworking-safe when linked with other objects compiled for ARMv4t, but
+also allows pure ARMv4 binaries to be built from the same ARMv4 objects.
+</p>
+<p>In the latter case, the switch <samp>--fix-v4bx</samp> must be passed to the
+linker, which causes v4t <code>BX rM</code> instructions to be rewritten as
+<code>MOV PC,rM</code>, since v4 processors do not have a <code>BX</code> instruction.
+</p>
+<p>In the former case, the switch should not be used, and &lsquo;<samp>R_ARM_V4BX</samp>&rsquo;
+relocations are ignored.
+</p>
+<a name="index-FIX_005fV4BX_005fINTERWORKING"></a>
+<a name="index-_002d_002dfix_002dv4bx_002dinterworking"></a>
+<p>Replace <code>BX rM</code> instructions identified by &lsquo;<samp>R_ARM_V4BX</samp>&rsquo;
+relocations with a branch to the following veneer:
+</p>
+<div class="smallexample">
+<pre class="smallexample">TST rM, #1
+MOVEQ PC, rM
+BX Rn
+</pre></div>
+
+<p>This allows generation of libraries/applications that work on ARMv4 cores
+and are still interworking safe. Note that the above veneer clobbers the
+condition flags, so may cause incorrect program behavior in rare cases.
+</p>
+<a name="index-USE_005fBLX"></a>
+<a name="index-_002d_002duse_002dblx"></a>
+<p>The &lsquo;<samp>--use-blx</samp>&rsquo; switch enables the linker to use ARM/Thumb
+BLX instructions (available on ARMv5t and above) in various
+situations. Currently it is used to perform calls via the PLT from Thumb
+code using BLX rather than using BX and a mode-switching stub before
+each PLT entry. This should lead to such calls executing slightly faster.
+</p>
+<a name="index-VFP11_005fDENORM_005fFIX"></a>
+<a name="index-_002d_002dvfp11_002ddenorm_002dfix"></a>
+<p>The &lsquo;<samp>--vfp11-denorm-fix</samp>&rsquo; switch enables a link-time workaround for a
+bug in certain VFP11 coprocessor hardware, which sometimes allows
+instructions with denorm operands (which must be handled by support code)
+to have those operands overwritten by subsequent instructions before
+the support code can read the intended values.
+</p>
+<p>The bug may be avoided in scalar mode if you allow at least one
+intervening instruction between a VFP11 instruction which uses a register
+and another instruction which writes to the same register, or at least two
+intervening instructions if vector mode is in use. The bug only affects
+full-compliance floating-point mode: you do not need this workaround if
+you are using &quot;runfast&quot; mode. Please contact ARM for further details.
+</p>
+<p>If you know you are using buggy VFP11 hardware, you can
+enable this workaround by specifying the linker option
+&lsquo;<samp>--vfp-denorm-fix=scalar</samp>&rsquo; if you are using the VFP11 scalar
+mode only, or &lsquo;<samp>--vfp-denorm-fix=vector</samp>&rsquo; if you are using
+vector mode (the latter also works for scalar code). The default is
+&lsquo;<samp>--vfp-denorm-fix=none</samp>&rsquo;.
+</p>
+<p>If the workaround is enabled, instructions are scanned for
+potentially-troublesome sequences, and a veneer is created for each
+such sequence which may trigger the erratum. The veneer consists of the
+first instruction of the sequence and a branch back to the subsequent
+instruction. The original instruction is then replaced with a branch to
+the veneer. The extra cycles required to call and return from the veneer
+are sufficient to avoid the erratum in both the scalar and vector cases.
+</p>
+<a name="index-ARM1176-erratum-workaround"></a>
+<a name="index-_002d_002dfix_002darm1176"></a>
+<a name="index-_002d_002dno_002dfix_002darm1176"></a>
+<p>The &lsquo;<samp>--fix-arm1176</samp>&rsquo; switch enables a link-time workaround for an erratum
+in certain ARM1176 processors. The workaround is enabled by default if you
+are targeting ARM v6 (excluding ARM v6T2) or earlier. It can be disabled
+unconditionally by specifying &lsquo;<samp>--no-fix-arm1176</samp>&rsquo;.
+</p>
+<p>Further information is available in the &ldquo;ARM1176JZ-S and ARM1176JZF-S
+Programmer Advice Notice&rdquo; available on the ARM documentation website at:
+http://infocenter.arm.com/.
+</p>
+<a name="index-STM32L4xx-erratum-workaround"></a>
+<a name="index-_002d_002dfix_002dstm32l4xx_002d629360"></a>
+
+<p>The &lsquo;<samp>--fix-stm32l4xx-629360</samp>&rsquo; switch enables a link-time
+workaround for a bug in the bus matrix / memory controller for some of
+the STM32 Cortex-M4 based products (STM32L4xx). When accessing
+off-chip memory via the affected bus for bus reads of 9 words or more,
+the bus can generate corrupt data and/or abort. These are only
+core-initiated accesses (not DMA), and might affect any access:
+integer loads such as LDM, POP and floating-point loads such as VLDM,
+VPOP. Stores are not affected.
+</p>
+<p>The bug can be avoided by splitting memory accesses into the
+necessary chunks to keep bus reads below 8 words.
+</p>
+<p>The workaround is not enabled by default, this is equivalent to use
+&lsquo;<samp>--fix-stm32l4xx-629360=none</samp>&rsquo;. If you know you are using buggy
+STM32L4xx hardware, you can enable the workaround by specifying the
+linker option &lsquo;<samp>--fix-stm32l4xx-629360</samp>&rsquo;, or the equivalent
+&lsquo;<samp>--fix-stm32l4xx-629360=default</samp>&rsquo;.
+</p>
+<p>If the workaround is enabled, instructions are scanned for
+potentially-troublesome sequences, and a veneer is created for each
+such sequence which may trigger the erratum. The veneer consists in a
+replacement sequence emulating the behaviour of the original one and a
+branch back to the subsequent instruction. The original instruction is
+then replaced with a branch to the veneer.
+</p>
+<p>The workaround does not always preserve the memory access order for
+the LDMDB instruction, when the instruction loads the PC.
+</p>
+<p>The workaround is not able to handle problematic instructions when
+they are in the middle of an IT block, since a branch is not allowed
+there. In that case, the linker reports a warning and no replacement
+occurs.
+</p>
+<p>The workaround is not able to replace problematic instructions with a
+PC-relative branch instruction if the &lsquo;<samp>.text</samp>&rsquo; section is too
+large. In that case, when the branch that replaces the original code
+cannot be encoded, the linker reports a warning and no replacement
+occurs.
+</p>
+<a name="index-NO_005fENUM_005fSIZE_005fWARNING"></a>
+<a name="index-_002d_002dno_002denum_002dsize_002dwarning"></a>
+<p>The <samp>--no-enum-size-warning</samp> switch prevents the linker from
+warning when linking object files that specify incompatible EABI
+enumeration size attributes. For example, with this switch enabled,
+linking of an object file using 32-bit enumeration values with another
+using enumeration values fitted into the smallest possible space will
+not be diagnosed.
+</p>
+<a name="index-NO_005fWCHAR_005fSIZE_005fWARNING"></a>
+<a name="index-_002d_002dno_002dwchar_002dsize_002dwarning"></a>
+<p>The <samp>--no-wchar-size-warning</samp> switch prevents the linker from
+warning when linking object files that specify incompatible EABI
+<code>wchar_t</code> size attributes. For example, with this switch enabled,
+linking of an object file using 32-bit <code>wchar_t</code> values with another
+using 16-bit <code>wchar_t</code> values will not be diagnosed.
+</p>
+<a name="index-PIC_005fVENEER"></a>
+<a name="index-_002d_002dpic_002dveneer"></a>
+<p>The &lsquo;<samp>--pic-veneer</samp>&rsquo; switch makes the linker use PIC sequences for
+ARM/Thumb interworking veneers, even if the rest of the binary
+is not PIC. This avoids problems on uClinux targets where
+&lsquo;<samp>--emit-relocs</samp>&rsquo; is used to generate relocatable binaries.
+</p>
+<a name="index-STUB_005fGROUP_005fSIZE"></a>
+<a name="index-_002d_002dstub_002dgroup_002dsize_003dN"></a>
+<p>The linker will automatically generate and insert small sequences of
+code into a linked ARM ELF executable whenever an attempt is made to
+perform a function call to a symbol that is too far away. The
+placement of these sequences of instructions - called stubs - is
+controlled by the command-line option <samp>--stub-group-size=N</samp>.
+The placement is important because a poor choice can create a need for
+duplicate stubs, increasing the code size. The linker will try to
+group stubs together in order to reduce interruptions to the flow of
+code, but it needs guidance as to how big these groups should be and
+where they should be placed.
+</p>
+<p>The value of &lsquo;<samp>N</samp>&rsquo;, the parameter to the
+<samp>--stub-group-size=</samp> option controls where the stub groups are
+placed. If it is negative then all stubs are placed after the first
+branch that needs them. If it is positive then the stubs can be
+placed either before or after the branches that need them. If the
+value of &lsquo;<samp>N</samp>&rsquo; is 1 (either +1 or -1) then the linker will choose
+exactly where to place groups of stubs, using its built in heuristics.
+A value of &lsquo;<samp>N</samp>&rsquo; greater than 1 (or smaller than -1) tells the
+linker that a single group of stubs can service at most &lsquo;<samp>N</samp>&rsquo; bytes
+from the input sections.
+</p>
+<p>The default, if <samp>--stub-group-size=</samp> is not specified, is
+&lsquo;<samp>N = +1</samp>&rsquo;.
+</p>
+<p>Farcalls stubs insertion is fully supported for the ARM-EABI target
+only, because it relies on object files properties not present
+otherwise.
+</p>
+<a name="index-Cortex_002dA8-erratum-workaround"></a>
+<a name="index-_002d_002dfix_002dcortex_002da8"></a>
+<a name="index-_002d_002dno_002dfix_002dcortex_002da8"></a>
+<p>The &lsquo;<samp>--fix-cortex-a8</samp>&rsquo; switch enables a link-time workaround for an erratum in certain Cortex-A8 processors. The workaround is enabled by default if you are targeting the ARM v7-A architecture profile. It can be enabled otherwise by specifying &lsquo;<samp>--fix-cortex-a8</samp>&rsquo;, or disabled unconditionally by specifying &lsquo;<samp>--no-fix-cortex-a8</samp>&rsquo;.
+</p>
+<p>The erratum only affects Thumb-2 code. Please contact ARM for further details.
+</p>
+<a name="index-Cortex_002dA53-erratum-835769-workaround"></a>
+<a name="index-_002d_002dfix_002dcortex_002da53_002d835769"></a>
+<a name="index-_002d_002dno_002dfix_002dcortex_002da53_002d835769"></a>
+<p>The &lsquo;<samp>--fix-cortex-a53-835769</samp>&rsquo; switch enables a link-time workaround for erratum 835769 present on certain early revisions of Cortex-A53 processors. The workaround is disabled by default. It can be enabled by specifying &lsquo;<samp>--fix-cortex-a53-835769</samp>&rsquo;, or disabled unconditionally by specifying &lsquo;<samp>--no-fix-cortex-a53-835769</samp>&rsquo;.
+</p>
+<p>Please contact ARM for further details.
+</p>
+<a name="index-_002d_002dmerge_002dexidx_002dentries"></a>
+<a name="index-_002d_002dno_002dmerge_002dexidx_002dentries-1"></a>
+<a name="index-Merging-exidx-entries"></a>
+<p>The &lsquo;<samp>--no-merge-exidx-entries</samp>&rsquo; switch disables the merging of adjacent exidx entries in debuginfo.
+</p>
+<a name="index-_002d_002dlong_002dplt"></a>
+<a name="index-32_002dbit-PLT-entries"></a>
+<p>The &lsquo;<samp>--long-plt</samp>&rsquo; option enables the use of 16 byte PLT entries
+which support up to 4Gb of code. The default is to use 12 byte PLT
+entries which only support 512Mb of code.
+</p>
+<a name="index-_002d_002dno_002dapply_002ddynamic_002drelocs"></a>
+<a name="index-AArch64-rela-addend"></a>
+<p>The &lsquo;<samp>--no-apply-dynamic-relocs</samp>&rsquo; option makes AArch64 linker do not apply
+link-time values for dynamic relocations.
+</p>
+<a name="index-Placement-of-SG-veneers"></a>
+<p>All SG veneers are placed in the special output section <code>.gnu.sgstubs</code>.
+Its start address must be set, either with the command-line option
+&lsquo;<samp>--section-start</samp>&rsquo; or in a linker script, to indicate where to place these
+veneers in memory.
+</p>
+<a name="index-_002d_002dcmse_002dimplib"></a>
+<a name="index-Secure-gateway-import-library"></a>
+<p>The &lsquo;<samp>--cmse-implib</samp>&rsquo; option requests that the import libraries
+specified by the &lsquo;<samp>--out-implib</samp>&rsquo; and &lsquo;<samp>--in-implib</samp>&rsquo; options are
+secure gateway import libraries, suitable for linking a non-secure
+executable against secure code as per ARMv8-M Security Extensions.
+</p>
+<a name="index-_002d_002din_002dimplib_003dfile"></a>
+<a name="index-Input-import-library"></a>
+<p>The &lsquo;<samp>--in-implib=file</samp>&rsquo; specifies an input import library whose symbols
+must keep the same address in the executable being produced. A warning is
+given if no &lsquo;<samp>--out-implib</samp>&rsquo; is given but new symbols have been introduced
+in the executable that should be listed in its import library. Otherwise, if
+&lsquo;<samp>--out-implib</samp>&rsquo; is specified, the symbols are added to the output import
+library. A warning is also given if some symbols present in the input import
+library have disappeared from the executable. This option is only effective
+for Secure Gateway import libraries, ie. when &lsquo;<samp>--cmse-implib</samp>&rsquo; is
+specified.
+</p>
+
+
+<hr>
+<a name="HPPA-ELF32"></a>
+<div class="header">
+<p>
+Next: <a href="#M68K" accesskey="n" rel="next">M68K</a>, Previous: <a href="#ARM" accesskey="p" rel="previous">ARM</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-HPPA-32_002dbit-ELF-Support"></a>
+<h3 class="section">5.4 <code>ld</code> and HPPA 32-bit ELF Support</h3>
+<a name="index-HPPA-multiple-sub_002dspace-stubs"></a>
+<a name="index-_002d_002dmulti_002dsubspace"></a>
+<p>When generating a shared library, <code>ld</code> will by default generate
+import stubs suitable for use with a single sub-space application.
+The &lsquo;<samp>--multi-subspace</samp>&rsquo; switch causes <code>ld</code> to generate export
+stubs, and different (larger) import stubs suitable for use with
+multiple sub-spaces.
+</p>
+<a name="index-HPPA-stub-grouping"></a>
+<a name="index-_002d_002dstub_002dgroup_002dsize_003dN-1"></a>
+<p>Long branch stubs and import/export stubs are placed by <code>ld</code> in
+stub sections located between groups of input sections.
+&lsquo;<samp>--stub-group-size</samp>&rsquo; specifies the maximum size of a group of input
+sections handled by one stub section. Since branch offsets are signed,
+a stub section may serve two groups of input sections, one group before
+the stub section, and one group after it. However, when using
+conditional branches that require stubs, it may be better (for branch
+prediction) that stub sections only serve one group of input sections.
+A negative value for &lsquo;<samp>N</samp>&rsquo; chooses this scheme, ensuring that
+branches to stubs always use a negative offset. Two special values of
+&lsquo;<samp>N</samp>&rsquo; are recognized, &lsquo;<samp>1</samp>&rsquo; and &lsquo;<samp>-1</samp>&rsquo;. These both instruct
+<code>ld</code> to automatically size input section groups for the branch types
+detected, with the same behaviour regarding stub placement as other
+positive or negative values of &lsquo;<samp>N</samp>&rsquo; respectively.
+</p>
+<p>Note that &lsquo;<samp>--stub-group-size</samp>&rsquo; does not split input sections. A
+single input section larger than the group size specified will of course
+create a larger group (of one section). If input sections are too
+large, it may not be possible for a branch to reach its stub.
+</p>
+
+
+<hr>
+<a name="M68K"></a>
+<div class="header">
+<p>
+Next: <a href="#MIPS" accesskey="n" rel="next">MIPS</a>, Previous: <a href="#HPPA-ELF32" accesskey="p" rel="previous">HPPA ELF32</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-the-Motorola-68K-family"></a>
+<h3 class="section">5.5 <code>ld</code> and the Motorola 68K family</h3>
+
+<a name="index-Motorola-68K-GOT-generation"></a>
+<a name="index-_002d_002dgot_003dtype"></a>
+<p>The &lsquo;<samp>--got=<var>type</var></samp>&rsquo; option lets you choose the GOT generation scheme.
+The choices are &lsquo;<samp>single</samp>&rsquo;, &lsquo;<samp>negative</samp>&rsquo;, &lsquo;<samp>multigot</samp>&rsquo; and
+&lsquo;<samp>target</samp>&rsquo;. When &lsquo;<samp>target</samp>&rsquo; is selected the linker chooses
+the default GOT generation scheme for the current target.
+&lsquo;<samp>single</samp>&rsquo; tells the linker to generate a single GOT with
+entries only at non-negative offsets.
+&lsquo;<samp>negative</samp>&rsquo; instructs the linker to generate a single GOT with
+entries at both negative and positive offsets. Not all environments
+support such GOTs.
+&lsquo;<samp>multigot</samp>&rsquo; allows the linker to generate several GOTs in the
+output file. All GOT references from a single input object
+file access the same GOT, but references from different input object
+files might access different GOTs. Not all environments support such GOTs.
+</p>
+
+
+<hr>
+<a name="MIPS"></a>
+<div class="header">
+<p>
+Next: <a href="#MMIX" accesskey="n" rel="next">MMIX</a>, Previous: <a href="#M68K" accesskey="p" rel="previous">M68K</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-the-MIPS-family"></a>
+<h3 class="section">5.6 <code>ld</code> and the MIPS family</h3>
+
+<a name="index-MIPS-microMIPS-instruction-choice-selection"></a>
+<a name="index-_002d_002dinsn32-1"></a>
+<a name="index-_002d_002dno_002dinsn32-1"></a>
+<p>The &lsquo;<samp>--insn32</samp>&rsquo; and &lsquo;<samp>--no-insn32</samp>&rsquo; options control the choice of
+microMIPS instructions used in code generated by the linker, such as that
+in the PLT or lazy binding stubs, or in relaxation. If &lsquo;<samp>--insn32</samp>&rsquo; is
+used, then the linker only uses 32-bit instruction encodings. By default
+or if &lsquo;<samp>--no-insn32</samp>&rsquo; is used, all instruction encodings are used,
+including 16-bit ones where possible.
+</p>
+<a name="index-MIPS-branch-relocation-check-control"></a>
+<a name="index-_002d_002dignore_002dbranch_002disa-1"></a>
+<a name="index-_002d_002dno_002dignore_002dbranch_002disa-1"></a>
+<p>The &lsquo;<samp>--ignore-branch-isa</samp>&rsquo; and &lsquo;<samp>--no-ignore-branch-isa</samp>&rsquo; options
+control branch relocation checks for invalid ISA mode transitions. If
+&lsquo;<samp>--ignore-branch-isa</samp>&rsquo; is used, then the linker accepts any branch
+relocations and any ISA mode transition required is lost in relocation
+calculation, except for some cases of <code>BAL</code> instructions which meet
+relaxation conditions and are converted to equivalent <code>JALX</code>
+instructions as the associated relocation is calculated. By default
+or if &lsquo;<samp>--no-ignore-branch-isa</samp>&rsquo; is used a check is made causing
+the loss of an ISA mode transition to produce an error.
+</p>
+
+
+<hr>
+<a name="MMIX"></a>
+<div class="header">
+<p>
+Next: <a href="#MSP430" accesskey="n" rel="next">MSP430</a>, Previous: <a href="#MIPS" accesskey="p" rel="previous">MIPS</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-MMIX"></a>
+<h3 class="section">5.7 <code>ld</code> and MMIX</h3>
+<p>For MMIX, there is a choice of generating <code>ELF</code> object files or
+<code>mmo</code> object files when linking. The simulator <code>mmix</code>
+understands the <code>mmo</code> format. The binutils <code>objcopy</code> utility
+can translate between the two formats.
+</p>
+<p>There is one special section, the &lsquo;<samp>.MMIX.reg_contents</samp>&rsquo; section.
+Contents in this section is assumed to correspond to that of global
+registers, and symbols referring to it are translated to special symbols,
+equal to registers. In a final link, the start address of the
+&lsquo;<samp>.MMIX.reg_contents</samp>&rsquo; section corresponds to the first allocated
+global register multiplied by 8. Register <code>$255</code> is not included in
+this section; it is always set to the program entry, which is at the
+symbol <code>Main</code> for <code>mmo</code> files.
+</p>
+<p>Global symbols with the prefix <code>__.MMIX.start.</code>, for example
+<code>__.MMIX.start..text</code> and <code>__.MMIX.start..data</code> are special.
+The default linker script uses these to set the default start address
+of a section.
+</p>
+<p>Initial and trailing multiples of zero-valued 32-bit words in a section,
+are left out from an mmo file.
+</p>
+
+
+<hr>
+<a name="MSP430"></a>
+<div class="header">
+<p>
+Next: <a href="#NDS32" accesskey="n" rel="next">NDS32</a>, Previous: <a href="#MMIX" accesskey="p" rel="previous">MMIX</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-MSP430"></a>
+<h3 class="section">5.8 <code>ld</code> and MSP430</h3>
+<p>For the MSP430 it is possible to select the MPU architecture. The flag &lsquo;<samp>-m [mpu type]</samp>&rsquo;
+will select an appropriate linker script for selected MPU type. (To get a list of known MPUs
+just pass &lsquo;<samp>-m help</samp>&rsquo; option to the linker).
+</p>
+<a name="index-MSP430-extra-sections"></a>
+<p>The linker will recognize some extra sections which are MSP430 specific:
+</p>
+<dl compact="compact">
+<dt><code>&lsquo;<samp>.vectors</samp>&rsquo;</code></dt>
+<dd><p>Defines a portion of ROM where interrupt vectors located.
+</p>
+</dd>
+<dt><code>&lsquo;<samp>.bootloader</samp>&rsquo;</code></dt>
+<dd><p>Defines the bootloader portion of the ROM (if applicable). Any code
+in this section will be uploaded to the MPU.
+</p>
+</dd>
+<dt><code>&lsquo;<samp>.infomem</samp>&rsquo;</code></dt>
+<dd><p>Defines an information memory section (if applicable). Any code in
+this section will be uploaded to the MPU.
+</p>
+</dd>
+<dt><code>&lsquo;<samp>.infomemnobits</samp>&rsquo;</code></dt>
+<dd><p>This is the same as the &lsquo;<samp>.infomem</samp>&rsquo; section except that any code
+in this section will not be uploaded to the MPU.
+</p>
+</dd>
+<dt><code>&lsquo;<samp>.noinit</samp>&rsquo;</code></dt>
+<dd><p>Denotes a portion of RAM located above &lsquo;<samp>.bss</samp>&rsquo; section.
+</p>
+<p>The last two sections are used by gcc.
+</p></dd>
+</dl>
+
+<dl compact="compact">
+<dd><a name="index-MSP430-Options"></a>
+<a name="index-_002d_002dcode_002dregion"></a>
+</dd>
+<dt><samp>--code-region=[either,lower,upper,none]</samp></dt>
+<dd><p>This will transform .text* sections to [either,lower,upper].text* sections. The
+argument passed to GCC for -mcode-region is propagated to the linker
+using this option.
+</p>
+<a name="index-_002d_002ddata_002dregion"></a>
+</dd>
+<dt><samp>--data-region=[either,lower,upper,none]</samp></dt>
+<dd><p>This will transform .data*, .bss* and .rodata* sections to
+[either,lower,upper].[data,bss,rodata]* sections. The argument passed to GCC
+for -mdata-region is propagated to the linker using this option.
+</p>
+<a name="index-_002d_002ddisable_002dsec_002dtransformation"></a>
+</dd>
+<dt><samp>--disable-sec-transformation</samp></dt>
+<dd><p>Prevent the transformation of sections as specified by the <code>--code-region</code>
+and <code>--data-region</code> options.
+This is useful if you are compiling and linking using a single call to the GCC
+wrapper, and want to compile the source files using -m[code,data]-region but
+not transform the sections for prebuilt libraries and objects.
+</p></dd>
+</dl>
+
+
+
+<hr>
+<a name="NDS32"></a>
+<div class="header">
+<p>
+Next: <a href="#Nios-II" accesskey="n" rel="next">Nios II</a>, Previous: <a href="#MSP430" accesskey="p" rel="previous">MSP430</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-NDS32"></a>
+<h3 class="section">5.9 <code>ld</code> and NDS32</h3>
+<a name="index-relaxing-on-NDS32"></a>
+<p>For NDS32, there are some options to select relaxation behavior. The linker
+relaxes objects according to these options.
+</p>
+<dl compact="compact">
+<dt><code>&lsquo;<samp>--m[no-]fp-as-gp</samp>&rsquo;</code></dt>
+<dd><p>Disable/enable fp-as-gp relaxation.
+</p>
+</dd>
+<dt><code>&lsquo;<samp>--mexport-symbols=FILE</samp>&rsquo;</code></dt>
+<dd><p>Exporting symbols and their address into FILE as linker script.
+</p>
+</dd>
+<dt><code>&lsquo;<samp>--m[no-]ex9</samp>&rsquo;</code></dt>
+<dd><p>Disable/enable link-time EX9 relaxation.
+</p>
+</dd>
+<dt><code>&lsquo;<samp>--mexport-ex9=FILE</samp>&rsquo;</code></dt>
+<dd><p>Export the EX9 table after linking.
+</p>
+</dd>
+<dt><code>&lsquo;<samp>--mimport-ex9=FILE</samp>&rsquo;</code></dt>
+<dd><p>Import the Ex9 table for EX9 relaxation.
+</p>
+</dd>
+<dt><code>&lsquo;<samp>--mupdate-ex9</samp>&rsquo;</code></dt>
+<dd><p>Update the existing EX9 table.
+</p>
+</dd>
+<dt><code>&lsquo;<samp>--mex9-limit=NUM</samp>&rsquo;</code></dt>
+<dd><p>Maximum number of entries in the ex9 table.
+</p>
+</dd>
+<dt><code>&lsquo;<samp>--mex9-loop-aware</samp>&rsquo;</code></dt>
+<dd><p>Avoid generating the EX9 instruction inside the loop.
+</p>
+</dd>
+<dt><code>&lsquo;<samp>--m[no-]ifc</samp>&rsquo;</code></dt>
+<dd><p>Disable/enable the link-time IFC optimization.
+</p>
+</dd>
+<dt><code>&lsquo;<samp>--mifc-loop-aware</samp>&rsquo;</code></dt>
+<dd><p>Avoid generating the IFC instruction inside the loop.
+</p></dd>
+</dl>
+
+
+
+<hr>
+<a name="Nios-II"></a>
+<div class="header">
+<p>
+Next: <a href="#PowerPC-ELF32" accesskey="n" rel="next">PowerPC ELF32</a>, Previous: <a href="#NDS32" accesskey="p" rel="previous">NDS32</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-the-Altera-Nios-II"></a>
+<h3 class="section">5.10 <code>ld</code> and the Altera Nios II</h3>
+<a name="index-Nios-II-call-relaxation"></a>
+<a name="index-_002d_002drelax-on-Nios-II"></a>
+
+<p>Call and immediate jump instructions on Nios II processors are limited to
+transferring control to addresses in the same 256MB memory segment,
+which may result in <code>ld</code> giving
+&lsquo;<samp>relocation truncated to fit</samp>&rsquo; errors with very large programs.
+The command-line option <samp>--relax</samp> enables the generation of
+trampolines that can access the entire 32-bit address space for calls
+outside the normal <code>call</code> and <code>jmpi</code> address range. These
+trampolines are inserted at section boundaries, so may not themselves
+be reachable if an input section and its associated call trampolines are
+larger than 256MB.
+</p>
+<p>The <samp>--relax</samp> option is enabled by default unless <samp>-r</samp>
+is also specified. You can disable trampoline generation by using the
+<samp>--no-relax</samp> linker option. You can also disable this optimization
+locally by using the &lsquo;<samp>set .noat</samp>&rsquo; directive in assembly-language
+source files, as the linker-inserted trampolines use the <code>at</code>
+register as a temporary.
+</p>
+<p>Note that the linker <samp>--relax</samp> option is independent of assembler
+relaxation options, and that using the GNU assembler&rsquo;s <samp>-relax-all</samp>
+option interferes with the linker&rsquo;s more selective call instruction relaxation.
+</p>
+
+
+<hr>
+<a name="PowerPC-ELF32"></a>
+<div class="header">
+<p>
+Next: <a href="#PowerPC64-ELF64" accesskey="n" rel="next">PowerPC64 ELF64</a>, Previous: <a href="#Nios-II" accesskey="p" rel="previous">Nios II</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-PowerPC-32_002dbit-ELF-Support"></a>
+<h3 class="section">5.11 <code>ld</code> and PowerPC 32-bit ELF Support</h3>
+<a name="index-PowerPC-long-branches"></a>
+<a name="index-_002d_002drelax-on-PowerPC"></a>
+<p>Branches on PowerPC processors are limited to a signed 26-bit
+displacement, which may result in <code>ld</code> giving
+&lsquo;<samp>relocation truncated to fit</samp>&rsquo; errors with very large programs.
+&lsquo;<samp>--relax</samp>&rsquo; enables the generation of trampolines that can access
+the entire 32-bit address space. These trampolines are inserted at
+section boundaries, so may not themselves be reachable if an input
+section exceeds 33M in size. You may combine &lsquo;<samp>-r</samp>&rsquo; and
+&lsquo;<samp>--relax</samp>&rsquo; to add trampolines in a partial link. In that case
+both branches to undefined symbols and inter-section branches are also
+considered potentially out of range, and trampolines inserted.
+</p>
+<a name="index-PowerPC-ELF32-options"></a>
+<dl compact="compact">
+<dd><a name="index-PowerPC-PLT"></a>
+<a name="index-_002d_002dbss_002dplt"></a>
+</dd>
+<dt><samp>--bss-plt</samp></dt>
+<dd><p>Current PowerPC GCC accepts a &lsquo;<samp>-msecure-plt</samp>&rsquo; option that
+generates code capable of using a newer PLT and GOT layout that has
+the security advantage of no executable section ever needing to be
+writable and no writable section ever being executable. PowerPC
+<code>ld</code> will generate this layout, including stubs to access the
+PLT, if all input files (including startup and static libraries) were
+compiled with &lsquo;<samp>-msecure-plt</samp>&rsquo;. &lsquo;<samp>--bss-plt</samp>&rsquo; forces the old
+BSS PLT (and GOT layout) which can give slightly better performance.
+</p>
+<a name="index-_002d_002dsecure_002dplt"></a>
+</dd>
+<dt><samp>--secure-plt</samp></dt>
+<dd><p><code>ld</code> will use the new PLT and GOT layout if it is linking new
+&lsquo;<samp>-fpic</samp>&rsquo; or &lsquo;<samp>-fPIC</samp>&rsquo; code, but does not do so automatically
+when linking non-PIC code. This option requests the new PLT and GOT
+layout. A warning will be given if some object file requires the old
+style BSS PLT.
+</p>
+<a name="index-PowerPC-GOT"></a>
+<a name="index-_002d_002dsdata_002dgot"></a>
+</dd>
+<dt><samp>--sdata-got</samp></dt>
+<dd><p>The new secure PLT and GOT are placed differently relative to other
+sections compared to older BSS PLT and GOT placement. The location of
+<code>.plt</code> must change because the new secure PLT is an initialized
+section while the old PLT is uninitialized. The reason for the
+<code>.got</code> change is more subtle: The new placement allows
+<code>.got</code> to be read-only in applications linked with
+&lsquo;<samp>-z relro -z now</samp>&rsquo;. However, this placement means that
+<code>.sdata</code> cannot always be used in shared libraries, because the
+PowerPC ABI accesses <code>.sdata</code> in shared libraries from the GOT
+pointer. &lsquo;<samp>--sdata-got</samp>&rsquo; forces the old GOT placement. PowerPC
+GCC doesn&rsquo;t use <code>.sdata</code> in shared libraries, so this option is
+really only useful for other compilers that may do so.
+</p>
+<a name="index-PowerPC-stub-symbols"></a>
+<a name="index-_002d_002demit_002dstub_002dsyms"></a>
+</dd>
+<dt><samp>--emit-stub-syms</samp></dt>
+<dd><p>This option causes <code>ld</code> to label linker stubs with a local
+symbol that encodes the stub type and destination.
+</p>
+<a name="index-PowerPC-TLS-optimization"></a>
+<a name="index-_002d_002dno_002dtls_002doptimize"></a>
+</dd>
+<dt><samp>--no-tls-optimize</samp></dt>
+<dd><p>PowerPC <code>ld</code> normally performs some optimization of code
+sequences used to access Thread-Local Storage. Use this option to
+disable the optimization.
+</p></dd>
+</dl>
+
+
+
+<hr>
+<a name="PowerPC64-ELF64"></a>
+<div class="header">
+<p>
+Next: <a href="#S_002f390-ELF" accesskey="n" rel="next">S/390 ELF</a>, Previous: <a href="#PowerPC-ELF32" accesskey="p" rel="previous">PowerPC ELF32</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-PowerPC64-64_002dbit-ELF-Support"></a>
+<h3 class="section">5.12 <code>ld</code> and PowerPC64 64-bit ELF Support</h3>
+
+<a name="index-PowerPC64-ELF64-options"></a>
+<dl compact="compact">
+<dd><a name="index-PowerPC64-stub-grouping"></a>
+<a name="index-_002d_002dstub_002dgroup_002dsize"></a>
+</dd>
+<dt><samp>--stub-group-size</samp></dt>
+<dd><p>Long branch stubs, PLT call stubs and TOC adjusting stubs are placed
+by <code>ld</code> in stub sections located between groups of input sections.
+&lsquo;<samp>--stub-group-size</samp>&rsquo; specifies the maximum size of a group of input
+sections handled by one stub section. Since branch offsets are signed,
+a stub section may serve two groups of input sections, one group before
+the stub section, and one group after it. However, when using
+conditional branches that require stubs, it may be better (for branch
+prediction) that stub sections only serve one group of input sections.
+A negative value for &lsquo;<samp>N</samp>&rsquo; chooses this scheme, ensuring that
+branches to stubs always use a negative offset. Two special values of
+&lsquo;<samp>N</samp>&rsquo; are recognized, &lsquo;<samp>1</samp>&rsquo; and &lsquo;<samp>-1</samp>&rsquo;. These both instruct
+<code>ld</code> to automatically size input section groups for the branch types
+detected, with the same behaviour regarding stub placement as other
+positive or negative values of &lsquo;<samp>N</samp>&rsquo; respectively.
+</p>
+<p>Note that &lsquo;<samp>--stub-group-size</samp>&rsquo; does not split input sections. A
+single input section larger than the group size specified will of course
+create a larger group (of one section). If input sections are too
+large, it may not be possible for a branch to reach its stub.
+</p>
+<a name="index-PowerPC64-stub-symbols"></a>
+<a name="index-_002d_002demit_002dstub_002dsyms-1"></a>
+</dd>
+<dt><samp>--emit-stub-syms</samp></dt>
+<dd><p>This option causes <code>ld</code> to label linker stubs with a local
+symbol that encodes the stub type and destination.
+</p>
+<a name="index-PowerPC64-dot-symbols"></a>
+<a name="index-_002d_002ddotsyms"></a>
+<a name="index-_002d_002dno_002ddotsyms"></a>
+</dd>
+<dt><samp>--dotsyms</samp></dt>
+<dt><samp>--no-dotsyms</samp></dt>
+<dd><p>These two options control how <code>ld</code> interprets version patterns
+in a version script. Older PowerPC64 compilers emitted both a
+function descriptor symbol with the same name as the function, and a
+code entry symbol with the name prefixed by a dot (&lsquo;<samp>.</samp>&rsquo;). To
+properly version a function &lsquo;<samp>foo</samp>&rsquo;, the version script thus needs
+to control both &lsquo;<samp>foo</samp>&rsquo; and &lsquo;<samp>.foo</samp>&rsquo;. The option
+&lsquo;<samp>--dotsyms</samp>&rsquo;, on by default, automatically adds the required
+dot-prefixed patterns. Use &lsquo;<samp>--no-dotsyms</samp>&rsquo; to disable this
+feature.
+</p>
+<a name="index-PowerPC64-register-save_002frestore-functions"></a>
+<a name="index-_002d_002dsave_002drestore_002dfuncs"></a>
+<a name="index-_002d_002dno_002dsave_002drestore_002dfuncs"></a>
+</dd>
+<dt><samp>--save-restore-funcs</samp></dt>
+<dt><samp>--no-save-restore-funcs</samp></dt>
+<dd><p>These two options control whether PowerPC64 <code>ld</code> automatically
+provides out-of-line register save and restore functions used by
+&lsquo;<samp>-Os</samp>&rsquo; code. The default is to provide any such referenced
+function for a normal final link, and to not do so for a relocatable
+link.
+</p>
+<a name="index-PowerPC64-TLS-optimization"></a>
+<a name="index-_002d_002dno_002dtls_002doptimize-1"></a>
+</dd>
+<dt><samp>--no-tls-optimize</samp></dt>
+<dd><p>PowerPC64 <code>ld</code> normally performs some optimization of code
+sequences used to access Thread-Local Storage. Use this option to
+disable the optimization.
+</p>
+<a name="index-PowerPC64-_005f_005ftls_005fget_005faddr-optimization"></a>
+<a name="index-_002d_002dtls_002dget_002daddr_002doptimize"></a>
+<a name="index-_002d_002dno_002dtls_002dget_002daddr_002doptimize"></a>
+<a name="index-_002d_002dtls_002dget_002daddr_002dregsave"></a>
+<a name="index-_002d_002dno_002dtls_002dget_002daddr_002dregsave"></a>
+</dd>
+<dt><samp>--tls-get-addr-optimize</samp></dt>
+<dt><samp>--no-tls-get-addr-optimize</samp></dt>
+<dd><p>These options control how PowerPC64 <code>ld</code> uses a special
+stub to call __tls_get_addr. PowerPC64 glibc 2.22 and later support
+an optimization that allows the second and subsequent calls to
+<code>__tls_get_addr</code> for a given symbol to be resolved by the special
+stub without calling in to glibc. By default the linker enables
+generation of the stub when glibc advertises the availability of
+__tls_get_addr_opt.
+Using <samp>--tls-get-addr-optimize</samp> with an older glibc won&rsquo;t do
+much besides slow down your applications, but may be useful if linking
+an application against an older glibc with the expectation that it
+will normally be used on systems having a newer glibc.
+<samp>--tls-get-addr-regsave</samp> forces generation of a stub that saves
+and restores volatile registers around the call into glibc. Normally,
+this is done when the linker detects a call to __tls_get_addr_desc.
+Such calls then go via the register saving stub to __tls_get_addr_opt.
+<samp>--no-tls-get-addr-regsave</samp> disables generation of the
+register saves.
+</p>
+<a name="index-PowerPC64-OPD-optimization"></a>
+<a name="index-_002d_002dno_002dopd_002doptimize"></a>
+</dd>
+<dt><samp>--no-opd-optimize</samp></dt>
+<dd><p>PowerPC64 <code>ld</code> normally removes <code>.opd</code> section entries
+corresponding to deleted link-once functions, or functions removed by
+the action of &lsquo;<samp>--gc-sections</samp>&rsquo; or linker script <code>/DISCARD/</code>.
+Use this option to disable <code>.opd</code> optimization.
+</p>
+<a name="index-PowerPC64-OPD-spacing"></a>
+<a name="index-_002d_002dnon_002doverlapping_002dopd"></a>
+</dd>
+<dt><samp>--non-overlapping-opd</samp></dt>
+<dd><p>Some PowerPC64 compilers have an option to generate compressed
+<code>.opd</code> entries spaced 16 bytes apart, overlapping the third word,
+the static chain pointer (unused in C) with the first word of the next
+entry. This option expands such entries to the full 24 bytes.
+</p>
+<a name="index-PowerPC64-TOC-optimization"></a>
+<a name="index-_002d_002dno_002dtoc_002doptimize"></a>
+</dd>
+<dt><samp>--no-toc-optimize</samp></dt>
+<dd><p>PowerPC64 <code>ld</code> normally removes unused <code>.toc</code> section
+entries. Such entries are detected by examining relocations that
+reference the TOC in code sections. A reloc in a deleted code section
+marks a TOC word as unneeded, while a reloc in a kept code section
+marks a TOC word as needed. Since the TOC may reference itself, TOC
+relocs are also examined. TOC words marked as both needed and
+unneeded will of course be kept. TOC words without any referencing
+reloc are assumed to be part of a multi-word entry, and are kept or
+discarded as per the nearest marked preceding word. This works
+reliably for compiler generated code, but may be incorrect if assembly
+code is used to insert TOC entries. Use this option to disable the
+optimization.
+</p>
+<a name="index-PowerPC64-inline-PLT-call-optimization"></a>
+<a name="index-_002d_002dno_002dinline_002doptimize"></a>
+</dd>
+<dt><samp>--no-inline-optimize</samp></dt>
+<dd><p>PowerPC64 <code>ld</code> normally replaces inline PLT call sequences
+marked with <code>R_PPC64_PLTSEQ</code>, <code>R_PPC64_PLTCALL</code>,
+<code>R_PPC64_PLT16_HA</code> and <code>R_PPC64_PLT16_LO_DS</code> relocations by
+a number of <code>nop</code>s and a direct call when the function is defined
+locally and can&rsquo;t be overridden by some other definition. This option
+disables that optimization.
+</p>
+<a name="index-PowerPC64-multi_002dTOC"></a>
+<a name="index-_002d_002dno_002dmulti_002dtoc"></a>
+</dd>
+<dt><samp>--no-multi-toc</samp></dt>
+<dd><p>If given any toc option besides <code>-mcmodel=medium</code> or
+<code>-mcmodel=large</code>, PowerPC64 GCC generates code for a TOC model
+where TOC
+entries are accessed with a 16-bit offset from r2. This limits the
+total TOC size to 64K. PowerPC64 <code>ld</code> extends this limit by
+grouping code sections such that each group uses less than 64K for its
+TOC entries, then inserts r2 adjusting stubs between inter-group
+calls. <code>ld</code> does not split apart input sections, so cannot
+help if a single input file has a <code>.toc</code> section that exceeds
+64K, most likely from linking multiple files with <code>ld -r</code>.
+Use this option to turn off this feature.
+</p>
+<a name="index-PowerPC64-TOC-sorting"></a>
+<a name="index-_002d_002dno_002dtoc_002dsort"></a>
+</dd>
+<dt><samp>--no-toc-sort</samp></dt>
+<dd><p>By default, <code>ld</code> sorts TOC sections so that those whose file
+happens to have a section called <code>.init</code> or <code>.fini</code> are
+placed first, followed by TOC sections referenced by code generated
+with PowerPC64 gcc&rsquo;s <code>-mcmodel=small</code>, and lastly TOC sections
+referenced only by code generated with PowerPC64 gcc&rsquo;s
+<code>-mcmodel=medium</code> or <code>-mcmodel=large</code> options. Doing this
+results in better TOC grouping for multi-TOC. Use this option to turn
+off this feature.
+</p>
+<a name="index-PowerPC64-PLT-stub-alignment"></a>
+<a name="index-_002d_002dplt_002dalign"></a>
+<a name="index-_002d_002dno_002dplt_002dalign"></a>
+</dd>
+<dt><samp>--plt-align</samp></dt>
+<dt><samp>--no-plt-align</samp></dt>
+<dd><p>Use these options to control whether individual PLT call stubs are
+aligned to a 32-byte boundary, or to the specified power of two
+boundary when using <code>--plt-align=</code>. A negative value may be
+specified to pad PLT call stubs so that they do not cross the
+specified power of two boundary (or the minimum number of boundaries
+if a PLT stub is so large that it must cross a boundary). By default
+PLT call stubs are aligned to 32-byte boundaries.
+</p>
+<a name="index-PowerPC64-PLT-call-stub-static-chain"></a>
+<a name="index-_002d_002dplt_002dstatic_002dchain"></a>
+<a name="index-_002d_002dno_002dplt_002dstatic_002dchain"></a>
+</dd>
+<dt><samp>--plt-static-chain</samp></dt>
+<dt><samp>--no-plt-static-chain</samp></dt>
+<dd><p>Use these options to control whether PLT call stubs load the static
+chain pointer (r11). <code>ld</code> defaults to not loading the static
+chain since there is never any need to do so on a PLT call.
+</p>
+<a name="index-PowerPC64-PLT-call-stub-thread-safety"></a>
+<a name="index-_002d_002dplt_002dthread_002dsafe"></a>
+<a name="index-_002d_002dno_002dplt_002dthread_002dsafe"></a>
+</dd>
+<dt><samp>--plt-thread-safe</samp></dt>
+<dt><samp>--no-plt-thread-safe</samp></dt>
+<dd><p>With power7&rsquo;s weakly ordered memory model, it is possible when using
+lazy binding for ld.so to update a plt entry in one thread and have
+another thread see the individual plt entry words update in the wrong
+order, despite ld.so carefully writing in the correct order and using
+memory write barriers. To avoid this we need some sort of read
+barrier in the call stub, or use LD_BIND_NOW=1. By default, <code>ld</code>
+looks for calls to commonly used functions that create threads, and if
+seen, adds the necessary barriers. Use these options to change the
+default behaviour.
+</p>
+<a name="index-PowerPC64-ELFv2-PLT-localentry-optimization"></a>
+<a name="index-_002d_002dplt_002dlocalentry"></a>
+<a name="index-_002d_002dno_002dplt_002dlocalentry"></a>
+</dd>
+<dt><samp>--plt-localentry</samp></dt>
+<dt><samp>--no-localentry</samp></dt>
+<dd><p>ELFv2 functions with localentry:0 are those with a single entry point,
+ie. global entry == local entry, and that have no requirement on r2
+(the TOC/GOT pointer) or r12, and guarantee r2 is unchanged on return.
+Such an external function can be called via the PLT without saving r2
+or restoring it on return, avoiding a common load-hit-store for small
+functions. The optimization is attractive, with up to 40% reduction
+in execution time for a small function, but can result in symbol
+interposition failures. Also, minor changes in a shared library,
+including system libraries, can cause a function that was localentry:0
+to become localentry:8. This will result in a dynamic loader
+complaint and failure to run. The option is experimental, use with
+care. <samp>--no-plt-localentry</samp> is the default.
+</p>
+<a name="index-PowerPC64-Power10-stubs"></a>
+<a name="index-_002d_002dpower10_002dstubs"></a>
+<a name="index-_002d_002dno_002dpower10_002dstubs"></a>
+</dd>
+<dt><samp>--power10-stubs</samp></dt>
+<dt><samp>--no-power10-stubs</samp></dt>
+<dd><p>When PowerPC64 <code>ld</code> links input object files containing
+relocations used on power10 prefixed instructions it normally creates
+linkage stubs (PLT call and long branch) using power10 instructions
+for <code>@notoc</code> PLT calls where <code>r2</code> is not known. The
+power10 notoc stubs are smaller and faster, so are preferred for
+power10. <samp>--power10-stubs</samp> and <samp>--no-power10-stubs</samp>
+allow you to override the linker&rsquo;s selection of stub instructions.
+<samp>--power10-stubs=auto</samp> allows the user to select the default
+auto mode.
+</p></dd>
+</dl>
+
+
+
+<hr>
+<a name="S_002f390-ELF"></a>
+<div class="header">
+<p>
+Next: <a href="#SPU-ELF" accesskey="n" rel="next">SPU ELF</a>, Previous: <a href="#PowerPC64-ELF64" accesskey="p" rel="previous">PowerPC64 ELF64</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-S_002f390-ELF-Support"></a>
+<h3 class="section">5.13 <code>ld</code> and S/390 ELF Support</h3>
+
+<a name="index-S_002f390-ELF-options"></a>
+<dl compact="compact">
+<dd>
+<a name="index-S_002f390"></a>
+<a name="index-_002d_002ds390_002dpgste"></a>
+</dd>
+<dt><samp>--s390-pgste</samp></dt>
+<dd><p>This option marks the result file with a <code>PT_S390_PGSTE</code>
+segment. The Linux kernel is supposed to allocate 4k page tables for
+binaries marked that way.
+</p></dd>
+</dl>
+
+
+
+<hr>
+<a name="SPU-ELF"></a>
+<div class="header">
+<p>
+Next: <a href="#TI-COFF" accesskey="n" rel="next">TI COFF</a>, Previous: <a href="#S_002f390-ELF" accesskey="p" rel="previous">S/390 ELF</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-SPU-ELF-Support"></a>
+<h3 class="section">5.14 <code>ld</code> and SPU ELF Support</h3>
+
+<a name="index-SPU-ELF-options"></a>
+<dl compact="compact">
+<dd>
+<a name="index-SPU-plugins"></a>
+<a name="index-_002d_002dplugin"></a>
+</dd>
+<dt><samp>--plugin</samp></dt>
+<dd><p>This option marks an executable as a PIC plugin module.
+</p>
+<a name="index-SPU-overlays"></a>
+<a name="index-_002d_002dno_002doverlays"></a>
+</dd>
+<dt><samp>--no-overlays</samp></dt>
+<dd><p>Normally, <code>ld</code> recognizes calls to functions within overlay
+regions, and redirects such calls to an overlay manager via a stub.
+<code>ld</code> also provides a built-in overlay manager. This option
+turns off all this special overlay handling.
+</p>
+<a name="index-SPU-overlay-stub-symbols"></a>
+<a name="index-_002d_002demit_002dstub_002dsyms-2"></a>
+</dd>
+<dt><samp>--emit-stub-syms</samp></dt>
+<dd><p>This option causes <code>ld</code> to label overlay stubs with a local
+symbol that encodes the stub type and destination.
+</p>
+<a name="index-SPU-extra-overlay-stubs"></a>
+<a name="index-_002d_002dextra_002doverlay_002dstubs"></a>
+</dd>
+<dt><samp>--extra-overlay-stubs</samp></dt>
+<dd><p>This option causes <code>ld</code> to add overlay call stubs on all
+function calls out of overlay regions. Normally stubs are not added
+on calls to non-overlay regions.
+</p>
+<a name="index-SPU-local-store-size"></a>
+<a name="index-_002d_002dlocal_002dstore_003dlo_003ahi"></a>
+</dd>
+<dt><samp>--local-store=lo:hi</samp></dt>
+<dd><p><code>ld</code> usually checks that a final executable for SPU fits in
+the address range 0 to 256k. This option may be used to change the
+range. Disable the check entirely with <samp>--local-store=0:0</samp>.
+</p>
+<a name="index-SPU"></a>
+<a name="index-_002d_002dstack_002danalysis"></a>
+</dd>
+<dt><samp>--stack-analysis</samp></dt>
+<dd><p>SPU local store space is limited. Over-allocation of stack space
+unnecessarily limits space available for code and data, while
+under-allocation results in runtime failures. If given this option,
+<code>ld</code> will provide an estimate of maximum stack usage.
+<code>ld</code> does this by examining symbols in code sections to
+determine the extents of functions, and looking at function prologues
+for stack adjusting instructions. A call-graph is created by looking
+for relocations on branch instructions. The graph is then searched
+for the maximum stack usage path. Note that this analysis does not
+find calls made via function pointers, and does not handle recursion
+and other cycles in the call graph. Stack usage may be
+under-estimated if your code makes such calls. Also, stack usage for
+dynamic allocation, e.g. alloca, will not be detected. If a link map
+is requested, detailed information about each function&rsquo;s stack usage
+and calls will be given.
+</p>
+<a name="index-SPU-1"></a>
+<a name="index-_002d_002demit_002dstack_002dsyms"></a>
+</dd>
+<dt><samp>--emit-stack-syms</samp></dt>
+<dd><p>This option, if given along with <samp>--stack-analysis</samp> will result
+in <code>ld</code> emitting stack sizing symbols for each function.
+These take the form <code>__stack_&lt;function_name&gt;</code> for global
+functions, and <code>__stack_&lt;number&gt;_&lt;function_name&gt;</code> for static
+functions. <code>&lt;number&gt;</code> is the section id in hex. The value of
+such symbols is the stack requirement for the corresponding function.
+The symbol size will be zero, type <code>STT_NOTYPE</code>, binding
+<code>STB_LOCAL</code>, and section <code>SHN_ABS</code>.
+</p></dd>
+</dl>
+
+
+
+<hr>
+<a name="TI-COFF"></a>
+<div class="header">
+<p>
+Next: <a href="#WIN32" accesskey="n" rel="next">WIN32</a>, Previous: <a href="#SPU-ELF" accesskey="p" rel="previous">SPU ELF</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld_0027s-Support-for-Various-TI-COFF-Versions"></a>
+<h3 class="section">5.15 <code>ld</code>&rsquo;s Support for Various TI COFF Versions</h3>
+<a name="index-TI-COFF-versions"></a>
+<a name="index-_002d_002dformat_003dversion"></a>
+<p>The &lsquo;<samp>--format</samp>&rsquo; switch allows selection of one of the various
+TI COFF versions. The latest of this writing is 2; versions 0 and 1 are
+also supported. The TI COFF versions also vary in header byte-order
+format; <code>ld</code> will read any version or byte order, but the output
+header format depends on the default specified by the specific target.
+</p>
+
+
+<hr>
+<a name="WIN32"></a>
+<div class="header">
+<p>
+Next: <a href="#Xtensa" accesskey="n" rel="next">Xtensa</a>, Previous: <a href="#TI-COFF" accesskey="p" rel="previous">TI COFF</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-WIN32-_0028cygwin_002fmingw_0029"></a>
+<h3 class="section">5.16 <code>ld</code> and WIN32 (cygwin/mingw)</h3>
+
+<p>This section describes some of the win32 specific <code>ld</code> issues.
+See <a href="#Options">Command-line Options</a> for detailed description of the
+command-line options mentioned here.
+</p>
+<dl compact="compact">
+<dd><a name="index-import-libraries"></a>
+</dd>
+<dt><em>import libraries</em></dt>
+<dd><p>The standard Windows linker creates and uses so-called import
+libraries, which contains information for linking to dll&rsquo;s. They are
+regular static archives and are handled as any other static
+archive. The cygwin and mingw ports of <code>ld</code> have specific
+support for creating such libraries provided with the
+&lsquo;<samp>--out-implib</samp>&rsquo; command-line option.
+</p>
+</dd>
+<dt><em>Resource only DLLs</em></dt>
+<dd><p>It is possible to create a DLL that only contains resources, ie just a
+&lsquo;<samp>.rsrc</samp>&rsquo; section, but in order to do so a custom linker script
+must be used. This is because the built-in default linker scripts
+will always create &lsquo;<samp>.text</samp>&rsquo; and &lsquo;<samp>.idata</samp>&rsquo; sections, even if
+there is no input to go into them.
+</p>
+<p>The script should look like this, although the <code>OUTPUT_FORMAT</code>
+should be changed to match the desired format.
+</p>
+<div class="example">
+<pre class="example">OUTPUT_FORMAT(pei-i386)
+SECTIONS
+{
+ . = SIZEOF_HEADERS;
+ . = ALIGN(__section_alignment__);
+ .rsrc __image_base__ + __section_alignment__ : ALIGN(4)
+ {
+ KEEP (*(.rsrc))
+ KEEP (*(.rsrc$*))
+ }
+ /DISCARD/ : { *(*) }
+}
+</pre></div>
+
+<p>With this script saved to a file called, eg <samp>rsrc.ld</samp>, a command
+line like this can be used to create the resource only DLL
+<samp>rsrc.dll</samp> from an input file called <samp>rsrc.o</samp>:
+</p>
+<div class="smallexample">
+<pre class="smallexample">ld -dll --subsystem windows -e 0 -s rsrc.o -o rsrc.dll -T rsrc.ld
+</pre></div>
+
+</dd>
+<dt><em>exporting DLL symbols</em></dt>
+<dd><a name="index-exporting-DLL-symbols"></a>
+<p>The cygwin/mingw <code>ld</code> has several ways to export symbols for dll&rsquo;s.
+</p>
+<dl compact="compact">
+<dt><em>using auto-export functionality</em></dt>
+<dd><a name="index-using-auto_002dexport-functionality"></a>
+<p>By default <code>ld</code> exports symbols with the auto-export functionality,
+which is controlled by the following command-line options:
+</p>
+<ul>
+<li> &ndash;export-all-symbols [This is the default]
+</li><li> &ndash;exclude-symbols
+</li><li> &ndash;exclude-libs
+</li><li> &ndash;exclude-modules-for-implib
+</li><li> &ndash;version-script
+</li></ul>
+
+<p>When auto-export is in operation, <code>ld</code> will export all the non-local
+(global and common) symbols it finds in a DLL, with the exception of a few
+symbols known to belong to the system&rsquo;s runtime and libraries. As it will
+often not be desirable to export all of a DLL&rsquo;s symbols, which may include
+private functions that are not part of any public interface, the command-line
+options listed above may be used to filter symbols out from the list for
+exporting. The &lsquo;<samp>--output-def</samp>&rsquo; option can be used in order to see the
+final list of exported symbols with all exclusions taken into effect.
+</p>
+<p>If &lsquo;<samp>--export-all-symbols</samp>&rsquo; is not given explicitly on the
+command line, then the default auto-export behavior will be <em>disabled</em>
+if either of the following are true:
+</p>
+<ul>
+<li> A DEF file is used.
+</li><li> Any symbol in any object file was marked with the __declspec(dllexport) attribute.
+</li></ul>
+
+</dd>
+<dt><em>using a DEF file</em></dt>
+<dd><a name="index-using-a-DEF-file"></a>
+<p>Another way of exporting symbols is using a DEF file. A DEF file is
+an ASCII file containing definitions of symbols which should be
+exported when a dll is created. Usually it is named &lsquo;<samp>&lt;dll
+name&gt;.def</samp>&rsquo; and is added as any other object file to the linker&rsquo;s
+command line. The file&rsquo;s name must end in &lsquo;<samp>.def</samp>&rsquo; or &lsquo;<samp>.DEF</samp>&rsquo;.
+</p>
+<div class="example">
+<pre class="example">gcc -o &lt;output&gt; &lt;objectfiles&gt; &lt;dll name&gt;.def
+</pre></div>
+
+<p>Using a DEF file turns off the normal auto-export behavior, unless the
+&lsquo;<samp>--export-all-symbols</samp>&rsquo; option is also used.
+</p>
+<p>Here is an example of a DEF file for a shared library called &lsquo;<samp>xyz.dll</samp>&rsquo;:
+</p>
+<div class="example">
+<pre class="example">LIBRARY &quot;xyz.dll&quot; BASE=0x20000000
+
+EXPORTS
+foo
+bar
+_bar = bar
+another_foo = abc.dll.afoo
+var1 DATA
+doo = foo == foo2
+eoo DATA == var1
+</pre></div>
+
+<p>This example defines a DLL with a non-default base address and seven
+symbols in the export table. The third exported symbol <code>_bar</code> is an
+alias for the second. The fourth symbol, <code>another_foo</code> is resolved
+by &quot;forwarding&quot; to another module and treating it as an alias for
+<code>afoo</code> exported from the DLL &lsquo;<samp>abc.dll</samp>&rsquo;. The final symbol
+<code>var1</code> is declared to be a data object. The &lsquo;<samp>doo</samp>&rsquo; symbol in
+export library is an alias of &lsquo;<samp>foo</samp>&rsquo;, which gets the string name
+in export table &lsquo;<samp>foo2</samp>&rsquo;. The &lsquo;<samp>eoo</samp>&rsquo; symbol is an data export
+symbol, which gets in export table the name &lsquo;<samp>var1</samp>&rsquo;.
+</p>
+<p>The optional <code>LIBRARY &lt;name&gt;</code> command indicates the <em>internal</em>
+name of the output DLL. If &lsquo;<samp>&lt;name&gt;</samp>&rsquo; does not include a suffix,
+the default library suffix, &lsquo;<samp>.DLL</samp>&rsquo; is appended.
+</p>
+<p>When the .DEF file is used to build an application, rather than a
+library, the <code>NAME &lt;name&gt;</code> command should be used instead of
+<code>LIBRARY</code>. If &lsquo;<samp>&lt;name&gt;</samp>&rsquo; does not include a suffix, the default
+executable suffix, &lsquo;<samp>.EXE</samp>&rsquo; is appended.
+</p>
+<p>With either <code>LIBRARY &lt;name&gt;</code> or <code>NAME &lt;name&gt;</code> the optional
+specification <code>BASE = &lt;number&gt;</code> may be used to specify a
+non-default base address for the image.
+</p>
+<p>If neither <code>LIBRARY &lt;name&gt;</code> nor <code>NAME &lt;name&gt;</code> is specified,
+or they specify an empty string, the internal name is the same as the
+filename specified on the command line.
+</p>
+<p>The complete specification of an export symbol is:
+</p>
+<div class="example">
+<pre class="example">EXPORTS
+ ( ( ( &lt;name1&gt; [ = &lt;name2&gt; ] )
+ | ( &lt;name1&gt; = &lt;module-name&gt; . &lt;external-name&gt;))
+ [ @ &lt;integer&gt; ] [NONAME] [DATA] [CONSTANT] [PRIVATE] [== &lt;name3&gt;] ) *
+</pre></div>
+
+<p>Declares &lsquo;<samp>&lt;name1&gt;</samp>&rsquo; as an exported symbol from the DLL, or declares
+&lsquo;<samp>&lt;name1&gt;</samp>&rsquo; as an exported alias for &lsquo;<samp>&lt;name2&gt;</samp>&rsquo;; or declares
+&lsquo;<samp>&lt;name1&gt;</samp>&rsquo; as a &quot;forward&quot; alias for the symbol
+&lsquo;<samp>&lt;external-name&gt;</samp>&rsquo; in the DLL &lsquo;<samp>&lt;module-name&gt;</samp>&rsquo;.
+Optionally, the symbol may be exported by the specified ordinal
+&lsquo;<samp>&lt;integer&gt;</samp>&rsquo; alias. The optional &lsquo;<samp>&lt;name3&gt;</samp>&rsquo; is the to be used
+string in import/export table for the symbol.
+</p>
+<p>The optional keywords that follow the declaration indicate:
+</p>
+<p><code>NONAME</code>: Do not put the symbol name in the DLL&rsquo;s export table. It
+will still be exported by its ordinal alias (either the value specified
+by the .def specification or, otherwise, the value assigned by the
+linker). The symbol name, however, does remain visible in the import
+library (if any), unless <code>PRIVATE</code> is also specified.
+</p>
+<p><code>DATA</code>: The symbol is a variable or object, rather than a function.
+The import lib will export only an indirect reference to <code>foo</code> as
+the symbol <code>_imp__foo</code> (ie, <code>foo</code> must be resolved as
+<code>*_imp__foo</code>).
+</p>
+<p><code>CONSTANT</code>: Like <code>DATA</code>, but put the undecorated <code>foo</code> as
+well as <code>_imp__foo</code> into the import library. Both refer to the
+read-only import address table&rsquo;s pointer to the variable, not to the
+variable itself. This can be dangerous. If the user code fails to add
+the <code>dllimport</code> attribute and also fails to explicitly add the
+extra indirection that the use of the attribute enforces, the
+application will behave unexpectedly.
+</p>
+<p><code>PRIVATE</code>: Put the symbol in the DLL&rsquo;s export table, but do not put
+it into the static import library used to resolve imports at link time. The
+symbol can still be imported using the <code>LoadLibrary/GetProcAddress</code>
+API at runtime or by using the GNU ld extension of linking directly to
+the DLL without an import library.
+</p>
+<p>See ld/deffilep.y in the binutils sources for the full specification of
+other DEF file statements
+</p>
+<a name="index-creating-a-DEF-file"></a>
+<p>While linking a shared dll, <code>ld</code> is able to create a DEF file
+with the &lsquo;<samp>--output-def &lt;file&gt;</samp>&rsquo; command-line option.
+</p>
+</dd>
+<dt><em>Using decorations</em></dt>
+<dd><a name="index-Using-decorations"></a>
+<p>Another way of marking symbols for export is to modify the source code
+itself, so that when building the DLL each symbol to be exported is
+declared as:
+</p>
+<div class="example">
+<pre class="example">__declspec(dllexport) int a_variable
+__declspec(dllexport) void a_function(int with_args)
+</pre></div>
+
+<p>All such symbols will be exported from the DLL. If, however,
+any of the object files in the DLL contain symbols decorated in
+this way, then the normal auto-export behavior is disabled, unless
+the &lsquo;<samp>--export-all-symbols</samp>&rsquo; option is also used.
+</p>
+<p>Note that object files that wish to access these symbols must <em>not</em>
+decorate them with dllexport. Instead, they should use dllimport,
+instead:
+</p>
+<div class="example">
+<pre class="example">__declspec(dllimport) int a_variable
+__declspec(dllimport) void a_function(int with_args)
+</pre></div>
+
+<p>This complicates the structure of library header files, because
+when included by the library itself the header must declare the
+variables and functions as dllexport, but when included by client
+code the header must declare them as dllimport. There are a number
+of idioms that are typically used to do this; often client code can
+omit the __declspec() declaration completely. See
+&lsquo;<samp>--enable-auto-import</samp>&rsquo; and &lsquo;<samp>automatic data imports</samp>&rsquo; for more
+information.
+</p></dd>
+</dl>
+
+<a name="index-automatic-data-imports"></a>
+</dd>
+<dt><em>automatic data imports</em></dt>
+<dd><p>The standard Windows dll format supports data imports from dlls only
+by adding special decorations (dllimport/dllexport), which let the
+compiler produce specific assembler instructions to deal with this
+issue. This increases the effort necessary to port existing Un*x
+code to these platforms, especially for large
+c++ libraries and applications. The auto-import feature, which was
+initially provided by Paul Sokolovsky, allows one to omit the
+decorations to achieve a behavior that conforms to that on POSIX/Un*x
+platforms. This feature is enabled with the &lsquo;<samp>--enable-auto-import</samp>&rsquo;
+command-line option, although it is enabled by default on cygwin/mingw.
+The &lsquo;<samp>--enable-auto-import</samp>&rsquo; option itself now serves mainly to
+suppress any warnings that are ordinarily emitted when linked objects
+trigger the feature&rsquo;s use.
+</p>
+<p>auto-import of variables does not always work flawlessly without
+additional assistance. Sometimes, you will see this message
+</p>
+<p>&quot;variable &rsquo;&lt;var&gt;&rsquo; can&rsquo;t be auto-imported. Please read the
+documentation for ld&rsquo;s <code>--enable-auto-import</code> for details.&quot;
+</p>
+<p>The &lsquo;<samp>--enable-auto-import</samp>&rsquo; documentation explains why this error
+occurs, and several methods that can be used to overcome this difficulty.
+One of these methods is the <em>runtime pseudo-relocs</em> feature, described
+below.
+</p>
+<a name="index-runtime-pseudo_002drelocation"></a>
+<p>For complex variables imported from DLLs (such as structs or classes),
+object files typically contain a base address for the variable and an
+offset (<em>addend</em>) within the variable&ndash;to specify a particular
+field or public member, for instance. Unfortunately, the runtime loader used
+in win32 environments is incapable of fixing these references at runtime
+without the additional information supplied by dllimport/dllexport decorations.
+The standard auto-import feature described above is unable to resolve these
+references.
+</p>
+<p>The &lsquo;<samp>--enable-runtime-pseudo-relocs</samp>&rsquo; switch allows these references to
+be resolved without error, while leaving the task of adjusting the references
+themselves (with their non-zero addends) to specialized code provided by the
+runtime environment. Recent versions of the cygwin and mingw environments and
+compilers provide this runtime support; older versions do not. However, the
+support is only necessary on the developer&rsquo;s platform; the compiled result will
+run without error on an older system.
+</p>
+<p>&lsquo;<samp>--enable-runtime-pseudo-relocs</samp>&rsquo; is not the default; it must be explicitly
+enabled as needed.
+</p>
+<a name="index-direct-linking-to-a-dll"></a>
+</dd>
+<dt><em>direct linking to a dll</em></dt>
+<dd><p>The cygwin/mingw ports of <code>ld</code> support the direct linking,
+including data symbols, to a dll without the usage of any import
+libraries. This is much faster and uses much less memory than does the
+traditional import library method, especially when linking large
+libraries or applications. When <code>ld</code> creates an import lib, each
+function or variable exported from the dll is stored in its own bfd, even
+though a single bfd could contain many exports. The overhead involved in
+storing, loading, and processing so many bfd&rsquo;s is quite large, and explains the
+tremendous time, memory, and storage needed to link against particularly
+large or complex libraries when using import libs.
+</p>
+<p>Linking directly to a dll uses no extra command-line switches other than
+&lsquo;<samp>-L</samp>&rsquo; and &lsquo;<samp>-l</samp>&rsquo;, because <code>ld</code> already searches for a number
+of names to match each library. All that is needed from the developer&rsquo;s
+perspective is an understanding of this search, in order to force ld to
+select the dll instead of an import library.
+</p>
+
+<p>For instance, when ld is called with the argument &lsquo;<samp>-lxxx</samp>&rsquo; it will attempt
+to find, in the first directory of its search path,
+</p>
+<div class="example">
+<pre class="example">libxxx.dll.a
+xxx.dll.a
+libxxx.a
+xxx.lib
+libxxx.lib
+cygxxx.dll (*)
+libxxx.dll
+xxx.dll
+</pre></div>
+
+<p>before moving on to the next directory in the search path.
+</p>
+<p>(*) Actually, this is not &lsquo;<samp>cygxxx.dll</samp>&rsquo; but in fact is &lsquo;<samp>&lt;prefix&gt;xxx.dll</samp>&rsquo;,
+where &lsquo;<samp>&lt;prefix&gt;</samp>&rsquo; is set by the <code>ld</code> option
+&lsquo;<samp>--dll-search-prefix=&lt;prefix&gt;</samp>&rsquo;. In the case of cygwin, the standard gcc spec
+file includes &lsquo;<samp>--dll-search-prefix=cyg</samp>&rsquo;, so in effect we actually search for
+&lsquo;<samp>cygxxx.dll</samp>&rsquo;.
+</p>
+<p>Other win32-based unix environments, such as mingw or pw32, may use other
+&lsquo;<samp>&lt;prefix&gt;</samp>&rsquo;es, although at present only cygwin makes use of this feature. It
+was originally intended to help avoid name conflicts among dll&rsquo;s built for the
+various win32/un*x environments, so that (for example) two versions of a zlib dll
+could coexist on the same machine.
+</p>
+<p>The generic cygwin/mingw path layout uses a &lsquo;<samp>bin</samp>&rsquo; directory for
+applications and dll&rsquo;s and a &lsquo;<samp>lib</samp>&rsquo; directory for the import
+libraries (using cygwin nomenclature):
+</p>
+<div class="example">
+<pre class="example">bin/
+ cygxxx.dll
+lib/
+ libxxx.dll.a (in case of dll's)
+ libxxx.a (in case of static archive)
+</pre></div>
+
+<p>Linking directly to a dll without using the import library can be
+done two ways:
+</p>
+<p>1. Use the dll directly by adding the &lsquo;<samp>bin</samp>&rsquo; path to the link line
+</p><div class="example">
+<pre class="example">gcc -Wl,-verbose -o a.exe -L../bin/ -lxxx
+</pre></div>
+
+<p>However, as the dll&rsquo;s often have version numbers appended to their names
+(&lsquo;<samp>cygncurses-5.dll</samp>&rsquo;) this will often fail, unless one specifies
+&lsquo;<samp>-L../bin -lncurses-5</samp>&rsquo; to include the version. Import libs are generally
+not versioned, and do not have this difficulty.
+</p>
+<p>2. Create a symbolic link from the dll to a file in the &lsquo;<samp>lib</samp>&rsquo;
+directory according to the above mentioned search pattern. This
+should be used to avoid unwanted changes in the tools needed for
+making the app/dll.
+</p>
+<div class="example">
+<pre class="example">ln -s bin/cygxxx.dll lib/[cyg|lib|]xxx.dll[.a]
+</pre></div>
+
+<p>Then you can link without any make environment changes.
+</p>
+<div class="example">
+<pre class="example">gcc -Wl,-verbose -o a.exe -L../lib/ -lxxx
+</pre></div>
+
+<p>This technique also avoids the version number problems, because the following is
+perfectly legal
+</p>
+<div class="example">
+<pre class="example">bin/
+ cygxxx-5.dll
+lib/
+ libxxx.dll.a -&gt; ../bin/cygxxx-5.dll
+</pre></div>
+
+<p>Linking directly to a dll without using an import lib will work
+even when auto-import features are exercised, and even when
+&lsquo;<samp>--enable-runtime-pseudo-relocs</samp>&rsquo; is used.
+</p>
+<p>Given the improvements in speed and memory usage, one might justifiably
+wonder why import libraries are used at all. There are three reasons:
+</p>
+<p>1. Until recently, the link-directly-to-dll functionality did <em>not</em>
+work with auto-imported data.
+</p>
+<p>2. Sometimes it is necessary to include pure static objects within the
+import library (which otherwise contains only bfd&rsquo;s for indirection
+symbols that point to the exports of a dll). Again, the import lib
+for the cygwin kernel makes use of this ability, and it is not
+possible to do this without an import lib.
+</p>
+<p>3. Symbol aliases can only be resolved using an import lib. This is
+critical when linking against OS-supplied dll&rsquo;s (eg, the win32 API)
+in which symbols are usually exported as undecorated aliases of their
+stdcall-decorated assembly names.
+</p>
+<p>So, import libs are not going away. But the ability to replace
+true import libs with a simple symbolic link to (or a copy of)
+a dll, in many cases, is a useful addition to the suite of tools
+binutils makes available to the win32 developer. Given the
+massive improvements in memory requirements during linking, storage
+requirements, and linking speed, we expect that many developers
+will soon begin to use this feature whenever possible.
+</p>
+</dd>
+<dt><em>symbol aliasing</em></dt>
+<dd><dl compact="compact">
+<dt><em>adding additional names</em></dt>
+<dd><p>Sometimes, it is useful to export symbols with additional names.
+A symbol &lsquo;<samp>foo</samp>&rsquo; will be exported as &lsquo;<samp>foo</samp>&rsquo;, but it can also be
+exported as &lsquo;<samp>_foo</samp>&rsquo; by using special directives in the DEF file
+when creating the dll. This will affect also the optional created
+import library. Consider the following DEF file:
+</p>
+<div class="example">
+<pre class="example">LIBRARY &quot;xyz.dll&quot; BASE=0x61000000
+
+EXPORTS
+foo
+_foo = foo
+</pre></div>
+
+<p>The line &lsquo;<samp>_foo = foo</samp>&rsquo; maps the symbol &lsquo;<samp>foo</samp>&rsquo; to &lsquo;<samp>_foo</samp>&rsquo;.
+</p>
+<p>Another method for creating a symbol alias is to create it in the
+source code using the &quot;weak&quot; attribute:
+</p>
+<div class="example">
+<pre class="example">void foo () { /* Do something. */; }
+void _foo () __attribute__ ((weak, alias (&quot;foo&quot;)));
+</pre></div>
+
+<p>See the gcc manual for more information about attributes and weak
+symbols.
+</p>
+</dd>
+<dt><em>renaming symbols</em></dt>
+<dd><p>Sometimes it is useful to rename exports. For instance, the cygwin
+kernel does this regularly. A symbol &lsquo;<samp>_foo</samp>&rsquo; can be exported as
+&lsquo;<samp>foo</samp>&rsquo; but not as &lsquo;<samp>_foo</samp>&rsquo; by using special directives in the
+DEF file. (This will also affect the import library, if it is
+created). In the following example:
+</p>
+<div class="example">
+<pre class="example">LIBRARY &quot;xyz.dll&quot; BASE=0x61000000
+
+EXPORTS
+_foo = foo
+</pre></div>
+
+<p>The line &lsquo;<samp>_foo = foo</samp>&rsquo; maps the exported symbol &lsquo;<samp>foo</samp>&rsquo; to
+&lsquo;<samp>_foo</samp>&rsquo;.
+</p></dd>
+</dl>
+
+<p>Note: using a DEF file disables the default auto-export behavior,
+unless the &lsquo;<samp>--export-all-symbols</samp>&rsquo; command-line option is used.
+If, however, you are trying to rename symbols, then you should list
+<em>all</em> desired exports in the DEF file, including the symbols
+that are not being renamed, and do <em>not</em> use the
+&lsquo;<samp>--export-all-symbols</samp>&rsquo; option. If you list only the
+renamed symbols in the DEF file, and use &lsquo;<samp>--export-all-symbols</samp>&rsquo;
+to handle the other symbols, then the both the new names <em>and</em>
+the original names for the renamed symbols will be exported.
+In effect, you&rsquo;d be aliasing those symbols, not renaming them,
+which is probably not what you wanted.
+</p>
+<a name="index-weak-externals"></a>
+</dd>
+<dt><em>weak externals</em></dt>
+<dd><p>The Windows object format, PE, specifies a form of weak symbols called
+weak externals. When a weak symbol is linked and the symbol is not
+defined, the weak symbol becomes an alias for some other symbol. There
+are three variants of weak externals:
+</p><ul>
+<li> Definition is searched for in objects and libraries, historically
+called lazy externals.
+</li><li> Definition is searched for only in other objects, not in libraries.
+This form is not presently implemented.
+</li><li> No search; the symbol is an alias. This form is not presently
+implemented.
+</li></ul>
+<p>As a GNU extension, weak symbols that do not specify an alternate symbol
+are supported. If the symbol is undefined when linking, the symbol
+uses a default value.
+</p>
+<a name="index-aligned-common-symbols"></a>
+</dd>
+<dt><em>aligned common symbols</em></dt>
+<dd><p>As a GNU extension to the PE file format, it is possible to specify the
+desired alignment for a common symbol. This information is conveyed from
+the assembler or compiler to the linker by means of GNU-specific commands
+carried in the object file&rsquo;s &lsquo;<samp>.drectve</samp>&rsquo; section, which are recognized
+by <code>ld</code> and respected when laying out the common symbols. Native
+tools will be able to process object files employing this GNU extension,
+but will fail to respect the alignment instructions, and may issue noisy
+warnings about unknown linker directives.
+</p>
+</dd>
+</dl>
+
+
+
+<hr>
+<a name="Xtensa"></a>
+<div class="header">
+<p>
+Previous: <a href="#WIN32" accesskey="p" rel="previous">WIN32</a>, Up: <a href="#Machine-Dependent" accesskey="u" rel="up">Machine Dependent</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="ld-and-Xtensa-Processors"></a>
+<h3 class="section">5.17 <code>ld</code> and Xtensa Processors</h3>
+
+<a name="index-Xtensa-processors"></a>
+<p>The default <code>ld</code> behavior for Xtensa processors is to interpret
+<code>SECTIONS</code> commands so that lists of explicitly named sections in a
+specification with a wildcard file will be interleaved when necessary to
+keep literal pools within the range of PC-relative load offsets. For
+example, with the command:
+</p>
+<div class="smallexample">
+<pre class="smallexample">SECTIONS
+{
+ .text : {
+ *(.literal .text)
+ }
+}
+</pre></div>
+
+<p><code>ld</code> may interleave some of the <code>.literal</code>
+and <code>.text</code> sections from different object files to ensure that the
+literal pools are within the range of PC-relative load offsets. A valid
+interleaving might place the <code>.literal</code> sections from an initial
+group of files followed by the <code>.text</code> sections of that group of
+files. Then, the <code>.literal</code> sections from the rest of the files
+and the <code>.text</code> sections from the rest of the files would follow.
+</p>
+<a name="index-_002d_002drelax-on-Xtensa"></a>
+<a name="index-relaxing-on-Xtensa"></a>
+<p>Relaxation is enabled by default for the Xtensa version of <code>ld</code> and
+provides two important link-time optimizations. The first optimization
+is to combine identical literal values to reduce code size. A redundant
+literal will be removed and all the <code>L32R</code> instructions that use it
+will be changed to reference an identical literal, as long as the
+location of the replacement literal is within the offset range of all
+the <code>L32R</code> instructions. The second optimization is to remove
+unnecessary overhead from assembler-generated &ldquo;longcall&rdquo; sequences of
+<code>L32R</code>/<code>CALLX<var>n</var></code> when the target functions are within
+range of direct <code>CALL<var>n</var></code> instructions.
+</p>
+<p>For each of these cases where an indirect call sequence can be optimized
+to a direct call, the linker will change the <code>CALLX<var>n</var></code>
+instruction to a <code>CALL<var>n</var></code> instruction, remove the <code>L32R</code>
+instruction, and remove the literal referenced by the <code>L32R</code>
+instruction if it is not used for anything else. Removing the
+<code>L32R</code> instruction always reduces code size but can potentially
+hurt performance by changing the alignment of subsequent branch targets.
+By default, the linker will always preserve alignments, either by
+switching some instructions between 24-bit encodings and the equivalent
+density instructions or by inserting a no-op in place of the <code>L32R</code>
+instruction that was removed. If code size is more important than
+performance, the <samp>--size-opt</samp> option can be used to prevent the
+linker from widening density instructions or inserting no-ops, except in
+a few cases where no-ops are required for correctness.
+</p>
+<p>The following Xtensa-specific command-line options can be used to
+control the linker:
+</p>
+<a name="index-Xtensa-options"></a>
+<dl compact="compact">
+<dt><samp>--size-opt</samp></dt>
+<dd><p>When optimizing indirect calls to direct calls, optimize for code size
+more than performance. With this option, the linker will not insert
+no-ops or widen density instructions to preserve branch target
+alignment. There may still be some cases where no-ops are required to
+preserve the correctness of the code.
+</p>
+</dd>
+<dt><samp>--abi-windowed</samp></dt>
+<dt><samp>--abi-call0</samp></dt>
+<dd><p>Choose ABI for the output object and for the generated PLT code.
+PLT code inserted by the linker must match ABI of the output object
+because windowed and call0 ABI use incompatible function call
+conventions.
+Default ABI is chosen by the ABI tag in the <code>.xtensa.info</code> section
+of the first input object.
+A warning is issued if ABI tags of input objects do not match each other
+or the chosen output object ABI.
+</p></dd>
+</dl>
+
+
+<hr>
+<a name="BFD"></a>
+<div class="header">
+<p>
+Next: <a href="#Reporting-Bugs" accesskey="n" rel="next">Reporting Bugs</a>, Previous: <a href="#Machine-Dependent" accesskey="p" rel="previous">Machine Dependent</a>, Up: <a href="#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="BFD-1"></a>
+<h2 class="chapter">6 BFD</h2>
+
+<a name="index-back-end"></a>
+<a name="index-object-file-management"></a>
+<a name="index-object-formats-available"></a>
+<a name="index-objdump-_002di"></a>
+<p>The linker accesses object and archive files using the BFD libraries.
+These libraries allow the linker to use the same routines to operate on
+object files whatever the object file format. A different object file
+format can be supported simply by creating a new BFD back end and adding
+it to the library. To conserve runtime memory, however, the linker and
+associated tools are usually configured to support only a subset of the
+object file formats available. You can use <code>objdump -i</code>
+(see <a href="http://sourceware.org/binutils/docs/binutils/objdump.html#objdump">objdump</a> in <cite>The GNU Binary Utilities</cite>) to
+list all the formats available for your configuration.
+</p>
+<a name="index-BFD-requirements"></a>
+<a name="index-requirements-for-BFD"></a>
+<p>As with most implementations, BFD is a compromise between
+several conflicting requirements. The major factor influencing
+BFD design was efficiency: any time used converting between
+formats is time which would not have been spent had BFD not
+been involved. This is partly offset by abstraction payback; since
+BFD simplifies applications and back ends, more time and care
+may be spent optimizing algorithms for a greater speed.
+</p>
+<p>One minor artifact of the BFD solution which you should bear in
+mind is the potential for information loss. There are two places where
+useful information can be lost using the BFD mechanism: during
+conversion and during output. See <a href="#BFD-information-loss">BFD information loss</a>.
+</p>
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#BFD-outline" accesskey="1">BFD outline</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">How it works: an outline of BFD
+</td></tr>
+</table>
+
+<hr>
+<a name="BFD-outline"></a>
+<div class="header">
+<p>
+Up: <a href="#BFD" accesskey="u" rel="up">BFD</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="How-It-Works_003a-An-Outline-of-BFD"></a>
+<h3 class="section">6.1 How It Works: An Outline of BFD</h3>
+<a name="index-opening-object-files"></a>
+
+<p>When an object file is opened, BFD subroutines automatically determine
+the format of the input object file. They then build a descriptor in
+memory with pointers to routines that will be used to access elements of
+the object file&rsquo;s data structures.
+</p>
+<p>As different information from the object files is required,
+BFD reads from different sections of the file and processes them.
+For example, a very common operation for the linker is processing symbol
+tables. Each BFD back end provides a routine for converting
+between the object file&rsquo;s representation of symbols and an internal
+canonical format. When the linker asks for the symbol table of an object
+file, it calls through a memory pointer to the routine from the
+relevant BFD back end which reads and converts the table into a canonical
+form. The linker then operates upon the canonical form. When the link is
+finished and the linker writes the output file&rsquo;s symbol table,
+another BFD back end routine is called to take the newly
+created symbol table and convert it into the chosen output format.
+</p>
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#BFD-information-loss" accesskey="1">BFD information loss</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Information Loss
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Canonical-format" accesskey="2">Canonical format</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">The BFD canonical object-file format
+</td></tr>
+</table>
+
+<hr>
+<a name="BFD-information-loss"></a>
+<div class="header">
+<p>
+Next: <a href="#Canonical-format" accesskey="n" rel="next">Canonical format</a>, Up: <a href="#BFD-outline" accesskey="u" rel="up">BFD outline</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Information-Loss"></a>
+<h4 class="subsection">6.1.1 Information Loss</h4>
+
+<p><em>Information can be lost during output.</em> The output formats
+supported by BFD do not provide identical facilities, and
+information which can be described in one form has nowhere to go in
+another format. One example of this is alignment information in
+<code>b.out</code>. There is nowhere in an <code>a.out</code> format file to store
+alignment information on the contained data, so when a file is linked
+from <code>b.out</code> and an <code>a.out</code> image is produced, alignment
+information will not propagate to the output file. (The linker will
+still use the alignment information internally, so the link is performed
+correctly).
+</p>
+<p>Another example is COFF section names. COFF files may contain an
+unlimited number of sections, each one with a textual section name. If
+the target of the link is a format which does not have many sections (e.g.,
+<code>a.out</code>) or has sections without names (e.g., the Oasys format), the
+link cannot be done simply. You can circumvent this problem by
+describing the desired input-to-output section mapping with the linker command
+language.
+</p>
+<p><em>Information can be lost during canonicalization.</em> The BFD
+internal canonical form of the external formats is not exhaustive; there
+are structures in input formats for which there is no direct
+representation internally. This means that the BFD back ends
+cannot maintain all possible data richness through the transformation
+between external to internal and back to external formats.
+</p>
+<p>This limitation is only a problem when an application reads one
+format and writes another. Each BFD back end is responsible for
+maintaining as much data as possible, and the internal BFD
+canonical form has structures which are opaque to the BFD core,
+and exported only to the back ends. When a file is read in one format,
+the canonical form is generated for BFD and the application. At the
+same time, the back end saves away any information which may otherwise
+be lost. If the data is then written back in the same format, the back
+end routine will be able to use the canonical form provided by the
+BFD core as well as the information it prepared earlier. Since
+there is a great deal of commonality between back ends,
+there is no information lost when
+linking or copying big endian COFF to little endian COFF, or <code>a.out</code> to
+<code>b.out</code>. When a mixture of formats is linked, the information is
+only lost from the files whose format differs from the destination.
+</p>
+<hr>
+<a name="Canonical-format"></a>
+<div class="header">
+<p>
+Previous: <a href="#BFD-information-loss" accesskey="p" rel="previous">BFD information loss</a>, Up: <a href="#BFD-outline" accesskey="u" rel="up">BFD outline</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="The-BFD-canonical-object_002dfile-format"></a>
+<h4 class="subsection">6.1.2 The BFD canonical object-file format</h4>
+
+<p>The greatest potential for loss of information occurs when there is the least
+overlap between the information provided by the source format, that
+stored by the canonical format, and that needed by the
+destination format. A brief description of the canonical form may help
+you understand which kinds of data you can count on preserving across
+conversions.
+<a name="index-BFD-canonical-format"></a>
+<a name="index-internal-object_002dfile-format"></a>
+</p>
+<dl compact="compact">
+<dt><em>files</em></dt>
+<dd><p>Information stored on a per-file basis includes target machine
+architecture, particular implementation format type, a demand pageable
+bit, and a write protected bit. Information like Unix magic numbers is
+not stored here&mdash;only the magic numbers&rsquo; meaning, so a <code>ZMAGIC</code>
+file would have both the demand pageable bit and the write protected
+text bit set. The byte order of the target is stored on a per-file
+basis, so that big- and little-endian object files may be used with one
+another.
+</p>
+</dd>
+<dt><em>sections</em></dt>
+<dd><p>Each section in the input file contains the name of the section, the
+section&rsquo;s original address in the object file, size and alignment
+information, various flags, and pointers into other BFD data
+structures.
+</p>
+</dd>
+<dt><em>symbols</em></dt>
+<dd><p>Each symbol contains a pointer to the information for the object file
+which originally defined it, its name, its value, and various flag
+bits. When a BFD back end reads in a symbol table, it relocates all
+symbols to make them relative to the base of the section where they were
+defined. Doing this ensures that each symbol points to its containing
+section. Each symbol also has a varying amount of hidden private data
+for the BFD back end. Since the symbol points to the original file, the
+private data format for that symbol is accessible. <code>ld</code> can
+operate on a collection of symbols of wildly different formats without
+problems.
+</p>
+<p>Normal global and simple local symbols are maintained on output, so an
+output file (no matter its format) will retain symbols pointing to
+functions and to global, static, and common variables. Some symbol
+information is not worth retaining; in <code>a.out</code>, type information is
+stored in the symbol table as long symbol names. This information would
+be useless to most COFF debuggers; the linker has command-line switches
+to allow users to throw it away.
+</p>
+<p>There is one word of type information within the symbol, so if the
+format supports symbol type information within symbols (for example, COFF,
+Oasys) and the type is simple enough to fit within one word
+(nearly everything but aggregates), the information will be preserved.
+</p>
+</dd>
+<dt><em>relocation level</em></dt>
+<dd><p>Each canonical BFD relocation record contains a pointer to the symbol to
+relocate to, the offset of the data to relocate, the section the data
+is in, and a pointer to a relocation type descriptor. Relocation is
+performed by passing messages through the relocation type
+descriptor and the symbol pointer. Therefore, relocations can be performed
+on output data using a relocation method that is only available in one of the
+input formats. For instance, Oasys provides a byte relocation format.
+A relocation record requesting this relocation type would point
+indirectly to a routine to perform this, so the relocation may be
+performed on a byte being written to a 68k COFF file, even though 68k COFF
+has no such relocation type.
+</p>
+</dd>
+<dt><em>line numbers</em></dt>
+<dd><p>Object formats can contain, for debugging purposes, some form of mapping
+between symbols, source line numbers, and addresses in the output file.
+These addresses have to be relocated along with the symbol information.
+Each symbol with an associated list of line number records points to the
+first record of the list. The head of a line number list consists of a
+pointer to the symbol, which allows finding out the address of the
+function whose line number is being described. The rest of the list is
+made up of pairs: offsets into the section and line numbers. Any format
+which can simply derive this information can pass it successfully
+between formats.
+</p></dd>
+</dl>
+
+<hr>
+<a name="Reporting-Bugs"></a>
+<div class="header">
+<p>
+Next: <a href="#MRI" accesskey="n" rel="next">MRI</a>, Previous: <a href="#BFD" accesskey="p" rel="previous">BFD</a>, Up: <a href="#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Reporting-Bugs-1"></a>
+<h2 class="chapter">7 Reporting Bugs</h2>
+<a name="index-bugs-in-ld"></a>
+<a name="index-reporting-bugs-in-ld"></a>
+
+<p>Your bug reports play an essential role in making <code>ld</code> reliable.
+</p>
+<p>Reporting a bug may help you by bringing a solution to your problem, or
+it may not. But in any case the principal function of a bug report is
+to help the entire community by making the next version of <code>ld</code>
+work better. Bug reports are your contribution to the maintenance of
+<code>ld</code>.
+</p>
+<p>In order for a bug report to serve its purpose, you must include the
+information that enables us to fix the bug.
+</p>
+<table class="menu" border="0" cellspacing="0">
+<tr><td align="left" valign="top">&bull; <a href="#Bug-Criteria" accesskey="1">Bug Criteria</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Have you found a bug?
+</td></tr>
+<tr><td align="left" valign="top">&bull; <a href="#Bug-Reporting" accesskey="2">Bug Reporting</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">How to report bugs
+</td></tr>
+</table>
+
+<hr>
+<a name="Bug-Criteria"></a>
+<div class="header">
+<p>
+Next: <a href="#Bug-Reporting" accesskey="n" rel="next">Bug Reporting</a>, Up: <a href="#Reporting-Bugs" accesskey="u" rel="up">Reporting Bugs</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="Have-You-Found-a-Bug_003f"></a>
+<h3 class="section">7.1 Have You Found a Bug?</h3>
+<a name="index-bug-criteria"></a>
+
+<p>If you are not sure whether you have found a bug, here are some guidelines:
+</p>
+<ul>
+<li> <a name="index-fatal-signal"></a>
+<a name="index-linker-crash"></a>
+<a name="index-crash-of-linker"></a>
+If the linker gets a fatal signal, for any input whatever, that is a
+<code>ld</code> bug. Reliable linkers never crash.
+
+</li><li> <a name="index-error-on-valid-input"></a>
+If <code>ld</code> produces an error message for valid input, that is a bug.
+
+</li><li> <a name="index-invalid-input"></a>
+If <code>ld</code> does not produce an error message for invalid input, that
+may be a bug. In the general case, the linker can not verify that
+object files are correct.
+
+</li><li> If you are an experienced user of linkers, your suggestions for
+improvement of <code>ld</code> are welcome in any case.
+</li></ul>
+
+<hr>
+<a name="Bug-Reporting"></a>
+<div class="header">
+<p>
+Previous: <a href="#Bug-Criteria" accesskey="p" rel="previous">Bug Criteria</a>, Up: <a href="#Reporting-Bugs" accesskey="u" rel="up">Reporting Bugs</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="How-to-Report-Bugs"></a>
+<h3 class="section">7.2 How to Report Bugs</h3>
+<a name="index-bug-reports"></a>
+<a name="index-ld-bugs_002c-reporting"></a>
+
+<p>A number of companies and individuals offer support for <small>GNU</small>
+products. If you obtained <code>ld</code> from a support organization, we
+recommend you contact that organization first.
+</p>
+<p>You can find contact information for many support companies and
+individuals in the file <samp>etc/SERVICE</samp> in the <small>GNU</small> Emacs
+distribution.
+</p>
+<p>Otherwise, send bug reports for <code>ld</code> to
+<a href="https://bugs.linaro.org/">https://bugs.linaro.org/</a>.
+</p>
+<p>The fundamental principle of reporting bugs usefully is this:
+<strong>report all the facts</strong>. If you are not sure whether to state a
+fact or leave it out, state it!
+</p>
+<p>Often people omit facts because they think they know what causes the
+problem and assume that some details do not matter. Thus, you might
+assume that the name of a symbol you use in an example does not
+matter. Well, probably it does not, but one cannot be sure. Perhaps
+the bug is a stray memory reference which happens to fetch from the
+location where that name is stored in memory; perhaps, if the name
+were different, the contents of that location would fool the linker
+into doing the right thing despite the bug. Play it safe and give a
+specific, complete example. That is the easiest thing for you to do,
+and the most helpful.
+</p>
+<p>Keep in mind that the purpose of a bug report is to enable us to fix
+the bug if it is new to us. Therefore, always write your bug reports
+on the assumption that the bug has not been reported previously.
+</p>
+<p>Sometimes people give a few sketchy facts and ask, &ldquo;Does this ring a
+bell?&rdquo; This cannot help us fix a bug, so it is basically useless. We
+respond by asking for enough details to enable us to investigate.
+You might as well expedite matters by sending them to begin with.
+</p>
+<p>To enable us to fix the bug, you should include all these things:
+</p>
+<ul>
+<li> The version of <code>ld</code>. <code>ld</code> announces it if you start it with
+the &lsquo;<samp>--version</samp>&rsquo; argument.
+
+<p>Without this, we will not know whether there is any point in looking for
+the bug in the current version of <code>ld</code>.
+</p>
+</li><li> Any patches you may have applied to the <code>ld</code> source, including any
+patches made to the <code>BFD</code> library.
+
+</li><li> The type of machine you are using, and the operating system name and
+version number.
+
+</li><li> What compiler (and its version) was used to compile <code>ld</code>&mdash;e.g.
+&ldquo;<code>gcc-2.7</code>&rdquo;.
+
+</li><li> The command arguments you gave the linker to link your example and
+observe the bug. To guarantee you will not omit something important,
+list them all. A copy of the Makefile (or the output from make) is
+sufficient.
+
+<p>If we were to try to guess the arguments, we would probably guess wrong
+and then we might not encounter the bug.
+</p>
+</li><li> A complete input file, or set of input files, that will reproduce the
+bug. It is generally most helpful to send the actual object files
+provided that they are reasonably small. Say no more than 10K. For
+bigger files you can either make them available by FTP or HTTP or else
+state that you are willing to send the object file(s) to whomever
+requests them. (Note - your email will be going to a mailing list, so
+we do not want to clog it up with large attachments). But small
+attachments are best.
+
+<p>If the source files were assembled using <code>gas</code> or compiled using
+<code>gcc</code>, then it may be OK to send the source files rather than the
+object files. In this case, be sure to say exactly what version of
+<code>gas</code> or <code>gcc</code> was used to produce the object files. Also say
+how <code>gas</code> or <code>gcc</code> were configured.
+</p>
+</li><li> A description of what behavior you observe that you believe is
+incorrect. For example, &ldquo;It gets a fatal signal.&rdquo;
+
+<p>Of course, if the bug is that <code>ld</code> gets a fatal signal, then we
+will certainly notice it. But if the bug is incorrect output, we might
+not notice unless it is glaringly wrong. You might as well not give us
+a chance to make a mistake.
+</p>
+<p>Even if the problem you experience is a fatal signal, you should still
+say so explicitly. Suppose something strange is going on, such as, your
+copy of <code>ld</code> is out of sync, or you have encountered a bug in the
+C library on your system. (This has happened!) Your copy might crash
+and ours would not. If you told us to expect a crash, then when ours
+fails to crash, we would know that the bug was not happening for us. If
+you had not told us to expect a crash, then we would not be able to draw
+any conclusion from our observations.
+</p>
+</li><li> If you wish to suggest changes to the <code>ld</code> source, send us context
+diffs, as generated by <code>diff</code> with the &lsquo;<samp>-u</samp>&rsquo;, &lsquo;<samp>-c</samp>&rsquo;, or
+&lsquo;<samp>-p</samp>&rsquo; option. Always send diffs from the old file to the new file.
+If you even discuss something in the <code>ld</code> source, refer to it by
+context, not by line number.
+
+<p>The line numbers in our development sources will not match those in your
+sources. Your line numbers would convey no useful information to us.
+</p></li></ul>
+
+<p>Here are some things that are not necessary:
+</p>
+<ul>
+<li> A description of the envelope of the bug.
+
+<p>Often people who encounter a bug spend a lot of time investigating
+which changes to the input file will make the bug go away and which
+changes will not affect it.
+</p>
+<p>This is often time consuming and not very useful, because the way we
+will find the bug is by running a single example under the debugger
+with breakpoints, not by pure deduction from a series of examples.
+We recommend that you save your time for something else.
+</p>
+<p>Of course, if you can find a simpler example to report <em>instead</em>
+of the original one, that is a convenience for us. Errors in the
+output will be easier to spot, running under the debugger will take
+less time, and so on.
+</p>
+<p>However, simplification is not vital; if you do not want to do this,
+report the bug anyway and send us the entire test case you used.
+</p>
+</li><li> A patch for the bug.
+
+<p>A patch for the bug does help us if it is a good one. But do not omit
+the necessary information, such as the test case, on the assumption that
+a patch is all we need. We might see problems with your patch and decide
+to fix the problem another way, or we might not understand it at all.
+</p>
+<p>Sometimes with a program as complicated as <code>ld</code> it is very hard to
+construct an example that will make the program follow a certain path
+through the code. If you do not send us the example, we will not be
+able to construct one, so we will not be able to verify that the bug is
+fixed.
+</p>
+<p>And if we cannot understand what bug you are trying to fix, or why your
+patch should be an improvement, we will not install it. A test case will
+help us to understand.
+</p>
+</li><li> A guess about what the bug is or what it depends on.
+
+<p>Such guesses are usually wrong. Even we cannot guess right about such
+things without first using the debugger to find the facts.
+</p></li></ul>
+
+<hr>
+<a name="MRI"></a>
+<div class="header">
+<p>
+Next: <a href="#GNU-Free-Documentation-License" accesskey="n" rel="next">GNU Free Documentation License</a>, Previous: <a href="#Reporting-Bugs" accesskey="p" rel="previous">Reporting Bugs</a>, Up: <a href="#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="MRI-Compatible-Script-Files"></a>
+<h2 class="appendix">Appendix A MRI Compatible Script Files</h2>
+<a name="index-MRI-compatibility"></a>
+<p>To aid users making the transition to <small>GNU</small> <code>ld</code> from the MRI
+linker, <code>ld</code> can use MRI compatible linker scripts as an
+alternative to the more general-purpose linker scripting language
+described in <a href="#Scripts">Scripts</a>. MRI compatible linker scripts have a much
+simpler command set than the scripting language otherwise used with
+<code>ld</code>. <small>GNU</small> <code>ld</code> supports the most commonly used MRI
+linker commands; these commands are described here.
+</p>
+<p>In general, MRI scripts aren&rsquo;t of much use with the <code>a.out</code> object
+file format, since it only has three sections and MRI scripts lack some
+features to make use of them.
+</p>
+<p>You can specify a file containing an MRI-compatible script using the
+&lsquo;<samp>-c</samp>&rsquo; command-line option.
+</p>
+<p>Each command in an MRI-compatible script occupies its own line; each
+command line starts with the keyword that identifies the command (though
+blank lines are also allowed for punctuation). If a line of an
+MRI-compatible script begins with an unrecognized keyword, <code>ld</code>
+issues a warning message, but continues processing the script.
+</p>
+<p>Lines beginning with &lsquo;<samp>*</samp>&rsquo; are comments.
+</p>
+<p>You can write these commands using all upper-case letters, or all
+lower case; for example, &lsquo;<samp>chip</samp>&rsquo; is the same as &lsquo;<samp>CHIP</samp>&rsquo;.
+The following list shows only the upper-case form of each command.
+</p>
+<dl compact="compact">
+<dd><a name="index-ABSOLUTE-_0028MRI_0029"></a>
+</dd>
+<dt><code>ABSOLUTE <var>secname</var></code></dt>
+<dt><code>ABSOLUTE <var>secname</var>, <var>secname</var>, &hellip; <var>secname</var></code></dt>
+<dd><p>Normally, <code>ld</code> includes in the output file all sections from all
+the input files. However, in an MRI-compatible script, you can use the
+<code>ABSOLUTE</code> command to restrict the sections that will be present in
+your output program. If the <code>ABSOLUTE</code> command is used at all in a
+script, then only the sections named explicitly in <code>ABSOLUTE</code>
+commands will appear in the linker output. You can still use other
+input sections (whatever you select on the command line, or using
+<code>LOAD</code>) to resolve addresses in the output file.
+</p>
+<a name="index-ALIAS-_0028MRI_0029"></a>
+</dd>
+<dt><code>ALIAS <var>out-secname</var>, <var>in-secname</var></code></dt>
+<dd><p>Use this command to place the data from input section <var>in-secname</var>
+in a section called <var>out-secname</var> in the linker output file.
+</p>
+<p><var>in-secname</var> may be an integer.
+</p>
+<a name="index-ALIGN-_0028MRI_0029"></a>
+</dd>
+<dt><code>ALIGN <var>secname</var> = <var>expression</var></code></dt>
+<dd><p>Align the section called <var>secname</var> to <var>expression</var>. The
+<var>expression</var> should be a power of two.
+</p>
+<a name="index-BASE-_0028MRI_0029"></a>
+</dd>
+<dt><code>BASE <var>expression</var></code></dt>
+<dd><p>Use the value of <var>expression</var> as the lowest address (other than
+absolute addresses) in the output file.
+</p>
+<a name="index-CHIP-_0028MRI_0029"></a>
+</dd>
+<dt><code>CHIP <var>expression</var></code></dt>
+<dt><code>CHIP <var>expression</var>, <var>expression</var></code></dt>
+<dd><p>This command does nothing; it is accepted only for compatibility.
+</p>
+<a name="index-END-_0028MRI_0029"></a>
+</dd>
+<dt><code>END</code></dt>
+<dd><p>This command does nothing whatever; it&rsquo;s only accepted for compatibility.
+</p>
+<a name="index-FORMAT-_0028MRI_0029"></a>
+</dd>
+<dt><code>FORMAT <var>output-format</var></code></dt>
+<dd><p>Similar to the <code>OUTPUT_FORMAT</code> command in the more general linker
+language, but restricted to S-records, if <var>output-format</var> is &lsquo;<samp>S</samp>&rsquo;
+</p>
+<a name="index-LIST-_0028MRI_0029"></a>
+</dd>
+<dt><code>LIST <var>anything</var>&hellip;</code></dt>
+<dd><p>Print (to the standard output file) a link map, as produced by the
+<code>ld</code> command-line option &lsquo;<samp>-M</samp>&rsquo;.
+</p>
+<p>The keyword <code>LIST</code> may be followed by anything on the
+same line, with no change in its effect.
+</p>
+<a name="index-LOAD-_0028MRI_0029"></a>
+</dd>
+<dt><code>LOAD <var>filename</var></code></dt>
+<dt><code>LOAD <var>filename</var>, <var>filename</var>, &hellip; <var>filename</var></code></dt>
+<dd><p>Include one or more object file <var>filename</var> in the link; this has the
+same effect as specifying <var>filename</var> directly on the <code>ld</code>
+command line.
+</p>
+<a name="index-NAME-_0028MRI_0029"></a>
+</dd>
+<dt><code>NAME <var>output-name</var></code></dt>
+<dd><p><var>output-name</var> is the name for the program produced by <code>ld</code>; the
+MRI-compatible command <code>NAME</code> is equivalent to the command-line
+option &lsquo;<samp>-o</samp>&rsquo; or the general script language command <code>OUTPUT</code>.
+</p>
+<a name="index-ORDER-_0028MRI_0029"></a>
+</dd>
+<dt><code>ORDER <var>secname</var>, <var>secname</var>, &hellip; <var>secname</var></code></dt>
+<dt><code>ORDER <var>secname</var> <var>secname</var> <var>secname</var></code></dt>
+<dd><p>Normally, <code>ld</code> orders the sections in its output file in the
+order in which they first appear in the input files. In an MRI-compatible
+script, you can override this ordering with the <code>ORDER</code> command. The
+sections you list with <code>ORDER</code> will appear first in your output
+file, in the order specified.
+</p>
+<a name="index-PUBLIC-_0028MRI_0029"></a>
+</dd>
+<dt><code>PUBLIC <var>name</var>=<var>expression</var></code></dt>
+<dt><code>PUBLIC <var>name</var>,<var>expression</var></code></dt>
+<dt><code>PUBLIC <var>name</var> <var>expression</var></code></dt>
+<dd><p>Supply a value (<var>expression</var>) for external symbol
+<var>name</var> used in the linker input files.
+</p>
+<a name="index-SECT-_0028MRI_0029"></a>
+</dd>
+<dt><code>SECT <var>secname</var>, <var>expression</var></code></dt>
+<dt><code>SECT <var>secname</var>=<var>expression</var></code></dt>
+<dt><code>SECT <var>secname</var> <var>expression</var></code></dt>
+<dd><p>You can use any of these three forms of the <code>SECT</code> command to
+specify the start address (<var>expression</var>) for section <var>secname</var>.
+If you have more than one <code>SECT</code> statement for the same
+<var>secname</var>, only the <em>first</em> sets the start address.
+</p></dd>
+</dl>
+
+<hr>
+<a name="GNU-Free-Documentation-License"></a>
+<div class="header">
+<p>
+Next: <a href="#LD-Index" accesskey="n" rel="next">LD Index</a>, Previous: <a href="#MRI" accesskey="p" rel="previous">MRI</a>, Up: <a href="#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="GNU-Free-Documentation-License-1"></a>
+<h2 class="appendix">Appendix B GNU Free Documentation License</h2>
+<div align="center">Version 1.3, 3 November 2008
+</div>
+
+<div class="display">
+<pre class="display">Copyright &copy; 2000, 2001, 2002, 2007, 2008 Free Software Foundation, Inc.
+<a href="http://fsf.org/">http://fsf.org/</a>
+
+Everyone is permitted to copy and distribute verbatim copies
+of this license document, but changing it is not allowed.
+</pre></div>
+
+<ol>
+<li> PREAMBLE
+
+<p>The purpose of this License is to make a manual, textbook, or other
+functional and useful document <em>free</em> in the sense of freedom: to
+assure everyone the effective freedom to copy and redistribute it,
+with or without modifying it, either commercially or noncommercially.
+Secondarily, this License preserves for the author and publisher a way
+to get credit for their work, while not being considered responsible
+for modifications made by others.
+</p>
+<p>This License is a kind of &ldquo;copyleft&rdquo;, which means that derivative
+works of the document must themselves be free in the same sense. It
+complements the GNU General Public License, which is a copyleft
+license designed for free software.
+</p>
+<p>We have designed this License in order to use it for manuals for free
+software, because free software needs free documentation: a free
+program should come with manuals providing the same freedoms that the
+software does. But this License is not limited to software manuals;
+it can be used for any textual work, regardless of subject matter or
+whether it is published as a printed book. We recommend this License
+principally for works whose purpose is instruction or reference.
+</p>
+</li><li> APPLICABILITY AND DEFINITIONS
+
+<p>This License applies to any manual or other work, in any medium, that
+contains a notice placed by the copyright holder saying it can be
+distributed under the terms of this License. Such a notice grants a
+world-wide, royalty-free license, unlimited in duration, to use that
+work under the conditions stated herein. The &ldquo;Document&rdquo;, below,
+refers to any such manual or work. Any member of the public is a
+licensee, and is addressed as &ldquo;you&rdquo;. You accept the license if you
+copy, modify or distribute the work in a way requiring permission
+under copyright law.
+</p>
+<p>A &ldquo;Modified Version&rdquo; of the Document means any work containing the
+Document or a portion of it, either copied verbatim, or with
+modifications and/or translated into another language.
+</p>
+<p>A &ldquo;Secondary Section&rdquo; is a named appendix or a front-matter section
+of the Document that deals exclusively with the relationship of the
+publishers or authors of the Document to the Document&rsquo;s overall
+subject (or to related matters) and contains nothing that could fall
+directly within that overall subject. (Thus, if the Document is in
+part a textbook of mathematics, a Secondary Section may not explain
+any mathematics.) The relationship could be a matter of historical
+connection with the subject or with related matters, or of legal,
+commercial, philosophical, ethical or political position regarding
+them.
+</p>
+<p>The &ldquo;Invariant Sections&rdquo; are certain Secondary Sections whose titles
+are designated, as being those of Invariant Sections, in the notice
+that says that the Document is released under this License. If a
+section does not fit the above definition of Secondary then it is not
+allowed to be designated as Invariant. The Document may contain zero
+Invariant Sections. If the Document does not identify any Invariant
+Sections then there are none.
+</p>
+<p>The &ldquo;Cover Texts&rdquo; are certain short passages of text that are listed,
+as Front-Cover Texts or Back-Cover Texts, in the notice that says that
+the Document is released under this License. A Front-Cover Text may
+be at most 5 words, and a Back-Cover Text may be at most 25 words.
+</p>
+<p>A &ldquo;Transparent&rdquo; copy of the Document means a machine-readable copy,
+represented in a format whose specification is available to the
+general public, that is suitable for revising the document
+straightforwardly with generic text editors or (for images composed of
+pixels) generic paint programs or (for drawings) some widely available
+drawing editor, and that is suitable for input to text formatters or
+for automatic translation to a variety of formats suitable for input
+to text formatters. A copy made in an otherwise Transparent file
+format whose markup, or absence of markup, has been arranged to thwart
+or discourage subsequent modification by readers is not Transparent.
+An image format is not Transparent if used for any substantial amount
+of text. A copy that is not &ldquo;Transparent&rdquo; is called &ldquo;Opaque&rdquo;.
+</p>
+<p>Examples of suitable formats for Transparent copies include plain
+<small>ASCII</small> without markup, Texinfo input format, LaTeX input
+format, <acronym>SGML</acronym> or <acronym>XML</acronym> using a publicly available
+<acronym>DTD</acronym>, and standard-conforming simple <acronym>HTML</acronym>,
+PostScript or <acronym>PDF</acronym> designed for human modification. Examples
+of transparent image formats include <acronym>PNG</acronym>, <acronym>XCF</acronym> and
+<acronym>JPG</acronym>. Opaque formats include proprietary formats that can be
+read and edited only by proprietary word processors, <acronym>SGML</acronym> or
+<acronym>XML</acronym> for which the <acronym>DTD</acronym> and/or processing tools are
+not generally available, and the machine-generated <acronym>HTML</acronym>,
+PostScript or <acronym>PDF</acronym> produced by some word processors for
+output purposes only.
+</p>
+<p>The &ldquo;Title Page&rdquo; means, for a printed book, the title page itself,
+plus such following pages as are needed to hold, legibly, the material
+this License requires to appear in the title page. For works in
+formats which do not have any title page as such, &ldquo;Title Page&rdquo; means
+the text near the most prominent appearance of the work&rsquo;s title,
+preceding the beginning of the body of the text.
+</p>
+<p>The &ldquo;publisher&rdquo; means any person or entity that distributes copies
+of the Document to the public.
+</p>
+<p>A section &ldquo;Entitled XYZ&rdquo; means a named subunit of the Document whose
+title either is precisely XYZ or contains XYZ in parentheses following
+text that translates XYZ in another language. (Here XYZ stands for a
+specific section name mentioned below, such as &ldquo;Acknowledgements&rdquo;,
+&ldquo;Dedications&rdquo;, &ldquo;Endorsements&rdquo;, or &ldquo;History&rdquo;.) To &ldquo;Preserve the Title&rdquo;
+of such a section when you modify the Document means that it remains a
+section &ldquo;Entitled XYZ&rdquo; according to this definition.
+</p>
+<p>The Document may include Warranty Disclaimers next to the notice which
+states that this License applies to the Document. These Warranty
+Disclaimers are considered to be included by reference in this
+License, but only as regards disclaiming warranties: any other
+implication that these Warranty Disclaimers may have is void and has
+no effect on the meaning of this License.
+</p>
+</li><li> VERBATIM COPYING
+
+<p>You may copy and distribute the Document in any medium, either
+commercially or noncommercially, provided that this License, the
+copyright notices, and the license notice saying this License applies
+to the Document are reproduced in all copies, and that you add no other
+conditions whatsoever to those of this License. You may not use
+technical measures to obstruct or control the reading or further
+copying of the copies you make or distribute. However, you may accept
+compensation in exchange for copies. If you distribute a large enough
+number of copies you must also follow the conditions in section 3.
+</p>
+<p>You may also lend copies, under the same conditions stated above, and
+you may publicly display copies.
+</p>
+</li><li> COPYING IN QUANTITY
+
+<p>If you publish printed copies (or copies in media that commonly have
+printed covers) of the Document, numbering more than 100, and the
+Document&rsquo;s license notice requires Cover Texts, you must enclose the
+copies in covers that carry, clearly and legibly, all these Cover
+Texts: Front-Cover Texts on the front cover, and Back-Cover Texts on
+the back cover. Both covers must also clearly and legibly identify
+you as the publisher of these copies. The front cover must present
+the full title with all words of the title equally prominent and
+visible. You may add other material on the covers in addition.
+Copying with changes limited to the covers, as long as they preserve
+the title of the Document and satisfy these conditions, can be treated
+as verbatim copying in other respects.
+</p>
+<p>If the required texts for either cover are too voluminous to fit
+legibly, you should put the first ones listed (as many as fit
+reasonably) on the actual cover, and continue the rest onto adjacent
+pages.
+</p>
+<p>If you publish or distribute Opaque copies of the Document numbering
+more than 100, you must either include a machine-readable Transparent
+copy along with each Opaque copy, or state in or with each Opaque copy
+a computer-network location from which the general network-using
+public has access to download using public-standard network protocols
+a complete Transparent copy of the Document, free of added material.
+If you use the latter option, you must take reasonably prudent steps,
+when you begin distribution of Opaque copies in quantity, to ensure
+that this Transparent copy will remain thus accessible at the stated
+location until at least one year after the last time you distribute an
+Opaque copy (directly or through your agents or retailers) of that
+edition to the public.
+</p>
+<p>It is requested, but not required, that you contact the authors of the
+Document well before redistributing any large number of copies, to give
+them a chance to provide you with an updated version of the Document.
+</p>
+</li><li> MODIFICATIONS
+
+<p>You may copy and distribute a Modified Version of the Document under
+the conditions of sections 2 and 3 above, provided that you release
+the Modified Version under precisely this License, with the Modified
+Version filling the role of the Document, thus licensing distribution
+and modification of the Modified Version to whoever possesses a copy
+of it. In addition, you must do these things in the Modified Version:
+</p>
+<ol>
+<li> Use in the Title Page (and on the covers, if any) a title distinct
+from that of the Document, and from those of previous versions
+(which should, if there were any, be listed in the History section
+of the Document). You may use the same title as a previous version
+if the original publisher of that version gives permission.
+
+</li><li> List on the Title Page, as authors, one or more persons or entities
+responsible for authorship of the modifications in the Modified
+Version, together with at least five of the principal authors of the
+Document (all of its principal authors, if it has fewer than five),
+unless they release you from this requirement.
+
+</li><li> State on the Title page the name of the publisher of the
+Modified Version, as the publisher.
+
+</li><li> Preserve all the copyright notices of the Document.
+
+</li><li> Add an appropriate copyright notice for your modifications
+adjacent to the other copyright notices.
+
+</li><li> Include, immediately after the copyright notices, a license notice
+giving the public permission to use the Modified Version under the
+terms of this License, in the form shown in the Addendum below.
+
+</li><li> Preserve in that license notice the full lists of Invariant Sections
+and required Cover Texts given in the Document&rsquo;s license notice.
+
+</li><li> Include an unaltered copy of this License.
+
+</li><li> Preserve the section Entitled &ldquo;History&rdquo;, Preserve its Title, and add
+to it an item stating at least the title, year, new authors, and
+publisher of the Modified Version as given on the Title Page. If
+there is no section Entitled &ldquo;History&rdquo; in the Document, create one
+stating the title, year, authors, and publisher of the Document as
+given on its Title Page, then add an item describing the Modified
+Version as stated in the previous sentence.
+
+</li><li> Preserve the network location, if any, given in the Document for
+public access to a Transparent copy of the Document, and likewise
+the network locations given in the Document for previous versions
+it was based on. These may be placed in the &ldquo;History&rdquo; section.
+You may omit a network location for a work that was published at
+least four years before the Document itself, or if the original
+publisher of the version it refers to gives permission.
+
+</li><li> For any section Entitled &ldquo;Acknowledgements&rdquo; or &ldquo;Dedications&rdquo;, Preserve
+the Title of the section, and preserve in the section all the
+substance and tone of each of the contributor acknowledgements and/or
+dedications given therein.
+
+</li><li> Preserve all the Invariant Sections of the Document,
+unaltered in their text and in their titles. Section numbers
+or the equivalent are not considered part of the section titles.
+
+</li><li> Delete any section Entitled &ldquo;Endorsements&rdquo;. Such a section
+may not be included in the Modified Version.
+
+</li><li> Do not retitle any existing section to be Entitled &ldquo;Endorsements&rdquo; or
+to conflict in title with any Invariant Section.
+
+</li><li> Preserve any Warranty Disclaimers.
+</li></ol>
+
+<p>If the Modified Version includes new front-matter sections or
+appendices that qualify as Secondary Sections and contain no material
+copied from the Document, you may at your option designate some or all
+of these sections as invariant. To do this, add their titles to the
+list of Invariant Sections in the Modified Version&rsquo;s license notice.
+These titles must be distinct from any other section titles.
+</p>
+<p>You may add a section Entitled &ldquo;Endorsements&rdquo;, provided it contains
+nothing but endorsements of your Modified Version by various
+parties&mdash;for example, statements of peer review or that the text has
+been approved by an organization as the authoritative definition of a
+standard.
+</p>
+<p>You may add a passage of up to five words as a Front-Cover Text, and a
+passage of up to 25 words as a Back-Cover Text, to the end of the list
+of Cover Texts in the Modified Version. Only one passage of
+Front-Cover Text and one of Back-Cover Text may be added by (or
+through arrangements made by) any one entity. If the Document already
+includes a cover text for the same cover, previously added by you or
+by arrangement made by the same entity you are acting on behalf of,
+you may not add another; but you may replace the old one, on explicit
+permission from the previous publisher that added the old one.
+</p>
+<p>The author(s) and publisher(s) of the Document do not by this License
+give permission to use their names for publicity for or to assert or
+imply endorsement of any Modified Version.
+</p>
+</li><li> COMBINING DOCUMENTS
+
+<p>You may combine the Document with other documents released under this
+License, under the terms defined in section 4 above for modified
+versions, provided that you include in the combination all of the
+Invariant Sections of all of the original documents, unmodified, and
+list them all as Invariant Sections of your combined work in its
+license notice, and that you preserve all their Warranty Disclaimers.
+</p>
+<p>The combined work need only contain one copy of this License, and
+multiple identical Invariant Sections may be replaced with a single
+copy. If there are multiple Invariant Sections with the same name but
+different contents, make the title of each such section unique by
+adding at the end of it, in parentheses, the name of the original
+author or publisher of that section if known, or else a unique number.
+Make the same adjustment to the section titles in the list of
+Invariant Sections in the license notice of the combined work.
+</p>
+<p>In the combination, you must combine any sections Entitled &ldquo;History&rdquo;
+in the various original documents, forming one section Entitled
+&ldquo;History&rdquo;; likewise combine any sections Entitled &ldquo;Acknowledgements&rdquo;,
+and any sections Entitled &ldquo;Dedications&rdquo;. You must delete all
+sections Entitled &ldquo;Endorsements.&rdquo;
+</p>
+</li><li> COLLECTIONS OF DOCUMENTS
+
+<p>You may make a collection consisting of the Document and other documents
+released under this License, and replace the individual copies of this
+License in the various documents with a single copy that is included in
+the collection, provided that you follow the rules of this License for
+verbatim copying of each of the documents in all other respects.
+</p>
+<p>You may extract a single document from such a collection, and distribute
+it individually under this License, provided you insert a copy of this
+License into the extracted document, and follow this License in all
+other respects regarding verbatim copying of that document.
+</p>
+</li><li> AGGREGATION WITH INDEPENDENT WORKS
+
+<p>A compilation of the Document or its derivatives with other separate
+and independent documents or works, in or on a volume of a storage or
+distribution medium, is called an &ldquo;aggregate&rdquo; if the copyright
+resulting from the compilation is not used to limit the legal rights
+of the compilation&rsquo;s users beyond what the individual works permit.
+When the Document is included in an aggregate, this License does not
+apply to the other works in the aggregate which are not themselves
+derivative works of the Document.
+</p>
+<p>If the Cover Text requirement of section 3 is applicable to these
+copies of the Document, then if the Document is less than one half of
+the entire aggregate, the Document&rsquo;s Cover Texts may be placed on
+covers that bracket the Document within the aggregate, or the
+electronic equivalent of covers if the Document is in electronic form.
+Otherwise they must appear on printed covers that bracket the whole
+aggregate.
+</p>
+</li><li> TRANSLATION
+
+<p>Translation is considered a kind of modification, so you may
+distribute translations of the Document under the terms of section 4.
+Replacing Invariant Sections with translations requires special
+permission from their copyright holders, but you may include
+translations of some or all Invariant Sections in addition to the
+original versions of these Invariant Sections. You may include a
+translation of this License, and all the license notices in the
+Document, and any Warranty Disclaimers, provided that you also include
+the original English version of this License and the original versions
+of those notices and disclaimers. In case of a disagreement between
+the translation and the original version of this License or a notice
+or disclaimer, the original version will prevail.
+</p>
+<p>If a section in the Document is Entitled &ldquo;Acknowledgements&rdquo;,
+&ldquo;Dedications&rdquo;, or &ldquo;History&rdquo;, the requirement (section 4) to Preserve
+its Title (section 1) will typically require changing the actual
+title.
+</p>
+</li><li> TERMINATION
+
+<p>You may not copy, modify, sublicense, or distribute the Document
+except as expressly provided under this License. Any attempt
+otherwise to copy, modify, sublicense, or distribute it is void, and
+will automatically terminate your rights under this License.
+</p>
+<p>However, if you cease all violation of this License, then your license
+from a particular copyright holder is reinstated (a) provisionally,
+unless and until the copyright holder explicitly and finally
+terminates your license, and (b) permanently, if the copyright holder
+fails to notify you of the violation by some reasonable means prior to
+60 days after the cessation.
+</p>
+<p>Moreover, your license from a particular copyright holder is
+reinstated permanently if the copyright holder notifies you of the
+violation by some reasonable means, this is the first time you have
+received notice of violation of this License (for any work) from that
+copyright holder, and you cure the violation prior to 30 days after
+your receipt of the notice.
+</p>
+<p>Termination of your rights under this section does not terminate the
+licenses of parties who have received copies or rights from you under
+this License. If your rights have been terminated and not permanently
+reinstated, receipt of a copy of some or all of the same material does
+not give you any rights to use it.
+</p>
+</li><li> FUTURE REVISIONS OF THIS LICENSE
+
+<p>The Free Software Foundation may publish new, revised versions
+of the GNU Free Documentation License from time to time. Such new
+versions will be similar in spirit to the present version, but may
+differ in detail to address new problems or concerns. See
+<a href="http://www.gnu.org/copyleft/">http://www.gnu.org/copyleft/</a>.
+</p>
+<p>Each version of the License is given a distinguishing version number.
+If the Document specifies that a particular numbered version of this
+License &ldquo;or any later version&rdquo; applies to it, you have the option of
+following the terms and conditions either of that specified version or
+of any later version that has been published (not as a draft) by the
+Free Software Foundation. If the Document does not specify a version
+number of this License, you may choose any version ever published (not
+as a draft) by the Free Software Foundation. If the Document
+specifies that a proxy can decide which future versions of this
+License can be used, that proxy&rsquo;s public statement of acceptance of a
+version permanently authorizes you to choose that version for the
+Document.
+</p>
+</li><li> RELICENSING
+
+<p>&ldquo;Massive Multiauthor Collaboration Site&rdquo; (or &ldquo;MMC Site&rdquo;) means any
+World Wide Web server that publishes copyrightable works and also
+provides prominent facilities for anybody to edit those works. A
+public wiki that anybody can edit is an example of such a server. A
+&ldquo;Massive Multiauthor Collaboration&rdquo; (or &ldquo;MMC&rdquo;) contained in the
+site means any set of copyrightable works thus published on the MMC
+site.
+</p>
+<p>&ldquo;CC-BY-SA&rdquo; means the Creative Commons Attribution-Share Alike 3.0
+license published by Creative Commons Corporation, a not-for-profit
+corporation with a principal place of business in San Francisco,
+California, as well as future copyleft versions of that license
+published by that same organization.
+</p>
+<p>&ldquo;Incorporate&rdquo; means to publish or republish a Document, in whole or
+in part, as part of another Document.
+</p>
+<p>An MMC is &ldquo;eligible for relicensing&rdquo; if it is licensed under this
+License, and if all works that were first published under this License
+somewhere other than this MMC, and subsequently incorporated in whole
+or in part into the MMC, (1) had no cover texts or invariant sections,
+and (2) were thus incorporated prior to November 1, 2008.
+</p>
+<p>The operator of an MMC Site may republish an MMC contained in the site
+under CC-BY-SA on the same site at any time before August 1, 2009,
+provided the MMC is eligible for relicensing.
+</p>
+</li></ol>
+
+<a name="ADDENDUM_003a-How-to-use-this-License-for-your-documents"></a>
+<h3 class="heading">ADDENDUM: How to use this License for your documents</h3>
+
+<p>To use this License in a document you have written, include a copy of
+the License in the document and put the following copyright and
+license notices just after the title page:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> Copyright (C) <var>year</var> <var>your name</var>.
+ Permission is granted to copy, distribute and/or modify this document
+ under the terms of the GNU Free Documentation License, Version 1.3
+ or any later version published by the Free Software Foundation;
+ with no Invariant Sections, no Front-Cover Texts, and no Back-Cover
+ Texts. A copy of the license is included in the section entitled ``GNU
+ Free Documentation License''.
+</pre></div>
+
+<p>If you have Invariant Sections, Front-Cover Texts and Back-Cover Texts,
+replace the &ldquo;with&hellip;Texts.&rdquo; line with this:
+</p>
+<div class="smallexample">
+<pre class="smallexample"> with the Invariant Sections being <var>list their titles</var>, with
+ the Front-Cover Texts being <var>list</var>, and with the Back-Cover Texts
+ being <var>list</var>.
+</pre></div>
+
+<p>If you have Invariant Sections without Cover Texts, or some other
+combination of the three, merge those two alternatives to suit the
+situation.
+</p>
+<p>If your document contains nontrivial examples of program code, we
+recommend releasing these examples in parallel under your choice of
+free software license, such as the GNU General Public License,
+to permit their use in free software.
+</p>
+
+<hr>
+<a name="LD-Index"></a>
+<div class="header">
+<p>
+Previous: <a href="#GNU-Free-Documentation-License" accesskey="p" rel="previous">GNU Free Documentation License</a>, Up: <a href="#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="#LD-Index" title="Index" rel="index">Index</a>]</p>
+</div>
+<a name="LD-Index-1"></a>
+<h2 class="unnumbered">LD Index</h2>
+
+<table><tr><th valign="top">Jump to: &nbsp; </th><td><a class="summary-letter" href="#LD-Index_cp_symbol-1"><b>&quot;</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-2"><b>-</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-3"><b>.</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-4"><b>/</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-5"><b>3</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-6"><b>:</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-7"><b>=</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-8"><b>&gt;</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-9"><b>[</b></a>
+ &nbsp;
+<br>
+<a class="summary-letter" href="#LD-Index_cp_letter-A"><b>A</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-B"><b>B</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-C"><b>C</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-D"><b>D</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-E"><b>E</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-F"><b>F</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-G"><b>G</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-H"><b>H</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-I"><b>I</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-K"><b>K</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-L"><b>L</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-M"><b>M</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-N"><b>N</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-O"><b>O</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-P"><b>P</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-Q"><b>Q</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-R"><b>R</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-S"><b>S</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-T"><b>T</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-U"><b>U</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-V"><b>V</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-W"><b>W</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-X"><b>X</b></a>
+ &nbsp;
+</td></tr></table>
+<table class="index-cp" border="0">
+<tr><td></td><th align="left">Index Entry</th><td>&nbsp;</td><th align="left"> Section</th></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_symbol-1">&quot;</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_0022"><code>&quot;</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Symbols">Symbols</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_symbol-2">-</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_0028"><code>-(</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002daccept_002dunknown_002dinput_002darch"><code>--accept-unknown-input-arch</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dadd_002dneeded"><code>--add-needed</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dadd_002dstdcall_002dalias"><code>--add-stdcall-alias</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dallow_002dmultiple_002ddefinition"><code>--allow-multiple-definition</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dallow_002dshlib_002dundefined"><code>--allow-shlib-undefined</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002das_002dneeded"><code>--as-needed</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002daudit-AUDITLIB"><code>--audit <var>AUDITLIB</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dauxiliary_003dname"><code>--auxiliary=<var>name</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dbank_002dwindow"><code>--bank-window</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dbase_002dfile"><code>--base-file</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dbe8"><code>--be8</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dbranch_002dstub-on-C_002dSKY"><code>--branch-stub on C-SKY</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dbss_002dplt"><code>--bss-plt</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC-ELF32">PowerPC ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dbuild_002did"><code>--build-id</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dbuild_002did_003dstyle"><code>--build-id=<var>style</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dcheck_002dsections"><code>--check-sections</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dcmse_002dimplib"><code>--cmse-implib</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dcode_002dregion"><code>--code-region</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MSP430">MSP430</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dcompact_002dbranches"><code>--compact-branches</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dcompress_002ddebug_002dsections_003dnone"><code>--compress-debug-sections=none</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dcompress_002ddebug_002dsections_003dzlib"><code>--compress-debug-sections=zlib</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dcompress_002ddebug_002dsections_003dzlib_002dgabi"><code>--compress-debug-sections=zlib-gabi</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dcompress_002ddebug_002dsections_003dzlib_002dgnu"><code>--compress-debug-sections=zlib-gnu</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dcompress_002ddebug_002dsections_003dzstd"><code>--compress-debug-sections=zstd</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dcopy_002ddt_002dneeded_002dentries"><code>--copy-dt-needed-entries</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dcref"><code>--cref</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dctf_002dshare_002dtypes"><code>--ctf-share-types</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dctf_002dvariables"><code>--ctf-variables</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddata_002dregion"><code>--data-region</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MSP430">MSP430</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddefault_002dimported_002dsymver"><code>--default-imported-symver</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddefault_002dscript_003dscript"><code>--default-script=<var>script</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddefault_002dsymver"><code>--default-symver</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddefsym_003dsymbol_003dexp"><code>--defsym=<var>symbol</var>=<var>exp</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddemangle_005b_003dstyle_005d"><code>--demangle[=<var>style</var>]</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddepaudit-AUDITLIB"><code>--depaudit <var>AUDITLIB</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddependency_002dfile_003ddepfile"><code>--dependency-file=<var>depfile</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddisable_002dauto_002dimage_002dbase"><code>--disable-auto-image-base</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddisable_002dauto_002dimport"><code>--disable-auto-import</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddisable_002dlarge_002daddress_002daware"><code>--disable-large-address-aware</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddisable_002dlinker_002dversion"><code>--disable-linker-version</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddisable_002dlong_002dsection_002dnames"><code>--disable-long-section-names</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddisable_002dmultiple_002dabs_002ddefs"><code>--disable-multiple-abs-defs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddisable_002dnew_002ddtags"><code>--disable-new-dtags</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddisable_002druntime_002dpseudo_002dreloc"><code>--disable-runtime-pseudo-reloc</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddisable_002dsec_002dtransformation"><code>--disable-sec-transformation</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MSP430">MSP430</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddisable_002dstdcall_002dfixup"><code>--disable-stdcall-fixup</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddiscard_002dall"><code>--discard-all</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddiscard_002dlocals"><code>--discard-locals</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddll"><code>--dll</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddll_002dsearch_002dprefix"><code>--dll-search-prefix</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddotsyms"><code>--dotsyms</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddsbt_002dindex"><code>--dsbt-index</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddsbt_002dsize"><code>--dsbt-size</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddynamic_002dlinker_003dfile"><code>--dynamic-linker=<var>file</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddynamic_002dlist_002dcpp_002dnew"><code>--dynamic-list-cpp-new</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddynamic_002dlist_002dcpp_002dtypeinfo"><code>--dynamic-list-cpp-typeinfo</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddynamic_002dlist_002ddata"><code>--dynamic-list-data</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddynamic_002dlist_003ddynamic_002dlist_002dfile"><code>--dynamic-list=<var>dynamic-list-file</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ddynamicbase"><code>--dynamicbase</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002deh_002dframe_002dhdr"><code>--eh-frame-hdr</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dembedded_002drelocs"><code>--embedded-relocs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002demit_002drelocs"><code>--emit-relocs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002demit_002dstack_002dsyms"><code>--emit-stack-syms</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002demit_002dstub_002dsyms"><code>--emit-stub-syms</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC-ELF32">PowerPC ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002demit_002dstub_002dsyms-1"><code>--emit-stub-syms</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002demit_002dstub_002dsyms-2"><code>--emit-stub-syms</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002denable_002dauto_002dimage_002dbase"><code>--enable-auto-image-base</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002denable_002dauto_002dimport"><code>--enable-auto-import</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002denable_002dextra_002dpe_002ddebug"><code>--enable-extra-pe-debug</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002denable_002dlinker_002dversion"><code>--enable-linker-version</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002denable_002dlong_002dsection_002dnames"><code>--enable-long-section-names</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002denable_002dnew_002ddtags"><code>--enable-new-dtags</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002denable_002dnon_002dcontiguous_002dregions"><code>--enable-non-contiguous-regions</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002denable_002dnon_002dcontiguous_002dregions_002dwarnings"><code>--enable-non-contiguous-regions-warnings</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002denable_002dreloc_002dsection"><code>--enable-reloc-section</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002denable_002druntime_002dpseudo_002dreloc"><code>--enable-runtime-pseudo-reloc</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002denable_002dstdcall_002dfixup"><code>--enable-stdcall-fixup</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dentry_003dentry"><code>--entry=<var>entry</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002derror_002dhandling_002dscript_003dscriptname"><code>--error-handling-script=<var>scriptname</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002derror_002dunresolved_002dsymbols"><code>--error-unresolved-symbols</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dexclude_002dall_002dsymbols"><code>--exclude-all-symbols</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dexclude_002dlibs"><code>--exclude-libs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dexclude_002dmodules_002dfor_002dimplib"><code>--exclude-modules-for-implib</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dexclude_002dsymbols"><code>--exclude-symbols</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dexport_002dall_002dsymbols"><code>--export-all-symbols</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dexport_002ddynamic"><code>--export-dynamic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dexport_002ddynamic_002dsymbol_002dlist_003dfile"><code>--export-dynamic-symbol-list=<var>file</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dexport_002ddynamic_002dsymbol_003dglob"><code>--export-dynamic-symbol=<var>glob</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dextra_002doverlay_002dstubs"><code>--extra-overlay-stubs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dfatal_002dwarnings"><code>--fatal-warnings</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dfile_002dalignment"><code>--file-alignment</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dfilter_003dname"><code>--filter=<var>name</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dfix_002darm1176"><code>--fix-arm1176</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dfix_002dcortex_002da53_002d835769"><code>--fix-cortex-a53-835769</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dfix_002dcortex_002da8"><code>--fix-cortex-a8</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dfix_002dstm32l4xx_002d629360"><code>--fix-stm32l4xx-629360</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dfix_002dv4bx"><code>--fix-v4bx</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dfix_002dv4bx_002dinterworking"><code>--fix-v4bx-interworking</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dforce_002ddynamic"><code>--force-dynamic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dforce_002dexe_002dsuffix"><code>--force-exe-suffix</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dforce_002dgroup_002dallocation"><code>--force-group-allocation</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dforceinteg"><code>--forceinteg</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dformat_003dformat"><code>--format=<var>format</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dformat_003dversion"><code>--format=<var>version</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#TI-COFF">TI COFF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dgc_002dkeep_002dexported"><code>--gc-keep-exported</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dgc_002dsections"><code>--gc-sections</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dgot"><code>--got</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dgot_003dtype"><code>--got=<var>type</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#M68K">M68K</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dgpsize_003dvalue"><code>--gpsize=<var>value</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dhash_002dsize_003dnumber"><code>--hash-size=<var>number</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dhash_002dstyle_003dstyle"><code>--hash-style=<var>style</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dheap"><code>--heap</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dhelp"><code>--help</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dhigh_002dentropy_002dva"><code>--high-entropy-va</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dignore_002dbranch_002disa"><code>--ignore-branch-isa</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dignore_002dbranch_002disa-1"><code>--ignore-branch-isa</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MIPS">MIPS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dimage_002dbase"><code>--image-base</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dimagic"><code>--imagic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002din_002dimplib_003dfile"><code>--in-implib=<var>file</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dinsert_002dtimestamp"><code>--insert-timestamp</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dinsn32"><code>--insn32</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dinsn32-1"><code>--insn32</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MIPS">MIPS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002djust_002dsymbols_003dfile"><code>--just-symbols=<var>file</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dkill_002dat"><code>--kill-at</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dlarge_002daddress_002daware"><code>--large-address-aware</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dld_002dgenerated_002dunwind_002dinfo"><code>--ld-generated-unwind-info</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dleading_002dunderscore"><code>--leading-underscore</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dlibrary_002dpath_003ddir"><code>--library-path=<var>dir</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dlibrary_003dnamespec"><code>--library=<var>namespec</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dlocal_002dstore_003dlo_003ahi"><code>--local-store=lo:hi</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dlong_002dplt"><code>--long-plt</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dmajor_002dimage_002dversion"><code>--major-image-version</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dmajor_002dos_002dversion"><code>--major-os-version</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dmajor_002dsubsystem_002dversion"><code>--major-subsystem-version</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dmax_002dcache_002dsize_003dsize"><code>--max-cache-size=<var>size</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dmerge_002dexidx_002dentries"><code>--merge-exidx-entries</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dminor_002dimage_002dversion"><code>--minor-image-version</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dminor_002dos_002dversion"><code>--minor-os-version</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dminor_002dsubsystem_002dversion"><code>--minor-subsystem-version</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dmri_002dscript_003dMRI_002dcmdfile"><code>--mri-script=<var>MRI-cmdfile</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dmulti_002dsubspace"><code>--multi-subspace</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#HPPA-ELF32">HPPA ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dnmagic"><code>--nmagic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dnmagic-1"><code>--nmagic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002daccept_002dunknown_002dinput_002darch"><code>--no-accept-unknown-input-arch</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dadd_002dneeded"><code>--no-add-needed</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dallow_002dshlib_002dundefined"><code>--no-allow-shlib-undefined</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dapply_002ddynamic_002drelocs"><code>--no-apply-dynamic-relocs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002das_002dneeded"><code>--no-as-needed</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dbind"><code>--no-bind</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dcheck_002dsections"><code>--no-check-sections</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dcompact_002dbranches"><code>--no-compact-branches</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dcopy_002ddt_002dneeded_002dentries"><code>--no-copy-dt-needed-entries</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dctf_002dvariables"><code>--no-ctf-variables</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002ddefine_002dcommon"><code>--no-define-common</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002ddemangle"><code>--no-demangle</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002ddotsyms"><code>--no-dotsyms</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002ddynamic_002dlinker"><code>--no-dynamic-linker</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002deh_002dframe_002dhdr"><code>--no-eh-frame-hdr</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002denum_002dsize_002dwarning"><code>--no-enum-size-warning</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dexport_002ddynamic"><code>--no-export-dynamic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dfatal_002dwarnings"><code>--no-fatal-warnings</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dfix_002darm1176"><code>--no-fix-arm1176</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dfix_002dcortex_002da53_002d835769"><code>--no-fix-cortex-a53-835769</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dfix_002dcortex_002da8"><code>--no-fix-cortex-a8</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dgc_002dsections"><code>--no-gc-sections</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dignore_002dbranch_002disa"><code>--no-ignore-branch-isa</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dignore_002dbranch_002disa-1"><code>--no-ignore-branch-isa</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MIPS">MIPS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dinline_002doptimize"><code>--no-inline-optimize</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dinsn32"><code>--no-insn32</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dinsn32-1"><code>--no-insn32</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MIPS">MIPS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002disolation"><code>--no-isolation</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dkeep_002dmemory"><code>--no-keep-memory</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dleading_002dunderscore"><code>--no-leading-underscore</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dmerge_002dexidx_002dentries"><code>--no-merge-exidx-entries</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dmerge_002dexidx_002dentries-1"><code>--no-merge-exidx-entries</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dmulti_002dtoc"><code>--no-multi-toc</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002domagic"><code>--no-omagic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002domagic-1"><code>--no-omagic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dopd_002doptimize"><code>--no-opd-optimize</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002doverlays"><code>--no-overlays</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dplt_002dalign"><code>--no-plt-align</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dplt_002dlocalentry"><code>--no-plt-localentry</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dplt_002dstatic_002dchain"><code>--no-plt-static-chain</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dplt_002dthread_002dsafe"><code>--no-plt-thread-safe</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dpower10_002dstubs"><code>--no-power10-stubs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dprint_002dgc_002dsections"><code>--no-print-gc-sections</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dprint_002dmap_002ddiscarded"><code>--no-print-map-discarded</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dprint_002dmap_002dlocals"><code>--no-print-map-locals</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dsave_002drestore_002dfuncs"><code>--no-save-restore-funcs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dseh"><code>--no-seh</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dstrip_002ddiscarded"><code>--no-strip-discarded</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dtls_002dget_002daddr_002doptimize"><code>--no-tls-get-addr-optimize</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dtls_002dget_002daddr_002dregsave"><code>--no-tls-get-addr-regsave</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dtls_002doptimize"><code>--no-tls-optimize</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC-ELF32">PowerPC ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dtls_002doptimize-1"><code>--no-tls-optimize</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dtoc_002doptimize"><code>--no-toc-optimize</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dtoc_002dsort"><code>--no-toc-sort</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dtrampoline"><code>--no-trampoline</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dundefined"><code>--no-undefined</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dundefined_002dversion"><code>--no-undefined-version</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dwarn_002dmismatch"><code>--no-warn-mismatch</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dwarn_002dsearch_002dmismatch"><code>--no-warn-search-mismatch</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dwarnings"><code>--no-warnings</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dwchar_002dsize_002dwarning"><code>--no-wchar-size-warning</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002dwhole_002darchive"><code>--no-whole-archive</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dnoinhibit_002dexec"><code>--noinhibit-exec</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dnon_002doverlapping_002dopd"><code>--non-overlapping-opd</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dnxcompat"><code>--nxcompat</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002doformat_003doutput_002dformat"><code>--oformat=<var>output-format</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002domagic"><code>--omagic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002domagic-1"><code>--omagic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dorphan_002dhandling_003dMODE"><code>--orphan-handling=<var>MODE</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dout_002dimplib"><code>--out-implib</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002doutput_002ddef"><code>--output-def</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002doutput_003doutput"><code>--output=<var>output</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dpackage_002dmetadata_003dJSON"><code>--package-metadata=<var>JSON</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dpic_002dexecutable"><code>--pic-executable</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dpic_002dveneer"><code>--pic-veneer</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dplt_002dalign"><code>--plt-align</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dplt_002dlocalentry"><code>--plt-localentry</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dplt_002dstatic_002dchain"><code>--plt-static-chain</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dplt_002dthread_002dsafe"><code>--plt-thread-safe</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dplugin"><code>--plugin</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dpop_002dstate"><code>--pop-state</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dpower10_002dstubs"><code>--power10-stubs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dprint_002dgc_002dsections"><code>--print-gc-sections</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dprint_002dmap"><code>--print-map</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dprint_002dmap_002ddiscarded"><code>--print-map-discarded</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dprint_002dmap_002dlocals"><code>--print-map-locals</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dprint_002dmemory_002dusage"><code>--print-memory-usage</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dprint_002doutput_002dformat"><code>--print-output-format</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dpush_002dstate"><code>--push-state</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dreduce_002dmemory_002doverheads"><code>--reduce-memory-overheads</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002drelax"><code>--relax</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002drelax-on-Nios-II"><code>--relax on Nios II</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Nios-II">Nios II</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002drelax-on-PowerPC"><code>--relax on PowerPC</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC-ELF32">PowerPC ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002drelax-on-Xtensa"><samp>--relax</samp> on Xtensa</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Xtensa">Xtensa</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002drelocatable"><code>--relocatable</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dremap_002dinputs_002dfile_003dfile"><code>--remap-inputs-file=<samp>file</samp></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dremap_002dinputs_003dpattern_003dfilename"><code>--remap-inputs=<samp>pattern</samp>=<samp>filename</samp></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002drequire_002ddefined_003dsymbol"><code>--require-defined=<var>symbol</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dretain_002dsymbols_002dfile_003dfilename"><code>--retain-symbols-file=<var>filename</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002ds390_002dpgste"><code>--s390-pgste</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#S_002f390-ELF">S/390 ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dsave_002drestore_002dfuncs"><code>--save-restore-funcs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dscript_003dscript"><code>--script=<var>script</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dsdata_002dgot"><code>--sdata-got</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC-ELF32">PowerPC ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dsection_002dalignment"><code>--section-alignment</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dsection_002dstart_003dsectionname_003dorg"><code>--section-start=<var>sectionname</var>=<var>org</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dsecure_002dplt"><code>--secure-plt</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC-ELF32">PowerPC ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dsort_002dcommon"><code>--sort-common</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dsort_002dsection_003dalignment"><code>--sort-section=alignment</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dsort_002dsection_003dname"><code>--sort-section=name</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dspare_002ddynamic_002dtags"><code>--spare-dynamic-tags</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dsplit_002dby_002dfile"><code>--split-by-file</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dsplit_002dby_002dreloc"><code>--split-by-reloc</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dstack"><code>--stack</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dstack_002danalysis"><code>--stack-analysis</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dstats"><code>--stats</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dstrip_002dall"><code>--strip-all</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dstrip_002ddebug"><code>--strip-debug</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dstrip_002ddiscarded"><code>--strip-discarded</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dstub_002dgroup_002dsize"><code>--stub-group-size</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dstub_002dgroup_002dsize-on-C_002dSKY"><code>--stub-group-size on C-SKY</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dstub_002dgroup_002dsize_003dN"><code>--stub-group-size=<var>N</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dstub_002dgroup_002dsize_003dN-1"><code>--stub-group-size=<var>N</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#HPPA-ELF32">HPPA ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dsubsystem"><code>--subsystem</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dsupport_002dold_002dcode"><code>--support-old-code</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dsysroot_003ddirectory"><code>--sysroot=<var>directory</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dtarget_002dhelp"><code>--target-help</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dtarget1_002dabs"><code>--target1-abs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dtarget1_002drel"><code>--target1-rel</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dtarget2_003dtype"><code>--target2=<var>type</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dtask_002dlink"><code>--task-link</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dthumb_002dentry_003dentry"><code>--thumb-entry=<var>entry</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dtls_002dget_002daddr_002doptimize"><code>--tls-get-addr-optimize</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dtls_002dget_002daddr_002dregsave"><code>--tls-get-addr-regsave</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dtrace"><code>--trace</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dtrace_002dsymbol_003dsymbol"><code>--trace-symbol=<var>symbol</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dtraditional_002dformat"><code>--traditional-format</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dtsaware"><code>--tsaware</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dundefined_003dsymbol"><code>--undefined=<var>symbol</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dunique_005b_003dSECTION_005d"><code>--unique[=<var>SECTION</var>]</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dunresolved_002dsymbols"><code>--unresolved-symbols</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002duse_002dblx"><code>--use-blx</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002duse_002dnul_002dprefixed_002dimport_002dtables"><code>--use-nul-prefixed-import-tables</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dverbose_005b_003dNUMBER_005d"><code>--verbose[=<var>NUMBER</var>]</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dversion"><code>--version</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dversion_002dscript_003dversion_002dscriptfile"><code>--version-script=<var>version-scriptfile</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dvfp11_002ddenorm_002dfix"><code>--vfp11-denorm-fix</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dwarn_002dalternate_002dem"><code>--warn-alternate-em</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dwarn_002dcommon"><code>--warn-common</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dwarn_002dconstructors"><code>--warn-constructors</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dwarn_002dexecstack"><code>--warn-execstack</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dwarn_002dmultiple_002dgp"><code>--warn-multiple-gp</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dwarn_002donce"><code>--warn-once</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dwarn_002drwx_002dsegments"><code>--warn-rwx-segments</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dwarn_002dsection_002dalign"><code>--warn-section-align</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dwarn_002dtextrel"><code>--warn-textrel</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dwarn_002dunresolved_002dsymbols"><code>--warn-unresolved-symbols</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dwdmdriver"><code>--wdmdriver</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dwhole_002darchive"><code>--whole-archive</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dwrap_003dsymbol"><code>--wrap=<var>symbol</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002da-keyword"><code>-a <var>keyword</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dassert-keyword"><code>-assert <var>keyword</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002db-format"><code>-b <var>format</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dBdynamic"><code>-Bdynamic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dBgroup"><code>-Bgroup</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dBno_002dsymbolic"><code>-Bno-symbolic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dBshareable"><code>-Bshareable</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dBstatic"><code>-Bstatic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dBsymbolic"><code>-Bsymbolic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dBsymbolic_002dfunctions"><code>-Bsymbolic-functions</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dc-MRI_002dcmdfile"><code>-c <var>MRI-cmdfile</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dcall_005fshared"><code>-call_shared</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dd"><code>-d</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002ddc"><code>-dc</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002ddn"><code>-dn</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002ddp"><code>-dp</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002ddT-script"><code>-dT <var>script</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002ddy"><code>-dy</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dE"><code>-E</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002de-entry"><code>-e <var>entry</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dEB"><code>-EB</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dEL"><code>-EL</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002df-name"><code>-f <var>name</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dF-name"><code>-F <var>name</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dfini_003dname"><code>-fini=<var>name</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dg"><code>-g</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dG-value"><code>-G <var>value</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dh-name"><code>-h <var>name</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002di"><code>-i</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dIfile"><code>-I<var>file</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dinit_003dname"><code>-init=<var>name</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dL-dir"><code>-L <var>dir</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dl-namespec"><code>-l <var>namespec</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dM"><code>-M</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dm-emulation"><code>-m <var>emulation</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dMap_003dmapfile"><code>-Map=<var>mapfile</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dn"><code>-n</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dN"><code>-N</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dN-1"><code>-N</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dn-1"><code>-n</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dno_002dpie"><code>-no-pie</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002d_002dno_002drelax">&ndash;no-relax</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dnon_005fshared"><code>-non_shared</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dnostdlib"><code>-nostdlib</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dO-level"><code>-O <var>level</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002do-output"><code>-o <var>output</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dP-AUDITLIB"><code>-P <var>AUDITLIB</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dpie"><code>-pie</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dplugin-name"><code>-plugin <var>name</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dq"><code>-q</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dqmagic"><code>-qmagic</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dQy"><code>-Qy</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dr"><code>-r</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dR-file"><code>-R <var>file</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002drpath_002dlink_003ddir"><code>-rpath-link=<var>dir</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002drpath_003ddir"><code>-rpath=<var>dir</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002ds"><code>-s</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dS"><code>-S</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dshared"><code>-shared</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dsoname_003dname"><code>-soname=<var>name</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dstatic"><code>-static</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dt"><code>-t</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dT-script"><code>-T <var>script</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dTbss_003dorg"><code>-Tbss=<var>org</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dTdata_003dorg"><code>-Tdata=<var>org</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dTldata_002dsegment_003dorg"><code>-Tldata-segment=<var>org</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dTrodata_002dsegment_003dorg"><code>-Trodata-segment=<var>org</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dTtext_002dsegment_003dorg"><code>-Ttext-segment=<var>org</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dTtext_003dorg"><code>-Ttext=<var>org</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002du-symbol"><code>-u <var>symbol</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dUr"><code>-Ur</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dv"><code>-v</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dV"><code>-V</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dw"><code>-w</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dx"><code>-x</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dX"><code>-X</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dY-path"><code>-Y <var>path</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dy-symbol"><code>-y <var>symbol</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dz"><code>-z</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dz-defs"><code>-z defs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dz-keyword"><code>-z <var>keyword</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dz-muldefs"><code>-z muldefs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002dz-undefs"><code>-z undefs</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_symbol-3">.</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002e"><code>.</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Location-Counter">Location Counter</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_symbol-4">/</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_002fDISCARD_002f">/DISCARD/</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Discarding">Output Section Discarding</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_symbol-5">3</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-32_002dbit-PLT-entries">32-bit PLT entries</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_symbol-6">:</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_003aphdr"><code>:<var>phdr</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Phdr">Output Section Phdr</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_symbol-7">=</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_003dfillexp"><code>=<var>fillexp</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Fill">Output Section Fill</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_symbol-8">&gt;</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_003eregion"><code>&gt;<var>region</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Region">Output Section Region</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_symbol-9">[</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-_005bCOMMON_005d">[COMMON]</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Common">Input Section Common</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-A">A</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-AArch64-rela-addend">AArch64 rela addend</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ABSOLUTE-_0028MRI_0029"><code>ABSOLUTE</code> (MRI)</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-absolute-and-relocatable-symbols">absolute and relocatable symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Expression-Section">Expression Section</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-absolute-expressions">absolute expressions</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Expression-Section">Expression Section</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ABSOLUTE_0028exp_0029"><code>ABSOLUTE(<var>exp</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ADDR_0028section_0029"><code>ADDR(<var>section</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-address_002c-section">address, section</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Address">Output Section Address</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ALIAS-_0028MRI_0029"><code>ALIAS</code> (MRI)</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ALIGN-_0028MRI_0029"><code>ALIGN</code> (MRI)</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-align-expression">align expression</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-align-location-counter">align location counter</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ALIGN_0028align_0029"><code>ALIGN(<var>align</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ALIGN_0028exp_002calign_0029"><code>ALIGN(<var>exp</var>,<var>align</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ALIGN_0028section_005falign_0029"><code>ALIGN(<var>section_align</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Forced-Output-Alignment">Forced Output Alignment</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-aligned-common-symbols">aligned common symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#WIN32">WIN32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ALIGNOF_0028section_0029"><code>ALIGNOF(<var>section</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-allocating-memory">allocating memory</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MEMORY">MEMORY</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-architecture">architecture</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-archive-files_002c-from-cmd-line">archive files, from cmd line</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-archive-search-path-in-linker-script">archive search path in linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-arithmetic">arithmetic</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Expressions">Expressions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-arithmetic-operators">arithmetic operators</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Operators">Operators</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ARM-interworking-support">ARM interworking support</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ARM1176-erratum-workaround">ARM1176 erratum workaround</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ASCIZ-_0060_0060string_0027_0027"><code>ASCIZ ``<var>string</var>''</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ASSERT"><code>ASSERT</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-assertion-in-linker-script">assertion in linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-assignment-in-scripts">assignment in scripts</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Assignments">Assignments</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-AS_005fNEEDED_0028files_0029"><code>AS_NEEDED(<var>files</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-AT_0028lma_0029"><code>AT(<var>lma</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-LMA">Output Section LMA</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-AT_003elma_005fregion"><code>AT&gt;<var>lma_region</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-LMA">Output Section LMA</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-automatic-data-imports">automatic data imports</a>:</td><td>&nbsp;</td><td valign="top"><a href="#WIN32">WIN32</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-B">B</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-back-end">back end</a>:</td><td>&nbsp;</td><td valign="top"><a href="#BFD">BFD</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-BASE-_0028MRI_0029"><code>BASE</code> (MRI)</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-BE8">BE8</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-BFD-canonical-format">BFD canonical format</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Canonical-format">Canonical format</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-BFD-requirements">BFD requirements</a>:</td><td>&nbsp;</td><td valign="top"><a href="#BFD">BFD</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-big_002dendian-objects">big-endian objects</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-binary-input-format">binary input format</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-BLOCK_0028exp_0029"><code>BLOCK(<var>exp</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-bug-criteria">bug criteria</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Bug-Criteria">Bug Criteria</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-bug-reports">bug reports</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Bug-Reporting">Bug Reporting</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-bugs-in-ld">bugs in <code>ld</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Reporting-Bugs">Reporting Bugs</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-BYTE_0028expression_0029"><code>BYTE(<var>expression</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-C">C</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-C_002b_002b-constructors_002c-arranging-in-link">C++ constructors, arranging in link</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Keywords">Output Section Keywords</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-CHIP-_0028MRI_0029"><code>CHIP</code> (MRI)</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-COLLECT_005fNO_005fDEMANGLE"><code>COLLECT_NO_DEMANGLE</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Environment">Environment</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-combining-symbols_002c-warnings-on">combining symbols, warnings on</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-COMDAT">COMDAT</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-COMDAT-1">COMDAT</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-command-files">command files</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Scripts">Scripts</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-command-line">command line</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-common-allocation">common allocation</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-common-allocation-1">common allocation</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-common-allocation-in-linker-script">common allocation in linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-common-allocation-in-linker-script-1">common allocation in linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-common-symbol-placement">common symbol placement</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Common">Input Section Common</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-COMMONPAGESIZE"><code>COMMONPAGESIZE</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Symbolic-Constants">Symbolic Constants</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-compatibility_002c-MRI">compatibility, MRI</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-CONSTANT"><code>CONSTANT</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Symbolic-Constants">Symbolic Constants</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-constants-in-linker-scripts">constants in linker scripts</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Constants">Constants</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-constraints-on-output-sections">constraints on output sections</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Constraint">Output Section Constraint</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-constructors">constructors</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-CONSTRUCTORS"><code>CONSTRUCTORS</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Keywords">Output Section Keywords</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-constructors_002c-arranging-in-link">constructors, arranging in link</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Keywords">Output Section Keywords</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-Cortex_002dA53-erratum-835769-workaround">Cortex-A53 erratum 835769 workaround</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-Cortex_002dA8-erratum-workaround">Cortex-A8 erratum workaround</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-crash-of-linker">crash of linker</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Bug-Criteria">Bug Criteria</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-CREATE_005fOBJECT_005fSYMBOLS"><code>CREATE_OBJECT_SYMBOLS</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Keywords">Output Section Keywords</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-creating-a-DEF-file">creating a DEF file</a>:</td><td>&nbsp;</td><td valign="top"><a href="#WIN32">WIN32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-cross-reference-table">cross reference table</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-cross-references">cross references</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-cross-references-1">cross references</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ctf-type-sharing">ctf type sharing</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ctf-variables">ctf variables</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-current-output-location">current output location</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Location-Counter">Location Counter</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-D">D</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-data">data</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-DATA_005fSEGMENT_005fALIGN_0028maxpagesize_002c-commonpagesize_0029"><code>DATA_SEGMENT_ALIGN(<var>maxpagesize</var>, <var>commonpagesize</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-DATA_005fSEGMENT_005fEND_0028exp_0029"><code>DATA_SEGMENT_END(<var>exp</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-DATA_005fSEGMENT_005fRELRO_005fEND_0028offset_002c-exp_0029"><code>DATA_SEGMENT_RELRO_END(<var>offset</var>, <var>exp</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-dbx">dbx</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-DEF-files_002c-creating">DEF files, creating</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-default-emulation">default emulation</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Environment">Environment</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-default-input-format">default input format</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Environment">Environment</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-defined-symbol">defined symbol</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-DEFINED_0028symbol_0029"><code>DEFINED(<var>symbol</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-deleting-local-symbols">deleting local symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-demangling_002c-default">demangling, default</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Environment">Environment</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-demangling_002c-from-command-line">demangling, from command line</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-dependency-file">dependency file</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-direct-linking-to-a-dll">direct linking to a dll</a>:</td><td>&nbsp;</td><td valign="top"><a href="#WIN32">WIN32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-discarding-sections">discarding sections</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Discarding">Output Section Discarding</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-discontinuous-memory">discontinuous memory</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MEMORY">MEMORY</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-DLLs_002c-creating">DLLs, creating</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-DLLs_002c-creating-1">DLLs, creating</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-DLLs_002c-creating-2">DLLs, creating</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-DLLs_002c-linking-to">DLLs, linking to</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-dot">dot</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Location-Counter">Location Counter</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-dot-inside-sections">dot inside sections</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Location-Counter">Location Counter</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-dot-outside-sections">dot outside sections</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Location-Counter">Location Counter</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-dynamic-linker_002c-from-command-line">dynamic linker, from command line</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-dynamic-symbol-table">dynamic symbol table</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-E">E</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ELF-program-headers">ELF program headers</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PHDRS">PHDRS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ELF-symbol-visibility">ELF symbol visibility</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-emulation">emulation</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-emulation_002c-default">emulation, default</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Environment">Environment</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-END-_0028MRI_0029"><code>END</code> (MRI)</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-endianness">endianness</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-entry-point">entry point</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Entry-Point">Entry Point</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-entry-point_002c-from-command-line">entry point, from command line</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-entry-point_002c-thumb">entry point, thumb</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ENTRY_0028symbol_0029"><code>ENTRY(<var>symbol</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Entry-Point">Entry Point</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-error-on-valid-input">error on valid input</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Bug-Criteria">Bug Criteria</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-example-of-linker-script">example of linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Simple-Example">Simple Example</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-EXCLUDE_005fFILE">EXCLUDE_FILE</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Basics">Input Section Basics</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-executable-segments_002c-warnings-on">executable segments, warnings on</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-executable-stack_002c-warnings-on">executable stack, warnings on</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-export-dynamic-symbol">export dynamic symbol</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-export-dynamic-symbol-list">export dynamic symbol list</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-exporting-DLL-symbols">exporting DLL symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#WIN32">WIN32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-expression-evaluation-order">expression evaluation order</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Evaluation">Evaluation</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-expression-sections">expression sections</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Expression-Section">Expression Section</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-expression_002c-absolute">expression, absolute</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-expressions">expressions</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Expressions">Expressions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-EXTERN"><code>EXTERN</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-F">F</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-fatal-signal">fatal signal</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Bug-Criteria">Bug Criteria</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-file-name-wildcard-patterns">file name wildcard patterns</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Wildcards">Input Section Wildcards</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-FILEHDR"><code>FILEHDR</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PHDRS">PHDRS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-filename-symbols">filename symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Keywords">Output Section Keywords</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-fill-pattern_002c-entire-section">fill pattern, entire section</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Fill">Output Section Fill</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-FILL_0028expression_0029"><code>FILL(<var>expression</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-finalization-function">finalization function</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-first-input-file">first input file</a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-first-instruction">first instruction</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Entry-Point">Entry Point</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-FIX_005fV4BX">FIX_V4BX</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-FIX_005fV4BX_005fINTERWORKING">FIX_V4BX_INTERWORKING</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-FORCE_005fCOMMON_005fALLOCATION"><code>FORCE_COMMON_ALLOCATION</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-FORCE_005fGROUP_005fALLOCATION"><code>FORCE_GROUP_ALLOCATION</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-forcing-input-section-alignment">forcing input section alignment</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Forced-Input-Alignment">Forced Input Alignment</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-forcing-output-section-alignment">forcing output section alignment</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Forced-Output-Alignment">Forced Output Alignment</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-forcing-the-creation-of-dynamic-sections">forcing the creation of dynamic sections</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-FORMAT-_0028MRI_0029"><code>FORMAT</code> (MRI)</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-functions-in-expressions">functions in expressions</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-G">G</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-garbage-collection">garbage collection</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-garbage-collection-1">garbage collection</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-garbage-collection-2">garbage collection</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-garbage-collection-3">garbage collection</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Keep">Input Section Keep</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-generating-optimized-output">generating optimized output</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-GNU-linker"><small>GNU</small> linker</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Overview">Overview</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-GNUTARGET"><code>GNUTARGET</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Environment">Environment</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-group-allocation-in-linker-script">group allocation in linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-group-allocation-in-linker-script-1">group allocation in linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-GROUP_0028files_0029"><code>GROUP(<var>files</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-grouping-input-files">grouping input files</a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-groups-of-archives">groups of archives</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-H">H</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-H8_002f300-support">H8/300 support</a>:</td><td>&nbsp;</td><td valign="top"><a href="#H8_002f300">H8/300</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-header-size">header size</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-heap-size">heap size</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-help">help</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-HIDDEN">HIDDEN</a>:</td><td>&nbsp;</td><td valign="top"><a href="#HIDDEN">HIDDEN</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-holes">holes</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Location-Counter">Location Counter</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-holes_002c-filling">holes, filling</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-HPPA-multiple-sub_002dspace-stubs">HPPA multiple sub-space stubs</a>:</td><td>&nbsp;</td><td valign="top"><a href="#HPPA-ELF32">HPPA ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-HPPA-stub-grouping">HPPA stub grouping</a>:</td><td>&nbsp;</td><td valign="top"><a href="#HPPA-ELF32">HPPA ELF32</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-I">I</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-image-base">image base</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-implicit-linker-scripts">implicit linker scripts</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Implicit-Linker-Scripts">Implicit Linker Scripts</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-import-libraries">import libraries</a>:</td><td>&nbsp;</td><td valign="top"><a href="#WIN32">WIN32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-INCLUDE-filename"><code>INCLUDE <var>filename</var></code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-including-a-linker-script">including a linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-including-an-entire-archive">including an entire archive</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-incremental-link">incremental link</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-INHIBIT_005fCOMMON_005fALLOCATION"><code>INHIBIT_COMMON_ALLOCATION</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-initialization-function">initialization function</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-initialized-data-in-ROM">initialized data in ROM</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-LMA">Output Section LMA</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-input-file-format-in-linker-script">input file format in linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Format-Commands">Format Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-input-filename-symbols">input filename symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Keywords">Output Section Keywords</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-input-files-in-linker-scripts">input files in linker scripts</a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-input-files_002c-displaying">input files, displaying</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-input-format">input format</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-input-format-1">input format</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-Input-import-library">Input import library</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-input-object-files-in-linker-scripts">input object files in linker scripts</a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-input-section-alignment">input section alignment</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Forced-Input-Alignment">Forced Input Alignment</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-input-section-basics">input section basics</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Basics">Input Section Basics</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-input-section-wildcards">input section wildcards</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Wildcards">Input Section Wildcards</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-input-sections">input sections</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section">Input Section</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-INPUT_0028files_0029"><code>INPUT(<var>files</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-INSERT"><code>INSERT</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-insert-user-script-into-default-script">insert user script into default script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-integer-notation">integer notation</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Constants">Constants</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-integer-suffixes">integer suffixes</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Constants">Constants</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-internal-object_002dfile-format">internal object-file format</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Canonical-format">Canonical format</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-invalid-input">invalid input</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Bug-Criteria">Bug Criteria</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-K">K</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-K-and-M-integer-suffixes">K and M integer suffixes</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Constants">Constants</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-KEEP">KEEP</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Keep">Input Section Keep</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-L">L</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-l-_003d"><code>l =</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MEMORY">MEMORY</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-lazy-evaluation">lazy evaluation</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Evaluation">Evaluation</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ld-bugs_002c-reporting"><code>ld</code> bugs, reporting</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Bug-Reporting">Bug Reporting</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ldata-segment-origin_002c-cmd-line">ldata segment origin, cmd line</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-LDEMULATION"><code>LDEMULATION</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Environment">Environment</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-LD_005fFEATURE_0028string_0029"><code>LD_FEATURE(<var>string</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-len-_003d"><code>len =</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MEMORY">MEMORY</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-LENGTH-_003d"><code>LENGTH =</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MEMORY">MEMORY</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-LENGTH_0028memory_0029"><code>LENGTH(<var>memory</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-library-search-path-in-linker-script">library search path in linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-link-map">link map</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-link-map-discarded">link map discarded</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-link_002dtime-runtime-library-search-path">link-time runtime library search path</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-linker-crash">linker crash</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Bug-Criteria">Bug Criteria</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-linker-plugins">linker plugins</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Plugins">Plugins</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-linker-script-concepts">linker script concepts</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Basic-Script-Concepts">Basic Script Concepts</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-linker-script-example">linker script example</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Simple-Example">Simple Example</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-linker-script-file-commands">linker script file commands</a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-linker-script-format">linker script format</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Script-Format">Script Format</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-linker-script-input-object-files">linker script input object files</a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-linker-script-simple-commands">linker script simple commands</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Simple-Commands">Simple Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-linker-scripts">linker scripts</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Scripts">Scripts</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-LINKER_005fVERSION">LINKER_VERSION</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-LINKER_005fVERSION-1"><code>LINKER_VERSION</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-LIST-_0028MRI_0029"><code>LIST</code> (MRI)</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-little_002dendian-objects">little-endian objects</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-LOAD-_0028MRI_0029"><code>LOAD</code> (MRI)</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-load-address">load address</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-LMA">Output Section LMA</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-LOADADDR_0028section_0029"><code>LOADADDR(<var>section</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-loading_002c-preventing">loading, preventing</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Type">Output Section Type</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-local-symbols_002c-deleting">local symbols, deleting</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-location-counter">location counter</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Location-Counter">Location Counter</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-LOG2CEIL_0028exp_0029"><code>LOG2CEIL(<var>exp</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-LONG_0028expression_0029"><code>LONG(<var>expression</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-M">M</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-M-and-K-integer-suffixes">M and K integer suffixes</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Constants">Constants</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-M68HC11-and-68HC12-support">M68HC11 and 68HC12 support</a>:</td><td>&nbsp;</td><td valign="top"><a href="#M68HC11_002f68HC12">M68HC11/68HC12</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-machine-architecture">machine architecture</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-machine-dependencies">machine dependencies</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Machine-Dependent">Machine Dependent</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-mapping-input-sections-to-output-sections">mapping input sections to output sections</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section">Input Section</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-MAX"><code>MAX</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-MAXPAGESIZE"><code>MAXPAGESIZE</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Symbolic-Constants">Symbolic Constants</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-MEMORY"><code>MEMORY</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MEMORY">MEMORY</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-memory-region-attributes">memory region attributes</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MEMORY">MEMORY</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-memory-regions">memory regions</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MEMORY">MEMORY</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-memory-regions-and-sections">memory regions and sections</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Region">Output Section Region</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-memory-usage">memory usage</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-memory-usage-1">memory usage</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-Merging-exidx-entries">Merging exidx entries</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-MIN"><code>MIN</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-MIPS-branch-relocation-check-control">MIPS branch relocation check control</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MIPS">MIPS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-MIPS-microMIPS-instruction-choice-selection">MIPS microMIPS instruction choice selection</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MIPS">MIPS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-Motorola-68K-GOT-generation">Motorola 68K GOT generation</a>:</td><td>&nbsp;</td><td valign="top"><a href="#M68K">M68K</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-MRI-compatibility">MRI compatibility</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-MSP430-extra-sections">MSP430 extra sections</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MSP430">MSP430</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-MSP430-Options">MSP430 Options</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MSP430">MSP430</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-N">N</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-NAME-_0028MRI_0029"><code>NAME</code> (MRI)</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-name_002c-section">name, section</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Name">Output Section Name</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-names">names</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Symbols">Symbols</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-naming-the-output-file">naming the output file</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-NEXT_0028exp_0029"><code>NEXT(<var>exp</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-Nios-II-call-relaxation">Nios II call relaxation</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Nios-II">Nios II</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-NMAGIC">NMAGIC</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-NOCROSSREFS_0028sections_0029"><code>NOCROSSREFS(<var>sections</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-NOCROSSREFS_005fTO_0028tosection-fromsections_0029"><code>NOCROSSREFS_TO(<var>tosection</var> <var>fromsections</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-NOLOAD"><code>NOLOAD</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Type">Output Section Type</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-not-enough-room-for-program-headers">not enough room for program headers</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-NO_005fENUM_005fSIZE_005fWARNING">NO_ENUM_SIZE_WARNING</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-NO_005fWCHAR_005fSIZE_005fWARNING">NO_WCHAR_SIZE_WARNING</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-O">O</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-o-_003d"><code>o =</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MEMORY">MEMORY</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-objdump-_002di"><code>objdump -i</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#BFD">BFD</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-object-file-management">object file management</a>:</td><td>&nbsp;</td><td valign="top"><a href="#BFD">BFD</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-object-files">object files</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-object-formats-available">object formats available</a>:</td><td>&nbsp;</td><td valign="top"><a href="#BFD">BFD</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-object-size">object size</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-OMAGIC">OMAGIC</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-OMAGIC-1">OMAGIC</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ONLY_005fIF_005fRO"><code>ONLY_IF_RO</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Constraint">Output Section Constraint</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ONLY_005fIF_005fRW"><code>ONLY_IF_RW</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Constraint">Output Section Constraint</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-opening-object-files">opening object files</a>:</td><td>&nbsp;</td><td valign="top"><a href="#BFD-outline">BFD outline</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-operators-for-arithmetic">operators for arithmetic</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Operators">Operators</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-options">options</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ORDER-_0028MRI_0029"><code>ORDER</code> (MRI)</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-org-_003d"><code>org =</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MEMORY">MEMORY</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ORIGIN-_003d"><code>ORIGIN =</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#MEMORY">MEMORY</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ORIGIN_0028memory_0029"><code>ORIGIN(<var>memory</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-orphan">orphan</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Orphan-Sections">Orphan Sections</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-orphan-sections">orphan sections</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-output-file-after-errors">output file after errors</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-output-file-format-in-linker-script">output file format in linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Format-Commands">Format Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-output-file-name-in-linker-script">output file name in linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-output-format">output format</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-output-section-alignment">output section alignment</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Forced-Output-Alignment">Forced Output Alignment</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-output-section-attributes">output section attributes</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Attributes">Output Section Attributes</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-output-section-data">output section data</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-OUTPUT_0028filename_0029"><code>OUTPUT(<var>filename</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-OUTPUT_005fARCH_0028bfdarch_0029"><code>OUTPUT_ARCH(<var>bfdarch</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-OUTPUT_005fFORMAT_0028bfdname_0029"><code>OUTPUT_FORMAT(<var>bfdname</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Format-Commands">Format Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-OVERLAY"><code>OVERLAY</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Overlay-Description">Overlay Description</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-overlays">overlays</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Overlay-Description">Overlay Description</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-P">P</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-partial-link">partial link</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PE-import-table-prefixing">PE import table prefixing</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PHDRS"><code>PHDRS</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PHDRS">PHDRS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PHDRS-1"><code>PHDRS</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#PHDRS">PHDRS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PIC_005fVENEER">PIC_VENEER</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-Placement-of-SG-veneers">Placement of SG veneers</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-plugins">plugins</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Plugins">Plugins</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-pop-state-governing-input-file-handling">pop state governing input file handling</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-position-dependent-executables">position dependent executables</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-position-independent-executables">position independent executables</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC-ELF32-options">PowerPC ELF32 options</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC-ELF32">PowerPC ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC-GOT">PowerPC GOT</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC-ELF32">PowerPC ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC-long-branches">PowerPC long branches</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC-ELF32">PowerPC ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC-PLT">PowerPC PLT</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC-ELF32">PowerPC ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC-stub-symbols">PowerPC stub symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC-ELF32">PowerPC ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC-TLS-optimization">PowerPC TLS optimization</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC-ELF32">PowerPC ELF32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-dot-symbols">PowerPC64 dot symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-ELF64-options">PowerPC64 ELF64 options</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-ELFv2-PLT-localentry-optimization">PowerPC64 ELFv2 PLT localentry optimization</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-inline-PLT-call-optimization">PowerPC64 inline PLT call optimization</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-multi_002dTOC">PowerPC64 multi-TOC</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-OPD-optimization">PowerPC64 OPD optimization</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-OPD-spacing">PowerPC64 OPD spacing</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-PLT-call-stub-static-chain">PowerPC64 PLT call stub static chain</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-PLT-call-stub-thread-safety">PowerPC64 PLT call stub thread safety</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-PLT-stub-alignment">PowerPC64 PLT stub alignment</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-Power10-stubs">PowerPC64 Power10 stubs</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-register-save_002frestore-functions">PowerPC64 register save/restore functions</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-stub-grouping">PowerPC64 stub grouping</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-stub-symbols">PowerPC64 stub symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-TLS-optimization">PowerPC64 TLS optimization</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-TOC-optimization">PowerPC64 TOC optimization</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-TOC-sorting">PowerPC64 TOC sorting</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PowerPC64-_005f_005ftls_005fget_005faddr-optimization">PowerPC64 __tls_get_addr optimization</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PowerPC64-ELF64">PowerPC64 ELF64</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-precedence-in-expressions">precedence in expressions</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Operators">Operators</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-prevent-unnecessary-loading">prevent unnecessary loading</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Type">Output Section Type</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-program-headers">program headers</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PHDRS">PHDRS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-program-headers-and-sections">program headers and sections</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Phdr">Output Section Phdr</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-program-headers_002c-not-enough-room">program headers, not enough room</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-program-segments">program segments</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PHDRS">PHDRS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PROVIDE">PROVIDE</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PROVIDE">PROVIDE</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PROVIDE_005fHIDDEN">PROVIDE_HIDDEN</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PROVIDE_005fHIDDEN">PROVIDE_HIDDEN</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-PUBLIC-_0028MRI_0029"><code>PUBLIC</code> (MRI)</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-push-state-governing-input-file-handling">push state governing input file handling</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-Q">Q</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-QUAD_0028expression_0029"><code>QUAD(<var>expression</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-quoted-symbol-names">quoted symbol names</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Symbols">Symbols</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-R">R</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-read_002donly-text">read-only text</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-read_002fwrite-from-cmd-line">read/write from cmd line</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-region-alias">region alias</a>:</td><td>&nbsp;</td><td valign="top"><a href="#REGION_005fALIAS">REGION_ALIAS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-region-names">region names</a>:</td><td>&nbsp;</td><td valign="top"><a href="#REGION_005fALIAS">REGION_ALIAS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-regions-of-memory">regions of memory</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MEMORY">MEMORY</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-REGION_005fALIAS_0028alias_002c-region_0029"><code>REGION_ALIAS(<var>alias</var>, <var>region</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#REGION_005fALIAS">REGION_ALIAS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-relative-expressions">relative expressions</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Expression-Section">Expression Section</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-relaxing-addressing-modes">relaxing addressing modes</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-relaxing-on-H8_002f300">relaxing on H8/300</a>:</td><td>&nbsp;</td><td valign="top"><a href="#H8_002f300">H8/300</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-relaxing-on-M68HC11">relaxing on M68HC11</a>:</td><td>&nbsp;</td><td valign="top"><a href="#M68HC11_002f68HC12">M68HC11/68HC12</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-relaxing-on-NDS32"><code>relaxing on NDS32</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#NDS32">NDS32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-relaxing-on-Xtensa">relaxing on Xtensa</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Xtensa">Xtensa</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-relocatable-and-absolute-symbols">relocatable and absolute symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Expression-Section">Expression Section</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-relocatable-output">relocatable output</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-remapping-inputs">remapping inputs</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-removing-sections">removing sections</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Discarding">Output Section Discarding</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-reporting-bugs-in-ld">reporting bugs in <code>ld</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Reporting-Bugs">Reporting Bugs</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-requirements-for-BFD">requirements for BFD</a>:</td><td>&nbsp;</td><td valign="top"><a href="#BFD">BFD</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-retain-relocations-in-final-executable">retain relocations in final executable</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-retaining-specified-symbols">retaining specified symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-rodata-segment-origin_002c-cmd-line">rodata segment origin, cmd line</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-ROM-initialized-data">ROM initialized data</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-LMA">Output Section LMA</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-round-up-expression">round up expression</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-round-up-location-counter">round up location counter</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-runtime-library-name">runtime library name</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-runtime-library-search-path">runtime library search path</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-runtime-pseudo_002drelocation">runtime pseudo-relocation</a>:</td><td>&nbsp;</td><td valign="top"><a href="#WIN32">WIN32</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-S">S</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-S_002f390">S/390</a>:</td><td>&nbsp;</td><td valign="top"><a href="#S_002f390-ELF">S/390 ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-S_002f390-ELF-options">S/390 ELF options</a>:</td><td>&nbsp;</td><td valign="top"><a href="#S_002f390-ELF">S/390 ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-scaled-integers">scaled integers</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Constants">Constants</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-scommon-section">scommon section</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Common">Input Section Common</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-script-files">script files</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-script-files-1">script files</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-scripts">scripts</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Scripts">Scripts</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-search-directory_002c-from-cmd-line">search directory, from cmd line</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-search-path-in-linker-script">search path in linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SEARCH_005fDIR_0028path_0029"><code>SEARCH_DIR(<var>path</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SECT-_0028MRI_0029"><code>SECT</code> (MRI)</a>:</td><td>&nbsp;</td><td valign="top"><a href="#MRI">MRI</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section-address">section address</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Address">Output Section Address</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section-address-in-expression">section address in expression</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section-alignment">section alignment</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section-alignment_002c-warnings-on">section alignment, warnings on</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section-data">section data</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section-fill-pattern">section fill pattern</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Fill">Output Section Fill</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section-groups">section groups</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section-groups-1">section groups</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section-load-address">section load address</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-LMA">Output Section LMA</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section-load-address-in-expression">section load address in expression</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section-name">section name</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Name">Output Section Name</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section-name-wildcard-patterns">section name wildcard patterns</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Wildcards">Input Section Wildcards</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section-size">section size</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section_002c-assigning-to-memory-region">section, assigning to memory region</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Region">Output Section Region</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-section_002c-assigning-to-program-header">section, assigning to program header</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Phdr">Output Section Phdr</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SECTIONS"><code>SECTIONS</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#SECTIONS">SECTIONS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-sections_002c-discarding">sections, discarding</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Discarding">Output Section Discarding</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-sections_002c-orphan">sections, orphan</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-Secure-gateway-import-library">Secure gateway import library</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-segment-origins_002c-cmd-line">segment origins, cmd line</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-segments_002c-ELF">segments, ELF</a>:</td><td>&nbsp;</td><td valign="top"><a href="#PHDRS">PHDRS</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SEGMENT_005fSTART_0028segment_002c-default_0029"><code>SEGMENT_START(<var>segment</var>, <var>default</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-shared-libraries">shared libraries</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SHORT_0028expression_0029"><code>SHORT(<var>expression</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SIZEOF_0028section_0029"><code>SIZEOF(<var>section</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SIZEOF_005fHEADERS"><code>SIZEOF_HEADERS</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-small-common-symbols">small common symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Common">Input Section Common</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SORT">SORT</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Wildcards">Input Section Wildcards</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SORT_005fBY_005fALIGNMENT">SORT_BY_ALIGNMENT</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Wildcards">Input Section Wildcards</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SORT_005fBY_005fINIT_005fPRIORITY">SORT_BY_INIT_PRIORITY</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Wildcards">Input Section Wildcards</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SORT_005fBY_005fNAME">SORT_BY_NAME</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Wildcards">Input Section Wildcards</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SORT_005fNONE">SORT_NONE</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Wildcards">Input Section Wildcards</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SPU">SPU</a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SPU-1">SPU</a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SPU-ELF-options">SPU ELF options</a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SPU-extra-overlay-stubs">SPU extra overlay stubs</a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SPU-local-store-size">SPU local store size</a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SPU-overlay-stub-symbols">SPU overlay stub symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SPU-overlays">SPU overlays</a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SPU-plugins">SPU plugins</a>:</td><td>&nbsp;</td><td valign="top"><a href="#SPU-ELF">SPU ELF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SQUAD_0028expression_0029"><code>SQUAD(<var>expression</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-stack-size">stack size</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-standard-Unix-system">standard Unix system</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-start-of-execution">start of execution</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Entry-Point">Entry Point</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-start_002dstop_002dgc">start-stop-gc</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-STARTUP_0028filename_0029"><code>STARTUP(<var>filename</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#File-Commands">File Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-static-library-dependencies">static library dependencies</a>:</td><td>&nbsp;</td><td valign="top"><a href="#libdep-Plugin">libdep Plugin</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-STM32L4xx-erratum-workaround">STM32L4xx erratum workaround</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-strip-all-symbols">strip all symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-strip-debugger-symbols">strip debugger symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-stripping-all-but-some-symbols">stripping all but some symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-STUB_005fGROUP_005fSIZE">STUB_GROUP_SIZE</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-SUBALIGN_0028subsection_005falign_0029"><code>SUBALIGN(<var>subsection_align</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Forced-Input-Alignment">Forced Input Alignment</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-suffixes-for-integers">suffixes for integers</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Constants">Constants</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-symbol-defaults">symbol defaults</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-symbol-definition_002c-scripts">symbol definition, scripts</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Assignments">Assignments</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-symbol-names">symbol names</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Symbols">Symbols</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-symbol-tracing">symbol tracing</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-symbol-versions">symbol versions</a>:</td><td>&nbsp;</td><td valign="top"><a href="#VERSION">VERSION</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-symbol_002donly-input">symbol-only input</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-symbolic-constants">symbolic constants</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Symbolic-Constants">Symbolic Constants</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-symbols_002c-from-command-line">symbols, from command line</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-symbols_002c-relocatable-and-absolute">symbols, relocatable and absolute</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Expression-Section">Expression Section</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-symbols_002c-require-defined">symbols, require defined</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-symbols_002c-retaining-selectively">symbols, retaining selectively</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-synthesizing-linker">synthesizing linker</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-synthesizing-on-H8_002f300">synthesizing on H8/300</a>:</td><td>&nbsp;</td><td valign="top"><a href="#H8_002f300">H8/300</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-T">T</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-TARGET_0028bfdname_0029"><code>TARGET(<var>bfdname</var>)</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#Format-Commands">Format Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-TARGET1">TARGET1</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-TARGET2">TARGET2</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-text-segment-origin_002c-cmd-line">text segment origin, cmd line</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-thumb-entry-point">thumb entry point</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-TI-COFF-versions">TI COFF versions</a>:</td><td>&nbsp;</td><td valign="top"><a href="#TI-COFF">TI COFF</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-traditional-format">traditional format</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-trampoline-generation-on-M68HC11">trampoline generation on M68HC11</a>:</td><td>&nbsp;</td><td valign="top"><a href="#M68HC11_002f68HC12">M68HC11/68HC12</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-trampoline-generation-on-M68HC12">trampoline generation on M68HC12</a>:</td><td>&nbsp;</td><td valign="top"><a href="#M68HC11_002f68HC12">M68HC11/68HC12</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-U">U</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-unallocated-address_002c-next">unallocated address, next</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Builtin-Functions">Builtin Functions</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-undefined-symbol">undefined symbol</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-undefined-symbol-in-linker-script">undefined symbol in linker script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Miscellaneous-Commands">Miscellaneous Commands</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-undefined-symbols_002c-warnings-on">undefined symbols, warnings on</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-uninitialized-data-placement">uninitialized data placement</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Common">Input Section Common</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-unspecified-memory">unspecified memory</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Output-Section-Data">Output Section Data</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-usage">usage</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-USE_005fBLX">USE_BLX</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-using-a-DEF-file">using a DEF file</a>:</td><td>&nbsp;</td><td valign="top"><a href="#WIN32">WIN32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-using-auto_002dexport-functionality">using auto-export functionality</a>:</td><td>&nbsp;</td><td valign="top"><a href="#WIN32">WIN32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-Using-decorations">Using decorations</a>:</td><td>&nbsp;</td><td valign="top"><a href="#WIN32">WIN32</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-V">V</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-variables_002c-defining">variables, defining</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Assignments">Assignments</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-verbose_005b_003dNUMBER_005d">verbose[=<var>NUMBER</var>]</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-version">version</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-version-script">version script</a>:</td><td>&nbsp;</td><td valign="top"><a href="#VERSION">VERSION</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-version-script_002c-symbol-versions">version script, symbol versions</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-VERSION-_007bscript-text_007d"><code>VERSION {script text}</code></a>:</td><td>&nbsp;</td><td valign="top"><a href="#VERSION">VERSION</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-versions-of-symbols">versions of symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#VERSION">VERSION</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-VFP11_005fDENORM_005fFIX">VFP11_DENORM_FIX</a>:</td><td>&nbsp;</td><td valign="top"><a href="#ARM">ARM</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-visibility">visibility</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-W">W</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-warnings_002c-on-combining-symbols">warnings, on combining symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-warnings_002c-on-executable-stack">warnings, on executable stack</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-warnings_002c-on-section-alignment">warnings, on section alignment</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-warnings_002c-on-undefined-symbols">warnings, on undefined symbols</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-warnings_002c-on-writeable-and-exectuable-segments">warnings, on writeable and exectuable segments</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Options">Options</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-weak-externals">weak externals</a>:</td><td>&nbsp;</td><td valign="top"><a href="#WIN32">WIN32</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-what-is-this_003f">what is this?</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Overview">Overview</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-wildcard-file-name-patterns">wildcard file name patterns</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Input-Section-Wildcards">Input Section Wildcards</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+<tr><th><a name="LD-Index_cp_letter-X">X</a></th><td></td><td></td></tr>
+<tr><td></td><td valign="top"><a href="#index-Xtensa-options">Xtensa options</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Xtensa">Xtensa</a></td></tr>
+<tr><td></td><td valign="top"><a href="#index-Xtensa-processors">Xtensa processors</a>:</td><td>&nbsp;</td><td valign="top"><a href="#Xtensa">Xtensa</a></td></tr>
+<tr><td colspan="4"> <hr></td></tr>
+</table>
+<table><tr><th valign="top">Jump to: &nbsp; </th><td><a class="summary-letter" href="#LD-Index_cp_symbol-1"><b>&quot;</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-2"><b>-</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-3"><b>.</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-4"><b>/</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-5"><b>3</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-6"><b>:</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-7"><b>=</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-8"><b>&gt;</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_symbol-9"><b>[</b></a>
+ &nbsp;
+<br>
+<a class="summary-letter" href="#LD-Index_cp_letter-A"><b>A</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-B"><b>B</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-C"><b>C</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-D"><b>D</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-E"><b>E</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-F"><b>F</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-G"><b>G</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-H"><b>H</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-I"><b>I</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-K"><b>K</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-L"><b>L</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-M"><b>M</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-N"><b>N</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-O"><b>O</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-P"><b>P</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-Q"><b>Q</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-R"><b>R</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-S"><b>S</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-T"><b>T</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-U"><b>U</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-V"><b>V</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-W"><b>W</b></a>
+ &nbsp;
+<a class="summary-letter" href="#LD-Index_cp_letter-X"><b>X</b></a>
+ &nbsp;
+</td></tr></table>
+
+
+<hr>
+
+
+
+</body>
+</html>