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.
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.
It is recommended by the Binutils installation documentation to build
Binutils outside of the source directory in a dedicated directory:
mkdir ../binutils-build
cd ../binutils-build
Next, prepare Binutils to be compiled:
../binutils-&binutils-version;/configure \
--prefix=/stage1 --disable-nls
The meaning of the configure switches is:
--prefix=/stage1: This tells the
configure script to prepare to install the Binutils programs in the
/stage1 directory.
--disable-nls: This disables
internationalization (a word often shortened to i18n). We don't need this
for our static programs and nls often causes problems
when linking statically.
Continue with compiling the package:
make configure-host
make LDFLAGS="-all-static"
The meaning of the make option is:
LDFLAGS="-all-static": This tells
the linker that all the Binutils programs should be linked
statically.
And install the package:
make install
Now already prepare the linker for the "locking in" of
glibc later on:
make -C ld clean
make -C ld LIB_PATH=/stage1/lib
Do not yet remove the binutils-* directories.
We will need them again a bit further on in this chapter.