According the the gcc build instructions you can build binutils concurrently with building gcc (as well as gmp,mpc,etc).
Here's what that page says :
If you also intend to build binutils
(either to upgrade an existing
installation or for use in place of
the corresponding tools of your OS),
unpack the binutils distribution
either in the same directory or a
separate one. In the latter case, add
symbolic links to any components of
the binutils you intend to build
alongside the compiler (bfd, binutils,
gas, gprof, ld, opcodes, ...) to the
directory containing the GCC sources.
Likewise the GMP, MPFR and MPC
libraries can be automatically built
together with GCC. Unpack the GMP,
MPFR and/or MPC source distributions
in the directory containing the GCC
sources and rename their directories
to gmp, mpfr and mpc, respectively (or
use symbolic links with the same
name).
This works fine for gmp,mpc, mpfr, but I can't seem to get it to build all of binutils.
Nor can I figure out how to get it to build the new gold linker from binutils.
The versions in question are gcc-4.4.2 and binutils-2.20.
A step by step instruction would be great (for me, and for others who run into this issue as well).
This should still be supported OK, as it's commonly used for building cross-compilers.
In fact, I've just done this with gcc 4.6.0 and binutils 2.21 (with gmp, mpc and mpfr at appropriate versions), and the following seemed to work fine:
- Get all the archives of the stuff you're going to build (gcc-4.6.0.tar.bz2, binutils-2.21.tar.bz2 etc) into a new dir, e.g.
src
Un-tar them all in this directory, so you end up with gcc-4.6.0/
binutils-2.21/
gmp-5.0.2/
and more sitting alongside one another
tar jxvf gcc-4.6.0.tar.bz2
... (unpack others here, watch file lists scroll past)
cd gcc-4.6.0
and symlink the gmp, mpc and mpfr directories without their version numbers in the links, e.g:
ln -s ../gmp-5.0.2 gmp
Now symlink everything from the binutils dir which doesn't exist in the gcc dir, so anything which already exists will take priority but the binutils tools will look be visible to the build:
for file in ../binutils-2.21/* ; do ln -s "${file}" ; done
Change up a dir and make a build directory to build all this in separately to the sources (this always used to be the recommended method, and it tends to still be more reliable than building inside the source dir):
cd .. ; mkdir build
At this point you should have a set of directories and links which looks something like this:
binutils-2.21/
build/
gcc-4.6.0/
gmp -> ../gmp-5.0.2
mpc -> ../mpc-0.9
mpfr -> ../mpfr-3.0.1
bfd -> ../binutils-2.21/bfd
binutils -> ../binutils-2.21/binutils
gas -> ../binutils-2.21/gas
... (lots more symlinks for binutils here, plus existing gcc stuff)
gmp-5.0.2/
mpc-0.9/
mpfr-3.0.1/
Configure the whole lot from this dir, with whatever options you need to pass to configure:
../gcc-4.6.0/configure --prefix=/foo/bar --enable-languages=c,c++,ada
Build, wait, install (you'll probably want to use make -j4
or so here to get some builds in parallel as it's going to take a while) :
make -j4 ; make install
Add the destination to your path if it's not already (and perhaps the lib dir to LD_LIBRARY_PATH if this is outside of those specified in /etc/ld.so.conf
, as mentioned in the messages about installing libraries during the make install
step), and everything should be up and running with this new version.
It's probably worth checking that you're using this installed version once you've opened a new shell, with :
`which gcc`
and
`which as`
..as well as that the version is as you expect with:
`gcc --version`
and
`as --version`
..as well as (of course) testing that the installed version builds executables fine with some simple examples before you let it loose on your code-base :)
Edit: The comments below contain some sets of versions which are known to work together. Not all combinations will work, so you might need to go through some trial and error for different combinations to those mentioned!
Much later edit: gdb is also possible to include in this build (again requires compatible component versions - see comments).
Add this as the last thing after binutils in a similar way, using for f in ../gdb-8.1.1/* ; do ln -s "${f}" ; done
and the build will automatically pick it up.
What you want to do is called a "combined tree" or "in-tree binutils" build. You can find documentation on how to proceed here and there.
I always build everything separately. After you've built and installed binutils, gcc should build fine as long as you give each configure script the same --target
and --prefix
options:
binutils:
$ ./configure --target=XYZ --prefix=/abc/def
$ make all install
then add the path (if necessary):
$ export PATH="$PATH:/abc/def/bin"
and build gcc:
$ ./configure --target=XYZ --prefix=/abc/def
$ make all-gcc install-gcc
Then build your libc and the rest of gcc if necessary (maybe a debugger, too!).