Installing Binutils-2.14 - Pass 1

Estimated build time:           1.0 SBU
Estimated required disk space:  194 MB

Contents of Binutils

(Last checked against version 2.14.)

Binutils is a collection of software development tools containing a linker, assembler and other tools to work with object files and archives.

Installed programs: addr2line, ar, as, c++filt, gprof, ld, nm, objcopy, objdump, ranlib, readelf, size, strings and strip

Installed libraries: libbfd.[a,so] and libopcodes.[a,so]

Binutils Installation Dependencies

(Last checked against version 2.11.2.)

Bash: sh
Binutils: ar, as, ld, nm, ranlib, strip
Coreutils: basename, cat, chmod, cp, echo, expr, hostname, ln, ls, mkdir
             mv, rm, rmdir, sleep, sort, touch, tr, true, uname, uniq
Diffutils: cmp
Gawk: gawk
GCC: cc, cc1, collect2, cpp, gcc
Glibc: ldconfig
Grep: egrep, fgrep, grep
Make: make
Sed: sed
Texinfo: install-info, makeinfo

Installation of Binutils

It is important that Binutils be the first package to get compiled, because both Glibc and GCC perform various tests on the available linker and assembler to determine which of their own features to enable.

Note: Even though Binutils is an important toolchain package, we are not going to run the test suite at this early stage. First, the test suite framework is not yet in place and second, the programs from this first pass will soon be overwritten by those installed in the second pass.

This package is known to behave badly when you have changed its default optimization flags (including the -march and -mcpu options). Therefore, if you have defined any environment variables that override default optimizations, such as CFLAGS and CXXFLAGS, we recommend unsetting or modifying them when building Binutils.

The Binutils documentation recommends building Binutils outside of the source directory in a dedicated build directory:

mkdir ../binutils-build
cd ../binutils-build

Note: If you want the SBU values listed in the rest of the book to be of any use, you will have to measure the time it takes to build this package. To achieve this easily, you could do something like: time { ./configure ... && ... && ... && make install; }.

Now prepare Binutils for compilation:

../binutils-2.14/configure \
    --prefix=/tools --disable-nls

The meaning of the configure options:

Continue with compiling the package:

make configure-host
make LDFLAGS="-all-static"

The meaning of the make options:

And install the package:

make install

Now prepare the linker for the "locking in" of Glibc later on:

make -C ld clean
make -C ld LDFLAGS="-all-static" LIB_PATH=/tools/lib

The meaning of the make options:

 

Warning

Do not yet remove the Binutils build and source directories. You will need them again in their current state a bit further on in this chapter.