diff options
Diffstat (limited to 'gnu/usr.bin/gcc/INSTALL')
-rw-r--r-- | gnu/usr.bin/gcc/INSTALL/README | 6 | ||||
-rw-r--r-- | gnu/usr.bin/gcc/INSTALL/binaries.html | 98 | ||||
-rw-r--r-- | gnu/usr.bin/gcc/INSTALL/build.html | 247 | ||||
-rw-r--r-- | gnu/usr.bin/gcc/INSTALL/configure.html | 675 | ||||
-rw-r--r-- | gnu/usr.bin/gcc/INSTALL/download.html | 67 | ||||
-rw-r--r-- | gnu/usr.bin/gcc/INSTALL/finalinstall.html | 141 | ||||
-rw-r--r-- | gnu/usr.bin/gcc/INSTALL/gfdl.html | 446 | ||||
-rw-r--r-- | gnu/usr.bin/gcc/INSTALL/index.html | 95 | ||||
-rw-r--r-- | gnu/usr.bin/gcc/INSTALL/old.html | 618 | ||||
-rw-r--r-- | gnu/usr.bin/gcc/INSTALL/specific.html | 1665 | ||||
-rw-r--r-- | gnu/usr.bin/gcc/INSTALL/test.html | 162 |
11 files changed, 4220 insertions, 0 deletions
diff --git a/gnu/usr.bin/gcc/INSTALL/README b/gnu/usr.bin/gcc/INSTALL/README new file mode 100644 index 00000000000..27bd1738bca --- /dev/null +++ b/gnu/usr.bin/gcc/INSTALL/README @@ -0,0 +1,6 @@ +This directory has been obsoleted for GCC snapshots and CVS access. + +For releases the installation documentation is generated from +gcc/doc/install.texi and copied into this directory. + +To read this documentation, please point your HTML browser to "index.html". diff --git a/gnu/usr.bin/gcc/INSTALL/binaries.html b/gnu/usr.bin/gcc/INSTALL/binaries.html new file mode 100644 index 00000000000..71da0a61c5c --- /dev/null +++ b/gnu/usr.bin/gcc/INSTALL/binaries.html @@ -0,0 +1,98 @@ +<html lang="en"> +<head> +<title>Installing GCC: Binaries</title> +<meta http-equiv="Content-Type" content="text/html"> +<meta name=description content="Installing GCC: Binaries"> +<meta name=generator content="makeinfo 4.2"> +<link href="http://www.gnu.org/software/texinfo/" rel=generator-home> +<!-- +Copyright © 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998, +1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc. +<br><p> +<p>Permission is granted to copy, distribute and/or modify this document +under the terms of the GNU Free Documentation License, Version 1.2 or +any later version published by the Free Software Foundation; with no +Invariant Sections, the Front-Cover texts being (a) (see below), and +with the Back-Cover Texts being (b) (see below). A copy of the +license is included in the section entitled "<a href="./gfdl.html">GNU Free Documentation License</a>". + +<p>(a) The FSF's Front-Cover Text is: + +<p>A GNU Manual + +<p>(b) The FSF's Back-Cover Text is: + +<p>You have freedom to copy and modify this GNU Manual, like GNU + software. Copies published by the Free Software Foundation raise + funds for GNU development.--> +</head> +<body> +<h1>Installing GCC: Binaries</h1> +We are often asked about pre-compiled versions of GCC. While we cannot +provide these for all platforms, below you'll find links to binaries for +various platforms where creating them by yourself is not easy due to various +reasons. + +<p>Please note that we did not create these binaries, nor do we +support them. If you have any problems installing them, please +contact their makers. + +<ul> +<li>AIX: +<ul> +<li><a href="http://www.bullfreeware.com">Bull's Freeware and Shareware Archive for AIX</a>; + +<li><a href="http://aixpdslib.seas.ucla.edu">UCLA Software Library for AIX</a>. +</ul> + +<li>DOS--<a href="http://www.delorie.com/djgpp/">DJGPP</a>. + +<li>Renesas H8/300[HS]--<a href="http://h8300-hms.sourceforge.net/">GNU Development Tools for the Renesas H8/300[HS] Series</a>. + +<li>HP-UX: +<ul> +<li><a href="http://hpux.cae.wisc.edu/">HP-UX Porting Center</a>; + +<li><a href="ftp://sunsite.informatik.rwth-aachen.de/pub/packages/gcc_hpux/">Binaries for HP-UX 11.00 at Aachen University of Technology</a>. +</ul> + +<li>Motorola 68HC11/68HC12--<a href="http://www.gnu-m68hc11.org">GNU Development Tools for the Motorola 68HC11/68HC12</a>. + +<li><a href="http://www.sco.com/skunkware/devtools/index.html#gcc">SCO OpenServer/Unixware</a>. + +<li>Sinix/Reliant Unix--<a href="ftp://ftp.fujitsu-siemens.com/pub/pd/gnu/gcc/">Siemens</a>. + +<li>Solaris 2 (SPARC, Intel)--<a href="http://www.sunfreeware.com/">Sunfreeware</a>. + +<li>SGI--<a href="http://freeware.sgi.com/">SGI Freeware</a>. + +<li>Microsoft Windows: +<ul> +<li>The <a href="http://sources.redhat.com/cygwin/">Cygwin</a> project; +<li>The <a href="http://www.mingw.org/">MinGW</a> project. +</ul> + +<li><a href="ftp://ftp.thewrittenword.com/packages/by-name/">The Written Word</a> offers binaries for +AIX 4.3.2. +IRIX 6.5, +Digital UNIX 4.0D and 5.1, +GNU/Linux (i386), +HP-UX 10.20, 11.00, and 11.11, and +Solaris/SPARC 2.5.1, 2.6, 2.7, 8, and 9, +</ul> + +<p>In addition to those specific offerings, you can get a binary +distribution CD-ROM from the +<a href="http://www.fsf.org/order/order.html">Free Software Foundation</a>. +It contains binaries for a number of platforms, and +includes not only GCC, but other stuff as well. The current CD does +not contain the latest version of GCC, but it should allow +bootstrapping the compiler. An updated version of that disk is in the +works. + +<hr /> +<p> +<a href="./index.html">Return to the GCC Installation page</a> + +</body></html> + diff --git a/gnu/usr.bin/gcc/INSTALL/build.html b/gnu/usr.bin/gcc/INSTALL/build.html new file mode 100644 index 00000000000..d1b3a95f407 --- /dev/null +++ b/gnu/usr.bin/gcc/INSTALL/build.html @@ -0,0 +1,247 @@ +<html lang="en"> +<head> +<title>Installing GCC: Building</title> +<meta http-equiv="Content-Type" content="text/html"> +<meta name=description content="Installing GCC: Building"> +<meta name=generator content="makeinfo 4.2"> +<link href="http://www.gnu.org/software/texinfo/" rel=generator-home> +<!-- +Copyright © 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998, +1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc. +<br><p> +<p>Permission is granted to copy, distribute and/or modify this document +under the terms of the GNU Free Documentation License, Version 1.2 or +any later version published by the Free Software Foundation; with no +Invariant Sections, the Front-Cover texts being (a) (see below), and +with the Back-Cover Texts being (b) (see below). A copy of the +license is included in the section entitled "<a href="./gfdl.html">GNU Free Documentation License</a>". + +<p>(a) The FSF's Front-Cover Text is: + +<p>A GNU Manual + +<p>(b) The FSF's Back-Cover Text is: + +<p>You have freedom to copy and modify this GNU Manual, like GNU + software. Copies published by the Free Software Foundation raise + funds for GNU development.--> +</head> +<body> +<h1>Installing GCC: Building</h1> +Now that GCC is configured, you are ready to build the compiler and +runtime libraries. + +<p>We <strong>highly</strong> recommend that GCC be built using GNU make; +other versions may work, then again they might not. +GNU make is required for compiling GNAT (the Ada compiler) and the Java +runtime library. + +<p>(For example, many broken versions of make will fail if you use the +recommended setup where <var>objdir</var> is different from <var>srcdir</var>. +Other broken versions may recompile parts of the compiler when +installing the compiler.) + +<p>Some commands executed when making the compiler may fail (return a +nonzero status) and be ignored by <code>make</code>. These failures, which +are often due to files that were not found, are expected, and can safely +be ignored. + +<p>It is normal to have compiler warnings when compiling certain files. +Unless you are a GCC developer, you can generally ignore these warnings +unless they cause compilation to fail. + +<p>On certain old systems, defining certain environment variables such as +<code>CC</code> can interfere with the functioning of <code>make</code>. + +<p>If you encounter seemingly strange errors when trying to build the +compiler in a directory other than the source directory, it could be +because you have previously configured the compiler in the source +directory. Make sure you have done all the necessary preparations. + +<p>If you build GCC on a BSD system using a directory stored in an old System +V file system, problems may occur in running <code>fixincludes</code> if the +System V file system doesn't support symbolic links. These problems +result in a failure to fix the declaration of <code>size_t</code> in +<code>sys/types.h</code>. If you find that <code>size_t</code> is a signed type and +that type mismatches occur, this could be the cause. + +<p>The solution is not to use such a directory for building GCC. + +<p>When building from CVS or snapshots, or if you modify parser sources, +you need the Bison parser generator installed. Any version 1.25 or +later should work; older versions may also work. If you do not modify +parser sources, releases contain the Bison-generated files and you do +not need Bison installed to build them. + +<p>When building from CVS or snapshots, or if you modify Texinfo +documentation, you need version 4.2 or later of Texinfo installed if you +want Info documentation to be regenerated. Releases contain Info +documentation pre-built for the unmodified documentation in the release. + +<h3><a name="TOC0"></a>Building a native compiler</h3> + +<p>For a native build issue the command <code>make bootstrap</code>. This +will build the entire GCC system, which includes the following steps: + +<ul> +<li>Build host tools necessary to build the compiler such as texinfo, bison, +gperf. + +<li>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. + +<li>Perform a 3-stage bootstrap of the compiler. + +<li>Perform a comparison test of the stage2 and stage3 compilers. + +<li>Build runtime libraries using the stage3 compiler from the previous step. + +</ul> + +<p>If you are short on disk space you might consider <code>make +bootstrap-lean</code> instead. This is identical to <code>make +bootstrap</code> 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. + +<p>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 as in the following example. This will save +roughly 40% of disk space both for the bootstrap and the final installation. +(Libraries will still contain debugging information.) + +<br><pre> make CFLAGS='-O' LIBCFLAGS='-g -O2' \ + LIBCXXFLAGS='-g -O2 -fno-implicit-templates' bootstrap +</pre> + +<p>If you wish to use non-default GCC flags when compiling the stage2 and +stage3 compilers, set <code>BOOT_CFLAGS</code> on the command line when doing +<code>make bootstrap</code>. Non-default optimization flags are less well +tested here than the default of <code>-g -O2</code>, but should still work. +In a few cases, you may find that you need to specify special flags such +as <code>-msoft-float</code> here to complete the bootstrap; or, if the +native compiler miscompiles the stage1 compiler, you may need to work +around this, by choosing <code>BOOT_CFLAGS</code> to avoid the parts of the +stage1 compiler that were miscompiled, or by using <code>make +bootstrap4</code> to increase the number of stages of bootstrap. + +<p>If you used the flag <code>--enable-languages=<small>...</small></code> 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 <code>LANGUAGES</code> when calling <code>make bootstrap</code> +<strong>does not</strong> work anymore! + +<p>If the comparison of stage2 and stage3 fails, this normally indicates +that the stage2 compiler has compiled GCC incorrectly, and is therefore +a potentially serious bug which you should investigate and report. (On +a few systems, meaningful comparison of object files is impossible; they +always appear "different". If you encounter this problem, you will +need to disable comparison in the <code>Makefile</code>.) + +<h3><a name="TOC1"></a>Building a cross compiler</h3> + +<p>We recommend reading the +<a href="http://www.objsw.com/CrossGCC/">crossgcc FAQ</a> +for information about building cross compilers. + +<p>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. + +<p>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. The installed native compiler needs to be GCC version +2.95 or later. + +<p>Assuming you have already installed a native copy of GCC and configured +your cross compiler, issue the command <code>make</code>, which performs the +following steps: + +<ul> +<li>Build host tools necessary to build the compiler such as texinfo, bison, +gperf. + +<li>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. + +<li>Build the compiler (single stage only). + +<li>Build runtime libraries using the compiler from the previous step. +</ul> + +<p>Note that if an error occurs in any step the make process will exit. + +<h3><a name="TOC2"></a>Building in parallel</h3> + +<p>You can use <code>make bootstrap MAKE="make -j 2" -j 2</code>, or just +<code>make -j 2 bootstrap</code> for GNU Make 3.79 and above, instead of +<code>make bootstrap</code> to build GCC in parallel. +You can also specify a bigger number, and in most cases using a value +greater than the number of processors in your machine will result in +fewer and shorter I/O latency hits, thus improving overall throughput; +this is especially true for slow drives and network filesystems. + +<h3><a name="TOC3"></a>Building the Ada compiler</h3> + +<p>In order to build GNAT, the Ada compiler, you need a working GNAT +compiler (GNAT version 3.13 or later, or GCC version 3.1 or later), +since the Ada front end is written in Ada (with some +GNAT-specific extensions), and GNU make. + +<p>However, you do not need a full installation of GNAT, just the GNAT +binary <code>gnat1</code>, a copy of <code>gnatbind</code>, and a compiler driver +which can deal with Ada input (by invoking the <code>gnat1</code> binary). +You can specify this compiler driver by setting the <code>ADAC</code> +environment variable at the configure step. <code>configure</code> can +detect the driver automatically if it has got a common name such as +<code>gcc</code> or <code>gnatgcc</code>. Of course, you still need a working +C compiler (the compiler driver can be different or not). +<code>configure</code> does not test whether the GNAT installation works +and has a sufficiently recent version; if too old a GNAT version is +installed, the build will fail unless <code>--enable-languages</code> is +used to disable building the Ada front end. + +<p>Additional build tools (such as <code>gnatmake</code>) or a working GNAT +run-time library installation are usually <em>not</em> required. However, +if you want to bootstrap the compiler using a minimal version of GNAT, +you have to issue the following commands before invoking <code>make +bootstrap</code> (this assumes that you start with an unmodified and consistent +source distribution): + +<br><pre> cd <var>srcdir</var>/gcc/ada + touch treeprs.ads [es]info.h nmake.ad[bs] +</pre> + +<p>At the moment, the GNAT library and several tools for GNAT are not built +by <code>make bootstrap</code>. You have to invoke +<code>make gnatlib_and_tools</code> in the <code><var>objdir</var>/gcc</code> +subdirectory before proceeding with the next steps. + +<p>For example, you can build a native Ada compiler by issuing the +following commands (assuming <code>make</code> is GNU make): + +<br><pre> cd <var>objdir</var> + <var>srcdir</var>/configure --enable-languages=c,ada + cd <var>srcdir</var>/gcc/ada + touch treeprs.ads [es]info.h nmake.ad[bs] + cd <var>objdir</var> + make bootstrap + cd gcc + make gnatlib_and_tools + cd .. +</pre> + +<p>Currently, when compiling the Ada front end, you cannot use the parallel +build feature described in the previous section. + +<hr /> +<p> +<a href="./index.html">Return to the GCC Installation page</a> + +</body></html> + diff --git a/gnu/usr.bin/gcc/INSTALL/configure.html b/gnu/usr.bin/gcc/INSTALL/configure.html new file mode 100644 index 00000000000..5f425a08af7 --- /dev/null +++ b/gnu/usr.bin/gcc/INSTALL/configure.html @@ -0,0 +1,675 @@ +<html lang="en"> +<head> +<title>Installing GCC: Configuration</title> +<meta http-equiv="Content-Type" content="text/html"> +<meta name=description content="Installing GCC: Configuration"> +<meta name=generator content="makeinfo 4.2"> +<link href="http://www.gnu.org/software/texinfo/" rel=generator-home> +<!-- +Copyright © 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998, +1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc. +<br><p> +<p>Permission is granted to copy, distribute and/or modify this document +under the terms of the GNU Free Documentation License, Version 1.2 or +any later version published by the Free Software Foundation; with no +Invariant Sections, the Front-Cover texts being (a) (see below), and +with the Back-Cover Texts being (b) (see below). A copy of the +license is included in the section entitled "<a href="./gfdl.html">GNU Free Documentation License</a>". + +<p>(a) The FSF's Front-Cover Text is: + +<p>A GNU Manual + +<p>(b) The FSF's Back-Cover Text is: + +<p>You have freedom to copy and modify this GNU Manual, like GNU + software. Copies published by the Free Software Foundation raise + funds for GNU development.--> +</head> +<body> +<h1>Installing GCC: Configuration</h1> +Like most GNU software, GCC must be configured before it can be built. +This document describes the recommended configuration procedure +for both native and cross targets. + +<p>We use <var>srcdir</var> to refer to the toplevel source directory for +GCC; we use <var>objdir</var> to refer to the toplevel build/object directory. + +<p>If you obtained the sources via CVS, <var>srcdir</var> must refer to the top +<code>gcc</code> directory, the one where the <code>MAINTAINERS</code> can be found, +and not its <code>gcc</code> subdirectory, otherwise the build will fail. + +<p>If either <var>srcdir</var> or <var>objdir</var> is located on an automounted NFS +file system, the shell's built-in <code>pwd</code> command will return +temporary pathnames. Using these can lead to various sorts of build +problems. To avoid this issue, set the <code>PWDCMD</code> environment +variable to an automounter-aware <code>pwd</code> command, e.g., +<code>pawd</code> or <code>amq -w</code>, during the configuration and build +phases. + +<p>First, we <strong>highly</strong> recommend that GCC be built into a +separate directory than the sources which does <strong>not</strong> reside +within the source tree. This is how we generally build GCC; building +where <var>srcdir</var> == <var>objdir</var> should still work, but doesn't +get extensive testing; building where <var>objdir</var> is a subdirectory +of <var>srcdir</var> is unsupported. + +<p>If you have previously built GCC in the same directory for a +different target machine, do <code>make distclean</code> to delete all files +that might be invalid. One of the files this deletes is <code>Makefile</code>; +if <code>make distclean</code> complains that <code>Makefile</code> does not exist +or issues a message like "don't know how to make distclean" it probably +means that the directory is already suitably clean. However, with the +recommended method of building in a separate <var>objdir</var>, you should +simply use a different <var>objdir</var> for each target. + +<p>Second, when configuring a native system, either <code>cc</code> or +<code>gcc</code> must be in your path or you must set <code>CC</code> in +your environment before running configure. Otherwise the configuration +scripts may fail. + +<p>Note that the bootstrap compiler and the resulting GCC must be link +compatible, else the bootstrap will fail with linker errors about +incompatible object file formats. Several multilibed targets are +affected by this requirement, see +<a href="specific.html">host/target specific installation notes</a>. + +<p>To configure GCC: + +<br><pre> % mkdir <var>objdir</var> + % cd <var>objdir</var> + % <var>srcdir</var>/configure [<var>options</var>] [<var>target</var>] +</pre> + +<h3><a name="TOC0"></a>Target specification</h3> + +<ul> +<li>GCC has code to correctly determine the correct value for <var>target</var> +for nearly all native systems. Therefore, we highly recommend you not +provide a configure target when configuring a native compiler. + +<li><var>target</var> must be specified as <code>--target=<var>target</var></code> +when configuring a cross compiler; examples of valid targets would be +i960-rtems, m68k-coff, sh-elf, etc. + +<li>Specifying just <var>target</var> instead of <code>--target=<var>target</var></code> +implies that the host defaults to <var>target</var>. +</ul> + +<h3><a name="TOC1"></a>Options specification</h3> + +<p>Use <var>options</var> to override several configure time options for +GCC. A list of supported <var>options</var> follows; <code>configure +--help</code> may list other options, but those not listed below may not +work and should not normally be used. + +<dl> +<dt><code>--prefix=<var>dirname</var></code> +<dd>Specify the toplevel installation +directory. This is the recommended way to install the tools into a directory +other than the default. The toplevel installation directory defaults to +<code>/usr/local</code>. + +<p>We <strong>highly</strong> recommend against <var>dirname</var> being the same or a +subdirectory of <var>objdir</var> or vice versa. If specifying a directory +beneath a user's home directory tree, some shells will not expand +<var>dirname</var> correctly if it contains the <code>~</code> metacharacter; use +<code>$HOME</code> instead. + +<p>These additional options control where certain parts of the distribution +are installed. Normally you should not need to use these options. +<dl> +<dt><code>--exec-prefix=<var>dirname</var></code> +<dd>Specify the toplevel installation directory for architecture-dependent +files. The default is <code><var>prefix</var></code>. + +<br><dt><code>--bindir=<var>dirname</var></code> +<dd>Specify the installation directory for the executables called by users +(such as <code>gcc</code> and <code>g++</code>). The default is +<code><var>exec-prefix</var>/bin</code>. + +<br><dt><code>--libdir=<var>dirname</var></code> +<dd>Specify the installation directory for object code libraries and +internal parts of GCC. The default is <code><var>exec-prefix</var>/lib</code>. + +<br><dt><code>--with-slibdir=<var>dirname</var></code> +<dd>Specify the installation directory for the shared libgcc library. The +default is <code><var>libdir</var></code>. + +<br><dt><code>--infodir=<var>dirname</var></code> +<dd>Specify the installation directory for documentation in info format. +The default is <code><var>prefix</var>/info</code>. + +<br><dt><code>--datadir=<var>dirname</var></code> +<dd>Specify the installation directory for some architecture-independent +data files referenced by GCC. The default is <code><var>prefix</var>/share</code>. + +<br><dt><code>--mandir=<var>dirname</var></code> +<dd>Specify the installation directory for manual pages. The default is +<code><var>prefix</var>/man</code>. (Note that the manual pages are only extracts from +the full GCC manuals, which are provided in Texinfo format. The manpages +are derived by an automatic conversion process from parts of the full +manual.) + +<br><dt><code>--with-gxx-include-dir=<var>dirname</var></code> +<dd>Specify +the installation directory for G++ header files. The default is +<code><var>prefix</var>/include/g++-v3</code>. + +</dl> + +<br><dt><code>--program-prefix=<var>prefix</var></code> +<dd>GCC supports some transformations of the names of its programs when +installing them. This option prepends <var>prefix</var> to the names of +programs to install in <var>bindir</var> (see above). For example, specifying +<code>--program-prefix=foo-</code> would result in <code>gcc</code> +being installed as <code>/usr/local/bin/foo-gcc</code>. + +<br><dt><code>--program-suffix=<var>suffix</var></code> +<dd>Appends <var>suffix</var> to the names of programs to install in <var>bindir</var> +(see above). For example, specifying <code>--program-suffix=-3.1</code> +would result in <code>gcc</code> being installed as +<code>/usr/local/bin/gcc-3.1</code>. + +<br><dt><code>--program-transform-name=<var>pattern</var></code> +<dd>Applies the <code>sed</code> script <var>pattern</var> to be applied to the names +of programs to install in <var>bindir</var> (see above). <var>pattern</var> has to +consist of one or more basic <code>sed</code> editing commands, separated by +semicolons. For example, if you want the <code>gcc</code> program name to be +transformed to the installed program <code>/usr/local/bin/myowngcc</code> and +the <code>g++</code> program name to be transformed to +<code>/usr/local/bin/gspecial++</code> without changing other program names, +you could use the pattern +<code>--program-transform-name='s/^gcc$/myowngcc/; s/^g++$/gspecial++/'</code> +to achieve this effect. + +<p>All three options can be combined and used together, resulting in more +complex conversion patterns. As a basic rule, <var>prefix</var> (and +<var>suffix</var>) are prepended (appended) before further transformations +can happen with a special transformation script <var>pattern</var>. + +<p>As currently implemented, this option only takes effect for native +builds; cross compiler binaries' names are not transformed even when a +transformation is explicitly asked for by one of these options. + +<p>For native builds, some of the installed programs are also installed +with the target alias in front of their name, as in +<code>i686-pc-linux-gnu-gcc</code>. All of the above transformations happen +before the target alias is prepended to the name - so, specifying +<code>--program-prefix=foo-</code> and <code>program-suffix=-3.1</code>, the +resulting binary would be installed as +<code>/usr/local/bin/i686-pc-linux-gnu-foo-gcc-3.1</code>. + +<p>As a last shortcoming, none of the installed Ada programs are +transformed yet, which will be fixed in some time. + +<br><dt><code>--with-local-prefix=<var>dirname</var></code> +<dd>Specify the +installation directory for local include files. The default is +<code>/usr/local</code>. Specify this option if you want the compiler to +search directory <code><var>dirname</var>/include</code> for locally installed +header files <em>instead</em> of <code>/usr/local/include</code>. + +<p>You should specify <code>--with-local-prefix</code> <strong>only</strong> if your +site has a different convention (not <code>/usr/local</code>) for where to put +site-specific files. + +<p>The default value for <code>--with-local-prefix</code> is <code>/usr/local</code> +regardless of the value of <code>--prefix</code>. Specifying +<code>--prefix</code> has no effect on which directory GCC searches for +local header files. This may seem counterintuitive, but actually it is +logical. + +<p>The purpose of <code>--prefix</code> is to specify where to <em>install +GCC</em>. The local header files in <code>/usr/local/include</code>--if you put +any in that directory--are not part of GCC. They are part of other +programs--perhaps many others. (GCC installs its own header files in +another directory which is based on the <code>--prefix</code> value.) + +<p>Both the local-prefix include directory and the GCC-prefix include +directory are part of GCC's "system include" directories. Although these +two directories are not fixed, they need to be searched in the proper +order for the correct processing of the include_next directive. The +local-prefix include directory is searched before the GCC-prefix +include directory. Another characteristic of system include directories +is that pedantic warnings are turned off for headers in these directories. + +<p>Some autoconf macros add <code>-I <var>directory</var></code> options to the +compiler command line, to ensure that directories containing installed +packages' headers are searched. When <var>directory</var> is one of GCC's +system include directories, GCC will ignore the option so that system +directories continue to be processed in the correct order. This +may result in a search order different from what was specified but the +directory will still be searched. + +<p>GCC automatically searches for ordinary libraries using +<code>GCC_EXEC_PREFIX</code>. Thus, when the same installation prefix is +used for both GCC and packages, GCC will automatically search for +both headers and libraries. This provides a configuration that is +easy to use. GCC behaves in a manner similar to that when it is +installed as a system compiler in <code>/usr</code>. + +<p>Sites that need to install multiple versions of GCC may not want to +use the above simple configuration. It is possible to use the +<code>--program-prefix</code>, <code>--program-suffix</code> and +<code>--program-transform-name</code> options to install multiple versions +into a single directory, but it may be simpler to use different prefixes +and the <code>--with-local-prefix</code> option to specify the location of the +site-specific files for each version. It will then be necessary for +users to specify explicitly the location of local site libraries +(e.g., with <code>LIBRARY_PATH</code>). + +<p>The same value can be used for both <code>--with-local-prefix</code> and +<code>--prefix</code> provided it is not <code>/usr</code>. This can be used +to avoid the default search of <code>/usr/local/include</code>. + +<p><strong>Do not</strong> specify <code>/usr</code> as the <code>--with-local-prefix</code>! +The directory you use for <code>--with-local-prefix</code> <strong>must not</strong> +contain any of the system's standard header files. If it did contain +them, certain programs would be miscompiled (including GNU Emacs, on +certain targets), because this would override and nullify the header +file corrections made by the <code>fixincludes</code> script. + +<p>Indications are that people who use this option use it based on mistaken +ideas of what it is for. People use it as if it specified where to +install part of GCC. Perhaps they make this assumption because +installing GCC creates the directory. + +<br><dt><code>--enable-shared[=<var>package</var>[,<small>...</small>]]</code> +<dd>Build shared versions of libraries, if shared libraries are supported on +the target platform. Unlike GCC 2.95.x and earlier, shared libraries +are enabled by default on all platforms that support shared libraries, +except for <code>libobjc</code> which is built as a static library only by +default. + +<p>If a list of packages is given as an argument, build shared libraries +only for the listed packages. For other packages, only static libraries +will be built. Package names currently recognized in the GCC tree are +<code>libgcc</code> (also known as <code>gcc</code>), <code>libstdc++</code> (not +<code>libstdc++-v3</code>), <code>libffi</code>, <code>zlib</code>, <code>boehm-gc</code> and +<code>libjava</code>. Note that <code>libobjc</code> does not recognize itself by +any name, so, if you list package names in <code>--enable-shared</code>, +you will only get static Objective-C libraries. <code>libf2c</code> and +<code>libiberty</code> do not support shared libraries at all. + +<p>Use <code>--disable-shared</code> to build only static libraries. Note that +<code>--disable-shared</code> does not accept a list of package names as +argument, only <code>--enable-shared</code> does. + +<br><dt><code><a name="with-gnu-as"></a>--with-gnu-as</code> +<dd>Specify that the compiler should assume that the +assembler it finds is the GNU assembler. However, this does not modify +the rules to find an assembler and will result in confusion if the +assembler found is not actually the GNU assembler. (Confusion may also +result if the compiler finds the GNU assembler but has not been +configured with <code>--with-gnu-as</code>.) If you have more than one +assembler installed on your system, you may want to use this option in +connection with <code>--with-as=<var>pathname</var></code>. + +<p>The following systems are the only ones where it makes a difference +whether you use the GNU assembler. On any other system, +<code>--with-gnu-as</code> has no effect. + +<ul> +<li><code>hppa1.0-<var>any</var>-<var>any</var></code> +<li><code>hppa1.1-<var>any</var>-<var>any</var></code> +<li><code>i386-<var>any</var>-sysv</code> +<li><code>m68k-bull-sysv</code> +<li><code>m68k-hp-hpux</code> +<li><code>m68000-hp-hpux</code> +<li><code>m68000-att-sysv</code> +<li><code><var>any</var>-lynx-lynxos</code> +<li><code>mips-<var>any</var></code> +<li><code>sparc-sun-solaris2.<var>any</var></code> +<li><code>sparc64-<var>any</var>-solaris2.<var>any</var></code> +</ul> + +<p>On the systems listed above (except for the HP-PA, the SPARC, for ISC on +the 386, and for <code>mips-sgi-irix5.*</code>), if you use the GNU assembler, +you should also use the GNU linker (and specify <code>--with-gnu-ld</code>). + +<br><dt><code><a name="with-as"></a>--with-as=<var>pathname</var></code> +<dd>Specify that the +compiler should use the assembler pointed to by <var>pathname</var>, rather +than the one found by the standard rules to find an assembler, which +are: +<ul> +<li>Check the +<code><var>exec_prefix</var>/lib/gcc-lib/<var>target</var>/<var>version</var></code> +directory, where <var>exec_prefix</var> defaults to <var>prefix</var> which +defaults to <code>/usr/local</code> unless overridden by the +<code>--prefix=<var>pathname</var></code> switch described above. <var>target</var> is the +target system triple, such as <code>sparc-sun-solaris2.7</code>, and +<var>version</var> denotes the GCC version, such as 3.0. +<li>Check operating system specific directories (e.g. <code>/usr/ccs/bin</code> on +Sun Solaris 2). +</ul> +Note that these rules do not check for the value of <code>PATH</code>. You may +want to use <code>--with-as</code> if no assembler is installed in the +directories listed above, or if you have multiple assemblers installed +and want to choose one that is not found by the above rules. + +<br><dt><code><a name="with-gnu-ld"></a>--with-gnu-ld</code> +<dd>Same as <a href="#with-gnu-as"><code>--with-gnu-as</code></a> +but for the linker. + +<br><dt><code>--with-ld=<var>pathname</var></code> +<dd>Same as <a href="#with-as"><code>--with-as</code></a> +but for the linker. + +<br><dt><code>--with-stabs</code> +<dd>Specify that stabs debugging +information should be used instead of whatever format the host normally +uses. Normally GCC uses the same debug format as the host system. + +<p>On MIPS based systems and on Alphas, you must specify whether you want +GCC to create the normal ECOFF debugging format, or to use BSD-style +stabs passed through the ECOFF symbol table. The normal ECOFF debug +format cannot fully handle languages other than C. BSD stabs format can +handle other languages, but it only works with the GNU debugger GDB. + +<p>Normally, GCC uses the ECOFF debugging format by default; if you +prefer BSD stabs, specify <code>--with-stabs</code> when you configure GCC. + +<p>No matter which default you choose when you configure GCC, the user +can use the <code>-gcoff</code> and <code>-gstabs+</code> options to specify explicitly +the debug format for a particular compilation. + +<p><code>--with-stabs</code> is meaningful on the ISC system on the 386, also, if +<code>--with-gas</code> is used. It selects use of stabs debugging +information embedded in COFF output. This kind of debugging information +supports C++ well; ordinary COFF debugging information does not. + +<p><code>--with-stabs</code> is also meaningful on 386 systems running SVR4. It +selects use of stabs debugging information embedded in ELF output. The +C++ compiler currently (2.6.0) does not support the DWARF debugging +information normally used on 386 SVR4 platforms; stabs provide a +workable alternative. This requires gas and gdb, as the normal SVR4 +tools can not generate or interpret stabs. + +<br><dt><code>--disable-multilib</code> +<dd>Specify that multiple target +libraries to support different target variants, calling +conventions, etc should not be built. The default is to build a +predefined set of them. + +<p>Some targets provide finer-grained control over which multilibs are built +(e.g., <code>--disable-softfloat</code>): +<dl> +<dt><code>arc-*-elf*</code> +<dd>biendian. + +<br><dt><code>arm-*-*</code> +<dd>fpu, 26bit, underscore, interwork, biendian, nofmult. + +<br><dt><code>m68*-*-*</code> +<dd>softfloat, m68881, m68000, m68020. + +<br><dt><code>mips*-*-*</code> +<dd>single-float, biendian, softfloat. + +<br><dt><code>powerpc*-*-*, rs6000*-*-*</code> +<dd>aix64, pthread, softfloat, powercpu, powerpccpu, powerpcos, biendian, +sysv, aix. + +</dl> + +<br><dt><code>--enable-threads</code> +<dd>Specify that the target +supports threads. This affects the Objective-C compiler and runtime +library, and exception handling for other languages like C++ and Java. +On some systems, this is the default. + +<p>In general, the best (and, in many cases, the only known) threading +model available will be configured for use. Beware that on some +systems, gcc has not been taught what threading models are generally +available for the system. In this case, <code>--enable-threads</code> is an +alias for <code>--enable-threads=single</code>. + +<br><dt><code>--disable-threads</code> +<dd>Specify that threading support should be disabled for the system. +This is an alias for <code>--enable-threads=single</code>. + +<br><dt><code>--enable-threads=<var>lib</var></code> +<dd>Specify that +<var>lib</var> is the thread support library. This affects the Objective-C +compiler and runtime library, and exception handling for other languages +like C++ and Java. The possibilities for <var>lib</var> are: + +<dl> +<dt><code>aix</code> +<dd>AIX thread support. +<br><dt><code>dce</code> +<dd>DCE thread support. +<br><dt><code>mach</code> +<dd>Generic MACH thread support, known to work on NeXTSTEP. (Please note +that the file needed to support this configuration, <code>gthr-mach.h</code>, is +missing and thus this setting will cause a known bootstrap failure.) +<br><dt><code>no</code> +<dd>This is an alias for <code>single</code>. +<br><dt><code>posix</code> +<dd>Generic POSIX thread support. +<br><dt><code>pthreads</code> +<dd>Same as <code>posix</code> on arm*-*-linux*, *-*-chorusos* and *-*-freebsd* +only. A future release of gcc might remove this alias or extend it +to all platforms. +<br><dt><code>rtems</code> +<dd>RTEMS thread support. +<br><dt><code>single</code> +<dd>Disable thread support, should work for all platforms. +<br><dt><code>solaris</code> +<dd>Sun Solaris 2 thread support. +<br><dt><code>vxworks</code> +<dd>VxWorks thread support. +<br><dt><code>win32</code> +<dd>Microsoft Win32 API thread support. +</dl> + +<br><dt><code>--with-cpu=<var>cpu</var></code> +<dd>Specify which cpu variant the +compiler should generate code for by default. This is currently +only supported on some ports, specifically arm, powerpc, and +SPARC. If configure does not recognize the model name (e.g. arm700, +603e, or ultrasparc) you provide, please check the +<code>gcc/config.gcc</code> script for a complete list of supported models. + +<br><dt><code>--enable-altivec</code> +<dd>Specify that the target supports AltiVec vector enhancements. This +option will adjust the ABI for AltiVec enhancements, as well as generate +AltiVec code when appropriate. This option is only available for +PowerPC systems. + +<br><dt><code>--enable-target-optspace</code> +<dd>Specify that target +libraries should be optimized for code space instead of code speed. +This is the default for the m32r platform. + +<br><dt><code>--disable-cpp</code> +<dd>Specify that a user visible <code>cpp</code> program should not be installed. + +<br><dt><code>--with-cpp-install-dir=<var>dirname</var></code> +<dd>Specify that the user visible <code>cpp</code> program should be installed +in <code><var>prefix</var>/<var>dirname</var>/cpp</code>, in addition to <var>bindir</var>. + +<br><dt><code>--enable-initfini-array</code> +<dd>Force the use of sections <code>.init_array</code> and <code>.fini_array</code> +(instead of <code>.init</code> and <code>.fini</code>) for constructors and +destructors. Option <code>--disable-initfini-array</code> has the +opposite effect. If neither option is specified, the configure script +will try to guess whether the <code>.init_array</code> and +<code>.fini_array</code> sections are supported and, if they are, use them. + +<br><dt><code>--enable-maintainer-mode</code> +<dd>The build rules that +regenerate the GCC master message catalog <code>gcc.pot</code> are normally +disabled. This is because it can only be rebuilt if the complete source +tree is present. If you have changed the sources and want to rebuild the +catalog, configuring with <code>--enable-maintainer-mode</code> will enable +this. Note that you need a recent version of the <code>gettext</code> tools +to do so. + +<br><dt><code>--enable-version-specific-runtime-libs</code> +<dd>Specify +that runtime libraries should be installed in the compiler specific +subdirectory (<code><var>libsubdir</var></code>) rather than the usual places. In +addition, <code>libstdc++</code>'s include files will be installed in +<code><var>libsubdir</var>/include/g++</code> unless you overruled it by using +<code>--with-gxx-include-dir=<var>dirname</var></code>. Using this option is +particularly useful if you intend to use several versions of GCC in +parallel. This is currently supported by <code>libf2c</code> and +<code>libstdc++</code>, and is the default for <code>libobjc</code> which cannot be +changed in this case. + +<br><dt><code>--enable-languages=<var>lang1</var>,<var>lang2</var>,<small>...</small></code> +<dd>Specify that only a particular subset of compilers and +their runtime libraries should be built. For a list of valid values for +<var>langN</var> you can issue the following command in the +<code>gcc</code> directory of your GCC source tree:<br> +<br><pre>grep language= */config-lang.in +</pre> +Currently, you can use any of the following: +<code>ada</code>, <code>c</code>, <code>c++</code>, <code>f77</code>, <code>java</code>, <code>objc</code>. +Building the Ada compiler has special requirements, see below.<br> +If you do not pass this flag, all languages available in the <code>gcc</code> +sub-tree will be configured. Re-defining <code>LANGUAGES</code> when calling +<code>make bootstrap</code> <strong>does not</strong> work anymore, as those +language sub-directories might not have been configured! + +<br><dt><code>--disable-libgcj</code> +<dd>Specify that the run-time libraries +used by GCJ should not be built. This is useful in case you intend +to use GCJ with some other run-time, or you're going to install it +separately, or it just happens not to build on your particular +machine. In general, if the Java front end is enabled, the GCJ +libraries will be enabled too, unless they're known to not work on +the target platform. If GCJ is enabled but <code>libgcj</code> isn't built, you +may need to port it; in this case, before modifying the top-level +<code>configure.in</code> so that <code>libgcj</code> is enabled by default on this platform, +you may use <code>--enable-libgcj</code> to override the default. + +<br><dt><code>--with-dwarf2</code> +<dd>Specify that the compiler should +use DWARF 2 debugging information as the default. + +<br><dt><code>--enable-win32-registry</code> +<dt><code>--enable-win32-registry=<var>key</var></code> +<dt><code>--disable-win32-registry</code> +<dd>The <code>--enable-win32-registry</code> option enables Windows-hosted GCC +to look up installations paths in the registry using the following key: + +<br><pre><code>HKEY_LOCAL_MACHINE\SOFTWARE\Free Software Foundation\<var>key</var></code> +</pre> + +<p><var>key</var> defaults to GCC version number, and can be overridden by the +<code>--enable-win32-registry=<var>key</var></code> option. Vendors and distributors +who use custom installers are encouraged to provide a different key, +perhaps one comprised of vendor name and GCC version number, to +avoid conflict with existing installations. This feature is enabled +by default, and can be disabled by <code>--disable-win32-registry</code> +option. This option has no effect on the other hosts. + +<br><dt><code>--nfp</code> +<dd>Specify that the machine does not have a floating point unit. This +option only applies to <code>m68k-sun-sunos<var>n</var></code>. On any other +system, <code>--nfp</code> has no effect. + +<br><dt><code>--enable-checking</code> +<dt><code>--enable-checking=<var>list</var></code> +<dd>When you specify this option, the compiler is built to perform checking +of tree node types when referencing fields of that node, and some other +internal consistency checks. This does not change the generated code, +but adds error checking within the compiler. This will slow down the +compiler and may only work properly if you are building the compiler +with GCC. This is on by default when building from CVS or snapshots, +but off for releases. More control over the checks may be had by +specifying <var>list</var>; the categories of checks available are +<code>misc</code>, <code>tree</code>, <code>gc</code>, <code>rtl</code>, <code>rtlflag</code>, +<code>gcac</code> and <code>valgrind</code>. The check <code>valgrind</code> requires the +external <code>valgrind</code> simulator, available from +<a href="http://developer.kde.org/~sewardj/">http://developer.kde.org/~sewardj/</a>. The default when <var>list</var> is +not specified is <code>misc,tree,gc,rtlflag</code>; the checks <code>rtl</code>, +<code>gcac</code> and <code>valgrind</code> are very expensive. + +<br><dt><code>--enable-coverage</code> +<br><dt><code>--enable-coverage=<var>level</var></code> +<dd>With this option, the compiler is built to collect self coverage +information, every time it is run. This is for internal development +purposes, and only works when the compiler is being built with gcc. The +<var>level</var> argument controls whether the compiler is built optimized or +not, values are <code>opt</code> and <code>noopt</code>. For coverage analysis you +want to disable optimization, for performance analysis you want to +enable optimization. When coverage is enabled, the default level is +without optimization. + +<br><dt><code>--enable-nls</code> +<dt><code>--disable-nls</code> +<dd>The <code>--enable-nls</code> option enables Native Language Support (NLS), +which lets GCC output diagnostics in languages other than American +English. Native Language Support is enabled by default if not doing a +canadian cross build. The <code>--disable-nls</code> option disables NLS. + +<br><dt><code>--with-included-gettext</code> +<dd>If NLS is enabled, the <code>--with-included-gettext</code> option causes the build +procedure to prefer its copy of GNU <code>gettext</code>. + +<br><dt><code>--with-catgets</code> +<dd>If NLS is enabled, and if the host lacks <code>gettext</code> but has the +inferior <code>catgets</code> interface, the GCC build procedure normally +ignores <code>catgets</code> and instead uses GCC's copy of the GNU +<code>gettext</code> library. The <code>--with-catgets</code> option causes the +build procedure to use the host's <code>catgets</code> in this situation. + +<br><dt><code>--with-libiconv-prefix=<var>dir</var></code> +<dd>Search for libiconv header files in <code><var>dir</var>/include</code> and +libiconv library files in <code><var>dir</var>/lib</code>. + +<br><dt><code>--with-system-zlib</code> +<dd>Use installed zlib rather than that included with GCC. This option +only applies if the Java front end is being built. + +<br><dt><code>--enable-obsolete</code> +<dd>Enable configuration for an obsoleted system. If you attempt to +configure GCC for a system (build, host, or target) which has been +obsoleted, and you do not specify this flag, configure will halt with an +error message. + +<p>All support for systems which have been obsoleted in one release of GCC +is removed entirely in the next major release, unless someone steps +forward to maintain the port. +</dl> + +<p>Some options which only apply to building cross compilers: +<dl> +<dt><code>--with-headers</code> +<dt><code>--with-headers=<var>dir</var></code> +<dd>Specifies that target headers are available when building a cross compiler. +The <var>dir</var> argument specifies a directory which has the target include +files. These include files will be copied into the <code>gcc</code> install +directory. <em>This option with the <var>dir</var> argument is required</em> when +building a cross compiler, if <code><var>prefix</var>/<var>target</var>/sys-include</code> +doesn't pre-exist. If <code><var>prefix</var>/<var>target</var>/sys-include</code> does +pre-exist, the <var>dir</var> argument may be omitted. <code>fixincludes</code> +will be run on these files to make them compatible with GCC. +<br><dt><code>--with-libs</code> +<dt><code>--with-libs=``<var>dir1</var> <var>dir2</var> <small>...</small> <var>dirN</var>''</code> +<dd>Specifies a list of directories which contain the target runtime +libraries. These libraries will be copied into the <code>gcc</code> install +directory. If the directory list is omitted, this option has no +effect. +<br><dt><code>--with-newlib</code> +<dd>Specifies that <code>newlib</code> is +being used as the target C library. This causes <code>__eprintf</code> to be +omitted from <code>libgcc.a</code> on the assumption that it will be provided by +<code>newlib</code>. +</dl> + +<p>Note that each <code>--enable</code> option has a corresponding +<code>--disable</code> option and that each <code>--with</code> option has a +corresponding <code>--without</code> option. + +<hr /> +<p> +<a href="./index.html">Return to the GCC Installation page</a> + +</body></html> + diff --git a/gnu/usr.bin/gcc/INSTALL/download.html b/gnu/usr.bin/gcc/INSTALL/download.html new file mode 100644 index 00000000000..469477d68e9 --- /dev/null +++ b/gnu/usr.bin/gcc/INSTALL/download.html @@ -0,0 +1,67 @@ +<html lang="en"> +<head> +<title>Downloading GCC</title> +<meta http-equiv="Content-Type" content="text/html"> +<meta name=description content="Downloading GCC"> +<meta name=generator content="makeinfo 4.2"> +<link href="http://www.gnu.org/software/texinfo/" rel=generator-home> +<!-- +Copyright © 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998, +1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc. +<br><p> +<p>Permission is granted to copy, distribute and/or modify this document +under the terms of the GNU Free Documentation License, Version 1.2 or +any later version published by the Free Software Foundation; with no +Invariant Sections, the Front-Cover texts being (a) (see below), and +with the Back-Cover Texts being (b) (see below). A copy of the +license is included in the section entitled "<a href="./gfdl.html">GNU Free Documentation License</a>". + +<p>(a) The FSF's Front-Cover Text is: + +<p>A GNU Manual + +<p>(b) The FSF's Back-Cover Text is: + +<p>You have freedom to copy and modify this GNU Manual, like GNU + software. Copies published by the Free Software Foundation raise + funds for GNU development.--> +</head> +<body> +<h1>Downloading GCC</h1> +GCC is distributed via <a href="http://gcc.gnu.org/cvs.html">CVS</a> and FTP +tarballs compressed with <code>gzip</code> or +<code>bzip2</code>. It is possible to download a full distribution or specific +components. + +<p>Please refer to our <a href="http://gcc.gnu.org/releases.html">releases web page</a> +for information on how to obtain GCC. + +<p>The full distribution includes the C, C++, Objective-C, Fortran, Java, +and Ada (in case of GCC 3.1 and later) compilers. The full distribution +also includes runtime libraries for C++, Objective-C, Fortran, and Java. +In GCC 3.0 and later versions, GNU compiler testsuites are also included +in the full distribution. + +<p>If you choose to download specific components, you must download the core +GCC distribution plus any language specific distributions you wish to +use. The core distribution includes the C language front end as well as the +shared components. Each language has a tarball which includes the language +front end as well as the language runtime (when appropriate). + +<p>Unpack the core distribution as well as any language specific +distributions in the same directory. + +<p>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 +(<code>bfd</code>, <code>binutils</code>, <code>gas</code>, <code>gprof</code>, <code>ld</code>, +<code>opcodes</code>, <small>...</small>) to the directory containing the GCC sources. + +<hr /> +<p> +<a href="./index.html">Return to the GCC Installation page</a> + +</body></html> + diff --git a/gnu/usr.bin/gcc/INSTALL/finalinstall.html b/gnu/usr.bin/gcc/INSTALL/finalinstall.html new file mode 100644 index 00000000000..deef09371aa --- /dev/null +++ b/gnu/usr.bin/gcc/INSTALL/finalinstall.html @@ -0,0 +1,141 @@ +<html lang="en"> +<head> +<title>Installing GCC: Final installation</title> +<meta http-equiv="Content-Type" content="text/html"> +<meta name=description content="Installing GCC: Final installation"> +<meta name=generator content="makeinfo 4.2"> +<link href="http://www.gnu.org/software/texinfo/" rel=generator-home> +<!-- +Copyright © 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998, +1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc. +<br><p> +<p>Permission is granted to copy, distribute and/or modify this document +under the terms of the GNU Free Documentation License, Version 1.2 or +any later version published by the Free Software Foundation; with no +Invariant Sections, the Front-Cover texts being (a) (see below), and +with the Back-Cover Texts being (b) (see below). A copy of the +license is included in the section entitled "<a href="./gfdl.html">GNU Free Documentation License</a>". + +<p>(a) The FSF's Front-Cover Text is: + +<p>A GNU Manual + +<p>(b) The FSF's Back-Cover Text is: + +<p>You have freedom to copy and modify this GNU Manual, like GNU + software. Copies published by the Free Software Foundation raise + funds for GNU development.--> +</head> +<body> +<h1>Installing GCC: Final installation</h1> +Now that GCC has been built (and optionally tested), you can install it with +<br><pre>cd <var>objdir</var>; make install +</pre> + +<p>We strongly recommend to install into a target directory where there is +no previous version of GCC present. + +<p>That step completes the installation of GCC; user level binaries can +be found in <code><var>prefix</var>/bin</code> where <var>prefix</var> is the value you +specified with the <code>--prefix</code> to configure (or <code>/usr/local</code> +by default). (If you specified <code>--bindir</code>, that directory will +be used instead; otherwise, if you specified <code>--exec-prefix</code>, +<code><var>exec-prefix</var>/bin</code> will be used.) Headers for the C++ and +Java libraries are installed in <code><var>prefix</var>/include</code>; libraries +in <code><var>libdir</var></code> (normally <code><var>prefix</var>/lib</code>); internal +parts of the compiler in <code><var>libdir</var>/gcc-lib</code>; documentation in +info format in <code><var>infodir</var></code> (normally <code><var>prefix</var>/info</code>). + +<p>When installing cross-compilers, GCC's executables +are not only installed into <code><var>bindir</var></code>, that +is, <code><var>exec-prefix</var>/bin</code>, but additionally into +<code><var>exec-prefix</var>/<var>target-alias</var>/bin</code>, if that directory +exists. Typically, such <dfn>tooldirs</dfn> hold target-specific +binutils, including assembler and linker. + +<p>Installation into a temporary staging area or into a <code>chroot</code> +jail can be achieved with the command + +<br><pre>make DESTDIR=<var>path-to-rootdir</var> install +</pre> + +<p>where <var>path-to-rootdir</var> is the absolute path of +a directory relative to which all installation paths will be +interpreted. Note that the directory specified by <code>DESTDIR</code> +need not exist yet; it will be created if necessary. + +<p>There is a subtle point with tooldirs and <code>DESTDIR</code>: +If you relocate a cross-compiler installation with +e.g. <code>DESTDIR=<var>rootdir</var></code>, then the directory +<code><var>rootdir</var>/<var>exec-prefix</var>/<var>target-alias</var>/bin</code> will +be filled with duplicated GCC executables only if it already exists, +it will not be created otherwise. This is regarded as a feature, +not as a bug, because it gives slightly more control to the packagers +using the <code>DESTDIR</code> feature. + +<p>If you built a released version of GCC using <code>make bootstrap</code> then please +quickly review the build status page for your release, available from +<a href="http://gcc.gnu.org/buildstat.html">http://gcc.gnu.org/buildstat.html</a>. +If your system is not listed for the version of GCC that you built, +send a note to +<a href="mailto:gcc@gcc.gnu.org">gcc@gcc.gnu.org</a> indicating +that you successfully built and installed GCC. +Include the following information: + +<ul> +<li>Output from running <code><var>srcdir</var>/config.guess</code>. Do not send us +that file itself, just the one-line output from running it. + +<li>The output of <code>gcc -v</code> for your newly installed gcc. +This tells us which version of GCC you built and the options you passed to +configure. + +<li>Whether you enabled all languages or a subset of them. If you used a +full distribution then this information is part of the configure +options in the output of <code>gcc -v</code>, but if you downloaded the +"core" compiler plus additional front ends then it isn't apparent +which ones you built unless you tell us about it. + +<li>If the build was for GNU/Linux, also include: +<ul> +<li>The distribution name and version (e.g., Red Hat 7.1 or Debian 2.2.3); +this information should be available from <code>/etc/issue</code>. + +<li>The version of the Linux kernel, available from <code>uname --version</code> +or <code>uname -a</code>. + +<li>The version of glibc you used; for RPM-based systems like Red Hat, +Mandrake, and SuSE type <code>rpm -q glibc</code> to get the glibc version, +and on systems like Debian and Progeny use <code>dpkg -l libc6</code>. +</ul> +For other systems, you can include similar information if you think it is +relevant. + +<li>Any other information that you think would be useful to people building +GCC on the same configuration. The new entry in the build status list +will include a link to the archived copy of your message. +</ul> + +<p>We'd also like to know if the +<a href="specific.html">host/target specific installation notes</a> +didn't include your host/target information or if that information is +incomplete or out of date. Send a note to +<a href="mailto:gcc@gcc.gnu.org">gcc@gcc.gnu.org</a> telling us how the information should be changed. + +<p>If you find a bug, please report it following our +<a href="../bugs.html">bug reporting guidelines</a>. + +<p>If you want to print the GCC manuals, do <code>cd <var>objdir</var>; make +dvi</code>. You will need to have <code>texi2dvi</code> (version at least 4.2) +and TeX installed. This creates a number of <code>.dvi</code> files in +subdirectories of <code><var>objdir</var></code>; these may be converted for +printing with programs such as <code>dvips</code>. You can also +<a href="http://www.gnu.org/order/order.html">buy printed manuals from the Free Software Foundation</a>, though such manuals may not be for the most +recent version of GCC. + +<hr /> +<p> +<a href="./index.html">Return to the GCC Installation page</a> + +</body></html> + diff --git a/gnu/usr.bin/gcc/INSTALL/gfdl.html b/gnu/usr.bin/gcc/INSTALL/gfdl.html new file mode 100644 index 00000000000..e0b3465ac1a --- /dev/null +++ b/gnu/usr.bin/gcc/INSTALL/gfdl.html @@ -0,0 +1,446 @@ +<html lang="en"> +<head> +<title>Installing GCC: GNU Free Documentation License</title> +<meta http-equiv="Content-Type" content="text/html"> +<meta name=description content="Installing GCC: GNU Free Documentation License"> +<meta name=generator content="makeinfo 4.2"> +<link href="http://www.gnu.org/software/texinfo/" rel=generator-home> +<!-- +Copyright © 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998, +1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc. +<br><p> +<p>Permission is granted to copy, distribute and/or modify this document +under the terms of the GNU Free Documentation License, Version 1.2 or +any later version published by the Free Software Foundation; with no +Invariant Sections, the Front-Cover texts being (a) (see below), and +with the Back-Cover Texts being (b) (see below). A copy of the +license is included in the section entitled "<a href="./gfdl.html">GNU Free Documentation License</a>". + +<p>(a) The FSF's Front-Cover Text is: + +<p>A GNU Manual + +<p>(b) The FSF's Back-Cover Text is: + +<p>You have freedom to copy and modify this GNU Manual, like GNU + software. Copies published by the Free Software Foundation raise + funds for GNU development.--> +</head> +<body> +<h1>Installing GCC: GNU Free Documentation License</h1> +<h1 align="center">Installing GCC: GNU Free Documentation License</h1> + +<div align="center">Version 1.2, November 2002</div> +<br><pre>Copyright © 2000,2001,2002 Free Software Foundation, Inc. +59 Temple Place, Suite 330, Boston, MA 02111-1307, USA + +Everyone is permitted to copy and distribute verbatim copies +of this license document, but changing it is not allowed. +</pre> + +<ol type=1 start=0> +</p><li>PREAMBLE + +<p>The purpose of this License is to make a manual, textbook, or other +functional and useful document <dfn>free</dfn> in the sense of freedom: to +assure everyone the effective freedom to copy and redistribute it, +with or without modifying it, either commercially or noncommercially. +Secondarily, this License preserves for the author and publisher a way +to get credit for their work, while not being considered responsible +for modifications made by others. + +<p>This License is a kind of "copyleft", which means that derivative +works of the document must themselves be free in the same sense. It +complements the GNU General Public License, which is a copyleft +license designed for free software. + +<p>We have designed this License in order to use it for manuals for free +software, because free software needs free documentation: a free +program should come with manuals providing the same freedoms that the +software does. But this License is not limited to software manuals; +it can be used for any textual work, regardless of subject matter or +whether it is published as a printed book. We recommend this License +principally for works whose purpose is instruction or reference. + +</p><li>APPLICABILITY AND DEFINITIONS + +<p>This License applies to any manual or other work, in any medium, that +contains a notice placed by the copyright holder saying it can be +distributed under the terms of this License. Such a notice grants a +world-wide, royalty-free license, unlimited in duration, to use that +work under the conditions stated herein. The "Document", below, +refers to any such manual or work. Any member of the public is a +licensee, and is addressed as "you". You accept the license if you +copy, modify or distribute the work in a way requiring permission +under copyright law. + +<p>A "Modified Version" of the Document means any work containing the +Document or a portion of it, either copied verbatim, or with +modifications and/or translated into another language. + +<p>A "Secondary Section" is a named appendix or a front-matter section +of the Document that deals exclusively with the relationship of the +publishers or authors of the Document to the Document's overall +subject (or to related matters) and contains nothing that could fall +directly within that overall subject. (Thus, if the Document is in +part a textbook of mathematics, a Secondary Section may not explain +any mathematics.) The relationship could be a matter of historical +connection with the subject or with related matters, or of legal, +commercial, philosophical, ethical or political position regarding +them. + +<p>The "Invariant Sections" are certain Secondary Sections whose titles +are designated, as being those of Invariant Sections, in the notice +that says that the Document is released under this License. If a +section does not fit the above definition of Secondary then it is not +allowed to be designated as Invariant. The Document may contain zero +Invariant Sections. If the Document does not identify any Invariant +Sections then there are none. + +<p>The "Cover Texts" are certain short passages of text that are listed, +as Front-Cover Texts or Back-Cover Texts, in the notice that says that +the Document is released under this License. A Front-Cover Text may +be at most 5 words, and a Back-Cover Text may be at most 25 words. + +<p>A "Transparent" copy of the Document means a machine-readable copy, +represented in a format whose specification is available to the +general public, that is suitable for revising the document +straightforwardly with generic text editors or (for images composed of +pixels) generic paint programs or (for drawings) some widely available +drawing editor, and that is suitable for input to text formatters or +for automatic translation to a variety of formats suitable for input +to text formatters. A copy made in an otherwise Transparent file +format whose markup, or absence of markup, has been arranged to thwart +or discourage subsequent modification by readers is not Transparent. +An image format is not Transparent if used for any substantial amount +of text. A copy that is not "Transparent" is called "Opaque". + +<p>Examples of suitable formats for Transparent copies include plain +<small>ASCII</small> without markup, Texinfo input format, LaTeX input +format, <small>SGML</small> or <small>XML</small> using a publicly available +<small>DTD</small>, and standard-conforming simple <small>HTML</small>, +PostScript or <small>PDF</small> designed for human modification. Examples +of transparent image formats include <small>PNG</small>, <small>XCF</small> and +<small>JPG</small>. Opaque formats include proprietary formats that can be +read and edited only by proprietary word processors, <small>SGML</small> or +<small>XML</small> for which the <small>DTD</small> and/or processing tools are +not generally available, and the machine-generated <small>HTML</small>, +PostScript or <small>PDF</small> produced by some word processors for +output purposes only. + +<p>The "Title Page" means, for a printed book, the title page itself, +plus such following pages as are needed to hold, legibly, the material +this License requires to appear in the title page. For works in +formats which do not have any title page as such, "Title Page" means +the text near the most prominent appearance of the work's title, +preceding the beginning of the body of the text. + +<p>A section "Entitled XYZ" means a named subunit of the Document whose +title either is precisely XYZ or contains XYZ in parentheses following +text that translates XYZ in another language. (Here XYZ stands for a +specific section name mentioned below, such as "Acknowledgements", +"Dedications", "Endorsements", or "History".) To "Preserve the Title" +of such a section when you modify the Document means that it remains a +section "Entitled XYZ" according to this definition. + +<p>The Document may include Warranty Disclaimers next to the notice which +states that this License applies to the Document. These Warranty +Disclaimers are considered to be included by reference in this +License, but only as regards disclaiming warranties: any other +implication that these Warranty Disclaimers may have is void and has +no effect on the meaning of this License. + +</p><li>VERBATIM COPYING + +<p>You may copy and distribute the Document in any medium, either +commercially or noncommercially, provided that this License, the +copyright notices, and the license notice saying this License applies +to the Document are reproduced in all copies, and that you add no other +conditions whatsoever to those of this License. You may not use +technical measures to obstruct or control the reading or further +copying of the copies you make or distribute. However, you may accept +compensation in exchange for copies. If you distribute a large enough +number of copies you must also follow the conditions in section 3. + +<p>You may also lend copies, under the same conditions stated above, and +you may publicly display copies. + +</p><li>COPYING IN QUANTITY + +<p>If you publish printed copies (or copies in media that commonly have +printed covers) of the Document, numbering more than 100, and the +Document's license notice requires Cover Texts, you must enclose the +copies in covers that carry, clearly and legibly, all these Cover +Texts: Front-Cover Texts on the front cover, and Back-Cover Texts on +the back cover. Both covers must also clearly and legibly identify +you as the publisher of these copies. The front cover must present +the full title with all words of the title equally prominent and +visible. You may add other material on the covers in addition. +Copying with changes limited to the covers, as long as they preserve +the title of the Document and satisfy these conditions, can be treated +as verbatim copying in other respects. + +<p>If the required texts for either cover are too voluminous to fit +legibly, you should put the first ones listed (as many as fit +reasonably) on the actual cover, and continue the rest onto adjacent +pages. + +<p>If you publish or distribute Opaque copies of the Document numbering +more than 100, you must either include a machine-readable Transparent +copy along with each Opaque copy, or state in or with each Opaque copy +a computer-network location from which the general network-using +public has access to download using public-standard network protocols +a complete Transparent copy of the Document, free of added material. +If you use the latter option, you must take reasonably prudent steps, +when you begin distribution of Opaque copies in quantity, to ensure +that this Transparent copy will remain thus accessible at the stated +location until at least one year after the last time you distribute an +Opaque copy (directly or through your agents or retailers) of that +edition to the public. + +<p>It is requested, but not required, that you contact the authors of the +Document well before redistributing any large number of copies, to give +them a chance to provide you with an updated version of the Document. + +</p><li>MODIFICATIONS + +<p>You may copy and distribute a Modified Version of the Document under +the conditions of sections 2 and 3 above, provided that you release +the Modified Version under precisely this License, with the Modified +Version filling the role of the Document, thus licensing distribution +and modification of the Modified Version to whoever possesses a copy +of it. In addition, you must do these things in the Modified Version: + +<ol type=A start=1> +</p><li>Use in the Title Page (and on the covers, if any) a title distinct +from that of the Document, and from those of previous versions +(which should, if there were any, be listed in the History section +of the Document). You may use the same title as a previous version +if the original publisher of that version gives permission. + +<li>List on the Title Page, as authors, one or more persons or entities +responsible for authorship of the modifications in the Modified +Version, together with at least five of the principal authors of the +Document (all of its principal authors, if it has fewer than five), +unless they release you from this requirement. + +<li>State on the Title page the name of the publisher of the +Modified Version, as the publisher. + +<li>Preserve all the copyright notices of the Document. + +<li>Add an appropriate copyright notice for your modifications +adjacent to the other copyright notices. + +<li>Include, immediately after the copyright notices, a license notice +giving the public permission to use the Modified Version under the +terms of this License, in the form shown in the Addendum below. + +<li>Preserve in that license notice the full lists of Invariant Sections +and required Cover Texts given in the Document's license notice. + +<li>Include an unaltered copy of this License. + +<li>Preserve the section Entitled "History", Preserve its Title, and add +to it an item stating at least the title, year, new authors, and +publisher of the Modified Version as given on the Title Page. If +there is no section Entitled "History" in the Document, create one +stating the title, year, authors, and publisher of the Document as +given on its Title Page, then add an item describing the Modified +Version as stated in the previous sentence. + +<li>Preserve the network location, if any, given in the Document for +public access to a Transparent copy of the Document, and likewise +the network locations given in the Document for previous versions +it was based on. These may be placed in the "History" section. +You may omit a network location for a work that was published at +least four years before the Document itself, or if the original +publisher of the version it refers to gives permission. + +<li>For any section Entitled "Acknowledgements" or "Dedications", Preserve +the Title of the section, and preserve in the section all the +substance and tone of each of the contributor acknowledgements and/or +dedications given therein. + +<li>Preserve all the Invariant Sections of the Document, +unaltered in their text and in their titles. Section numbers +or the equivalent are not considered part of the section titles. + +<li>Delete any section Entitled "Endorsements". Such a section +may not be included in the Modified Version. + +<li>Do not retitle any existing section to be Entitled "Endorsements" or +to conflict in title with any Invariant Section. + +<li>Preserve any Warranty Disclaimers. +</ol> + +<p>If the Modified Version includes new front-matter sections or +appendices that qualify as Secondary Sections and contain no material +copied from the Document, you may at your option designate some or all +of these sections as invariant. To do this, add their titles to the +list of Invariant Sections in the Modified Version's license notice. +These titles must be distinct from any other section titles. + +<p>You may add a section Entitled "Endorsements", provided it contains +nothing but endorsements of your Modified Version by various +parties--for example, statements of peer review or that the text has +been approved by an organization as the authoritative definition of a +standard. + +<p>You may add a passage of up to five words as a Front-Cover Text, and a +passage of up to 25 words as a Back-Cover Text, to the end of the list +of Cover Texts in the Modified Version. Only one passage of +Front-Cover Text and one of Back-Cover Text may be added by (or +through arrangements made by) any one entity. If the Document already +includes a cover text for the same cover, previously added by you or +by arrangement made by the same entity you are acting on behalf of, +you may not add another; but you may replace the old one, on explicit +permission from the previous publisher that added the old one. + +<p>The author(s) and publisher(s) of the Document do not by this License +give permission to use their names for publicity for or to assert or +imply endorsement of any Modified Version. + +</p><li>COMBINING DOCUMENTS + +<p>You may combine the Document with other documents released under this +License, under the terms defined in section 4 above for modified +versions, provided that you include in the combination all of the +Invariant Sections of all of the original documents, unmodified, and +list them all as Invariant Sections of your combined work in its +license notice, and that you preserve all their Warranty Disclaimers. + +<p>The combined work need only contain one copy of this License, and +multiple identical Invariant Sections may be replaced with a single +copy. If there are multiple Invariant Sections with the same name but +different contents, make the title of each such section unique by +adding at the end of it, in parentheses, the name of the original +author or publisher of that section if known, or else a unique number. +Make the same adjustment to the section titles in the list of +Invariant Sections in the license notice of the combined work. + +<p>In the combination, you must combine any sections Entitled "History" +in the various original documents, forming one section Entitled +"History"; likewise combine any sections Entitled "Acknowledgements", +and any sections Entitled "Dedications". You must delete all +sections Entitled "Endorsements." + +</p><li>COLLECTIONS OF DOCUMENTS + +<p>You may make a collection consisting of the Document and other documents +released under this License, and replace the individual copies of this +License in the various documents with a single copy that is included in +the collection, provided that you follow the rules of this License for +verbatim copying of each of the documents in all other respects. + +<p>You may extract a single document from such a collection, and distribute +it individually under this License, provided you insert a copy of this +License into the extracted document, and follow this License in all +other respects regarding verbatim copying of that document. + +</p><li>AGGREGATION WITH INDEPENDENT WORKS + +<p>A compilation of the Document or its derivatives with other separate +and independent documents or works, in or on a volume of a storage or +distribution medium, is called an "aggregate" if the copyright +resulting from the compilation is not used to limit the legal rights +of the compilation's users beyond what the individual works permit. +When the Document is included an aggregate, this License does not +apply to the other works in the aggregate which are not themselves +derivative works of the Document. + +<p>If the Cover Text requirement of section 3 is applicable to these +copies of the Document, then if the Document is less than one half of +the entire aggregate, the Document's Cover Texts may be placed on +covers that bracket the Document within the aggregate, or the +electronic equivalent of covers if the Document is in electronic form. +Otherwise they must appear on printed covers that bracket the whole +aggregate. + +</p><li>TRANSLATION + +<p>Translation is considered a kind of modification, so you may +distribute translations of the Document under the terms of section 4. +Replacing Invariant Sections with translations requires special +permission from their copyright holders, but you may include +translations of some or all Invariant Sections in addition to the +original versions of these Invariant Sections. You may include a +translation of this License, and all the license notices in the +Document, and any Warrany Disclaimers, provided that you also include +the original English version of this License and the original versions +of those notices and disclaimers. In case of a disagreement between +the translation and the original version of this License or a notice +or disclaimer, the original version will prevail. + +<p>If a section in the Document is Entitled "Acknowledgements", +"Dedications", or "History", the requirement (section 4) to Preserve +its Title (section 1) will typically require changing the actual +title. + +</p><li>TERMINATION + +<p>You may not copy, modify, sublicense, or distribute the Document except +as expressly provided for under this License. Any other attempt to +copy, modify, sublicense or distribute the Document is void, and will +automatically terminate your rights under this License. However, +parties who have received copies, or rights, from you under this +License will not have their licenses terminated so long as such +parties remain in full compliance. + +</p><li>FUTURE REVISIONS OF THIS LICENSE + +<p>The Free Software Foundation may publish new, revised versions +of the GNU Free Documentation License from time to time. Such new +versions will be similar in spirit to the present version, but may +differ in detail to address new problems or concerns. See +<a href="http://www.gnu.org/copyleft/">http://www.gnu.org/copyleft/</a>. + +<p>Each version of the License is given a distinguishing version number. +If the Document specifies that a particular numbered version of this +License "or any later version" applies to it, you have the option of +following the terms and conditions either of that specified version or +of any later version that has been published (not as a draft) by the +Free Software Foundation. If the Document does not specify a version +number of this License, you may choose any version ever published (not +as a draft) by the Free Software Foundation. +</ol> + +<h3><a name="TOC0"></a>ADDENDUM: How to use this License for your documents</h3> + +<p>To use this License in a document you have written, include a copy of +the License in the document and put the following copyright and +license notices just after the title page: + +<br><pre> Copyright (C) <var>year</var> <var>your name</var>. + Permission is granted to copy, distribute and/or modify this document + under the terms of the GNU Free Documentation License, Version 1.2 + or any later version published by the Free Software Foundation; + with no Invariant Sections, no Front-Cover Texts, and no Back-Cover Texts. + A copy of the license is included in the section entitled ``GNU + Free Documentation License''. +</pre> + +<p>If you have Invariant Sections, Front-Cover Texts and Back-Cover Texts, +replace the "with...Texts." line with this: + +<br><pre> with the Invariant Sections being <var>list their titles</var>, with + the Front-Cover Texts being <var>list</var>, and with the Back-Cover Texts + being <var>list</var>. +</pre> + +<p>If you have Invariant Sections without Cover Texts, or some other +combination of the three, merge those two alternatives to suit the +situation. + +<p>If your document contains nontrivial examples of program code, we +recommend releasing these examples in parallel under your choice of +free software license, such as the GNU General Public License, +to permit their use in free software. + +<hr /> +<p> +<a href="./index.html">Return to the GCC Installation page</a> + +</body></html> + diff --git a/gnu/usr.bin/gcc/INSTALL/index.html b/gnu/usr.bin/gcc/INSTALL/index.html new file mode 100644 index 00000000000..97ef25421d0 --- /dev/null +++ b/gnu/usr.bin/gcc/INSTALL/index.html @@ -0,0 +1,95 @@ +<html lang="en"> +<head> +<title>Installing GCC</title> +<meta http-equiv="Content-Type" content="text/html"> +<meta name=description content="Installing GCC"> +<meta name=generator content="makeinfo 4.2"> +<link href="http://www.gnu.org/software/texinfo/" rel=generator-home> +<!-- +Copyright © 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998, +1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc. +<br><p> +<p>Permission is granted to copy, distribute and/or modify this document +under the terms of the GNU Free Documentation License, Version 1.2 or +any later version published by the Free Software Foundation; with no +Invariant Sections, the Front-Cover texts being (a) (see below), and +with the Back-Cover Texts being (b) (see below). A copy of the +license is included in the section entitled "<a href="./gfdl.html">GNU Free Documentation License</a>". + +<p>(a) The FSF's Front-Cover Text is: + +<p>A GNU Manual + +<p>(b) The FSF's Back-Cover Text is: + +<p>You have freedom to copy and modify this GNU Manual, like GNU + software. Copies published by the Free Software Foundation raise + funds for GNU development.--> +</head> +<body> +<h1>Installing GCC</h1> +The latest version of this document is always available at +<a href="http://gcc.gnu.org/install/">http://gcc.gnu.org/install/</a>. + +<p>This document describes the generic installation procedure for GCC as well +as detailing some target specific installation instructions. + +<p>GCC includes several components that previously were separate distributions +with their own installation instructions. This document supersedes all +package specific installation instructions. + +<p><em>Before</em> starting the build/install procedure please check the +<a href="specific.html">host/target specific installation notes</a>. +We recommend you browse the entire generic installation instructions before +you proceed. + +<p>Lists of successful builds for released versions of GCC are +available at <a href="http://gcc.gnu.org/buildstat.html">http://gcc.gnu.org/buildstat.html</a>. +These lists are updated as new information becomes available. + +<p>The installation procedure itself is broken into five steps. + +<ol type=1 start=1> +</p><li><a href="download.html">Downloading the source</a> +<li><a href="configure.html">Configuration</a> +<li><a href="build.html">Building</a> +<li><a href="test.html">Testing</a> (optional) +<li><a href="finalinstall.html">Final install</a> +</ol> + +<p>Please note that GCC does not support <code>make uninstall</code> and probably +won't do so in the near future as this would open a can of worms. Instead, +we suggest that you install GCC into a directory of its own and simply +remove that directory when you do not need that specific version of GCC +any longer, and, if shared libraries are installed there as well, no +more binaries exist that use them. + +<p>There are also some <a href="old.html">old installation instructions</a>, +which are mostly obsolete but still contain some information which has +not yet been merged into the main part of this manual. + +<hr /> +<p> +<a href="./index.html">Return to the GCC Installation page</a> + +Copyright © 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998, +1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc. +<br><p> +<p>Permission is granted to copy, distribute and/or modify this document +under the terms of the GNU Free Documentation License, Version 1.2 or +any later version published by the Free Software Foundation; with no +Invariant Sections, the Front-Cover texts being (a) (see below), and +with the Back-Cover Texts being (b) (see below). A copy of the +license is included in the section entitled "<a href="./gfdl.html">GNU Free Documentation License</a>". + +<p>(a) The FSF's Front-Cover Text is: + +<p>A GNU Manual + +<p>(b) The FSF's Back-Cover Text is: + +<p>You have freedom to copy and modify this GNU Manual, like GNU + software. Copies published by the Free Software Foundation raise + funds for GNU development. +</body></html> + diff --git a/gnu/usr.bin/gcc/INSTALL/old.html b/gnu/usr.bin/gcc/INSTALL/old.html new file mode 100644 index 00000000000..220d523a1c2 --- /dev/null +++ b/gnu/usr.bin/gcc/INSTALL/old.html @@ -0,0 +1,618 @@ +<html lang="en"> +<head> +<title>Installing GCC: Old documentation</title> +<meta http-equiv="Content-Type" content="text/html"> +<meta name=description content="Installing GCC: Old documentation"> +<meta name=generator content="makeinfo 4.2"> +<link href="http://www.gnu.org/software/texinfo/" rel=generator-home> +<!-- +Copyright © 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998, +1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc. +<br><p> +<p>Permission is granted to copy, distribute and/or modify this document +under the terms of the GNU Free Documentation License, Version 1.2 or +any later version published by the Free Software Foundation; with no +Invariant Sections, the Front-Cover texts being (a) (see below), and +with the Back-Cover Texts being (b) (see below). A copy of the +license is included in the section entitled "<a href="./gfdl.html">GNU Free Documentation License</a>". + +<p>(a) The FSF's Front-Cover Text is: + +<p>A GNU Manual + +<p>(b) The FSF's Back-Cover Text is: + +<p>You have freedom to copy and modify this GNU Manual, like GNU + software. Copies published by the Free Software Foundation raise + funds for GNU development.--> +</head> +<body> +<h1>Installing GCC: Old documentation</h1> +<h1 align="center">Old installation documentation</h1> + +<p>Note most of this information is out of date and superseded by the +previous chapters of this manual. It is provided for historical +reference only, because of a lack of volunteers to merge it into the +main manual. + +<p>Here is the procedure for installing GNU CC on a GNU or Unix system. +See <a href="#VMS%20Install">VMS Install</a>, for VMS systems. + +<ol type=1 start=1> +</p><li>If you have chosen a configuration for GNU CC which requires other GNU +tools (such as GAS or the GNU linker) instead of the standard system +tools, install the required tools in the build directory under the names +<code>as</code>, <code>ld</code> or whatever is appropriate. + +<p>Alternatively, you can do subsequent compilation using a value of the +<code>PATH</code> environment variable such that the necessary GNU tools come +before the standard system tools. + +</p><li>Specify the host, build and target machine configurations. You do this +when you run the <code>configure</code> script. + +<p>The <dfn>build</dfn> machine is the system which you are using, the +<dfn>host</dfn> machine is the system where you want to run the resulting +compiler (normally the build machine), and the <dfn>target</dfn> machine is +the system for which you want the compiler to generate code. + +<p>If you are building a compiler to produce code for the machine it runs +on (a native compiler), you normally do not need to specify any operands +to <code>configure</code>; it will try to guess the type of machine you are on +and use that as the build, host and target machines. So you don't need +to specify a configuration when building a native compiler unless +<code>configure</code> cannot figure out what your configuration is or guesses +wrong. + +<p>In those cases, specify the build machine's <dfn>configuration name</dfn> +with the <code>--host</code> option; the host and target will default to be +the same as the host machine. (If you are building a cross-compiler, +see <a href="#Cross-Compiler">Cross-Compiler</a>.) + +<p>Here is an example: + +<br><pre>./configure --host=sparc-sun-sunos4.1 +</pre> + +<p>A configuration name may be canonical or it may be more or less +abbreviated. + +<p>A canonical configuration name has three parts, separated by dashes. +It looks like this: <code><var>cpu</var>-<var>company</var>-<var>system</var></code>. +(The three parts may themselves contain dashes; <code>configure</code> +can figure out which dashes serve which purpose.) For example, +<code>m68k-sun-sunos4.1</code> specifies a Sun 3. + +<p>You can also replace parts of the configuration by nicknames or aliases. +For example, <code>sun3</code> stands for <code>m68k-sun</code>, so +<code>sun3-sunos4.1</code> is another way to specify a Sun 3. + +<p>You can specify a version number after any of the system types, and some +of the CPU types. In most cases, the version is irrelevant, and will be +ignored. So you might as well specify the version if you know it. + +<p>See <a href="#Configurations">Configurations</a>, for a list of supported configuration names and +notes on many of the configurations. You should check the notes in that +section before proceeding any further with the installation of GNU CC. + +</ol> + +<h2><a name="Configurations"></a>Configurations Supported by GNU CC</h2> + +<p>Here are the possible CPU types: + +<blockquote> +1750a, a29k, alpha, arm, avr, c<var>n</var>, clipper, dsp16xx, elxsi, fr30, h8300, +hppa1.0, hppa1.1, i370, i386, i486, i586, i686, i786, i860, i960, ip2k, m32r, +m68000, m68k, m6811, m6812, m88k, mcore, mips, mipsel, mips64, mips64el, +mn10200, mn10300, ns32k, pdp11, powerpc, powerpcle, romp, rs6000, sh, sparc, +sparclite, sparc64, v850, vax, we32k. +</blockquote> + +<p>Here are the recognized company names. As you can see, customary +abbreviations are used rather than the longer official names. + +<blockquote> +acorn, alliant, altos, apollo, apple, att, bull, +cbm, convergent, convex, crds, dec, dg, dolphin, +elxsi, encore, harris, hitachi, hp, ibm, intergraph, isi, +mips, motorola, ncr, next, ns, omron, plexus, +sequent, sgi, sony, sun, tti, unicom, wrs. +</blockquote> + +<p>The company name is meaningful only to disambiguate when the rest of +the information supplied is insufficient. You can omit it, writing +just <code><var>cpu</var>-<var>system</var></code>, if it is not needed. For example, +<code>vax-ultrix4.2</code> is equivalent to <code>vax-dec-ultrix4.2</code>. + +<p>Here is a list of system types: + +<blockquote> +386bsd, aix, acis, amigaos, aos, aout, aux, bosx, bsd, clix, coff, ctix, cxux, +dgux, dynix, ebmon, ecoff, elf, esix, freebsd, hms, genix, gnu, linux, +linux-gnu, hiux, hpux, iris, irix, isc, luna, lynxos, mach, minix, msdos, mvs, +netbsd, newsos, nindy, ns, osf, osfrose, ptx, riscix, riscos, rtu, sco, sim, +solaris, sunos, sym, sysv, udi, ultrix, unicos, uniplus, unos, vms, vsta, +vxworks, winnt, xenix. +</blockquote> + +<p>You can omit the system type; then <code>configure</code> guesses the +operating system from the CPU and company. + +<p>You can add a version number to the system type; this may or may not +make a difference. For example, you can write <code>bsd4.3</code> or +<code>bsd4.4</code> to distinguish versions of BSD. In practice, the version +number is most needed for <code>sysv3</code> and <code>sysv4</code>, which are often +treated differently. + +<p><code>linux-gnu</code> is the canonical name for the GNU/Linux target; however +GNU CC will also accept <code>linux</code>. The version of the kernel in use is +not relevant on these systems. A suffix such as <code>libc1</code> or <code>aout</code> +distinguishes major versions of the C library; all of the suffixed versions +are obsolete. + +<p>If you specify an impossible combination such as <code>i860-dg-vms</code>, +then you may get an error message from <code>configure</code>, or it may +ignore part of the information and do the best it can with the rest. +<code>configure</code> always prints the canonical name for the alternative +that it used. GNU CC does not support all possible alternatives. + +<p>Often a particular model of machine has a name. Many machine names are +recognized as aliases for CPU/company combinations. Thus, the machine +name <code>sun3</code>, mentioned above, is an alias for <code>m68k-sun</code>. +Sometimes we accept a company name as a machine name, when the name is +popularly used for a particular machine. Here is a table of the known +machine names: + +<blockquote> +3300, 3b1, 3b<var>n</var>, 7300, altos3068, altos, +apollo68, att-7300, balance, +convex-c<var>n</var>, crds, decstation-3100, +decstation, delta, encore, +fx2800, gmicro, hp7<var>nn</var>, hp8<var>nn</var>, +hp9k2<var>nn</var>, hp9k3<var>nn</var>, hp9k7<var>nn</var>, +hp9k8<var>nn</var>, iris4d, iris, isi68, +m3230, magnum, merlin, miniframe, +mmax, news-3600, news800, news, next, +pbd, pc532, pmax, powerpc, powerpcle, ps2, risc-news, +rtpc, sun2, sun386i, sun386, sun3, +sun4, symmetry, tower-32, tower. +</blockquote> + +<p>Remember that a machine name specifies both the cpu type and the company +name. +If you want to install your own homemade configuration files, you can +use <code>local</code> as the company name to access them. If you use +configuration <code><var>cpu</var>-local</code>, the configuration name +without the cpu prefix +is used to form the configuration file names. + +<p>Thus, if you specify <code>m68k-local</code>, configuration uses +files <code>m68k.md</code>, <code>local.h</code>, <code>m68k.c</code>, +<code>xm-local.h</code>, <code>t-local</code>, and <code>x-local</code>, all in the +directory <code>config/m68k</code>. + +<p>Here is a list of configurations that have special treatment or special +things you must know: + +<dl> +<dt><code>vax-dec-vms</code> +<dd>See <a href="#VMS%20Install">VMS Install</a>, for details on how to install GNU CC on VMS. +</dl> + +<h2><a name="Cross-Compiler"></a>Building and Installing a Cross-Compiler</h2> + +<p>GNU CC can function as a cross-compiler for many machines, but not all. + +<ul> +<li>Cross-compilers for the Mips as target using the Mips assembler +currently do not work, because the auxiliary programs +<code>mips-tdump.c</code> and <code>mips-tfile.c</code> can't be compiled on +anything but a Mips. It does work to cross compile for a Mips +if you use the GNU assembler and linker. + +<li>Cross-compilers between machines with different floating point formats +have not all been made to work. GNU CC now has a floating point +emulator with which these can work, but each target machine description +needs to be updated to take advantage of it. + +<li>Cross-compilation between machines of different word sizes is +somewhat problematic and sometimes does not work. +</ul> + +<p>Since GNU CC generates assembler code, you probably need a +cross-assembler that GNU CC can run, in order to produce object files. +If you want to link on other than the target machine, you need a +cross-linker as well. You also need header files and libraries suitable +for the target machine that you can install on the host machine. + +<h2>Steps of Cross-Compilation</h2> + +<p>To compile and run a program using a cross-compiler involves several +steps: + +<ul> +<li>Run the cross-compiler on the host machine to produce assembler files +for the target machine. This requires header files for the target +machine. + +<li>Assemble the files produced by the cross-compiler. You can do this +either with an assembler on the target machine, or with a +cross-assembler on the host machine. + +<li>Link those files to make an executable. You can do this either with a +linker on the target machine, or with a cross-linker on the host +machine. Whichever machine you use, you need libraries and certain +startup files (typically <code>crt<small>...</small>.o</code>) for the target machine. +</ul> + +<p>It is most convenient to do all of these steps on the same host machine, +since then you can do it all with a single invocation of GNU CC. This +requires a suitable cross-assembler and cross-linker. For some targets, +the GNU assembler and linker are available. + +<h2>Configuring a Cross-Compiler</h2> + +<p>To build GNU CC as a cross-compiler, you start out by running +<code>configure</code>. Use the <code>--target=<var>target</var></code> to specify the +target type. If <code>configure</code> was unable to correctly identify the +system you are running on, also specify the <code>--build=<var>build</var></code> +option. For example, here is how to configure for a cross-compiler that +produces code for an HP 68030 system running BSD on a system that +<code>configure</code> can correctly identify: + +<br><pre>./configure --target=m68k-hp-bsd4.3 +</pre> + +<h2>Tools and Libraries for a Cross-Compiler</h2> + +<p>If you have a cross-assembler and cross-linker available, you should +install them now. Put them in the directory +<code>/usr/local/<var>target</var>/bin</code>. Here is a table of the tools +you should put in this directory: + +<dl> +<dt><code>as</code> +<dd>This should be the cross-assembler. + +<br><dt><code>ld</code> +<dd>This should be the cross-linker. + +<br><dt><code>ar</code> +<dd>This should be the cross-archiver: a program which can manipulate +archive files (linker libraries) in the target machine's format. + +<br><dt><code>ranlib</code> +<dd>This should be a program to construct a symbol table in an archive file. +</dl> + +<p>The installation of GNU CC will find these programs in that directory, +and copy or link them to the proper place to for the cross-compiler to +find them when run later. + +<p>The easiest way to provide these files is to build the Binutils package +and GAS. Configure them with the same <code>--host</code> and <code>--target</code> +options that you use for configuring GNU CC, then build and install +them. They install their executables automatically into the proper +directory. Alas, they do not support all the targets that GNU CC +supports. + +<p>If you want to install libraries to use with the cross-compiler, such as +a standard C library, put them in the directory +<code>/usr/local/<var>target</var>/lib</code>; installation of GNU CC copies +all the files in that subdirectory into the proper place for GNU CC to +find them and link with them. Here's an example of copying some +libraries from a target machine: + +<br><pre>ftp <var>target-machine</var> +lcd /usr/local/<var>target</var>/lib +cd /lib +get libc.a +cd /usr/lib +get libg.a +get libm.a +quit +</pre> + +<p>The precise set of libraries you'll need, and their locations on +the target machine, vary depending on its operating system. + +<p>Many targets require "start files" such as <code>crt0.o</code> and +<code>crtn.o</code> which are linked into each executable; these too should be +placed in <code>/usr/local/<var>target</var>/lib</code>. There may be several +alternatives for <code>crt0.o</code>, for use with profiling or other +compilation options. Check your target's definition of +<code>STARTFILE_SPEC</code> to find out what start files it uses. +Here's an example of copying these files from a target machine: + +<br><pre>ftp <var>target-machine</var> +lcd /usr/local/<var>target</var>/lib +prompt +cd /lib +mget *crt*.o +cd /usr/lib +mget *crt*.o +quit +</pre> + +<h2>Cross-Compilers and Header Files</h2> + +<p>If you are cross-compiling a standalone program or a program for an +embedded system, then you may not need any header files except the few +that are part of GNU CC (and those of your program). However, if you +intend to link your program with a standard C library such as +<code>libc.a</code>, then you probably need to compile with the header files +that go with the library you use. + +<p>The GNU C compiler does not come with these files, because (1) they are +system-specific, and (2) they belong in a C library, not in a compiler. + +<p>If the GNU C library supports your target machine, then you can get the +header files from there (assuming you actually use the GNU library when +you link your program). + +<p>If your target machine comes with a C compiler, it probably comes with +suitable header files also. If you make these files accessible from the host +machine, the cross-compiler can use them also. + +<p>Otherwise, you're on your own in finding header files to use when +cross-compiling. + +<p>When you have found suitable header files, you should put them in the +directory <code>/usr/local/<var>target</var>/include</code>, before building the +cross compiler. Then installation will run fixincludes properly and +install the corrected versions of the header files where the compiler +will use them. + +<p>Provide the header files before you build the cross-compiler, because +the build stage actually runs the cross-compiler to produce parts of +<code>libgcc.a</code>. (These are the parts that <em>can</em> be compiled with +GNU CC.) Some of them need suitable header files. + +<p>Here's an example showing how to copy the header files from a target +machine. On the target machine, do this: + +<br><pre>(cd /usr/include; tar cf - .) > tarfile +</pre> + +<p>Then, on the host machine, do this: + +<br><pre>ftp <var>target-machine</var> +lcd /usr/local/<var>target</var>/include +get tarfile +quit +tar xf tarfile +</pre> + +<h2>Actually Building the Cross-Compiler</h2> + +<p>Now you can proceed just as for compiling a single-machine compiler +through the step of building stage 1. + +<p>Do not try to build stage 2 for a cross-compiler. It doesn't work to +rebuild GNU CC as a cross-compiler using the cross-compiler, because +that would produce a program that runs on the target machine, not on the +host. For example, if you compile a 386-to-68030 cross-compiler with +itself, the result will not be right either for the 386 (because it was +compiled into 68030 code) or for the 68030 (because it was configured +for a 386 as the host). If you want to compile GNU CC into 68030 code, +whether you compile it on a 68030 or with a cross-compiler on a 386, you +must specify a 68030 as the host when you configure it. + +<p>To install the cross-compiler, use <code>make install</code>, as usual. + +<h2><a name="VMS%20Install"></a>Installing GNU CC on VMS</h2> + +<p>The VMS version of GNU CC is distributed in a backup saveset containing +both source code and precompiled binaries. + +<p>To install the <code>gcc</code> command so you can use the compiler easily, in +the same manner as you use the VMS C compiler, you must install the VMS CLD +file for GNU CC as follows: + +<ol type=1 start=1> +</p><li>Define the VMS logical names <code>GNU_CC</code> and <code>GNU_CC_INCLUDE</code> +to point to the directories where the GNU CC executables +(<code>gcc-cpp.exe</code>, <code>gcc-cc1.exe</code>, etc.) and the C include files are +kept respectively. This should be done with the commands: + +<br><pre>$ assign /system /translation=concealed - + disk:[gcc.] gnu_cc +$ assign /system /translation=concealed - + disk:[gcc.include.] gnu_cc_include +</pre> + +<p>with the appropriate disk and directory names. These commands can be +placed in your system startup file so they will be executed whenever +the machine is rebooted. You may, if you choose, do this via the +<code>GCC_INSTALL.COM</code> script in the <code>[GCC]</code> directory. + +</p><li>Install the <code>GCC</code> command with the command line: + +<br><pre>$ set command /table=sys$common:[syslib]dcltables - + /output=sys$common:[syslib]dcltables gnu_cc:[000000]gcc +$ install replace sys$common:[syslib]dcltables +</pre> + +<li>To install the help file, do the following: + +<br><pre>$ library/help sys$library:helplib.hlb gcc.hlp +</pre> + +<p>Now you can invoke the compiler with a command like <code>gcc /verbose +file.c</code>, which is equivalent to the command <code>gcc -v -c file.c</code> in +Unix. +</ol> + +<p>If you wish to use GNU C++ you must first install GNU CC, and then +perform the following steps: + +<ol type=1 start=1> +</p><li>Define the VMS logical name <code>GNU_GXX_INCLUDE</code> to point to the +directory where the preprocessor will search for the C++ header files. +This can be done with the command: + +<br><pre>$ assign /system /translation=concealed - + disk:[gcc.gxx_include.] gnu_gxx_include +</pre> + +<p>with the appropriate disk and directory name. If you are going to be +using a C++ runtime library, this is where its install procedure will install +its header files. + +</p><li>Obtain the file <code>gcc-cc1plus.exe</code>, and place this in the same +directory that <code>gcc-cc1.exe</code> is kept. + +<p>The GNU C++ compiler can be invoked with a command like <code>gcc /plus +/verbose file.cc</code>, which is equivalent to the command <code>g++ -v -c +file.cc</code> in Unix. +</ol> + +<p>We try to put corresponding binaries and sources on the VMS distribution +tape. But sometimes the binaries will be from an older version than the +sources, because we don't always have time to update them. (Use the +<code>/version</code> option to determine the version number of the binaries and +compare it with the source file <code>version.c</code> to tell whether this is +so.) In this case, you should use the binaries you get to recompile the +sources. If you must recompile, here is how: + +<ol type=1 start=1> +</p><li>Execute the command procedure <code>vmsconfig.com</code> to set up the files +<code>tm.h</code>, <code>config.h</code>, <code>aux-output.c</code>, and <code>md.</code>, and +to create files <code>tconfig.h</code> and <code>hconfig.h</code>. This procedure +also creates several linker option files used by <code>make-cc1.com</code> and +a data file used by <code>make-l2.com</code>. + +<br><pre>$ @vmsconfig.com +</pre> + +<li>Setup the logical names and command tables as defined above. In +addition, define the VMS logical name <code>GNU_BISON</code> to point at the +to the directories where the Bison executable is kept. This should be +done with the command: + +<br><pre>$ assign /system /translation=concealed - + disk:[bison.] gnu_bison +</pre> + +<p>You may, if you choose, use the <code>INSTALL_BISON.COM</code> script in the +<code>[BISON]</code> directory. + +</p><li>Install the <code>BISON</code> command with the command line: + +<br><pre>$ set command /table=sys$common:[syslib]dcltables - + /output=sys$common:[syslib]dcltables - + gnu_bison:[000000]bison +$ install replace sys$common:[syslib]dcltables +</pre> + +<li>Type <code>@make-gcc</code> to recompile everything, or submit the file +<code>make-gcc.com</code> to a batch queue. If you wish to build the GNU C++ +compiler as well as the GNU CC compiler, you must first edit +<code>make-gcc.com</code> and follow the instructions that appear in the +comments. + +<li>In order to use GCC, you need a library of functions which GCC compiled code +will call to perform certain tasks, and these functions are defined in the +file <code>libgcc2.c</code>. To compile this you should use the command procedure +<code>make-l2.com</code>, which will generate the library <code>libgcc2.olb</code>. +<code>libgcc2.olb</code> should be built using the compiler built from +the same distribution that <code>libgcc2.c</code> came from, and +<code>make-gcc.com</code> will automatically do all of this for you. + +<p>To install the library, use the following commands: + +<br><pre>$ library gnu_cc:[000000]gcclib/delete=(new,eprintf) +$ library gnu_cc:[000000]gcclib/delete=L_* +$ library libgcc2/extract=*/output=libgcc2.obj +$ library gnu_cc:[000000]gcclib libgcc2.obj +</pre> + +<p>The first command simply removes old modules that will be replaced with +modules from <code>libgcc2</code> under different module names. The modules +<code>new</code> and <code>eprintf</code> may not actually be present in your +<code>gcclib.olb</code>--if the VMS librarian complains about those modules +not being present, simply ignore the message and continue on with the +next command. The second command removes the modules that came from the +previous version of the library <code>libgcc2.c</code>. + +<p>Whenever you update the compiler on your system, you should also update the +library with the above procedure. + +</p><li>You may wish to build GCC in such a way that no files are written to the +directory where the source files reside. An example would be the when +the source files are on a read-only disk. In these cases, execute the +following DCL commands (substituting your actual path names): + +<br><pre>$ assign dua0:[gcc.build_dir.]/translation=concealed, - + dua1:[gcc.source_dir.]/translation=concealed gcc_build +$ set default gcc_build:[000000] +</pre> + +<p>where the directory <code>dua1:[gcc.source_dir]</code> contains the source +code, and the directory <code>dua0:[gcc.build_dir]</code> is meant to contain +all of the generated object files and executables. Once you have done +this, you can proceed building GCC as described above. (Keep in mind +that <code>gcc_build</code> is a rooted logical name, and thus the device +names in each element of the search list must be an actual physical +device name rather than another rooted logical name). + +</p><li><strong>If you are building GNU CC with a previous version of GNU CC, +you also should check to see that you have the newest version of the +assembler</strong>. In particular, GNU CC version 2 treats global constant +variables slightly differently from GNU CC version 1, and GAS version +1.38.1 does not have the patches required to work with GCC version 2. +If you use GAS 1.38.1, then <code>extern const</code> variables will not have +the read-only bit set, and the linker will generate warning messages +about mismatched psect attributes for these variables. These warning +messages are merely a nuisance, and can safely be ignored. + +<li>If you want to build GNU CC with the VAX C compiler, you will need to +make minor changes in <code>make-cccp.com</code> and <code>make-cc1.com</code> +to choose alternate definitions of <code>CC</code>, <code>CFLAGS</code>, and +<code>LIBS</code>. See comments in those files. However, you must +also have a working version of the GNU assembler (GNU as, aka GAS) as +it is used as the back end for GNU CC to produce binary object modules +and is not included in the GNU CC sources. GAS is also needed to +compile <code>libgcc2</code> in order to build <code>gcclib</code> (see above); +<code>make-l2.com</code> expects to be able to find it operational in +<code>gnu_cc:[000000]gnu-as.exe</code>. + +<p>To use GNU CC on VMS, you need the VMS driver programs +<code>gcc.exe</code>, <code>gcc.com</code>, and <code>gcc.cld</code>. They are +distributed with the VMS binaries (<code>gcc-vms</code>) rather than the +GNU CC sources. GAS is also included in <code>gcc-vms</code>, as is Bison. + +<p>Once you have successfully built GNU CC with VAX C, you should use the +resulting compiler to rebuild itself. Before doing this, be sure to +restore the <code>CC</code>, <code>CFLAGS</code>, and <code>LIBS</code> definitions in +<code>make-cccp.com</code> and <code>make-cc1.com</code>. The second generation +compiler will be able to take advantage of many optimizations that must +be suppressed when building with other compilers. +</ol> + +<p>Under previous versions of GNU CC, the generated code would occasionally +give strange results when linked with the sharable <code>VAXCRTL</code> library. +Now this should work. + +<p>Even with this version, however, GNU CC itself should not be linked with +the sharable <code>VAXCRTL</code>. The version of <code>qsort</code> in +<code>VAXCRTL</code> has a bug (known to be present in VMS versions V4.6 +through V5.5) which causes the compiler to fail. + +<p>The executables are generated by <code>make-cc1.com</code> and +<code>make-cccp.com</code> use the object library version of <code>VAXCRTL</code> in +order to make use of the <code>qsort</code> routine in <code>gcclib.olb</code>. If +you wish to link the compiler executables with the shareable image +version of <code>VAXCRTL</code>, you should edit the file <code>tm.h</code> (created +by <code>vmsconfig.com</code>) to define the macro <code>QSORT_WORKAROUND</code>. + +<p><code>QSORT_WORKAROUND</code> is always defined when GNU CC is compiled with +VAX C, to avoid a problem in case <code>gcclib.olb</code> is not yet +available. +<hr /> +<p> +<a href="./index.html">Return to the GCC Installation page</a> + +</body></html> + diff --git a/gnu/usr.bin/gcc/INSTALL/specific.html b/gnu/usr.bin/gcc/INSTALL/specific.html new file mode 100644 index 00000000000..7f4c2891b71 --- /dev/null +++ b/gnu/usr.bin/gcc/INSTALL/specific.html @@ -0,0 +1,1665 @@ +<html lang="en"> +<head> +<title>Host/Target specific installation notes for GCC</title> +<meta http-equiv="Content-Type" content="text/html"> +<meta name=description content="Host/Target specific installation notes for GCC"> +<meta name=generator content="makeinfo 4.2"> +<link href="http://www.gnu.org/software/texinfo/" rel=generator-home> +<!-- +Copyright © 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998, +1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc. +<br><p> +<p>Permission is granted to copy, distribute and/or modify this document +under the terms of the GNU Free Documentation License, Version 1.2 or +any later version published by the Free Software Foundation; with no +Invariant Sections, the Front-Cover texts being (a) (see below), and +with the Back-Cover Texts being (b) (see below). A copy of the +license is included in the section entitled "<a href="./gfdl.html">GNU Free Documentation License</a>". + +<p>(a) The FSF's Front-Cover Text is: + +<p>A GNU Manual + +<p>(b) The FSF's Back-Cover Text is: + +<p>You have freedom to copy and modify this GNU Manual, like GNU + software. Copies published by the Free Software Foundation raise + funds for GNU development.--> +</head> +<body> +<h1>Host/Target specific installation notes for GCC</h1> +Please read this document carefully <em>before</em> installing the +GNU Compiler Collection on your machine. + +<ul> +<li><a href="#alpha*-*-*">alpha*-*-*</a> +<li><a href="#alpha*-dec-osf*">alpha*-dec-osf*</a> +<li><a href="#alphaev5-cray-unicosmk*">alphaev5-cray-unicosmk*</a> +<li><a href="#arc-*-elf">arc-*-elf</a> +<li><a href="#arm-*-aout">arm-*-aout</a> +<li><a href="#arm-*-elf">arm-*-elf</a> +<li><a href="#arm*-*-linux-gnu">arm*-*-linux-gnu</a> +<li><a href="#avr">avr</a> +<li><a href="#c4x">c4x</a> +<li><a href="#dos">DOS</a> +<li><a href="#dsp16xx">dsp16xx</a> +<li><a href="#*-*-freebsd*">*-*-freebsd*</a> +<li><a href="#h8300-hms">h8300-hms</a> +<li><a href="#hppa*-hp-hpux*">hppa*-hp-hpux*</a> +<li><a href="#hppa*-hp-hpux9">hppa*-hp-hpux9</a> +<li><a href="#hppa*-hp-hpux10">hppa*-hp-hpux10</a> +<li><a href="#hppa*-hp-hpux11">hppa*-hp-hpux11</a> +<li><a href="#i370-*-*">i370-*-*</a> +<li><a href="#*-*-linux-gnu">*-*-linux-gnu</a> +<li><a href="#ix86-*-linux*aout">i?86-*-linux*aout</a> +<li><a href="#ix86-*-linux*">i?86-*-linux*</a> +<li><a href="#ix86-*-sco">i?86-*-sco</a> +<li><a href="#ix86-*-sco3.2v4">i?86-*-sco3.2v4</a> +<li><a href="#ix86-*-sco3.2v5*">i?86-*-sco3.2v5*</a> +<li><a href="#ix86-*-udk">i?86-*-udk</a> +<li><a href="#ix86-*-esix">i?86-*-esix</a> +<li><a href="#ia64-*-linux">ia64-*-linux</a> +<li><a href="#ia64-*-hpux*">ia64-*-hpux*</a> +<li><a href="#*-lynx-lynxos">*-lynx-lynxos</a> +<li><a href="#*-ibm-aix*">*-ibm-aix*</a> +<li><a href="#ip2k-*-elf">ip2k-*-elf</a> +<li><a href="#m32r-*-elf">m32r-*-elf</a> +<li><a href="#m68000-hp-bsd">m68000-hp-bsd</a> +<li><a href="#m6811-elf">m6811-elf</a> +<li><a href="#m6812-elf">m6812-elf</a> +<li><a href="#m68k-att-sysv">m68k-att-sysv</a> +<li><a href="#m68k-crds-unos">m68k-crds-unos</a> +<li><a href="#m68k-hp-hpux">m68k-hp-hpux</a> +<li><a href="#m68k-ncr-*">m68k-ncr-*</a> +<li><a href="#m68k-sun">m68k-sun</a> +<li><a href="#m68k-sun-sunos4.1.1">m68k-sun-sunos4.1.1</a> +<li><a href="#mips-*-*">mips-*-*</a> +<li><a href="#mips-sgi-irix5">mips-sgi-irix5</a> +<li><a href="#mips-sgi-irix6">mips-sgi-irix6</a> +<li><a href="#powerpc*-*-*">powerpc*-*-*</a> powerpc-*-sysv4 +<li><a href="#powerpc-*-darwin*">powerpc-*-darwin*</a> +<li><a href="#powerpc-*-elf">powerpc-*-elf</a> powerpc-*-sysv4 +<li><a href="#powerpc-*-linux-gnu*">powerpc-*-linux-gnu*</a> +<li><a href="#powerpc-*-netbsd*">powerpc-*-netbsd*</a> +<li><a href="#powerpc-*-eabiaix">powerpc-*-eabiaix</a> +<li><a href="#powerpc-*-eabisim">powerpc-*-eabisim</a> +<li><a href="#powerpc-*-eabi">powerpc-*-eabi</a> +<li><a href="#powerpcle-*-elf">powerpcle-*-elf</a> powerpcle-*-sysv4 +<li><a href="#powerpcle-*-eabisim">powerpcle-*-eabisim</a> +<li><a href="#powerpcle-*-eabi">powerpcle-*-eabi</a> +<li><a href="#s390-*-linux*">s390-*-linux*</a> +<li><a href="#s390x-*-linux*">s390x-*-linux*</a> +<li><a href="#*-*-solaris2*">*-*-solaris2*</a> +<li><a href="#sparc-sun-solaris2*">sparc-sun-solaris2*</a> +<li><a href="#sparc-sun-solaris2.7">sparc-sun-solaris2.7</a> +<li><a href="#sparc-sun-sunos4*">sparc-sun-sunos4*</a> +<li><a href="#sparc-unknown-linux-gnulibc1">sparc-unknown-linux-gnulibc1</a> +<li><a href="#sparc-*-linux*">sparc-*-linux*</a> +<li><a href="#sparc64-*-solaris2*">sparc64-*-solaris2*</a> +<li><a href="#sparcv9-*-solaris2*">sparcv9-*-solaris2*</a> +<li><a href="#*-*-sysv*">*-*-sysv*</a> +<li><a href="#vax-dec-ultrix">vax-dec-ultrix</a> +<li><a href="#xtensa-*-elf">xtensa-*-elf</a> +<li><a href="#xtensa-*-linux*">xtensa-*-linux*</a> +<li><a href="#windows">Microsoft Windows</a> +<li><a href="#os2">OS/2</a> +<li><a href="#older">Older systems</a> +</ul> + +<ul> +<li><a href="#elf_targets">all ELF targets</a> (SVR4, Solaris 2, etc.) +</ul> + +<!- ------- host/target specific issues start here --------------- -> +<hr /> + +<h3><a name="TOC0"></a><a name="alpha*-*-*"></a>alpha*-*-*</h3> + +<p>This section contains general configuration information for all +alpha-based platforms using ELF (in particular, ignore this section for +DEC OSF/1, Digital UNIX and Tru64 UNIX). In addition to reading this +section, please read all other sections that match your target. + +<p>We require binutils 2.11.2 or newer. +Previous binutils releases had a number of problems with DWARF 2 +debugging information, not the least of which is incorrect linking of +shared libraries. + +<hr /> + +<h3><a name="TOC1"></a><a name="alpha*-dec-osf*"></a>alpha*-dec-osf*</h3> + +<p>Systems using processors that implement the DEC Alpha architecture and +are running the DEC/Compaq Unix (DEC OSF/1, Digital UNIX, or Compaq +Tru64 UNIX) operating system, for example the DEC Alpha AXP systems. + +<p>As of GCC 3.2, versions before <code>alpha*-dec-osf4</code> are no longer +supported. (These are the versions which identify themselves as DEC +OSF/1.) + +<p>In Digital Unix V4.0, virtual memory exhausted bootstrap failures +may be fixed by configuring with <code>--with-gc=simple</code>, +reconfiguring Kernel Virtual Memory and Swap parameters +per the <code>/usr/sbin/sys_check</code> Tuning Suggestions, +or applying the patch in +<a href="http://gcc.gnu.org/ml/gcc/2002-08/msg00822.html">http://gcc.gnu.org/ml/gcc/2002-08/msg00822.html</a>. + +<p>In Tru64 UNIX V5.1, Compaq introduced a new assembler that does not +currently (2001-06-13) work with <code>mips-tfile</code>. As a workaround, +we need to use the old assembler, invoked via the barely documented +<code>-oldas</code> option. To bootstrap GCC, you either need to use the +Compaq C Compiler: + +<br><pre> % CC=cc <var>srcdir</var>/configure [<var>options</var>] [<var>target</var>] +</pre> + +<p>or you can use a copy of GCC 2.95.3 or higher built on Tru64 UNIX V4.0: + +<br><pre> % CC=gcc -Wa,-oldas <var>srcdir</var>/configure [<var>options</var>] [<var>target</var>] +</pre> + +<p>As of GNU binutils 2.11.2, neither GNU <code>as</code> nor GNU <code>ld</code> +are supported on Tru64 UNIX, so you must not configure GCC with +<code>--with-gnu-as</code> or <code>--with-gnu-ld</code>. + +<p>The <code>--enable-threads</code> options isn't supported yet. A patch is +in preparation for a future release. + +<p>GCC writes a <code>.verstamp</code> directive to the assembler output file +unless it is built as a cross-compiler. It gets the version to use from +the system header file <code>/usr/include/stamp.h</code>. If you install a +new version of DEC Unix, you should rebuild GCC to pick up the new version +stamp. + +<p>Note that since the Alpha is a 64-bit architecture, cross-compilers from +32-bit machines will not generate code as efficient as that generated +when the compiler is running on a 64-bit machine because many +optimizations that depend on being able to represent a word on the +target in an integral value on the host cannot be performed. Building +cross-compilers on the Alpha for 32-bit machines has only been tested in +a few cases and may not work properly. + +<p><code>make compare</code> may fail on old versions of DEC Unix unless you add +<code>-save-temps</code> to <code>CFLAGS</code>. On these systems, the name of the +assembler input file is stored in the object file, and that makes +comparison fail if it differs between the <code>stage1</code> and +<code>stage2</code> compilations. The option <code>-save-temps</code> forces a +fixed name to be used for the assembler input file, instead of a +randomly chosen name in <code>/tmp</code>. Do not add <code>-save-temps</code> +unless the comparisons fail without that option. If you add +<code>-save-temps</code>, you will have to manually delete the <code>.i</code> and +<code>.s</code> files after each series of compilations. + +<p>GCC now supports both the native (ECOFF) debugging format used by DBX +and GDB and an encapsulated STABS format for use only with GDB. See the +discussion of the <code>--with-stabs</code> option of <code>configure</code> above +for more information on these formats and how to select them. + +<p>There is a bug in DEC's assembler that produces incorrect line numbers +for ECOFF format when the <code>.align</code> directive is used. To work +around this problem, GCC will not emit such alignment directives +while writing ECOFF format debugging information even if optimization is +being performed. Unfortunately, this has the very undesirable +side-effect that code addresses when <code>-O</code> is specified are +different depending on whether or not <code>-g</code> is also specified. + +<p>To avoid this behavior, specify <code>-gstabs+</code> and use GDB instead of +DBX. DEC is now aware of this problem with the assembler and hopes to +provide a fix shortly. + +<hr /> + +<h3><a name="TOC2"></a><a name="alphaev5-cray-unicosmk*"></a>alphaev5-cray-unicosmk*</h3> + +<p>Cray T3E systems running Unicos/Mk. + +<p>This port is incomplete and has many known bugs. We hope to improve the +support for this target soon. Currently, only the C front end is supported, +and it is not possible to build parallel applications. Cray modules are not +supported; in particular, Craylibs are assumed to be in +<code>/opt/ctl/craylibs/craylibs</code>. + +<p>You absolutely <strong>must</strong> use GNU make on this platform. Also, you +need to tell GCC where to find the assembler and the linker. The +simplest way to do so is by providing <code>--with-as</code> and +<code>--with-ld</code> to <code>configure</code>, e.g. + +<br><pre> configure --with-as=/opt/ctl/bin/cam --with-ld=/opt/ctl/bin/cld \ + --enable-languages=c +</pre> + +<p>The comparison test during <code>make bootstrap</code> fails on Unicos/Mk +because the assembler inserts timestamps into object files. You should +be able to work around this by doing <code>make all</code> after getting this +failure. + +<hr /> + +<h3><a name="TOC3"></a><a name="arc-*-elf"></a>arc-*-elf</h3> + +<p>Argonaut ARC processor. +This configuration is intended for embedded systems. + +<hr /> + +<h3><a name="TOC4"></a><a name="arm-*-aout"></a>arm-*-aout</h3> + +<p>This configuration is obsoleted in GCC 3.3. + +<p>Advanced RISC Machines ARM-family processors. These are often used in +embedded applications. There are no standard Unix configurations. +This configuration corresponds to the basic instruction sequences and will +produce <code>a.out</code> format object modules. + +<p>You may need to make a variant of the file <code>arm.h</code> for your particular +configuration. + +<hr /> + +<h3><a name="TOC5"></a><a name="arm-*-elf"></a>arm-*-elf</h3> + +<p>This configuration is intended for embedded systems. + +<hr /> + +<h3><a name="TOC6"></a><a name="arm*-*-linux-gnu"></a>arm*-*-linux-gnu</h3> + +<p>We require GNU binutils 2.10 or newer. + +<hr /> + +<h3><a name="TOC7"></a><a name="avr"></a>avr</h3> + +<p>ATMEL AVR-family micro controllers. These are used in embedded +applications. There are no standard Unix configurations. +See "AVR Options" in the main manual +for the list of supported MCU types. + +<p>Use <code>configure --target=avr --enable-languages="c"</code> to configure GCC. + +<p>Further installation notes and other useful information about AVR tools +can also be obtained from: + +<ul> +<li><a href="http://www.openavr.org">http://www.openavr.org</a> +<li><a href="http://home.overta.ru/users/denisc/">http://home.overta.ru/users/denisc/</a> +<li><a href="http://www.amelek.gda.pl/avr/">http://www.amelek.gda.pl/avr/</a> +</ul> + +<p>We <em>strongly</em> recommend using binutils 2.13 or newer. + +<p>The following error: +<br><pre> Error: register required +</pre> + +<p>indicates that you should upgrade to a newer version of the binutils. + +<hr /> + +<h3><a name="TOC8"></a><a name="c4x"></a>c4x</h3> + +<p>Texas Instruments TMS320C3x and TMS320C4x Floating Point Digital Signal +Processors. These are used in embedded applications. There are no +standard Unix configurations. +See "TMS320C3x/C4x Options" in the main manual +for the list of supported MCU types. + +<p>GCC can be configured as a cross compiler for both the C3x and C4x +architectures on the same system. Use <code>configure --target=c4x +--enable-languages="c,c++"</code> to configure. + +<p>Further installation notes and other useful information about C4x tools +can also be obtained from: + +<ul> +<li><a href="http://www.elec.canterbury.ac.nz/c4x/">http://www.elec.canterbury.ac.nz/c4x/</a> +</ul> + +<hr /> + +<h3><a name="TOC9"></a><a name="cris"></a>CRIS</h3> + +<p>CRIS is the CPU architecture in Axis Communications ETRAX system-on-a-chip +series. These are used in embedded applications. + +<p>See "CRIS Options" in the main manual +for a list of CRIS-specific options. + +<p>There are a few different CRIS targets: +<dl> +<dt><code>cris-axis-aout</code> +<dd>Old target. Includes a multilib for the <code>elinux</code> a.out-based +target. No multilibs for newer architecture variants. +<br><dt><code>cris-axis-elf</code> +<dd>Mainly for monolithic embedded systems. Includes a multilib for the +<code>v10</code> core used in <code>ETRAX 100 LX</code>. +<br><dt><code>cris-axis-linux-gnu</code> +<dd>A GNU/Linux port for the CRIS architecture, currently targeting +<code>ETRAX 100 LX</code> by default. +</dl> + +<p>For <code>cris-axis-aout</code> and <code>cris-axis-elf</code> you need binutils 2.11 +or newer. For <code>cris-axis-linux-gnu</code> you need binutils 2.12 or newer. + +<p>Pre-packaged tools can be obtained from +<a href="ftp://ftp.axis.com/pub/axis/tools/cris/compiler-kit/">ftp://ftp.axis.com/pub/axis/tools/cris/compiler-kit/</a>. More +information about this platform is available at +<a href="http://developer.axis.com/">http://developer.axis.com/</a>. + +<hr /> + +<h3><a name="TOC10"></a><a name="dos"></a>DOS</h3> + +<p>Please have a look at our <a href="binaries.html">binaries page</a>. + +<p>You cannot install GCC by itself on MSDOS; it will not compile under +any MSDOS compiler except itself. You need to get the complete +compilation package DJGPP, which includes binaries as well as sources, +and includes all the necessary compilation tools and libraries. + +<hr /> + +<h3><a name="TOC11"></a><a name="dsp16xx"></a>dsp16xx</h3> + +<p>A port to the AT&T DSP1610 family of processors. + +<hr /> + +<h3><a name="TOC12"></a><a name="*-*-freebsd*"></a>*-*-freebsd*</h3> + +<p>The version of binutils installed in <code>/usr/bin</code> is known to work unless +otherwise specified in any per-architecture notes. However, binutils +2.12.1 or greater is known to improve overall testsuite results. + +<p>Support for FreeBSD 1 was discontinued in GCC 3.2. + +<p>For FreeBSD 2 or any mutant a.out versions of FreeBSD 3: All +configuration support and files as shipped with GCC 2.95 are still in +place. FreeBSD 2.2.7 has been known to bootstrap completely; however, +it is unknown which version of binutils was used (it is assumed that it +was the system copy in <code>/usr/bin</code>) and C++ EH failures were noted. + +<p>For FreeBSD using the ELF file format: DWARF 2 debugging is now the +default for all CPU architectures. It had been the default on +FreeBSD/alpha since its inception. You may use <code>-gstabs</code> instead +of <code>-g</code>, if you really want the old debugging format. There are +no known issues with mixing object files and libraries with different +debugging formats. Otherwise, this release of GCC should now match more +of the configuration used in the stock FreeBSD configuration of GCC. In +particular, <code>--enable-threads</code> is now configured by default. +However, as a general user, do not attempt to replace the system +compiler with this release. Known to bootstrap and check with good +results on FreeBSD 4.8-STABLE and 5-CURRENT. In the past, known to +bootstrap and check with good results on FreeBSD 3.0, 3.4, 4.0, 4.2, +4.3, 4.4, 4.5-STABLE. + +<p>In principle, <code>--enable-threads</code> is now compatible with +<code>--enable-libgcj</code> on FreeBSD. However, it has only been built +and tested on <code>i386-*-freebsd[45]</code> and <code>alpha-*-freebsd[45]</code>. +The static +library may be incorrectly built (symbols are missing at link time). +There is a rare timing-based startup hang (probably involves an +assumption about the thread library). Multi-threaded boehm-gc (required for +libjava) exposes severe threaded signal-handling bugs on FreeBSD before +4.5-RELEASE. Other CPU architectures +supported by FreeBSD will require additional configuration tuning in, at +the very least, both boehm-gc and libffi. + +<p>Shared <code>libgcc_s.so</code> is now built and installed by default. + +<hr /> + +<h3><a name="TOC13"></a><a name="h8300-hms"></a>h8300-hms</h3> + +<p>Renesas H8/300 series of processors. + +<p>Please have a look at our <a href="binaries.html">binaries page</a>. + +<p>The calling convention and structure layout has changed in release 2.6. +All code must be recompiled. The calling convention now passes the +first three arguments in function calls in registers. Structures are no +longer a multiple of 2 bytes. + +<hr /> + +<h3><a name="TOC14"></a><a name="hppa*-hp-hpux*"></a>hppa*-hp-hpux*</h3> + +<p>Support for HP-UX versions 7, 8, and 9 is obsoleted in GCC 3.3. + +<p>We <em>highly</em> recommend using gas/binutils 2.8 or newer on all hppa +platforms; you may encounter a variety of problems when using the HP +assembler. + +<p>Specifically, <code>-g</code> does not work on HP-UX (since that system +uses a peculiar debugging format which GCC does not know about), unless you +use GAS and GDB and configure GCC with the +<a href="./configure.html#with-gnu-as"><code>--with-gnu-as</code></a> and +<code>--with-as=<small>...</small></code> options. + +<p>If you wish to use the pa-risc 2.0 architecture support with a 32-bit +runtime, you must use either the HP assembler, gas/binutils 2.11 or newer, +or a recent +<a href="ftp://sources.redhat.com/pub/binutils/snapshots">snapshot of gas</a>. + +<p>There are two default scheduling models for instructions. These are +PROCESSOR_7100LC and PROCESSOR_8000. They are selected from the pa-risc +architecture specified for the target machine when configuring. +PROCESSOR_8000 is the default. PROCESSOR_7100LC is selected when +the target is a <code>hppa1*</code> machine. + +<p>The PROCESSOR_8000 model is not well suited to older processors. Thus, +it is important to completely specify the machine architecture when +configuring if you want a model other than PROCESSOR_8000. The macro +TARGET_SCHED_DEFAULT can be defined in BOOT_CFLAGS if a different +default scheduling model is desired. + +<p>More specific information to <code>hppa*-hp-hpux*</code> targets follows. + +<hr /> + +<h3><a name="TOC15"></a><a name="hppa*-hp-hpux9"></a>hppa*-hp-hpux9</h3> + +<p>Support for this system is obsoleted in GCC 3.3. + +<p>The HP assembler has major problems on this platform. We've tried to work +around the worst of the problems. However, those workarounds may be causing +linker crashes in some circumstances; the workarounds also probably prevent +shared libraries from working. Use the GNU assembler to avoid these problems. + +<p>The configuration scripts for GCC will also trigger a bug in the hpux9 +shell. To avoid this problem set <code>CONFIG_SHELL</code> to <code>/bin/ksh</code> +and <code>SHELL</code> to <code>/bin/ksh</code> in your environment. + +<hr /> + +<h3><a name="TOC16"></a><a name="hppa*-hp-hpux10"></a>hppa*-hp-hpux10</h3> + +<p>For hpux10.20, we <em>highly</em> recommend you pick up the latest sed patch +<code>PHCO_19798</code> from HP. HP has two sites which provide patches free of +charge: + +<ul> +<li><a href="http://us.itrc.hp.com/service/home/home.do">US, Canada, Asia-Pacific, and +Latin-America</a> +<li><a href="http://europe.itrc.hp.com/service/home/home.do">http://europe.itrc.hp.com/service/home/home.do</a> Europe. +</ul> + +<p>The HP assembler on these systems is much better than the hpux9 assembler, +but still has some problems. Most notably the assembler inserts timestamps +into each object file it creates, causing the 3-stage comparison test to fail +during a <code>make bootstrap</code>. You should be able to continue by +saying <code>make all</code> after getting the failure from <code>make +bootstrap</code>. + +<hr /> + +<h3><a name="TOC17"></a><a name="hppa*-hp-hpux11"></a>hppa*-hp-hpux11</h3> + +<p>GCC 3.0 and up support HP-UX 11. On 64-bit capable systems, there +are two distinct ports. The <code>hppa2.0w-hp-hpux11*</code> port generates +code for the 32-bit pa-risc runtime architecture. It uses the HP +linker. The <code>hppa64-hp-hpux11*</code> port generates 64-bit code for the +pa-risc 2.0 architecture. The script config.guess now selects the port +type based on the type compiler detected during configuration. You must +set your <code>PATH</code> or define <code>CC</code> so that configure finds an appropriate +compiler for the initial bootstrap. Different prefixes must be used if +both ports are to be installed on the same system. + +<p>It is best to explicitly configure the <code>hppa64-hp-hpux11*</code> target +with the <code>--with-ld=<small>...</small></code> option. We support both the HP +and GNU linkers for this target. The two linkers require different +link commands. Thus, it's not possible to switch linkers during a +GCC build. This has been been reported to occur in a unified build +of binutils and GCC. + +<p>GCC 2.95.x is not supported under HP-UX 11 and cannot be used to +compile GCC 3.0 and up. Refer to <a href="binaries.html">binaries</a> for +information about obtaining precompiled GCC binaries for HP-UX. + +<p>You must use GNU binutils 2.11 or above with the 32-bit port. Thread +support is not currently implemented, so <code>--enable-threads</code> does +not work. See: + +<ul> +<li><a href="http://gcc.gnu.org/ml/gcc-prs/2002-01/msg00551.html">http://gcc.gnu.org/ml/gcc-prs/2002-01/msg00551.html</a> +<li><a href="http://gcc.gnu.org/ml/gcc-bugs/2002-01/msg00663.html">http://gcc.gnu.org/ml/gcc-bugs/2002-01/msg00663.html</a> +</ul> + +<p>GCC 3.3 and later support weak symbols on the 32-bit port using SOM +secondary definition symbols. This feature is not enabled for earlier +versions of HP-UX since there have been bugs in the linker support for +secondary symbols. The HP linker patches <code>PHSS_26559</code> and +<code>PHSS_24304</code> for HP-UX 11.00 and 11.11, respectively, correct the +problem of linker core dumps creating C++ libraries. Earlier patches +may work but they have not been tested. + +<p>GCC 3.3 nows uses the ELF DT_INIT_ARRAY and DT_FINI_ARRAY capability +to run initializers and finalizers on the 64-bit port. The feature +requires CVS binutils as of January 2, 2003, or a subsequent release +to correct a problem arising from HP's non-standard use of the .init +and .fini sections. The 32-bit port uses the linker <code>+init</code> +and <code>+fini</code> options. As with the support for secondary symbols, +there have been bugs in the order in which these options are executed +by the HP linker. So, again a recent linker patch is recommended. + +<p>The HP assembler has many limitations and is not recommended for either +the 32 or 64-bit ports. For example, it does not support weak symbols +or alias definitions. As a result, explicit template instantiations +are required when using C++. This will make it difficult if not +impossible to build many C++ applications. You also can't generate +debugging information when using the HP assembler with GCC. + +<p>There are a number of issues to consider in selecting which linker to +use with the 64-bit port. The GNU 64-bit linker can only create dynamic +binaries. The <code>-static</code> option causes linking with archive +libraries but doesn't produce a truly static binary. Dynamic binaries +still require final binding by the dynamic loader to resolve a set of +dynamic-loader-defined symbols. The default behavior of the HP linker +is the same as the GNU linker. However, it can generate true 64-bit +static binaries using the <code>+compat</code> option. + +<p>The HP 64-bit linker doesn't support linkonce semantics. As a +result, C++ programs have many more sections than they should. + +<p>The GNU 64-bit linker has some issues with shared library support +and exceptions. As a result, we only support libgcc in archive +format. For similar reasons, dwarf2 unwind and exception support +are disabled. The GNU linker also has problems creating binaries +with <code>-static</code>. It doesn't provide stubs for internal +calls to global functions in shared libraries, so these calls +can't be overloaded. + +<p>There are several possible approaches to building the distribution. +Binutils can be built first using the HP tools. Then, the GCC +distribution can be built. The second approach is to build GCC +first using the HP tools, then build binutils, then rebuild GCC. +There have been problems with various binary distributions, so +it is best not to start from a binary distribution. + +<p>When starting with a HP compiler, it is preferable to use the ANSI +compiler as the bundled compiler only supports traditional C. +Bootstrapping with the bundled compiler is tested infrequently and +problems often arise because of the subtle differences in semantics +between traditional and ISO C. + +<p>This port still is undergoing significant development. + +<hr /> + +<h3><a name="TOC18"></a><a name="i370-*-*"></a>i370-*-*</h3> + +<p>This port is very preliminary and has many known bugs. We hope to +have a higher-quality port for this machine soon. + +<hr /> + +<h3><a name="TOC19"></a><a name="*-*-linux-gnu"></a>*-*-linux-gnu</h3> + +<p>Versions of libstdc++-v3 starting with 3.2.1 require bugfixes present +in glibc 2.2.5 and later. More information is available in the +libstdc++-v3 documentation. + +<p>If you use glibc 2.2 (or 2.1.9x), GCC 2.95.2 won't install +out-of-the-box. You'll get compile errors while building <code>libstdc++</code>. +The patch <a href="glibc-2.2.patch">glibc-2.2.patch</a>, that is to be +applied in the GCC source tree, fixes the compatibility problems. + +<p>Currently Glibc 2.2.3 (and older releases) and GCC 3.0 are out of sync +since the latest exception handling changes for GCC. Compiling glibc +with GCC 3.0 will give a binary incompatible glibc and therefore cause +lots of problems and might make your system completely unusable. This +will definitely need fixes in glibc but might also need fixes in GCC. We +strongly advise to wait for glibc 2.2.4 and to read the release notes of +glibc 2.2.4 whether patches for GCC 3.0 are needed. You can use glibc +2.2.3 with GCC 3.0, just do not try to recompile it. + +<hr /> + +<h3><a name="TOC20"></a><a name="ix86-*-linux*aout"></a>i?86-*-linux*aout</h3> + +<p>Use this configuration to generate <code>a.out</code> binaries on Linux-based +GNU systems. This configuration is being superseded. You must use +gas/binutils version 2.5.2 or later. + +<hr /> + +<h3><a name="TOC21"></a><a name="ix86-*-linux*"></a>i?86-*-linux*</h3> + +<p>As of GCC 3.3, binutils 2.13.1 or later is required for this platform. +See <a href="http://gcc.gnu.org/PR10877">bug 10877</a> for more information. + +<p>If you receive Signal 11 errors when building on GNU/Linux, then it is +possible you have a hardware problem. Further information on this can be +found on <a href="http://www.bitwizard.nl/sig11/">www.bitwizard.nl</a>. + +<hr /> + +<h3><a name="TOC22"></a><a name="ix86-*-sco"></a>i?86-*-sco</h3> + +<p>Compilation with RCC is recommended. Also, it may be a good idea to +link with GNU malloc instead of the malloc that comes with the system. + +<hr /> + +<h3><a name="TOC23"></a><a name="ix86-*-sco3.2v5*"></a>i?86-*-sco3.2v5*</h3> + +<p>Use this for the SCO OpenServer Release 5 family of operating systems. + +<p>Unlike earlier versions of GCC, the ability to generate COFF with this +target is no longer provided. + +<p>Earlier versions of GCC emitted DWARF 1 when generating ELF to allow +the system debugger to be used. That support was too burdensome to +maintain. GCC now emits only DWARF 2 for this target. This means you +may use either the UDK debugger or GDB to debug programs built by this +version of GCC. + +<p>GCC is now only supported on releases 5.0.4 and later, and requires that +you install Support Level Supplement OSS646B or later, and the latest +version of the Supplement Graphics, Web and X11 Libraries (GWXLIBS) +package. If you are using release 5.0.7 of OpenServer, you must have at +least the first maintenance pack installed (this includes the relevant +portions of OSS646 and GWXLIBS). OSS646, also known as the "Execution +Environment Update", provides updated link editors and assemblers, as well +as updated standard C and math libraries. The C startup modules are also +updated to support the System V gABI draft, and GCC relies on that +behavior. GWXLIBS provides a collection of commonly used open source +libraries, some of which GCC depends on (such as GNU gettext and zlib). +SCO OpenServer Release 5.0.7 has all of this built in by default, but +GWXLIBS is significantly updated in Maintenance Pack 1. Please visit +<a href="ftp://ftp.sco.com/pub/openserver5">ftp://ftp.sco.com/pub/openserver5</a> +and +<a href="ftp://ftp.sco.com/pub/openserver5/opensrc">ftp://ftp.sco.com/pub/openserver5/opensrc</a> +for the latest versions of these (and other potentially useful) supplements. + +<p>Although there is support for using the native assembler, it is recommended +that you configure GCC to use the GNU assembler. You do this by using the +flags <a href="./configure.html#with-gnu-as"><code>--with-gnu-as</code></a>. You +should use a modern version of GNU binutils. Version 2.14 was used for all +testing. In general, only the <code>--with-gnu-as</code> option is tested. A +modern bintuils (as well as a plethora of other development related GNU +utilities) can be found in the GNU Development Tools package. See the +SCO web and ftp sites for details. That package also contains the +currently "officially supported" version of GCC, version 2.95.3. It is +useful for bootstrapping this version. + +<hr /> + +<h3><a name="TOC24"></a><a name="ix86-*-udk"></a>i?86-*-udk</h3> + +<p>This target emulates the SCO Universal Development Kit and requires that +package be installed. (If it is installed, you will have a +<code>/udk/usr/ccs/bin/cc</code> file present.) It's very much like the +<code>i?86-*-unixware7*</code> target +but is meant to be used when hosting on a system where UDK isn't the +default compiler such as OpenServer 5 or Unixware 2. This target will +generate binaries that will run on OpenServer, Unixware 2, or Unixware 7, +with the same warnings and caveats as the SCO UDK. + +<p>This target is a little tricky to build because we have to distinguish +it from the native tools (so it gets headers, startups, and libraries +from the right place) while making the tools not think we're actually +building a cross compiler. The easiest way to do this is with a configure +command like this: + +<br><pre> CC=/udk/usr/ccs/bin/cc <var>/your/path/to</var>/gcc/configure \ + --host=i686-pc-udk --target=i686-pc-udk --program-prefix=udk- +</pre> + +<p><em>You should substitute <code>i686</code> in the above command with the appropriate +processor for your host.</em> + +<p>After the usual <code>make bootstrap</code> and +<code>make install</code>, you can then access the UDK-targeted GCC +tools by adding <code>udk-</code> before the commonly known name. For +example, to invoke the C compiler, you would use <code>udk-gcc</code>. +They will coexist peacefully with any native-target GCC tools you may +have installed. + +<hr /> + +<h3><a name="TOC25"></a><a name="ia64-*-linux"></a>ia64-*-linux</h3> + +<p>IA-64 processor (also known as IPF, or Itanium Processor Family) +running GNU/Linux. + +<p>The toolchain is not completely finished, so requirements will continue +to change. +GCC 3.0.1 and later require glibc 2.2.4. +GCC 3.0.2 requires binutils from 2001-09-05 or later. +GCC 3.0.1 requires binutils 2.11.1 or later. + +<p>None of the following versions of GCC has an ABI that is compatible +with any of the other versions in this list, with the exception that +Red Hat 2.96 and Trillian 000171 are compatible with each other: +3.0.2, 3.0.1, 3.0, Red Hat 2.96, and Trillian 000717. +This primarily affects C++ programs and programs that create shared libraries. +Because of these ABI incompatibilities, GCC 3.0.2 is not recommended for +user programs on GNU/Linux systems built using earlier compiler releases. +GCC 3.0.2 is recommended for compiling linux, the kernel. +GCC 3.0.2 is believed to be fully ABI compliant, and hence no more major +ABI changes are expected. + +<hr /> + +<h3><a name="TOC26"></a><a name="ia64-*-hpux*"></a>ia64-*-hpux*</h3> + +<p>Building GCC on this target requires the GNU Assembler. The bundled HP +assembler will not work. To prevent GCC from using the wrong assembler, +the option <code>--with-gnu-as</code> may be necessary. + +<p>The GCC libunwind library has not been ported to HPUX. This means that for +GCC versions 3.2.3 and earlier, <code>--enable-libunwind-exceptions</code> +is required to build GCC. For GCC 3.3 and later, this is the default. + +<hr /> + +<h3><a name="TOC27"></a><a name="*-lynx-lynxos"></a>*-lynx-lynxos</h3> + +<p>Support for SPARC LynxOS is obsoleted in GCC 3.3. + +<p>LynxOS 2.2 and earlier comes with GCC 1.x already installed as +<code>/bin/gcc</code>. You should compile with this instead of <code>/bin/cc</code>. +You can tell GCC to use the GNU assembler and linker, by specifying +<code>--with-gnu-as --with-gnu-ld</code> when configuring. These will produce +COFF format object files and executables; otherwise GCC will use the +installed tools, which produce <code>a.out</code> format executables. + +<hr /> +<!- rs6000-ibm-aix*, powerpc-ibm-aix* -> + +<h3><a name="TOC28"></a><a name="*-ibm-aix*"></a>*-ibm-aix*</h3> + +<p>Support for AIX versions 1, 2, and 3 is obsoleted in GCC 3.3. + +<p>AIX Make frequently has problems with GCC makefiles. GNU Make 3.76 or +newer is recommended to build on this platform. + +<p>Errors involving <code>alloca</code> when building GCC generally are due +to an incorrect definition of <code>CC</code> in the Makefile or mixing files +compiled with the native C compiler and GCC. During the stage1 phase of +the build, the native AIX compiler <strong>must</strong> be invoked as <code>cc</code> +(not <code>xlc</code>). Once <code>configure</code> has been informed of +<code>xlc</code>, one needs to use <code>make distclean</code> to remove the +configure cache files and ensure that <code>CC</code> environment variable +does not provide a definition that will confuse <code>configure</code>. +If this error occurs during stage2 or later, then the problem most likely +is the version of Make (see above). + +<p>The native <code>as</code> and <code>ld</code> are recommended for bootstrapping +on AIX 4 and required for bootstrapping on AIX 5L. The GNU Assembler +reports that it supports WEAK symbols on AIX 4, which causes GCC to try to +utilize weak symbol functionality although it is not supported. The GNU +Assembler and Linker do not support AIX 5L sufficiently to bootstrap GCC. +The native AIX tools do interoperate with GCC. + +<p>Building <code>libstdc++.a</code> requires a fix for an AIX Assembler bug +APAR IY26685 (AIX 4.3) or APAR IY25528 (AIX 5.1). + +<p><code>libstdc++</code> in GCC 3.2 increments the major version number of the +shared object and GCC installation places the <code>libstdc++.a</code> +shared library in a common location which will overwrite the GCC 3.1 +version of the shared library. Applications either need to be +re-linked against the new shared library or the GCC 3.1 version of the +<code>libstdc++</code> shared object needs to be available to the AIX +runtime loader. The GCC 3.1 <code>libstdc++.so.4</code> shared object can +be installed for runtime dynamic loading using the following steps to +set the <code>F_LOADONLY</code> flag in the shared object for <em>each</em> +multilib <code>libstdc++.a</code> installed: + +<p>Extract the shared object from each the GCC 3.1 <code>libstdc++.a</code> +archive: +<br><pre> % ar -x libstdc++.a libstdc++.so.4 +</pre> + +<p>Enable the <code>F_LOADONLY</code> flag so that the shared object will be +available for runtime dynamic loading, but not linking: +<br><pre> % strip -e libstdc++.so.4 +</pre> + +<p>Archive the runtime-only shared object in the GCC 3.2 +<code>libstdc++.a</code> archive: +<br><pre> % ar -q libstdc++.a libstdc++.so.4 +</pre> + +<p>Linking executables and shared libraries may produce warnings of +duplicate symbols. The assembly files generated by GCC for AIX always +have included multiple symbol definitions for certain global variable +and function declarations in the original program. The warnings should +not prevent the linker from producing a correct library or runnable +executable. + +<p>AIX 4.3 utilizes a "large format" archive to support both 32-bit and +64-bit object modules. The routines provided in AIX 4.3.0 and AIX 4.3.1 +to parse archive libraries did not handle the new format correctly. +These routines are used by GCC and result in error messages during +linking such as "not a COFF file". The version of the routines shipped +with AIX 4.3.1 should work for a 32-bit environment. The <code>-g</code> +option of the archive command may be used to create archives of 32-bit +objects using the original "small format". A correct version of the +routines is shipped with AIX 4.3.2 and above. + +<p>Some versions of the AIX binder (linker) can fail with a relocation +overflow severe error when the <code>-bbigtoc</code> option is used to link +GCC-produced object files into an executable that overflows the TOC. A fix +for APAR IX75823 (OVERFLOW DURING LINK WHEN USING GCC AND -BBIGTOC) is +available from IBM Customer Support and from its +<a href="http://techsupport.services.ibm.com/">techsupport.services.ibm.com</a> +website as PTF U455193. + +<p>The AIX 4.3.2.1 linker (bos.rte.bind_cmds Level 4.3.2.1) will dump core +with a segmentation fault when invoked by any version of GCC. A fix for +APAR IX87327 is available from IBM Customer Support and from its +<a href="http://techsupport.services.ibm.com/">techsupport.services.ibm.com</a> +website as PTF U461879. This fix is incorporated in AIX 4.3.3 and above. + +<p>The initial assembler shipped with AIX 4.3.0 generates incorrect object +files. A fix for APAR IX74254 (64BIT DISASSEMBLED OUTPUT FROM COMPILER FAILS +TO ASSEMBLE/BIND) is available from IBM Customer Support and from its +<a href="http://techsupport.services.ibm.com/">techsupport.services.ibm.com</a> +website as PTF U453956. This fix is incorporated in AIX 4.3.1 and above. + +<p>AIX provides National Language Support (NLS). Compilers and assemblers +use NLS to support locale-specific representations of various data +formats including floating-point numbers (e.g., <code>.</code> vs <code>,</code> for +separating decimal fractions). There have been problems reported where +GCC does not produce the same floating-point formats that the assembler +expects. If one encounters this problem, set the <code>LANG</code> +environment variable to <code>C</code> or <code>En_US</code>. + +<p>By default, GCC for AIX 4.1 and above produces code that can be used on +both Power or PowerPC processors. + +<p>A default can be specified with the <code>-mcpu=<var>cpu_type</var></code> +switch and using the configure option <code>--with-cpu-<var>cpu_type</var></code>. + +<hr /> + +<h3><a name="TOC29"></a><a name="ip2k-*-elf"></a>ip2k-*-elf</h3> + +<p>Ubicom IP2022 micro controller. +This configuration is intended for embedded systems. +There are no standard Unix configurations. + +<p>Use <code>configure --target=ip2k-elf --enable-languages=c</code> to configure GCC. + +<hr /> + +<h3><a name="TOC30"></a><a name="m32r-*-elf"></a>m32r-*-elf</h3> + +<p>Renesas M32R processor. +This configuration is intended for embedded systems. + +<hr /> + +<h3><a name="TOC31"></a><a name="m68000-hp-bsd"></a>m68000-hp-bsd</h3> + +<p>Support for this system is obsoleted in GCC 3.3. + +<p>HP 9000 series 200 running BSD. Note that the C compiler that comes +with this system cannot compile GCC; contact <a href="mailto:law@cygnus.com">law@cygnus.com</a> +to get binaries of GCC for bootstrapping. + +<hr /> + +<h3><a name="TOC32"></a><a name="m6811-elf"></a>m6811-elf</h3> + +<p>Motorola 68HC11 family micro controllers. These are used in embedded +applications. There are no standard Unix configurations. + +<hr /> + +<h3><a name="TOC33"></a><a name="m6812-elf"></a>m6812-elf</h3> + +<p>Motorola 68HC12 family micro controllers. These are used in embedded +applications. There are no standard Unix configurations. + +<hr /> + +<h3><a name="TOC34"></a><a name="m68k-att-sysv"></a>m68k-att-sysv</h3> + +<p>Support for this system is obsoleted in GCC 3.3. + +<p>AT&T 3b1, a.k.a. 7300 PC. This version of GCC cannot +be compiled with the system C compiler, which is too buggy. +You will need to get a previous version of GCC and use it to +bootstrap. Binaries are available from the OSU-CIS archive, at +<a href="ftp://ftp.uu.net/systems/att7300/">ftp://ftp.uu.net/systems/att7300/</a>. + +<hr /> + +<h3><a name="TOC35"></a><a name="m68k-crds-unos"></a>m68k-crds-unos</h3> + +<p>Support for this system is obsoleted in GCC 3.3. + +<p>Use <code>configure unos</code> for building on Unos. + +<p>The Unos assembler is named <code>casm</code> instead of <code>as</code>. For some +strange reason linking <code>/bin/as</code> to <code>/bin/casm</code> changes the +behavior, and does not work. So, when installing GCC, you should +install the following script as <code>as</code> in the subdirectory where +the passes of GCC are installed: + +<br><pre>#!/bin/sh +casm $* +</pre> + +<p>The default Unos library is named <code>libunos.a</code> instead of +<code>libc.a</code>. To allow GCC to function, either change all +references to <code>-lc</code> in <code>gcc.c</code> to <code>-lunos</code> or link +<code>/lib/libc.a</code> to <code>/lib/libunos.a</code>. + +<p>When compiling GCC with the standard compiler, to overcome bugs in +the support of <code>alloca</code>, do not use <code>-O</code> when making stage 2. +Then use the stage 2 compiler with <code>-O</code> to make the stage 3 +compiler. This compiler will have the same characteristics as the usual +stage 2 compiler on other systems. Use it to make a stage 4 compiler +and compare that with stage 3 to verify proper compilation. + +<p>(Perhaps simply defining <code>ALLOCA</code> in <code>x-crds</code> as described in +the comments there will make the above paragraph superfluous. Please +inform us of whether this works.) + +<p>Unos uses memory segmentation instead of demand paging, so you will need +a lot of memory. 5 Mb is barely enough if no other tasks are running. +If linking <code>cc1</code> fails, try putting the object files into a library +and linking from that library. + +<hr /> + +<h3><a name="TOC36"></a><a name="m68k-hp-hpux"></a>m68k-hp-hpux</h3> + +<p>HP 9000 series 300 or 400 running HP-UX. HP-UX version 8.0 has a bug in +the assembler that prevents compilation of GCC. This +bug manifests itself during the first stage of compilation, while +building <code>libgcc2.a</code>: + +<br><pre>_floatdisf +cc1: warning: `-g' option not supported on this version of GCC +cc1: warning: `-g1' option not supported on this version of GCC +./xgcc: Internal compiler error: program as got fatal signal 11 +</pre> + +<p>A patched version of the assembler is available as the file +<a href="ftp://altdorf.ai.mit.edu/archive/cph/hpux-8.0-assembler">ftp://altdorf.ai.mit.edu/archive/cph/hpux-8.0-assembler</a>. If you +have HP software support, the patch can also be obtained directly from +HP, as described in the following note: + +<blockquote> +This is the patched assembler, to patch SR#1653-010439, where the +assembler aborts on floating point constants. + +<p>The bug is not really in the assembler, but in the shared library +version of the function "cvtnum(3c)". The bug on "cvtnum(3c)" is +SR#4701-078451. Anyway, the attached assembler uses the archive +library version of "cvtnum(3c)" and thus does not exhibit the bug. +</blockquote> + +<p>This patch is also known as PHCO_4484. + +<p>In addition, if you wish to use gas, you must use +gas version 2.1 or later, and you must use the GNU linker version 2.1 or +later. Earlier versions of gas relied upon a program which converted the +gas output into the native HP-UX format, but that program has not been +kept up to date. gdb does not understand that native HP-UX format, so +you must use gas if you wish to use gdb. + +<p>On HP-UX version 8.05, but not on 8.07 or more recent versions, the +<code>fixproto</code> shell script triggers a bug in the system shell. If you +encounter this problem, upgrade your operating system or use BASH (the +GNU shell) to run <code>fixproto</code>. This bug will cause the fixproto +program to report an error of the form: + +<br><pre>./fixproto: sh internal 1K buffer overflow +</pre> + +<p>To fix this, you can also change the first line of the fixproto script +to look like: + +<br><pre>#!/bin/ksh +</pre> + +<hr /> + +<h3><a name="TOC37"></a><a name="m68k-ncr-*"></a>m68k-ncr-*</h3> + +<p>Support for this system is obsoleted in GCC 3.3. + +<p>On the Tower models 4<var>n</var>0 and 6<var>n</var>0, by default a process is not +allowed to have more than one megabyte of memory. GCC cannot compile +itself (or many other programs) with <code>-O</code> in that much memory. + +<p>To solve this problem, reconfigure the kernel adding the following line +to the configuration file: + +<br><pre>MAXUMEM = 4096 +</pre> + +<hr /> + +<h3><a name="TOC38"></a><a name="m68k-sun"></a>m68k-sun</h3> + +<p>Support for this system is obsoleted in GCC 3.3. + +<p>Sun 3. We do not provide a configuration file to use the Sun FPA by +default, because programs that establish signal handlers for floating +point traps inherently cannot work with the FPA. + +<hr /> + +<h3><a name="TOC39"></a><a name="m68k-sun-sunos4.1.1"></a>m68k-sun-sunos4.1.1</h3> + +<p>Support for this system is obsoleted in GCC 3.3. + +<p>It is reported that you may need the GNU assembler on this platform. + +<hr /> + +<h3><a name="TOC40"></a><a name="mips-*-*"></a>mips-*-*</h3> + +<p>If on a MIPS system you get an error message saying "does not have gp +sections for all it's [sic] sectons [sic]", don't worry about it. This +happens whenever you use GAS with the MIPS linker, but there is not +really anything wrong, and it is okay to use the output file. You can +stop such warnings by installing the GNU linker. + +<p>It would be nice to extend GAS to produce the gp tables, but they are +optional, and there should not be a warning about their absence. + +<p>The libstdc++ atomic locking routines for MIPS targets requires MIPS II +and later. A patch went in just after the GCC 3.3 release to +make <code>mips*-*-*</code> use the generic implementation instead. You can also +configure for <code>mipsel-elf</code> as a workaround. The +<code>mips*-*-linux*</code> target continues to use the MIPS II routines. More +work on this is expected in future releases. + +<hr /> + +<h3><a name="TOC41"></a><a name="mips-sgi-irix5"></a>mips-sgi-irix5</h3> + +<p>This configuration has considerable problems, which will be fixed in a +future release. + +<p>In order to compile GCC on an SGI running IRIX 5, the "compiler_dev.hdr" +subsystem must be installed from the IDO CD-ROM supplied by Silicon +Graphics. It is also available for download from +<a href="http://www.sgi.com/developers/devtools/apis/ido.html">http://www.sgi.com/developers/devtools/apis/ido.html</a>. + +<p><code>make compare</code> may fail on version 5 of IRIX unless you add +<code>-save-temps</code> to <code>CFLAGS</code>. On these systems, the name of the +assembler input file is stored in the object file, and that makes +comparison fail if it differs between the <code>stage1</code> and +<code>stage2</code> compilations. The option <code>-save-temps</code> forces a +fixed name to be used for the assembler input file, instead of a +randomly chosen name in <code>/tmp</code>. Do not add <code>-save-temps</code> +unless the comparisons fail without that option. If you do you +<code>-save-temps</code>, you will have to manually delete the <code>.i</code> and +<code>.s</code> files after each series of compilations. + +<p>If you use the MIPS C compiler to bootstrap, it may be necessary +to increase its table size for switch statements with the +<code>-Wf,-XNg1500</code> option. If you use the <code>-O2</code> +optimization option, you also need to use <code>-Olimit 3000</code>. + +<p>To enable debugging under IRIX 5, you must use GNU <code>as</code> 2.11.2 +or later, +and use the <code>--with-gnu-as</code> configure option when configuring GCC. +GNU <code>as</code> is distributed as part of the binutils package. +When using release 2.11.2, you need to apply a patch +<a href="http://sources.redhat.com/ml/binutils/2001-07/msg00352.html">http://sources.redhat.com/ml/binutils/2001-07/msg00352.html</a> +which will be included in the next release of binutils. + +<p>When building GCC, the build process loops rebuilding <code>cc1</code> over +and over again. This happens on <code>mips-sgi-irix5.2</code>, and possibly +other platforms. It has been reported that this is a known bug in the +<code>make</code> shipped with IRIX 5.2. We recommend you use GNU +<code>make</code> instead of the vendor supplied <code>make</code> program; +however, you may have success with <code>smake</code> on IRIX 5.2 if you do +not have GNU <code>make</code> available. + +<hr /> + +<h3><a name="TOC42"></a><a name="mips-sgi-irix6"></a>mips-sgi-irix6</h3> + +<p>If you are using IRIX <code>cc</code> as your bootstrap compiler, you must +ensure that the N32 ABI is in use. To test this, compile a simple C +file with <code>cc</code> and then run <code>file</code> on the +resulting object file. The output should look like: + +<br><pre>test.o: ELF N32 MSB <small>...</small> +</pre> + +<p>If you see: + +<br><pre>test.o: ELF 32-bit MSB <small>...</small> +</pre> + +<p>or + +<br><pre>test.o: ELF 64-bit MSB <small>...</small> +</pre> + +<p>then your version of <code>cc</code> uses the O32 or N64 ABI by default. You +should set the environment variable <code>CC</code> to <code>cc -n32</code> +before configuring GCC. + +<p>If you want the resulting <code>gcc</code> to run on old 32-bit systems +with the MIPS R4400 CPU, you need to ensure that only code for the mips3 +instruction set architecture (ISA) is generated. While GCC 3.x does +this correctly, both GCC 2.95 and SGI's MIPSpro <code>cc</code> may change +the ISA depending on the machine where GCC is built. Using one of them +as the bootstrap compiler may result in mips4 code, which won't run at +all on mips3-only systems. For the test program above, you should see: + +<br><pre>test.o: ELF N32 MSB mips-3 <small>...</small> +</pre> + +<p>If you get: + +<br><pre>test.o: ELF N32 MSB mips-4 <small>...</small> +</pre> + +<p>instead, you should set the environment variable <code>CC</code> to <code>cc +-n32 -mips3</code> or <code>gcc -mips3</code> respectively before configuring GCC. + +<p>GCC on IRIX 6 is usually built to support both the N32 and N64 ABIs. If +you build GCC on a system that doesn't have the N64 libraries installed, +you need to configure with <code>--disable-multilib</code> so GCC doesn't +try to use them. Look for <code>/usr/lib64/libc.so.1</code> to see if you +have the 64-bit libraries installed. + +<p>You must <em>not</em> use GNU <code>as</code> (which isn't built anyway as of +binutils 2.11.2) on IRIX 6 platforms; doing so will only cause problems. + +<p>GCC does not currently support generating O32 ABI binaries in the +<code>mips-sgi-irix6</code> configurations. It is possible to create a GCC +with O32 ABI only support by configuring it for the <code>mips-sgi-irix5</code> +target and using a patched GNU <code>as</code> 2.11.2 as documented in the +<a href="#mips-sgi-irix5"><code>mips-sgi-irix5</code></a> section above. Using the +native assembler requires patches to GCC which will be included in a +future release. It is +expected that O32 ABI support will be available again in a future release. + +<p>The <code>--enable-threads</code> option doesn't currently work, a patch is +in preparation for a future release. The <code>--enable-libgcj</code> +option is disabled by default: IRIX 6 uses a very low default limit +(20480) for the command line length. Although libtool contains a +workaround for this problem, at least the N64 <code>libgcj</code> is known not +to build despite this, running into an internal error of the native +<code>ld</code>. A sure fix is to increase this limit (<code>ncargs</code>) to +its maximum of 262144 bytes. If you have root access, you can use the +<code>systune</code> command to do this. + +<p>GCC does not correctly pass/return structures which are +smaller than 16 bytes and which are not 8 bytes. The problem is very +involved and difficult to fix. It affects a number of other targets also, +but IRIX 6 is affected the most, because it is a 64-bit target, and 4 byte +structures are common. The exact problem is that structures are being padded +at the wrong end, e.g. a 4 byte structure is loaded into the lower 4 bytes +of the register when it should be loaded into the upper 4 bytes of the +register. + +<p>GCC is consistent with itself, but not consistent with the SGI C compiler +(and the SGI supplied runtime libraries), so the only failures that can +happen are when there are library functions that take/return such +structures. There are very few such library functions. Currently this +is known to affect <code>inet_ntoa</code>, <code>inet_lnaof</code>, +<code>inet_netof</code>, <code>inet_makeaddr</code>, and <code>semctl</code>. Until the +bug is fixed, GCC contains workarounds for the known affected functions. + +<p>See <a href="http://freeware.sgi.com/">http://freeware.sgi.com/</a> for more +information about using GCC on IRIX platforms. + +<hr /> + +<h3><a name="TOC43"></a><a name="powerpc*-*-*"></a>powerpc-*-*</h3> + +<p>You can specify a default version for the <code>-mcpu=<var>cpu_type</var></code> +switch by using the configure option <code>--with-cpu-<var>cpu_type</var></code>. + +<hr /> + +<h3><a name="TOC44"></a><a name="powerpc-*-darwin*"></a>powerpc-*-darwin*</h3> + +<p>PowerPC running Darwin (Mac OS X kernel). + +<p>Pre-installed versions of Mac OS X may not include any developer tools, +meaning that you will not be able to build GCC from source. Tool +binaries are available at +<a href="http://developer.apple.com/tools/compilers.html">http://developer.apple.com/tools/compilers.html</a> (free +registration required). + +<p>The default stack limit of 512K is too small, which may cause compiles +to fail with 'Bus error'. Set the stack larger, for instance +by doing <code>limit stack 800</code>. It's a good idea to use the GNU +preprocessor instead of Apple's <code>cpp-precomp</code> during the first stage of +bootstrapping; this is automatic when doing <code>make bootstrap</code>, but +to do it from the toplevel objdir you will need to say <code>make +CC='cc -no-cpp-precomp' bootstrap</code>. + +<p>The version of GCC shipped by Apple typically includes a number of +extensions not available in a standard GCC release. These extensions +are generally specific to Mac programming. + +<hr /> + +<h3><a name="TOC45"></a><a name="powerpc-*-elf"></a>powerpc-*-elf, powerpc-*-sysv4</h3> + +<p>PowerPC system in big endian mode, running System V.4. + +<hr /> + +<h3><a name="TOC46"></a><a name="powerpc-*-linux-gnu*"></a>powerpc-*-linux-gnu*</h3> + +<p>You will need +<a href="ftp://ftp.kernel.org/pub/linux/devel/binutils">binutils 2.13.90.0.10</a> +or newer for a working GCC. + +<hr /> + +<h3><a name="TOC47"></a><a name="powerpc-*-netbsd*"></a>powerpc-*-netbsd*</h3> + +<p>PowerPC system in big endian mode running NetBSD. To build the +documentation you will need Texinfo version 4.2 (NetBSD 1.5.1 included +Texinfo version 3.12). + +<hr /> + +<h3><a name="TOC48"></a><a name="powerpc-*-eabiaix"></a>powerpc-*-eabiaix</h3> + +<p>Embedded PowerPC system in big endian mode with <code>-mcall-aix</code> selected as +the default. + +<hr /> + +<h3><a name="TOC49"></a><a name="powerpc-*-eabisim"></a>powerpc-*-eabisim</h3> + +<p>Embedded PowerPC system in big endian mode for use in running under the +PSIM simulator. + +<hr /> + +<h3><a name="TOC50"></a><a name="powerpc-*-eabi"></a>powerpc-*-eabi</h3> + +<p>Embedded PowerPC system in big endian mode. + +<hr /> + +<h3><a name="TOC51"></a><a name="powerpcle-*-elf"></a>powerpcle-*-elf, powerpcle-*-sysv4</h3> + +<p>PowerPC system in little endian mode, running System V.4. + +<hr /> + +<h3><a name="TOC52"></a><a name="powerpcle-*-eabisim"></a>powerpcle-*-eabisim</h3> + +<p>Embedded PowerPC system in little endian mode for use in running under +the PSIM simulator. + +<hr /> + +<h3><a name="TOC53"></a><a name="powerpcle-*-eabi"></a>powerpcle-*-eabi</h3> + +<p>Embedded PowerPC system in little endian mode. + +<hr /> + +<h3><a name="TOC54"></a><a name="s390-*-linux*"></a>s390-*-linux*</h3> + +<p>S/390 system running Linux for S/390. + +<hr /> + +<h3><a name="TOC55"></a><a name="s390x-*-linux*"></a>s390x-*-linux*</h3> + +<p>zSeries system (64-bit) running Linux for zSeries. + +<hr /> + +<h3><a name="TOC56"></a><a name="*-*-solaris2*"></a>*-*-solaris2*</h3> + +<p>Sun does not ship a C compiler with Solaris 2. To bootstrap and install +GCC you first have to install a pre-built compiler, see our +<a href="binaries.html">binaries page</a> for details. + +<p>The Solaris 2 <code>/bin/sh</code> will often fail to configure +<code>libstdc++-v3</code>, <code>boehm-gc</code> or <code>libjava</code>. We therefore +recommend to use the following sequence of commands to bootstrap and +install GCC: + +<br><pre> % CONFIG_SHELL=/bin/ksh + % export CONFIG_SHELL + % <var>srcdir</var>/configure [<var>options</var>] [<var>target</var>] + % gmake bootstrap + % gmake install +</pre> + +<p>As explained in the <a href="build.html">build</a> instructions, we recommend +to use GNU make, which we call <code>gmake</code> here to distinguish it +from Sun make. + +<p>Solaris 2 comes with a number of optional OS packages. Some of these +are needed to use GCC fully, namely <code>SUNWarc</code>, +<code>SUNWbtool</code>, <code>SUNWesu</code>, <code>SUNWhea</code>, <code>SUNWlibm</code>, +<code>SUNWsprot</code>, and <code>SUNWtoo</code>. If you did not install all +optional packages when installing Solaris 2, you will need to verify that +the packages that GCC needs are installed. + +<p>To check whether an optional package is installed, use +the <code>pkginfo</code> command. To add an optional package, use the +<code>pkgadd</code> command. For further details, see the Solaris 2 +documentation. + +<p>Trying to use the linker and other tools in +<code>/usr/ucb</code> to install GCC has been observed to cause trouble. +For example, the linker may hang indefinitely. The fix is to remove +<code>/usr/ucb</code> from your <code>PATH</code>. + +<p>The build process works more smoothly with the legacy Sun tools so, if you +have <code>/usr/xpg4/bin</code> in your <code>PATH</code>, we recommend that you place +<code>/usr/bin</code> before <code>/usr/xpg4/bin</code> for the duration of the build. + +<p>All releases of GNU binutils prior to 2.11.2 have known bugs on this +platform. We recommend the use of GNU binutils 2.11.2 or the vendor +tools (Sun <code>as</code>, Sun <code>ld</code>). + +<p>Sun bug 4296832 turns up when compiling X11 headers with GCC 2.95 or +newer: <code>g++</code> will complain that types are missing. These headers assume +that omitting the type means <code>int</code>; this assumption worked for C89 but +is wrong for C++, and is now wrong for C99 also. + +<p><code>g++</code> accepts such (invalid) constructs with the option +<code>-fpermissive</code>; it +will assume that any missing type is <code>int</code> (as defined by C89). + +<p>There are patches for Solaris 2.6 (105633-56 or newer for SPARC, +106248-42 or newer for Intel), Solaris 7 (108376-21 or newer for SPARC, +108377-20 for Intel), and Solaris 8 (108652-24 or newer for SPARC, +108653-22 for Intel) that fix this bug. + +<hr /> + +<h3><a name="TOC57"></a><a name="sparc-sun-solaris2*"></a>sparc-sun-solaris2*</h3> + +<p>When GCC is configured to use binutils 2.11.2 or later the binaries +produced are smaller than the ones produced using Sun's native tools; +this difference is quite significant for binaries containing debugging +information. + +<p>Sun <code>as</code> 4.x is broken in that it cannot cope with long symbol names. +A typical error message might look similar to the following: + +<br><pre>/usr/ccs/bin/as: "/var/tmp/ccMsw135.s", line 11041: error: + can't compute value of an expression involving an external symbol. +</pre> + +<p>This is Sun bug 4237974. This is fixed with patch 108908-02 for Solaris +2.6 and has been fixed in later (5.x) versions of the assembler, +starting with Solaris 7. + +<p>Starting with Solaris 7, the operating system is capable of executing +64-bit SPARC V9 binaries. GCC 3.1 and later properly supports +this; the <code>-m64</code> option enables 64-bit code generation. +However, if all you want is code tuned for the UltraSPARC CPU, you +should try the <code>-mtune=ultrasparc</code> option instead, which produces +code that, unlike full 64-bit code, can still run on non-UltraSPARC +machines. + +<p>When configuring on a Solaris 7 or later system that is running a kernel +that supports only 32-bit binaries, one must configure with +<code>--disable-multilib</code>, since we will not be able to build the +64-bit target libraries. + +<hr /> + +<h3><a name="TOC58"></a><a name="sparc-sun-solaris2.7"></a>sparc-sun-solaris2.7</h3> + +<p>Sun patch 107058-01 (1999-01-13) for Solaris 7/SPARC triggers a bug in +the dynamic linker. This problem (Sun bug 4210064) affects GCC 2.8 +and later, including all EGCS releases. Sun formerly recommended +107058-01 for all Solaris 7 users, but around 1999-09-01 it started to +recommend it only for people who use Sun's compilers. + +<p>Here are some workarounds to this problem: +<ul> +<li>Do not install Sun patch 107058-01 until after Sun releases a +complete patch for bug 4210064. This is the simplest course to take, +unless you must also use Sun's C compiler. Unfortunately 107058-01 +is preinstalled on some new Solaris 7-based hosts, so you may have to +back it out. + +<li>Copy the original, unpatched Solaris 7 +<code>/usr/ccs/bin/as</code> into +<code>/usr/local/lib/gcc-lib/sparc-sun-solaris2.7/3.1/as</code>, +adjusting the latter name to fit your local conventions and software +version numbers. + +<li>Install Sun patch 106950-03 (1999-05-25) or later. Nobody with +both 107058-01 and 106950-03 installed has reported the bug with GCC +and Sun's dynamic linker. This last course of action is riskiest, +for two reasons. First, you must install 106950 on all hosts that +run code generated by GCC; it doesn't suffice to install it only on +the hosts that run GCC itself. Second, Sun says that 106950-03 is +only a partial fix for bug 4210064, but Sun doesn't know whether the +partial fix is adequate for GCC. Revision -08 or later should fix +the bug. The current (as of 2001-09-24) revision is -14, and is included in +the Solaris 7 Recommended Patch Cluster. +</ul> + +<p>GCC 3.3 triggers a bug in version 5.0 Alpha 03/27/98 of the Sun assembler, +which causes a bootstrap failure when linking the 64-bit shared version of +libgcc. A typical error message is: + +<br><pre>ld: fatal: relocation error: R_SPARC_32: file libgcc/sparcv9/_muldi3.o: + symbol <unknown>: offset 0xffffffff7ec133e7 is non-aligned. +</pre> + +<p>This bug has been fixed in the final 5.0 version of the assembler. + +<p> +<hr /> + +<h3><a name="TOC59"></a><a name="sparc-sun-sunos4*"></a>sparc-sun-sunos4*</h3> + +<p>Support for this system is obsoleted in GCC 3.3. + +<p>A bug in the SunOS 4 linker will cause it to crash when linking +<code>-fPIC</code> compiled objects (and will therefore not allow you to build +shared libraries). + +<p>To fix this problem you can either use the most recent version of +binutils or get the latest SunOS 4 linker patch (patch ID 100170-10) +from Sun's patch site. + +<p>Sometimes on a Sun 4 you may observe a crash in the program +<code>genflags</code> or <code>genoutput</code> while building GCC. This is said to +be due to a bug in <code>sh</code>. You can probably get around it by running +<code>genflags</code> or <code>genoutput</code> manually and then retrying the +<code>make</code>. + +<hr /> + +<h3><a name="TOC60"></a><a name="sparc-unknown-linux-gnulibc1"></a>sparc-unknown-linux-gnulibc1</h3> + +<p>Support for this system is obsoleted in GCC 3.3. + +<p>It has been reported that you might need +<a href="ftp://ftp.yggdrasil.com/private/hjl">binutils 2.8.1.0.23</a> +for this platform, too. + +<hr /> + +<h3><a name="TOC61"></a><a name="sparc-*-linux*"></a>sparc-*-linux*</h3> + +<p>GCC versions 3.0 and higher require binutils 2.11.2 and glibc 2.2.4 +or newer on this platform. All earlier binutils and glibc +releases mishandled unaligned relocations on <code>sparc-*-*</code> targets. + +<hr /> + +<h3><a name="TOC62"></a><a name="sparc64-*-solaris2*"></a>sparc64-*-solaris2*</h3> + +<p>The following compiler flags must be specified in the configure +step in order to bootstrap this target with the Sun compiler: + +<br><pre> % CC="cc -xildoff -xarch=v9" <var>srcdir</var>/configure [<var>options</var>] [<var>target</var>] +</pre> + +<p><code>-xildoff</code> turns off the incremental linker, and <code>-xarch=v9</code> +specifies the SPARC-V9 architecture to the Sun linker and assembler. + +<hr /> + +<h3><a name="TOC63"></a><a name="sparcv9-*-solaris2*"></a>sparcv9-*-solaris2*</h3> + +<p>This is a synonym for sparc64-*-solaris2*. + +<hr /> + +<h3><a name="TOC64"></a><a name="%23*-*-sysv*"></a>*-*-sysv*</h3> + +<p>On System V release 3, you may get this error message +while linking: + +<br><pre>ld fatal: failed to write symbol name <var>something</var> + in strings table for file <var>whatever</var> +</pre> + +<p>This probably indicates that the disk is full or your ulimit won't allow +the file to be as large as it needs to be. + +<p>This problem can also result because the kernel parameter <code>MAXUMEM</code> +is too small. If so, you must regenerate the kernel and make the value +much larger. The default value is reported to be 1024; a value of 32768 +is said to work. Smaller values may also work. + +<p>On System V, if you get an error like this, + +<br><pre>/usr/local/lib/bison.simple: In function `yyparse': +/usr/local/lib/bison.simple:625: virtual memory exhausted +</pre> + +<p>that too indicates a problem with disk space, ulimit, or <code>MAXUMEM</code>. + +<p>On a System V release 4 system, make sure <code>/usr/bin</code> precedes +<code>/usr/ucb</code> in <code>PATH</code>. The <code>cc</code> command in +<code>/usr/ucb</code> uses libraries which have bugs. + +<hr /> + +<h3><a name="TOC65"></a><a name="vax-dec-ultrix"></a>vax-dec-ultrix</h3> + +<p>Don't try compiling with VAX C (<code>vcc</code>). It produces incorrect code +in some cases (for example, when <code>alloca</code> is used). + +<hr /> + +<h3><a name="TOC66"></a><a name="xtensa-*-elf"></a>xtensa-*-elf</h3> + +<p>This target is intended for embedded Xtensa systems using the +<code>newlib</code> C library. It uses ELF but does not support shared +objects. Designed-defined instructions specified via the +Tensilica Instruction Extension (TIE) language are only supported +through inline assembly. + +<p>The Xtensa configuration information must be specified prior to +building GCC. The <code>gcc/config/xtensa/xtensa-config.h</code> header +file contains the configuration information. If you created your +own Xtensa configuration with the Xtensa Processor Generator, the +downloaded files include a customized copy of this header file, +which you can use to replace the default header file. + +<hr /> + +<h3><a name="TOC67"></a><a name="xtensa-*-linux*"></a>xtensa-*-linux*</h3> + +<p>This target is for Xtensa systems running GNU/Linux. It supports ELF +shared objects and the GNU C library (glibc). It also generates +position-independent code (PIC) regardless of whether the +<code>-fpic</code> or <code>-fPIC</code> options are used. In other +respects, this target is the same as the +<a href="#xtensa-*-elf"><code>xtensa-*-elf</code></a> target. + +<hr /> + +<h3><a name="TOC68"></a><a name="windows"></a>Microsoft Windows (32-bit)</h3> + +<p>A port of GCC 2.95.2 and 3.x is included with the +<a href="http://www.cygwin.com/">Cygwin environment</a>. + +<p>Current (as of early 2001) snapshots of GCC will build under Cygwin +without modification. + +<p>GCC does not currently build with Microsoft's C++ compiler and there +are no plans to make it do so. + +<hr /> + +<h3><a name="TOC69"></a><a name="os2"></a>OS/2</h3> + +<p>GCC does not currently support OS/2. However, Andrew Zabolotny has been +working on a generic OS/2 port with pgcc. The current code can be found +at <a href="http://www.goof.com/pcg/os2/">http://www.goof.com/pcg/os2/</a>. + +<p>An older copy of GCC 2.8.1 is included with the EMX tools available at +<a href="ftp://ftp.leo.org/pub/comp/os/os2/leo/devtools/emx+gcc/">ftp://ftp.leo.org/pub/comp/os/os2/leo/devtools/emx+gcc/</a>. + +<hr /> + +<h3><a name="TOC70"></a><a name="older"></a>Older systems</h3> + +<p>GCC contains support files for many older (1980s and early +1990s) Unix variants. For the most part, support for these systems +has not been deliberately removed, but it has not been maintained for +several years and may suffer from bitrot. + +<p>Starting with GCC 3.1, each release has a list of "obsoleted" systems. +Support for these systems is still present in that release, but +<code>configure</code> will fail unless the <code>--enable-obsolete</code> +option is given. Unless a maintainer steps forward, support for these +systems will be removed from the next release of GCC. + +<p>Support for old systems as hosts for GCC can cause problems if the +workarounds for compiler, library and operating system bugs affect the +cleanliness or maintainability of the rest of GCC. In some cases, to +bring GCC up on such a system, if still possible with current GCC, may +require first installing an old version of GCC which did work on that +system, and using it to compile a more recent GCC, to avoid bugs in the +vendor compiler. Old releases of GCC 1 and GCC 2 are available in the +<code>old-releases</code> directory on the <a href="../mirrors.html">GCC mirror sites</a>. Header bugs may generally be avoided using +<code>fixincludes</code>, but bugs or deficiencies in libraries and the +operating system may still cause problems. + +<p>Support for older systems as targets for cross-compilation is less +problematic than support for them as hosts for GCC; if an enthusiast +wishes to make such a target work again (including resurrecting any of +the targets that never worked with GCC 2, starting from the last CVS +version before they were removed), patches +<a href="../contribute.html">following the usual requirements</a> would be +likely to be accepted, since they should not affect the support for more +modern targets. + +<p>For some systems, old versions of GNU binutils may also be useful, +and are available from <code>pub/binutils/old-releases</code> on +<a href="http://sources.redhat.com/mirrors.html">sources.redhat.com mirror sites</a>. + +<p>Some of the information on specific systems above relates to +such older systems, but much of the information +about GCC on such systems (which may no longer be applicable to +current GCC) is to be found in the GCC texinfo manual. + +<hr /> + +<h3><a name="TOC71"></a><a name="elf_targets"></a>all ELF targets (SVR4, Solaris 2, etc.)</h3> + +<p>C++ support is significantly better on ELF targets if you use the +<a href="./configure.html#with-gnu-ld">GNU linker</a>; duplicate copies of +inlines, vtables and template instantiations will be discarded +automatically. + +<hr /> +<p> +<a href="./index.html">Return to the GCC Installation page</a> + +</body></html> + diff --git a/gnu/usr.bin/gcc/INSTALL/test.html b/gnu/usr.bin/gcc/INSTALL/test.html new file mode 100644 index 00000000000..2abc431384c --- /dev/null +++ b/gnu/usr.bin/gcc/INSTALL/test.html @@ -0,0 +1,162 @@ +<html lang="en"> +<head> +<title>Installing GCC: Testing</title> +<meta http-equiv="Content-Type" content="text/html"> +<meta name=description content="Installing GCC: Testing"> +<meta name=generator content="makeinfo 4.2"> +<link href="http://www.gnu.org/software/texinfo/" rel=generator-home> +<!-- +Copyright © 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998, +1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc. +<br><p> +<p>Permission is granted to copy, distribute and/or modify this document +under the terms of the GNU Free Documentation License, Version 1.2 or +any later version published by the Free Software Foundation; with no +Invariant Sections, the Front-Cover texts being (a) (see below), and +with the Back-Cover Texts being (b) (see below). A copy of the +license is included in the section entitled "<a href="./gfdl.html">GNU Free Documentation License</a>". + +<p>(a) The FSF's Front-Cover Text is: + +<p>A GNU Manual + +<p>(b) The FSF's Back-Cover Text is: + +<p>You have freedom to copy and modify this GNU Manual, like GNU + software. Copies published by the Free Software Foundation raise + funds for GNU development.--> +</head> +<body> +<h1>Installing GCC: Testing</h1> +Before you install GCC, we encourage you to run the testsuites and to +compare your results with results from a similar configuration that have +been submitted to the +<a href="http://gcc.gnu.org/ml/gcc-testresults/">gcc-testresults mailing list</a>. +Some of these archived results are linked from the build status lists +at <a href="http://gcc.gnu.org/buildstat.html">http://gcc.gnu.org/buildstat.html</a>, although not everyone who +reports a successful build runs the testsuites and submits the results. +This step is optional and may require you to download additional software, +but it can give you confidence in your new GCC installation or point out +problems before you install and start using your new GCC. + +<p>First, you must have <a href="download.html">downloaded the testsuites</a>. +These are part of the full distribution, but if you downloaded the +"core" compiler plus any front ends, you must download the testsuites +separately. + +<p>Second, you must have the testing tools installed. This includes +<a href="http://www.gnu.org/software/dejagnu/">DejaGnu</a> 1.4.1 or 1.4.3 +and later, Tcl, and Expect; the DejaGnu site has links to these. + +<p>If the directories where <code>runtest</code> and <code>expect</code> were +installed are not in the <code>PATH</code>, you may need to set the following +environment variables appropriately, as in the following example (which +assumes that DejaGnu has been installed under <code>/usr/local</code>): + +<br><pre> TCL_LIBRARY = /usr/local/share/tcl8.0 + DEJAGNULIBS = /usr/local/share/dejagnu +</pre> + +<p>(On systems such as Cygwin, these paths are required to be actual +paths, not mounts or links; presumably this is due to some lack of +portability in the DejaGnu code.) + +<p>Finally, you can run the testsuite (which may take a long time): +<br><pre> cd <var>objdir</var>; make -k check +</pre> + +<p>This will test various components of GCC, such as compiler +front ends and runtime libraries. While running the testsuite, DejaGnu +might emit some harmless messages resembling +<code>WARNING: Couldn't find the global config file.</code> or +<code>WARNING: Couldn't find tool init file</code> that can be ignored. + +<h3><a name="TOC0"></a>How can I run the test suite on selected tests?</h3> + +<p>In order to run sets of tests selectively, there are targets +<code>make check-gcc</code> and <code>make check-g++</code> +in the <code>gcc</code> subdirectory of the object directory. You can also +just run <code>make check</code> in a subdirectory of the object directory. + +<p>A more selective way to just run all <code>gcc</code> execute tests in the +testsuite is to use + +<br><pre> make check-gcc RUNTESTFLAGS="execute.exp <var>other-options</var>" +</pre> + +<p>Likewise, in order to run only the <code>g++</code> "old-deja" tests in +the testsuite with filenames matching <code>9805*</code>, you would use + +<br><pre> make check-g++ RUNTESTFLAGS="old-deja.exp=9805* <var>other-options</var>" +</pre> + +<p>The <code>*.exp</code> files are located in the testsuite directories of the GCC +source, the most important ones being <code>compile.exp</code>, +<code>execute.exp</code>, <code>dg.exp</code> and <code>old-deja.exp</code>. +To get a list of the possible <code>*.exp</code> files, pipe the +output of <code>make check</code> into a file and look at the +<code>Running <small>...</small> .exp</code> lines. + +<p>The Java runtime tests can be executed via <code>make check</code> +in the <code><var>target</var>/libjava/testsuite</code> directory in +the build tree. + +<h3><a name="TOC1"></a>Additional testing for Java Class Libraries</h3> + +<p>The <a href="http://sources.redhat.com/mauve/">Mauve Project</a> provides +a suite of tests for the Java Class Libraries. This suite can be run +as part of libgcj testing by placing the Mauve tree within the libjava +testsuite at <code>libjava/testsuite/libjava.mauve/mauve</code>, or by +specifying the location of that tree when invoking <code>make</code>, as in +<code>make MAUVEDIR=~/mauve check</code>. + +<a href="http://www-124.ibm.com/developerworks/oss/cvs/jikes/~checkout~/jacks/jacks.html">Jacks</a> +is a free test suite that tests Java compiler front ends. This suite +can be run as part of libgcj testing by placing the Jacks tree within +the libjava testsuite at <code>libjava/testsuite/libjava.jacks/jacks</code>. + +<h3><a name="TOC2"></a>How to interpret test results</h3> + +<p>The result of running the testsuite are various <code>*.sum</code> and <code>*.log</code> +files in the testsuite subdirectories. The <code>*.log</code> files contain a +detailed log of the compiler invocations and the corresponding +results, the <code>*.sum</code> files summarize the results. These summaries +contain status codes for all tests: + +<ul> +<li>PASS: the test passed as expected +<li>XPASS: the test unexpectedly passed +<li>FAIL: the test unexpectedly failed +<li>XFAIL: the test failed as expected +<li>UNSUPPORTED: the test is not supported on this platform +<li>ERROR: the testsuite detected an error +<li>WARNING: the testsuite detected a possible problem +</ul> + +<p>It is normal for some tests to report unexpected failures. At the +current time our testing harness does not allow fine grained control +over whether or not a test is expected to fail. We expect to fix this +problem in future releases. + +<h3><a name="TOC3"></a>Submitting test results</h3> + +<p>If you want to report the results to the GCC project, use the +<code>contrib/test_summary</code> shell script. Start it in the <var>objdir</var> with + +<br><pre> <var>srcdir</var>/contrib/test_summary -p your_commentary.txt \ + -m gcc-testresults@gcc.gnu.org |sh +</pre> + +<p>This script uses the <code>Mail</code> program to send the results, so +make sure it is in your <code>PATH</code>. The file <code>your_commentary.txt</code> is +prepended to the testsuite summary and should contain any special +remarks you have on your results or your build environment. Please +do not edit the testsuite result block or the subject line, as these +messages may be automatically processed. + +<hr /> +<p> +<a href="./index.html">Return to the GCC Installation page</a> + +</body></html> + |