blob: 6e66c2dc3c98c35c41a4e1f97f5357c12c635821 [file] [log] [blame]
<html lang="en">
<head>
<title>Entry Point - Untitled</title>
<meta http-equiv="Content-Type" content="text/html">
<meta name="description" content="Untitled">
<meta name="generator" content="makeinfo 4.13">
<link title="Top" rel="start" href="index.html#Top">
<link rel="up" href="Simple-Commands.html#Simple-Commands" title="Simple Commands">
<link rel="next" href="File-Commands.html#File-Commands" title="File Commands">
<link href="http://www.gnu.org/software/texinfo/" rel="generator-home" title="Texinfo Homepage">
<!--
This file documents the GNU linker LD
(Sourcery G++ Lite 2011.03-41)
version 2.20.51.
Copyright (C) 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000,
2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 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''.-->
<meta http-equiv="Content-Style-Type" content="text/css">
<style type="text/css"><!--
pre.display { font-family:inherit }
pre.format { font-family:inherit }
pre.smalldisplay { font-family:inherit; font-size:smaller }
pre.smallformat { font-family:inherit; font-size:smaller }
pre.smallexample { font-size:smaller }
pre.smalllisp { font-size:smaller }
span.sc { font-variant:small-caps }
span.roman { font-family:serif; font-weight:normal; }
span.sansserif { font-family:sans-serif; font-weight:normal; }
--></style>
<link rel="stylesheet" type="text/css" href="../cs.css">
</head>
<body>
<div class="node">
<a name="Entry-Point"></a>
<p>
Next:&nbsp;<a rel="next" accesskey="n" href="File-Commands.html#File-Commands">File Commands</a>,
Up:&nbsp;<a rel="up" accesskey="u" href="Simple-Commands.html#Simple-Commands">Simple Commands</a>
<hr>
</div>
<h4 class="subsection">3.4.1 Setting the Entry Point</h4>
<p><a name="index-ENTRY_0028_0040var_007bsymbol_007d_0029-342"></a><a name="index-start-of-execution-343"></a><a name="index-first-instruction-344"></a><a name="index-entry-point-345"></a>The first instruction to execute in a program is called the <dfn>entry
point</dfn>. You can use the <code>ENTRY</code> linker script command to set the
entry point. The argument is a symbol name:
<pre class="smallexample"> ENTRY(<var>symbol</var>)
</pre>
<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:
<ul>
<li>the &lsquo;<samp><span class="samp">-e</span></samp>&rsquo; <var>entry</var> command-line option;
<li>the <code>ENTRY(</code><var>symbol</var><code>)</code> command in a linker script;
<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>the address of the first byte of the &lsquo;<samp><span class="samp">.text</span></samp>&rsquo; section, if present;
<li>The address <code>0</code>.
</ul>
</body></html>