| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 | <?xml version="1.0" encoding="ISO-8859-1"?><!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.3//EN" "http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd" [  <!ENTITY % general-entities SYSTEM "../general.ent">  %general-entities;]><sect1 id="ch-tools-binutils-pass1"><title>Binutils-&binutils-version; - Pass 1</title><?dbhtml filename="binutils-pass1.html"?><indexterm zone="ch-tools-binutils-pass1"><primary sortas="a-Binutils">Binutils</primary><secondary>tools, pass 1</secondary></indexterm><xi:include xmlns:xi="http://www.w3.org/2003/XInclude" href="../chapter06/binutils.xml" xpointer="xpointer(/sect1/para[1])"/><screen>&buildtime; 1.0 SBU&diskspace; 194 MB</screen><xi:include xmlns:xi="http://www.w3.org/2003/XInclude" href="../chapter06/binutils.xml" xpointer="xpointer(/sect1/para[2])"/><sect2><title>Installation of Binutils</title><para>It is important that Binutils be the first package to get compiled,because both Glibc and GCC perform various tests on the available linker andassembler to determine which of their own features to enable.</para><para>This package is known to behave badly when you change its defaultoptimization flags (including the <emphasis>-march</emphasis> and<emphasis>-mcpu</emphasis> options). Therefore, if you have defined anyenvironment variables that override default optimizations, such as CFLAGS andCXXFLAGS, we recommend un-setting them when building Binutils.</para><para>The Binutils documentation recommends building Binutils outside of thesource directory in a dedicated build directory:</para><screen><userinput>mkdir ../binutils-buildcd ../binutils-build</userinput></screen><note><para>If you want the SBU values listed in the rest of the book to be ofany use, you will have to measure the time it takes to build this package --from the configuration up to and including the first install. To achieve thiseasily, you could wrap the four commands in a <command>time</command> commandlike this: <userinput>time { ./configure ... && ... && ...&& make install; }</userinput>.</para></note><para>Now prepare Binutils for compilation:</para><screen><userinput>../binutils-&binutils-version;/configure --prefix=/tools --disable-nls</userinput></screen><para>The meaning of the configure options:</para><itemizedlist><listitem><para><userinput>--prefix=/tools</userinput>: This tells theconfigure script to prepare to install the Binutils programs in the<filename>/tools</filename> directory.</para></listitem><listitem><para><userinput>--disable-nls</userinput>: This disablesinternationalization (a word often shortened to i18n). We don't need thisfor our static programs and <emphasis>nls</emphasis> often causes problemswhen linking statically.</para></listitem></itemizedlist><para>Continue with compiling the package:</para><screen><userinput>make configure-hostmake LDFLAGS="-all-static"</userinput></screen><para>The meaning of the make parameters:</para><itemizedlist><listitem><para><userinput>configure-host</userinput>: This forces all thesubdirectories to be configured immediately. A statically linked build willfail without it. We therefore use this option to work around theproblem.</para></listitem><listitem><para><userinput>LDFLAGS="-all-static"</userinput>: This tells thelinker that all the Binutils programs should be linked statically. However,strictly speaking, <emphasis>"-all-static"</emphasis> is passed to the<command>libtool</command> program, which then passes<emphasis>"-static"</emphasis> to the linker.</para></listitem></itemizedlist><para>Compilation is complete. Normally we would now run the test suite, butat this early stage the test suite framework (Tcl, Expect and DejaGnu) is notyet in place. And there would be little point in running the tests anyhow,since the programs from this first pass will soon be replaced by those from thesecond.</para><para>Now install the package:</para><screen><userinput>make install</userinput></screen><para>Now prepare the linker for the <quote>Adjusting</quote> phase later on:</para><screen><userinput>make -C ld cleanmake -C ld LDFLAGS="-all-static" LIB_PATH=/tools/lib</userinput></screen><para>The meaning of the make parameters:</para><itemizedlist><listitem><para><userinput>-C ld clean</userinput>: This tells the make programto remove all the compiled files in the <filename class="directory">ld</filename> subdirectory.</para></listitem><listitem><para><userinput>-C ld LDFLAGS="-all-static"LIB_PATH=/tools/lib</userinput>: This option rebuilds everything in the<filename class="directory">ld</filename> subdirectory. Specifying the LIB_PATHmakefile variable on the command line allows us to override the default valueand have it point to our temporary tools location. The value of this variablespecifies the linker's default library search path. You will see how thispreparation is used later on in the chapter.</para></listitem></itemizedlist><warning><para><emphasis>Do not yet remove</emphasis> the Binutils build andsource directories. You will need them again in their current state a bitfurther on in this chapter.</para></warning></sect2><sect2><title> </title><para> </para><para>The details on this package are found in <xref linkend="contents-binutils"/>.</para><para> </para></sect2></sect1>
 |