2004-07-28 03:11:36 +00:00
|
|
|
@c Copyright (C) 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
|
2002-02-01 18:16:02 +00:00
|
|
|
@c This is part of the GCC manual.
|
|
|
|
@c For copying conditions, see the file gcc.texi.
|
|
|
|
|
|
|
|
@node Makefile
|
|
|
|
@subsection Makefile Targets
|
|
|
|
@cindex makefile targets
|
|
|
|
@cindex targets, makefile
|
|
|
|
|
|
|
|
@table @code
|
|
|
|
@item all
|
|
|
|
This is the default target. Depending on what your build/host/target
|
|
|
|
configuration is, it coordinates all the things that need to be built.
|
|
|
|
|
|
|
|
@item doc
|
2004-07-28 03:11:36 +00:00
|
|
|
Produce info-formatted documentation and man pages. Essentially it
|
|
|
|
calls @samp{make man} and @samp{make info}.
|
|
|
|
|
|
|
|
@item dvi
|
|
|
|
Produce DVI-formatted documentation.
|
|
|
|
|
|
|
|
@item man
|
|
|
|
Generate man pages.
|
|
|
|
|
|
|
|
@item info
|
|
|
|
Generate info-formatted pages.
|
2002-02-01 18:16:02 +00:00
|
|
|
|
|
|
|
@item mostlyclean
|
|
|
|
Delete the files made while building the compiler.
|
|
|
|
|
|
|
|
@item clean
|
2003-07-11 03:40:53 +00:00
|
|
|
That, and all the other files built by @samp{make all}.
|
2002-02-01 18:16:02 +00:00
|
|
|
|
|
|
|
@item distclean
|
2003-07-11 03:40:53 +00:00
|
|
|
That, and all the files created by @command{configure}.
|
2002-02-01 18:16:02 +00:00
|
|
|
|
|
|
|
@item maintainer-clean
|
|
|
|
Distclean plus any file that can be generated from other files. Note
|
|
|
|
that additional tools may be required beyond what is normally needed to
|
|
|
|
build gcc.
|
|
|
|
|
2004-07-28 03:11:36 +00:00
|
|
|
@item srcextra
|
|
|
|
Generates files in the source directory that do not exist in CVS but
|
|
|
|
should go into a release tarball. One example is @file{gcc/c-parse.c}
|
|
|
|
which is generated from the CVS source file @file{gcc/c-parse.in}.
|
|
|
|
|
|
|
|
@item srcinfo
|
|
|
|
@itemx srcman
|
|
|
|
Copies the info-formatted and manpage documentation into the source
|
|
|
|
directory usually for the purpose of generating a release tarball.
|
|
|
|
|
2002-02-01 18:16:02 +00:00
|
|
|
@item install
|
|
|
|
Installs gcc.
|
|
|
|
|
|
|
|
@item uninstall
|
|
|
|
Deletes installed files.
|
|
|
|
|
|
|
|
@item check
|
|
|
|
Run the testsuite. This creates a @file{testsuite} subdirectory that
|
|
|
|
has various @file{.sum} and @file{.log} files containing the results of
|
2003-07-11 03:40:53 +00:00
|
|
|
the testing. You can run subsets with, for example, @samp{make check-gcc}.
|
2002-02-01 18:16:02 +00:00
|
|
|
You can specify specific tests by setting RUNTESTFLAGS to be the name
|
|
|
|
of the @file{.exp} file, optionally followed by (for some tests) an equals
|
|
|
|
and a file wildcard, like:
|
|
|
|
|
2002-09-17 04:03:37 +00:00
|
|
|
@smallexample
|
2002-02-01 18:16:02 +00:00
|
|
|
make check-gcc RUNTESTFLAGS="execute.exp=19980413-*"
|
2002-09-17 04:03:37 +00:00
|
|
|
@end smallexample
|
2002-02-01 18:16:02 +00:00
|
|
|
|
|
|
|
Note that running the testsuite may require additional tools be
|
|
|
|
installed, such as TCL or dejagnu.
|
|
|
|
|
|
|
|
@item bootstrap
|
2004-07-28 03:11:36 +00:00
|
|
|
Builds GCC three times---once with the native compiler, once with the
|
2002-02-01 18:16:02 +00:00
|
|
|
native-built compiler it just built, and once with the compiler it built
|
|
|
|
the second time. In theory, the last two should produce the same
|
2003-07-11 03:40:53 +00:00
|
|
|
results, which @samp{make compare} can check. Each step of this process
|
2002-02-01 18:16:02 +00:00
|
|
|
is called a ``stage'', and the results of each stage @var{N}
|
|
|
|
(@var{N} = 1@dots{}3) are copied to a subdirectory @file{stage@var{N}/}.
|
|
|
|
|
|
|
|
@item bootstrap-lean
|
|
|
|
Like @code{bootstrap}, except that the various stages are removed once
|
|
|
|
they're no longer needed. This saves disk space.
|
|
|
|
|
|
|
|
@item bubblestrap
|
2004-07-28 03:11:36 +00:00
|
|
|
This incrementally rebuilds each of the three stages, one at a time.
|
|
|
|
It does this by ``bubbling'' the stages up from their subdirectories
|
|
|
|
(if they had been built previously), rebuilding them, and copying them
|
|
|
|
back to their subdirectories. This will allow you to, for example,
|
|
|
|
continue a bootstrap after fixing a bug which causes the stage2 build
|
|
|
|
to crash.
|
2002-02-01 18:16:02 +00:00
|
|
|
|
|
|
|
@item quickstrap
|
|
|
|
Rebuilds the most recently built stage. Since each stage requires
|
2004-07-28 03:11:36 +00:00
|
|
|
special invocation, using this target means you don't have to keep
|
|
|
|
track of which stage you're on or what invocation that stage needs.
|
2002-02-01 18:16:02 +00:00
|
|
|
|
|
|
|
@item cleanstrap
|
2003-07-11 03:40:53 +00:00
|
|
|
Removed everything (@samp{make clean}) and rebuilds (@samp{make bootstrap}).
|
2002-02-01 18:16:02 +00:00
|
|
|
|
2004-07-28 03:11:36 +00:00
|
|
|
@item restrap
|
|
|
|
Like @code{cleanstrap}, except that the process starts from the first
|
|
|
|
stage build, not from scratch.
|
|
|
|
|
2002-02-01 18:16:02 +00:00
|
|
|
@item stage@var{N} (@var{N} = 1@dots{}4)
|
|
|
|
For each stage, moves the appropriate files to the @file{stage@var{N}}
|
|
|
|
subdirectory.
|
|
|
|
|
|
|
|
@item unstage@var{N} (@var{N} = 1@dots{}4)
|
|
|
|
Undoes the corresponding @code{stage@var{N}}.
|
|
|
|
|
|
|
|
@item restage@var{N} (@var{N} = 1@dots{}4)
|
|
|
|
Undoes the corresponding @code{stage@var{N}} and rebuilds it with the
|
|
|
|
appropriate flags.
|
|
|
|
|
|
|
|
@item compare
|
|
|
|
Compares the results of stages 2 and 3. This ensures that the compiler
|
|
|
|
is running properly, since it should produce the same object files
|
|
|
|
regardless of how it itself was compiled.
|
|
|
|
|
2004-07-28 03:11:36 +00:00
|
|
|
@item profiledbootstrap
|
|
|
|
Builds a compiler with profiling feedback information. For more
|
|
|
|
information, see
|
|
|
|
@ref{Building,,Building with profile feedback,gccinstall,Installing GCC}.
|
|
|
|
This is actually a target in the top-level directory, which then
|
|
|
|
recurses into the @file{gcc} subdirectory multiple times.
|
|
|
|
|
2002-02-01 18:16:02 +00:00
|
|
|
@end table
|