[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
all
doc
make dvi
is
available for DVI-formatted documentation, and make
generated-manpages
to generate man pages.
mostlyclean
clean
make all
.
distclean
configure
.
extraclean
maintainer-clean
install
uninstall
check
make check-gcc
.
You can specify specific tests by setting RUNTESTFLAGS to be the name
of the `.exp' file, optionally followed by (for some tests) an equals
and a file wildcard, like:
make check-gcc RUNTESTFLAGS="execute.exp=19980413-*" |
Note that running the testsuite may require additional tools be installed, such as TCL or dejagnu.
bootstrap
make compare
can check. Each step of this process
is called a "stage", and the results of each stage N
(N = 1...3) are copied to a subdirectory `stageN/'.
bootstrap-lean
bootstrap
, except that the various stages are removed once
they're no longer needed. This saves disk space.
bubblestrap
quickstrap
cleanstrap
make clean
) and rebuilds (make bootstrap
).
stageN (N = 1...4)
unstageN (N = 1...4)
stageN
.
restageN (N = 1...4)
stageN
and rebuilds it with the
appropriate flags.
compare
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
This section is not instructions for building GCC. If you are trying to do a build, you should first read http://gcc.gnu.org/install/ or whatever installation instructions came with your source package.
The configure and build process has a long and colorful history, and can be confusing to anyone who doesn't know why things are the way they are. While there are other documents which describe the configuration process in detail, here are a few things that everyone working on GCC should know.
There are three system names that the build knows about: the machine you are building on (build), the machine that you are building for (host), and the machine that GCC will produce code for (target). When you configure GCC, you specify these with `--build=', `--host=', and `--target='.
Specifying the host without specifying the build should be avoided, as
configure
may (and once did) assume that the host you specify
is also the build, which may not be true.
If build, host, and target are all the same, this is called a native. If build and host are the same but target is different, this is called a cross. If build, host, and target are all different this is called a canadian (for obscure reasons dealing with Canada's political party and the background of the person working on the build at that time). If host and target are the same, but build is different, you are using a cross-compiler to build a native for a different system. Some people call this a host-x-host, crossed native, or cross-built native. If build and target are the same, but host is different, you are using a cross compiler to build a cross compiler that produces code for the machine you're building on. This is rare, so there is no common say of describing it (although I propose calling it a crossback).
If build and host are the same, the GCC you are building will also be
used to build the target libraries (like libstdc++
). If build and host
are different, you must have already build and installed a cross
compiler that will be used to build the target libraries (if you
configured with `--target=foo-bar', this compiler will be called
foo-bar-gcc
).
In the case of target libraries, the machine you're building for is the
machine you specified with `--target'. So, build is the machine
you're building on (no change there), host is the machine you're
building for (the target libraries are built for the target, so host is
the target you specified), and target doesn't apply (because you're not
building a compiler, you're building libraries). The configure/make
process will adjust these variables as needed. It also sets
$with_cross_host
to the original `--host' value in case you
need it.
Libiberty, for example, is built twice. The first time, host comes from `--host' and the second time host comes from `--target'. Historically, libiberty has not been built for the build machine, though, which causes some interesting issues with programs used to generate sources for the build. Fixing this, so that libiberty is built three times, has long been on the to-do list.
[ << ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |