1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- <?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-pass2">
- <title>Binutils-&binutils-version; - Pass 2</title>
- <?dbhtml filename="binutils-pass2.html"?>
- <indexterm zone="ch-tools-binutils-pass2">
- <primary sortas="a-Binutils">Binutils</primary>
- <secondary>tools, pass 2</secondary></indexterm>
- <screen>&buildtime; 1.5 SBU
- &diskspace; 108 MB</screen>
- <sect2>
- <title>Re-installation of Binutils</title>
- <para>Create a separate build directory again:</para>
- <screen><userinput>mkdir ../binutils-build
- cd ../binutils-build</userinput></screen>
- <para>Now prepare Binutils for compilation:</para>
- <screen><userinput>../binutils-&binutils-version;/configure --prefix=/tools \
- --enable-shared --with-lib-path=/tools/lib</userinput></screen>
- <para>The meaning of the new configure option:</para>
- <itemizedlist>
- <listitem><para><userinput>--with-lib-path=/tools/lib</userinput>: This tells
- the configure script to specify the library search path during the compilation
- of Binutils, resulting in <emphasis>/tools/lib</emphasis> to be passed to the
- linker. This prevents the linker from searching through library directories on
- the host.</para></listitem>
- </itemizedlist>
- <para>Before starting to build Binutils, remember to unset any environment
- variables that override the default optimization flags.</para>
- <para>Compile the package:</para>
- <screen><userinput>make</userinput></screen>
- <para>Compilation is now complete. As discussed earlier, we don't recommend
- running the test suites for the temporary tools here in this chapter. If
- nevertheless you want to run the Binutils test suite, the following command
- will do so:</para>
- <screen><userinput>make -k check</userinput></screen>
- <para>Except for a few known failures, the binutils tests should all pass. The
- exceptions to this rule are as follows:</para>
- <screen>* 5 FAIL (unexpected failure) for visibility
- * 1 FAIL for selective4
- * 1 FAIL for selective5</screen>
- <!--
- <para>There should be no unexpected failures here, expected failures are fine.
- Unfortunately, there is no easy way to view the test results summary like there
- was for the GCC package. However, if a failure occurs here, it should be easy
- to spot. The output shown will contain something like:</para>
- <blockquote><screen>make[1]: *** [check-binutils] Error 2</screen></blockquote>
- -->
- <para>And install the package:</para>
- <screen><userinput>make install</userinput></screen>
- <para>Now prepare the linker for the "Re-adjusting" phase in the next
- chapter:</para>
- <screen><userinput>make -C ld clean
- make -C ld LIB_PATH=/usr/lib:/lib</userinput></screen>
- <warning><para><emphasis>Do not yet remove</emphasis> the Binutils source and
- build directories. You will need these directories again in the next chapter
- in the state they are in now.</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>
|