Installing GCC: Building Now that GCC is configured, you are ready to build the compiler and runtime libraries. We _highly_ recommend that GCC be built using GNU make; other versions may work, then again they might not. (For example, many broken versions of make will fail if you use the recommended setup where _objdir_ is different from _srcdir_.) Building a native compiler For a native build issue the command `make bootstrap'. This will build the entire GCC system, which includes the following steps: * Build host tools necessary to build the compiler such as texinfo, bison, gperf. * Build target tools for use by the compiler such as binutils (bfd, binutils, gas, gprof, ld, and opcodes) if they have been individually linked or moved into the top level GCC source tree before configuring. * Perform a 3-stage bootstrap of the compiler. * Perform a comparison test of the stage2 and stage3 compilers. * Build runtime libraries using the stage3 compiler from the previous step. If you are short on disk space you might consider `make bootstrap-lean' instead. This is identical to `make bootstrap' except that object files from the stage1 and stage2 of the 3-stage bootstrap of the compiler are deleted as soon as they are no longer needed. If you want to save additional space during the bootstrap and in the final installation as well, you can build the compiler binaries without debugging information with "make CFLAGS='-O' LIBCFLAGS='-g -O2' LIBCXXFLAGS='-g -O2 -fno-implicit-templates' bootstrap". This will save roughly 40% of disk space both for the bootstrap and the final installation. (Libraries will still contain debugging information.) If you used the flag --enable-languages=... to restrict the compilers to be built, only those you've actually enabled will be built. This will of course only build those runtime libraries, for which the particular compiler has been built. Please note, that re-defining LANGUAGES when calling `make bootstrap' _*does not*_ work anymore! Building a cross compiler We recommend reading the [1]crossgcc FAQ for information about building cross compilers. When building a cross compiler, it is not generally possible to do a 3-stage bootstrap of the compiler. This makes for an interesting problem as parts of GCC can only be built with GCC. To build a cross compiler, we first recommend building and installing a native compiler. You can then use the native GCC compiler to build the cross compiler. Assuming you have already installed a native copy of GCC and configured your cross compiler, issue the command "make", which performs the following steps: * Build host tools necessary to build the compiler such as texinfo, bison, gperf. * Build target tools for use by the compiler such as binutils (bfd, binutils, gas, gprof, ld, and opcodes) if they have been individually linked or moved into the top level GCC source tree before configuring. * Build the compiler (single stage only). * Build runtime libraries using the compiler from the previous step. Note that if an error occurs in any step the make process will exit. Building in parallel If you have a multiprocessor system you can use `make bootstrap MAKE="make -j 2" -j 2' or just `make -j 2 bootstrap' for GNU Make 3.79 and above instead of just `make bootstrap' when building GCC. You can use a bigger number instead of two if you like. In most cases, it won't help to use a number bigger than the number of processors in your machine. _________________________________________________________________ [2]Return to the GCC Installation page References 1. http://www.objsw.com/CrossGCC/ 2. http://gcc.gnu.org/install/index.html