]>
Commit | Line | Data |
---|---|---|
f42974dc DW |
1 | \input texinfo.tex @c -*-texinfo-*- |
2 | @c @ifnothtml | |
3 | @c %**start of header | |
4 | @setfilename install.info | |
5 | @settitle Installing GCC | |
6 | @setchapternewpage odd | |
7 | @c %**end of header | |
8 | @c @end ifnothtml | |
9 | ||
10 | @c Specify title for specific html page | |
11 | @ifset indexhtml | |
12 | @settitle Installing GCC | |
13 | @end ifset | |
14 | @ifset specifichtml | |
15 | @settitle Host/Target specific installation notes for GCC | |
16 | @end ifset | |
17 | @ifset downloadhtml | |
18 | @settitle Downloading GCC | |
19 | @end ifset | |
20 | @ifset configurehtml | |
21 | @settitle Installing GCC: Configuration | |
22 | @end ifset | |
23 | @ifset buildhtml | |
24 | @settitle Installing GCC: Building | |
25 | @end ifset | |
26 | @ifset testhtml | |
27 | @settitle Installing GCC: Testing | |
28 | @end ifset | |
29 | @ifset finalinstallhtml | |
30 | @settitle Installing GCC: Final installation | |
31 | @end ifset | |
32 | @ifset binarieshtml | |
33 | @settitle Installing GCC: Binaries | |
34 | @end ifset | |
35 | ||
e427d51a | 36 | @comment $Id: install.texi,v 1.4 2001/05/22 14:54:01 gerald Exp $ |
f42974dc DW |
37 | @c Copyright (C) 2001 Free Software Foundation, Inc. |
38 | @c *** Converted to texinfo by Dean Wakerley, dean@wakerley.com | |
39 | ||
40 | @c Include everything if we're not making html | |
41 | @ifnothtml | |
42 | @set indexhtml | |
43 | @set specifichtml | |
44 | @set downloadhtml | |
45 | @set configurehtml | |
46 | @set buildhtml | |
47 | @set testhtml | |
48 | @set finalinstallhtml | |
49 | @set binarieshtml | |
50 | @end ifnothtml | |
51 | ||
52 | @c Part 2 Summary Description and Copyright | |
53 | @ifinfo | |
54 | ||
55 | Copyright @copyright{} 2001 Free Software Foundation, Inc. | |
56 | @end ifinfo | |
57 | ||
58 | @c Part 3 Titlepage and Copyright | |
59 | @titlepage | |
60 | @sp 10 | |
61 | @comment The title is printed in a large font. | |
62 | @center @titlefont{Sample Title} | |
63 | ||
64 | @c The following two commands start the copyright page. | |
65 | @page | |
66 | vskip 0pt plus 1filll | |
67 | Copyright @copyright{} 2001 Free Software Foundation, Inc. | |
68 | @end titlepage | |
69 | ||
70 | @c Part 4 Top node and Master Menu | |
71 | @ifinfo | |
72 | @node Top, , , (dir) | |
73 | @comment node-name, next, Previous, up | |
74 | ||
75 | @menu | |
76 | * Installing GCC:: This document describes the generic installation | |
77 | procedure for GCC as well as detailing some target | |
78 | specific installation instructions. | |
79 | ||
80 | * Specific:: Host/target specific installation notes for GCC. | |
81 | * Binaries:: Where to get pre-compiled binaries. | |
82 | ||
83 | * Concept Index:: This index has two entries. | |
84 | @end menu | |
85 | @end ifinfo | |
86 | ||
87 | @c Part 5 The Body of the Document | |
88 | @c ***Installing GCC********************************************************** | |
89 | @ifinfo | |
90 | @comment node-name, next, previous, up | |
91 | @node Installing GCC, Binaries, , Top | |
92 | @end ifinfo | |
93 | @ifset indexhtml | |
94 | @html | |
95 | <h1 align="center">Installing GCC</h1> | |
96 | @end html | |
97 | @ifnothtml | |
98 | @chapter Installing GCC | |
99 | @end ifnothtml | |
100 | ||
101 | The latest version of this document is always available at | |
102 | @uref{http://gcc.gnu.org/install/,,http://gcc.gnu.org/install/}. | |
103 | ||
104 | This document describes the generic installation procedure for GCC as well | |
105 | as detailing some target specific installation instructions. | |
106 | ||
107 | GCC includes several components that previously were separate distributions | |
108 | with their own installation instructions. This document supersedes all | |
109 | package specific installation instructions. We provide the component | |
110 | specific installation information in the source distribution for historical | |
111 | reference purposes only. | |
112 | ||
113 | @emph{Before} starting the build/install procedure please check the | |
114 | @ifnothtml | |
115 | @xref{Specific, host/target specific installation notes}. | |
116 | @end ifnothtml | |
117 | @ifnotinfo | |
118 | @uref{specific.html,,host/target specific installation notes}. | |
119 | @end ifnotinfo | |
120 | We recommend you browse the entire generic installation instructions before | |
121 | you proceed. | |
122 | ||
123 | The installation procedure itself is broken into five steps. | |
124 | ||
125 | @ifinfo | |
126 | @menu | |
127 | * Downloading the source:: | |
128 | * Configuration:: | |
129 | * Building:: | |
130 | * Testing:: (optional) | |
131 | * Final install:: | |
132 | @end menu | |
133 | @end ifinfo | |
134 | @ifnotinfo | |
135 | @enumerate | |
136 | @item | |
137 | @uref{download.html,,Downloading the source} | |
138 | @item | |
139 | @uref{configure.html,,Configuration} | |
140 | @item | |
141 | @uref{build.html,,Building} | |
142 | @item | |
143 | @uref{test.html,,Testing} (optional) | |
144 | @item | |
145 | @uref{finalinstall.html,,Final install} | |
146 | @end enumerate | |
147 | @end ifnotinfo | |
148 | ||
149 | Please note that GCC does not support `@code{make uninstall}' and probably | |
150 | won't do so in the near future as this would open a can of worms. Instead, | |
151 | we suggest that you install GCC into a directory of its own and simply | |
152 | remove that directory when you do not need that specific version of GCC any longer. | |
153 | ||
154 | @html | |
155 | <hr> | |
156 | <p> | |
157 | @end html | |
158 | @ifhtml | |
159 | @uref{./index.html,,Return to the GCC Installation page} | |
160 | @end ifhtml | |
161 | @end ifset | |
162 | ||
163 | @c ***Downloading the source************************************************** | |
164 | @ifinfo | |
165 | @comment node-name, next, previous, up | |
166 | @node Downloading the source, Configuration, , Installing GCC | |
167 | @end ifinfo | |
168 | @ifset downloadhtml | |
169 | @html | |
170 | <h1 align="center">Downloading GCC</h1> | |
171 | @end html | |
172 | @ifnothtml | |
173 | @chapter Downloading GCC | |
174 | @end ifnothtml | |
175 | @cindex Downloading GCC | |
176 | @cindex Downloading the Source | |
177 | ||
178 | GCC is distributed via CVS and FTP tarballs compressed with gzip or | |
179 | bzip2. It is possible to download a full distribution or specific | |
180 | components. | |
181 | ||
182 | Please refer to our @uref{http://gcc.gnu.org/releases.html,,releases web page} | |
183 | for information on how to obtain GCC. | |
184 | ||
185 | The full distribution includes the C, C++, Objective-C, Fortran, Java, | |
186 | and Chill compilers. The full distribution also includes runtime libraries | |
187 | for C++, Objective-C and Fortran. In the future the GNU compiler testsuites | |
188 | will be included in the full distribution. | |
189 | ||
190 | If you choose to download specific components, you must download the core | |
191 | gcc distribution plus any language specific distributions you wish to | |
192 | use. The core distribution includes the C language front-end as well as the | |
193 | shared components. Each language has a tarball which includes the language | |
194 | front-end as well as the language runtime (when appropriate). | |
195 | ||
196 | Unpack the core distribution as well as any language specific | |
197 | distributions in the same directory. | |
198 | ||
199 | If you also intend to build binutils (either to upgrade an existing | |
200 | installation or for use in place of the corresponding tools of your | |
201 | OS), unpack the binutils distribution either in the same directory or | |
202 | a separate one. In the latter case, add symbolic links to any | |
203 | components of the binutils you intend to build alongside the compiler | |
204 | (bfd, binutils, gas, gprof, ld, opcodes,...) to the directory containing | |
205 | the GCC sources. | |
206 | ||
207 | @html | |
208 | <hr> | |
209 | <p> | |
210 | @end html | |
211 | @ifhtml | |
212 | @uref{./index.html,,Return to the GCC Installation page} | |
213 | @end ifhtml | |
214 | @end ifset | |
215 | ||
216 | @c ***Configuration*********************************************************** | |
217 | @ifinfo | |
218 | @comment node-name, next, previous, up | |
219 | @node Configuration, Building, Downloading the source, Installing GCC | |
220 | @end ifinfo | |
221 | @ifset configurehtml | |
222 | @html | |
223 | <h1 align="center">Installing GCC: Configuration</h1> | |
224 | @end html | |
225 | @ifnothtml | |
226 | @chapter Installing GCC: Configuration | |
227 | @end ifnothtml | |
228 | @cindex Configuration | |
229 | @cindex Installing GCC: Configuration | |
230 | ||
231 | Like most GNU software, GCC must be configured before it can be built. | |
232 | This document describes the recommended configuration procedure | |
233 | for both native and cross targets. | |
234 | ||
235 | We use @emph{srcdir} to refer to the toplevel source directory for | |
236 | GCC; we use @emph{objdir} to refer to the toplevel build/object directory. | |
237 | ||
238 | First, we @strong{highly} recommend that GCC be built into a | |
239 | separate directory than the sources which does @strong{not} reside | |
240 | within the source tree. This is how we generally build GCC; building | |
241 | where @emph{srcdir} == @emph{objdir} should still work, but doesn't | |
242 | get extensive testing; building where @emph{objdir} is a subdirectory | |
243 | of @emph{srcdir} is unsupported. | |
244 | ||
df002c7d DE |
245 | Second, when configuring a native system, either ``@command{cc}'' or |
246 | ``@command{gcc}'' must be in your path or you must set @command{CC} in | |
247 | your environment before running configure. Otherwise the configuration | |
248 | scripts may fail. | |
f42974dc DW |
249 | |
250 | To configure GCC: | |
251 | ||
252 | @example | |
253 | % mkdir @emph{objdir} | |
254 | % cd @emph{objdir} | |
255 | % @emph{srcdir}/configure @strong{[target] [options]} | |
256 | @end example | |
257 | ||
258 | ||
259 | @strong{target specification} | |
260 | @itemize @bullet | |
261 | @item | |
262 | GCC has code to correctly determine the correct value for @strong{target} | |
263 | for nearly all native systems. Therefore, we highly recommend you not | |
264 | provide a configure target when configuring a native compiler. | |
265 | ||
266 | @item | |
267 | @strong{target} must be specified as @option{--target=}@emph{target} | |
268 | when configuring a cross compiler; examples of valid targets would be | |
269 | i960-rtems, m68k-coff, sh-elf, etc. | |
270 | ||
271 | @item | |
272 | Specifying just @strong{target} instead of @option{--target=}@emph{target} | |
273 | implies that the host defaults to @strong{target}. | |
274 | @end itemize | |
275 | ||
276 | ||
277 | @strong{options specification} | |
278 | ||
279 | Use @strong{options} to override several configure time options for | |
280 | GCC. A partial list of supported @option{options}: | |
281 | ||
282 | @itemize @bullet | |
283 | @item | |
284 | @option{--prefix=}@emph{dirname} @minus{}@minus{} Specify the toplevel installation | |
285 | directory. This is the recommended way to install the tools into a directory | |
286 | other than the default. The toplevel installation directory defaults to | |
287 | @code{/usr/local}. | |
288 | ||
289 | We @strong{highly} recommend against @emph{dirname} being the same or a | |
290 | subdirectory of @emph{objdir} or vice versa. | |
291 | ||
292 | These additional options control where certain parts of the distribution | |
293 | are installed. Normally you should not need to use these options. | |
294 | @itemize @bullet | |
295 | @item | |
296 | @option{--with-local-prefix=}@emph{dirname} @minus{}@minus{} Specify the installation | |
297 | directory for local include files. The default is @code{/usr/local}. | |
298 | ||
299 | @item | |
300 | @option{--with-gxx-include-dir=}@emph{dirname} @minus{}@minus{} Specify the installation | |
301 | directory for g++ header files. The default is @command{/usr/local/include/g++}. | |
302 | ||
303 | @end itemize | |
304 | ||
305 | @item | |
306 | @option{--enable-shared} @minus{}@minus{} Build shared versions of the C++ runtime | |
307 | libraries if supported. This is the default on most systems. Use @option{--disable-shared} | |
308 | for static libraries. Note that up to the gcc version 2.95.x series, static | |
309 | libraries were the default on all systems. | |
310 | ||
311 | @item | |
312 | @option{--with-gnu-as} @minus{}@minus{} Specify that the compiler should assume that the | |
313 | assembler it finds is the GNU assembler. However, this does not modify the rules to find an | |
314 | assembler and will result in confusion if found assembler is not actually the GNU assembler. | |
315 | If you have more than one assembler installed on your system, you may want to use this option | |
316 | in connection with @option{--with-as=/path/to/gas}. | |
317 | ||
318 | @item | |
319 | @option{--with-as=@emph{/path/to/as}} @minus{}@minus{} Specify that the compiler should use the | |
320 | assembler pointed to by @emph{pathname}, rather than the one found by the standard rules to | |
321 | find an assembler, which are: | |
322 | @itemize @bullet | |
323 | @item | |
324 | Check the @emph{$exec_prefix/lib/gcc-lib/$target/$version} directory, where @emph{$exec_prefix} | |
325 | defaults to @emph{$prefix} which defaults to @file{/usr/local} unless overridden by the | |
326 | @option{--prefix=/pathname} switch described above. @emph{$target} is the target system triple, | |
327 | such as @emph{sparc-sun-solaris2.7}, and @emph{$version} denotes the GCC version, such as 2.95.2. | |
328 | @item | |
329 | Check operating system specific directories (e.g. @file{/usr/ccs/bin} on Sun Solaris). | |
330 | @end itemize | |
331 | Note that these rules do not check for the value of @emph{$PATH}. You may want to use | |
332 | @option{--with-as} if no assembler is installed in the directories listed above, or if you have | |
333 | multiple assemblers installed and want to choose one that is not found by the above rules. | |
334 | ||
335 | @item | |
336 | @option{--with-gnu-ld} @minus{}@minus{} Same as @option{--with-gnu-as} but for linker. | |
337 | ||
338 | @item | |
339 | @option{--with-ld=@emph{/path/to/ld}} @minus{}@minus{} Same as @option{--with-as}, but for the | |
340 | linker. | |
341 | ||
342 | @item | |
343 | @option{--with-stabs} @minus{}@minus{} Specify that stabs debugging information should be used | |
344 | instead of whatever format the host normally uses. Normally GCC uses the | |
345 | same debug format as the host system. | |
346 | ||
347 | @item | |
348 | @option{--enable-multilib} @minus{}@minus{} Specify that multiple target libraries | |
349 | should be built to support different target variants, calling conventions, | |
350 | etc. This is the default. | |
351 | ||
352 | @item | |
353 | @option{--enable-threads} @minus{}@minus{} Specify that the target supports threads. | |
354 | This affects the Objective-C compiler and runtime library, and exception | |
355 | handling for other languages like C++ and Java. | |
356 | ||
357 | @item | |
358 | @option{--enable-threads=}@emph{lib} @minus{}@minus{} Specify that @emph{lib} is the thread | |
359 | support library. This affects the Objective-C compiler and runtime library, | |
360 | and exception handling for other languages like C++ and Java. | |
361 | ||
362 | @item | |
363 | @option{--with-cpu=}@emph{cpu} @minus{}@minus{} Specify which cpu variant the | |
364 | compiler should generate code for by default. This is currently | |
365 | only supported on the some ports, specifically arm, powerpc, and | |
366 | SPARC. If configure does not recognize the model name (e.g. arm700, | |
367 | 603e, or ultrasparc) you provide, please check the configure script | |
368 | for a complete list of supported models. | |
369 | ||
370 | @item | |
371 | @option{--enable-target-optspace} @minus{}@minus{} Specify that target libraries | |
372 | should be optimized for code space instead of code speed. This is the | |
373 | default for the m32r platform. | |
374 | ||
375 | @item | |
376 | @option{--enable-cpp} @minus{}@minus{} Specify that a shell script which emulates | |
377 | traditional cpp functionality should be installed. | |
378 | ||
379 | @item | |
380 | @option{--enable-cpplib} @minus{}@minus{} Specify that the functionality of | |
381 | CPP should be integrated into the compiler itself. This option is | |
382 | not supported by snapshots since November 2000. In snapshots where | |
383 | it is supported, it is not enabled by default, except for snapshots | |
384 | very close to November 2000. | |
385 | ||
386 | @item | |
387 | @option{--without-fast-fixincludes} @minus{}@minus{} Specify that the old, slower | |
388 | method of fixing the system header files should be used. | |
389 | EGCS 1.1.x and older releases default to the slow version. GCC 2.95 and | |
390 | newer releases will default to the fast version. | |
391 | ||
392 | @item | |
393 | @option{--enable-version-specific-runtime-libs} @minus{}@minus{} Specify that runtime | |
394 | libraries should be installed in the compiler specific subdirectory | |
395 | (@option{$@{libsubdir@}}) rather than the usual places. | |
396 | In addition, libstdc++'s include files will be installed in | |
397 | @option{$@{libsubdir@}/include/g++} unless you overruled it by using | |
398 | @option{--with-gxx-include-dir=}@emph{dirname}. | |
399 | Using this option is particularly useful if you intend to use several | |
400 | versions of GCC in parallel. This is currently supported by @option{libf2c} | |
401 | and @option{libstdc++}. | |
402 | ||
403 | @item | |
404 | @option{--enable-languages=}@emph{lang1}@option{,}@emph{lang2}@option{,...} | |
405 | @minus{}@minus{} Specify that only a particular subset of compilers and their runtime libraries | |
406 | should be built. For a list of valid values for @emph{lang}@option{x} you can issue | |
407 | the following command in the @option{gcc} directory of your GCC source tree:@* | |
408 | @command{grep language= */config-lang.in}@* | |
409 | Currently, you can use any of the following: @code{c++}, @code{f77}, @code{java} and @code{objc}. | |
410 | @code{CHILL} is not currently maintained, and will almost | |
411 | certainly fail to compile. Note that this switch does not work with | |
412 | EGCS 1.1.2 or older versions of egcs. It is supported in GCC 2.95 | |
413 | and newer versions.@* | |
414 | If you do not pass this flag, all languages available in the @code{gcc} sub-tree | |
415 | will be configured. Re-defining LANGUAGES when calling @command{make bootstrap} | |
416 | @strong{*does not*} work anymore, as those language sub-directories might not have been | |
417 | configured! | |
418 | ||
419 | @item | |
420 | @option{--disable-libgcj} @minus{}@minus{} Specify that the run-time libraries | |
421 | used by GCJ should not be built. This is useful in case you intend | |
422 | to use GCJ with some other run-time, or you're going to install it | |
423 | separately, or it just happens not to build on your particular | |
424 | machine. In general, if the Java front-end is enabled, the GCJ | |
425 | libraries will be enabled too, unless they're known to not work on | |
426 | the target platform. If GCJ is enabled but libgcj isn't built, you | |
427 | may need to port it; in this case, before modifying the top-level | |
428 | configure.in so that libgcj is enabled by default on this platform, | |
429 | you may use @option{--enable-libgcj} to override the default. | |
430 | ||
431 | @item | |
432 | @option{--with-dwarf2} @minus{}@minus{} Specify that the compiler should use DWARF2 | |
433 | debugging information as the default. | |
434 | @end itemize | |
435 | ||
436 | Some options which only apply to building cross compilers: | |
437 | @itemize @bullet | |
438 | @item | |
439 | @option{--with-headers=}@emph{dir} @minus{}@minus{} Specifies a directory which has | |
440 | target include files. | |
441 | @emph{This options is required} when building a cross | |
442 | compiler, if @code{$@{prefix@}/$@{target@}/sys-include} doesn't pre-exist. | |
443 | These include files will be copied into the @code{gcc} install directory. | |
444 | Fixincludes will be run on these files to make them compatible with @command{gcc}. | |
445 | @item | |
446 | @option{--with-libs=}@emph{``dir1 dir2 ... dirN''} @minus{}@minus{} Specifies a list of | |
447 | directories which contain the target runtime libraries. These libraries will | |
448 | be copied into the @code{gcc} install directory. | |
449 | @item | |
450 | @option{--with-newlib} @minus{}@minus{} Specifies that ``newlib'' is being used as the target | |
451 | C library. This causes @code{__eprintf} to be omitted from libgcc.a on the | |
452 | assumption that it will be provided by newlib. | |
453 | @end itemize | |
454 | ||
455 | Note that each @option{--enable} option has a corresponding @option{--disable} option and | |
456 | that each @option{--with} option has a corresponding @option{--without} option. | |
457 | ||
458 | @html | |
459 | <hr> | |
460 | <p> | |
461 | @end html | |
462 | @ifhtml | |
463 | @uref{./index.html,,Return to the GCC Installation page} | |
464 | @end ifhtml | |
465 | @end ifset | |
466 | ||
467 | @c ***Building**************************************************************** | |
468 | @ifinfo | |
469 | @comment node-name, next, previous, up | |
470 | @node Building, Testing, Configuration, Installing GCC | |
471 | @end ifinfo | |
472 | @ifset buildhtml | |
473 | @html | |
474 | <h1 align="center">Installing GCC: Building</h1> | |
475 | @end html | |
476 | @ifnothtml | |
477 | @chapter Building | |
478 | @end ifnothtml | |
479 | @cindex Installing GCC: Building | |
480 | ||
481 | Now that GCC is configured, you are ready to build the compiler and | |
482 | runtime libraries. | |
483 | ||
484 | We @strong{highly} recommend that GCC be built using GNU make; | |
485 | other versions may work, then again they might not. | |
486 | ||
487 | (For example, many broken versions of make will fail if you use the | |
488 | recommended setup where @emph{objdir} is different from @emph{srcdir}.) | |
489 | ||
490 | ||
491 | @section Building a native compiler | |
492 | ||
493 | For a native build issue the command `@code{make bootstrap}'. This | |
494 | will build the entire GCC system, which includes the following steps: | |
495 | ||
496 | @itemize @bullet | |
497 | @item | |
498 | Build host tools necessary to build the compiler such as texinfo, bison, | |
499 | gperf. | |
500 | ||
501 | @item | |
502 | Build target tools for use by the compiler such as binutils (bfd, | |
503 | binutils, gas, gprof, ld, and opcodes)@* | |
504 | if they have been individually linked | |
505 | or moved into the top level GCC source tree before configuring. | |
506 | ||
507 | @item | |
508 | Perform a 3-stage bootstrap of the compiler. | |
509 | ||
510 | @item | |
511 | Perform a comparison test of the stage2 and stage3 compilers. | |
512 | ||
513 | @item | |
514 | Build runtime libraries using the stage3 compiler from the previous step. | |
515 | ||
516 | @end itemize | |
517 | ||
518 | If you are short on disk space you might consider `@code{make | |
519 | bootstrap-lean}' instead. This is identical to `@code{make | |
520 | bootstrap}' except that object files from the stage1 and | |
521 | stage2 of the 3-stage bootstrap of the compiler are deleted as | |
522 | soon as they are no longer needed. | |
523 | ||
524 | ||
525 | If you want to save additional space during the bootstrap and in | |
526 | the final installation as well, you can build the compiler binaries | |
527 | without debugging information with ``@code{make CFLAGS='-O' LIBCFLAGS='-g | |
528 | -O2' LIBCXXFLAGS='-g -O2 -fno-implicit-templates' bootstrap}''. This will save | |
529 | roughly 40% of disk space both for the bootstrap and the final installation. | |
530 | (Libraries will still contain debugging information.) | |
531 | ||
532 | If you used the flag @code{--enable-languages=...} to restrict | |
533 | the compilers to be built, only those you've actually enabled will be | |
534 | built. This will of course only build those runtime libraries, for | |
535 | which the particular compiler has been built. Please note, | |
536 | that re-defining LANGUAGES when calling `@code{make bootstrap}' | |
537 | @strong{*does not*} work anymore! | |
538 | ||
539 | ||
540 | @section Building a cross compiler | |
541 | ||
542 | We recommend reading the | |
543 | @uref{http://www.objsw.com/CrossGCC/,,crossgcc FAQ} | |
544 | for information about building cross compilers. | |
545 | ||
546 | When building a cross compiler, it is not generally possible to do a | |
547 | 3-stage bootstrap of the compiler. This makes for an interesting problem | |
548 | as parts of GCC can only be built with GCC. | |
549 | ||
550 | To build a cross compiler, we first recommend building and installing a | |
551 | native compiler. You can then use the native GCC compiler to build the | |
552 | cross compiler. | |
553 | ||
554 | Assuming you have already installed a native copy of GCC and configured | |
555 | your cross compiler, issue the command `@code{make}', which performs the | |
556 | following steps: | |
557 | ||
558 | @itemize @bullet | |
559 | @item | |
560 | Build host tools necessary to build the compiler such as texinfo, bison, | |
561 | gperf. | |
562 | ||
563 | @item | |
564 | Build target tools for use by the compiler such as binutils (bfd, | |
565 | binutils, gas, gprof, ld, and opcodes) | |
566 | if they have been individually linked or moved into the top level GCC source | |
567 | tree before configuring. | |
568 | ||
569 | @item | |
570 | Build the compiler (single stage only). | |
571 | ||
572 | @item | |
573 | Build runtime libraries using the compiler from the previous step. | |
574 | @end itemize | |
575 | ||
576 | Note that if an error occurs in any step the make process will exit. | |
577 | ||
578 | @section Building in parallel | |
579 | ||
580 | If you have a multiprocessor system you can use `@code{make bootstrap | |
581 | MAKE="make -j 2" -j 2}' or just `@code{make -j 2 bootstrap}' | |
582 | for GNU Make 3.79 and above instead of just `@code{make bootstrap}' | |
583 | when building GCC. You can use a bigger number instead of two if | |
584 | you like. In most cases, it won't help to use a number bigger than | |
585 | the number of processors in your machine. | |
586 | ||
587 | @html | |
588 | <hr> | |
589 | <p> | |
590 | @end html | |
591 | @ifhtml | |
592 | @uref{./index.html,,Return to the GCC Installation page} | |
593 | @end ifhtml | |
594 | @end ifset | |
595 | ||
596 | @c ***Testing***************************************************************** | |
597 | @ifinfo | |
598 | @comment node-name, next, previous, up | |
599 | @node Testing, Final install, Building, Installing GCC | |
600 | @end ifinfo | |
601 | @ifset testhtml | |
602 | @html | |
603 | <h1 align="center">Installing GCC: Testing</h1> | |
604 | @end html | |
605 | @ifnothtml | |
606 | @chapter Installing GCC: Testing | |
607 | @end ifnothtml | |
608 | @cindex Testing | |
609 | @cindex Installing GCC: Testing | |
610 | @cindex Testsuite | |
611 | ||
612 | @strong{Please note that this is only applicable | |
613 | to current development versions of GCC and GCC 3.0 or later. | |
614 | GCC 2.95.x does not come with a testsuite.} | |
615 | ||
616 | Before you install GCC, you might wish to run the testsuite. This | |
617 | step is optional and may require you to download additional software. | |
618 | ||
619 | First, you must have @uref{download.html,,downloaded the testsuites}. | |
620 | The full distribution contains testsuites; only if you downloaded the | |
621 | ``core'' compiler plus any front ends, you do not have the testsuites. | |
622 | ||
623 | Second, you must have a @uref{http://www.gnu.org/software/dejagnu/,,current version of DejaGnu} installed; | |
624 | dejagnu 1.3 is not sufficient. | |
625 | ||
626 | Now you may need specific preparations: | |
627 | ||
628 | @itemize @bullet | |
629 | @item | |
630 | In order to run the libio tests on targets which do not fully | |
631 | support Unix/POSIX commands (e.g. Cygwin), the references to the dbz | |
632 | directory have to be deleted from @code{libio/configure.in}. | |
633 | ||
634 | @item | |
635 | The following environment variables must be set appropriately, as in | |
636 | the following example (which assumes that DejaGnu has been installed | |
637 | under @code{/usr/local}): | |
638 | ||
639 | @example | |
640 | TCL_LIBRARY = /usr/local/share/tcl8.0 | |
641 | DEJAGNULIBS = /usr/local/share/dejagnu | |
642 | @end example | |
643 | ||
644 | On systems such as Cygwin, these paths are required to be actual | |
645 | paths, not mounts or links; presumably this is due to some lack of | |
646 | portability in the DejaGnu code. | |
647 | ||
648 | @end itemize | |
649 | ||
650 | Finally, you can run the testsuite (which may take a long time): | |
651 | @example | |
652 | cd @emph{objdir}; make -k check | |
653 | @end example | |
654 | ||
655 | The testing process will try to test as many components in the GCC | |
656 | distribution as possible, including the C, C++ and Fortran compilers as | |
657 | well as the C++ runtime libraries. | |
658 | ||
659 | @section How can I run the test suite on selected tests? | |
660 | ||
661 | As a first possibility to cut down the number of tests that are run it is | |
662 | possible to use `@code{make check-gcc}' or `@code{make check-g++}' | |
663 | in the gcc subdirectory of the object directory. To further cut down the | |
664 | tests the following is possible: | |
665 | ||
666 | @example | |
667 | make check-gcc RUNTESTFLAGS="execute.exp <other options>" | |
668 | @end example | |
669 | ||
670 | This will run all gcc execute tests in the testsuite. | |
671 | ||
672 | @example | |
673 | make check-g++ RUNTESTFLAGS="old-deja.exp=9805* <other options>" | |
674 | @end example | |
675 | ||
676 | This will run the g++ "old-deja" tests in the testsuite where the filename | |
677 | matches 9805*. | |
678 | ||
679 | The *.exp files are located in the testsuite directories of the GCC | |
680 | source, the most important ones being compile.exp, execute.exp, dg.exp | |
681 | and old-deja.exp. To get a list of the possible *.exp files, pipe the | |
682 | output of `@code{make check}' into a file and look at the | |
683 | "@code{Running ... .exp}" lines. | |
684 | ||
685 | @section How to interpret test results | |
686 | ||
687 | After the testsuite has run you'll find various *.sum and *.log | |
688 | files in the testsuite subdirectories. The *.log files contain a | |
689 | detailed log of the compiler invocations and the corresponding | |
690 | results, the *.sum files summarize the results. These summaries list | |
691 | all the tests that have been run with a corresponding status code: | |
692 | ||
693 | @itemize @bullet | |
694 | @item | |
695 | PASS: the test passed as expected | |
696 | @item | |
697 | XPASS: the test unexpectedly passed | |
698 | @item | |
699 | FAIL: the test unexpectedly failed | |
700 | @item | |
701 | XFAIL: the test failed as expected | |
702 | @item | |
703 | UNSUPPORTED: the test is not supported on this platform | |
704 | @item | |
705 | ERROR: the testsuite detected an error | |
706 | @item | |
707 | WARNING: the testsuite detected a possible problem | |
708 | @end itemize | |
709 | ||
710 | It is normal for some tests to report unexpected failures. At the current time | |
711 | our testing harness does not allow fine grained control over whether or not a | |
712 | test is expected to fail. We expect to fix this problem in future releases. | |
713 | ||
714 | ||
715 | @section Submitting test results | |
716 | ||
717 | If you want to report the results to the GCC project, use the | |
718 | @code{contrib/test_summary} shell script. Start it in the @emph{objdir} with | |
719 | ||
720 | @example | |
721 | @emph{srcdir}/contrib/test_summary -p your_commentary.txt -m gcc-testresults@@gcc.gnu.org |sh | |
722 | @end example | |
723 | ||
724 | This script uses the @code{Mail} program to send the results, so | |
725 | make sure it is in your @env{PATH}. The file @file{your_commentary.txt} is | |
726 | prepended to the testsuite summary and should contain any special | |
727 | remarks you have on your results or your build environment. Please | |
728 | do not edit the testsuite result block or the subject line, as these | |
729 | messages are automatically parsed and presented at the | |
730 | @uref{http://gcc.gnu.org/testresults/,,GCC testresults} web | |
731 | page. Here you can also gather information on how specific tests | |
732 | behave on different platforms and compare them with your results. A | |
733 | few failing testcases are possible even on released versions and you | |
734 | should look here first if you think your results are unreasonable. | |
735 | ||
736 | @end ifset | |
737 | ||
738 | @c ***Final install*********************************************************** | |
739 | @ifinfo | |
740 | @comment node-name, next, previous, up | |
741 | @node Final install, , Testing, Installing GCC | |
742 | @end ifinfo | |
743 | @ifset finalinstallhtml | |
744 | @html | |
745 | <h1 align="center">Installing GCC: Final installation</h1> | |
746 | @end html | |
747 | @ifnothtml | |
748 | @chapter Installing GCC: Final installation | |
749 | @end ifnothtml | |
750 | ||
751 | Now that GCC has been built and tested, you can install it with | |
752 | `@command{cd @emph{objdir}; make install}' for a native compiler or | |
753 | `@command{cd @emph{objdir}; make install LANGUAGES="c c++"}' for | |
754 | a cross compiler (note installing cross compilers will be easier in the | |
755 | next release!). | |
756 | ||
757 | That step completes the installation of GCC; user level binaries can | |
758 | be found in @code{@emph{prefix}/bin} where @code{@emph{prefix}} is the value you specified | |
759 | with the @option{--prefix} to configure (or @file{/usr/local} by default). | |
760 | ||
761 | If you don't mind, please quickly review the | |
762 | @uref{http://gcc.gnu.org/gcc-2.95/buildstat.html,,build status page}. | |
763 | If your system is not listed, send a note to | |
764 | @uref{mailto:gcc@@gcc.gnu.org,,gcc@@gcc.gnu.org} indicating | |
765 | that you successfully built and installed GCC. | |
766 | ||
767 | Include the output from running @code{@emph{srcdir}/config.guess}. (Do not | |
768 | send us the config.guess file itself, just the output from running | |
769 | it!) | |
770 | ||
771 | If you find a bug, please report it following our | |
772 | @uref{../bugs.html,,bug reporting guidelines}. | |
773 | ||
774 | @html | |
775 | <hr> | |
776 | <p> | |
777 | @end html | |
778 | @ifhtml | |
779 | @uref{./index.html,,Return to the GCC Installation page} | |
780 | @end ifhtml | |
781 | @end ifset | |
782 | ||
783 | @c ***Binaries**************************************************************** | |
784 | @ifinfo | |
785 | @comment node-name, next, previous, up | |
786 | @node Binaries, Specific, Installing GCC, Top | |
787 | @end ifinfo | |
788 | @ifset binarieshtml | |
789 | @html | |
790 | <h1 align="center">Installing GCC: Binaries</h1> | |
791 | @end html | |
792 | @ifnothtml | |
793 | @chapter Installing GCC: Binaries | |
794 | @end ifnothtml | |
795 | @cindex Binaries | |
796 | @cindex Installing GCC: Binaries | |
797 | ||
798 | We are often asked about pre-compiled versions of GCC. While we cannot | |
799 | provide these for all platforms, below you'll find links to binaries for | |
800 | various platforms where creating them by yourself is not easy due to various | |
801 | reasons. | |
802 | ||
803 | Please note that we did not create these binaries, nor do we | |
804 | support them. If you have any problems installing them, please | |
805 | contact their makers. | |
806 | ||
807 | @itemize | |
808 | @item | |
df002c7d DE |
809 | AIX: |
810 | @itemize | |
811 | @item | |
812 | @uref{http://www-frec.bull.com/docs/download.htm,,Bull's Freeware and Shareware Archive for AIX}; | |
813 | ||
814 | @item | |
815 | @uref{http://aixpdlib.seas.ucla.edu,,UCLA Software Library for AIX}; | |
816 | @end itemize | |
f42974dc DW |
817 | |
818 | @item | |
819 | DOS - @uref{http://www.delorie.com/djgpp/,,DJGPP}; | |
820 | ||
821 | @item | |
822 | @uref{http://hpux.cae.wisc.edu/,,HP-UX Porting Center}; | |
823 | ||
824 | @item | |
825 | @uref{http://www.sco.com/skunkware/devtools/index.html#gcc,,SCO OpenServer/Unixware}; | |
826 | ||
827 | @item | |
828 | Solaris (SPARC, Intel) - @uref{http://www.sunfreeware.com/,,Sunfreeware}; | |
829 | ||
830 | @item | |
831 | SGI - @uref{http://freeware.sgi.com/,,SGI Freeware}; | |
832 | ||
833 | @item | |
834 | Windows 95, 98, and NT: | |
835 | @itemize | |
836 | @item | |
837 | The @uref{http://sources.redhat.com/cygwin/,,Cygwin} project; | |
838 | @item | |
839 | @uref{http://www.xraylith.wisc.edu/~khan/software/gnu-win32/,,GNU Win32} | |
840 | related projects by Mumit Khan. | |
841 | @end itemize | |
842 | ||
843 | @item | |
844 | @uref{ftp://ftp.thewrittenword.com/packages/free/by-name/gcc-2.95.2/,,The | |
845 | Written Word} offers binaries for Solaris 2.5.1, 2.6, 2.7/SPARC, 2.7/Intel, | |
846 | IRIX 6.2, 6.5, Digital UNIX 4.0D, HP-UX 10.20, and HP-UX 11.00. | |
847 | ||
848 | @item | |
849 | Hitachi H8/300[HS] - | |
850 | @uref{http://h8300-hms.sourceforge.net/,,GNU Development Tools for the | |
851 | Hitachi H8/300[HS] Series} | |
852 | ||
853 | @end itemize | |
854 | ||
855 | In addition to those specific offerings, you can get a binary | |
856 | distribution CD-ROM from the | |
857 | @uref{http://www.fsf.org/order/order.html,,Free Software Foundation}. | |
858 | It contains binaries for a number of platforms, and | |
859 | includes not only GCC, but other stuff as well. The current CD does | |
860 | not contain the latest version of GCC, but it should allow | |
861 | bootstrapping the compiler. An updated version of that disk is in the | |
862 | works. | |
863 | ||
864 | @html | |
865 | <hr> | |
866 | <p> | |
867 | @end html | |
868 | @ifhtml | |
869 | @uref{./index.html,,Return to the GCC Installation page} | |
870 | @end ifhtml | |
871 | @end ifset | |
872 | ||
873 | @c ***Specific**************************************************************** | |
874 | @ifinfo | |
875 | @comment node-name, next, previous, up | |
876 | @node Specific, Concept Index, Binaries, Top | |
877 | @end ifinfo | |
878 | @ifset specifichtml | |
879 | @html | |
880 | <h1 align="center">Host/target specific installation notes for GCC</h1> | |
881 | @end html | |
882 | @ifnothtml | |
883 | @chapter Host/target specific installation notes for GCC | |
884 | @end ifnothtml | |
885 | @cindex Specific | |
886 | @cindex Specific installation notes | |
887 | @cindex Target specific installation | |
888 | @cindex Host specific installation | |
889 | @cindex Target specific installation notes | |
890 | ||
891 | Please read this document carefully @emph{before} installing the | |
892 | GNU Compiler Collection on your machine. | |
893 | ||
894 | @itemize | |
895 | @item | |
896 | @uref{#alpha*-dec-linux*,,alpha*-dec-linux*} | |
897 | @item | |
898 | @uref{#alpha*-dec-osf*,,alpha*-dec-osf*} | |
899 | @item | |
900 | @uref{#avr,,avr} | |
901 | @item | |
902 | @uref{#dos,,DOS} | |
903 | @item | |
904 | @uref{#h8300-hms,,h8300-hms} | |
905 | @item | |
906 | @uref{#hppa*-hp-hpux*,,hppa*-hp-hpux*} | |
907 | @item | |
908 | @uref{#hppa*-hp-hpux9,,hppa*-hp-hpux9} | |
909 | @item | |
910 | @uref{#hppa*-hp-hpux10,,hppa*-hp-hpux10} | |
911 | @item | |
912 | @uref{#hppa*-hp-hpux11,,hppa*-hp-hpux11} | |
913 | @item | |
914 | @uref{#*-*-linux-gnu,,*-*-linux-gnu} | |
915 | @item | |
916 | @uref{#ix86-*-linux*,,i?86-*-linux*} | |
917 | @item | |
918 | @uref{#ix86-*-sco3.2v5*,,i?86-*-sco3.2v5*} | |
919 | @item | |
920 | @uref{#ix86-*-solaris*,,i?86-*-solaris*} | |
921 | @item | |
922 | @uref{#ix86-*-udk,,i?86-*-udk} | |
923 | @item | |
924 | @uref{#*-ibm-aix*,,*-ibm-aix*} | |
925 | @item | |
926 | @uref{#m68k-*-nextstep*,,m68k-*-nextstep*} | |
927 | @item | |
928 | @uref{#m68k-sun-sunos4.1.1,,m68k-sun-sunos4.1.1} | |
929 | @item | |
930 | @uref{#mips*-sgi-irix[45],,mips*-sgi-irix[45]} | |
931 | @item | |
932 | @uref{#mips*-sgi-irix6,,mips*-sgi-irix6} | |
933 | @item | |
934 | @uref{#powerpc-*-linux-gnu*,,powerpc-*-linux-gnu*} | |
935 | @item | |
936 | @uref{#*-*-solaris*,,*-*-solaris*} | |
937 | @item | |
938 | @uref{#sparc-sun-solaris*,,sparc-sun-solaris*} | |
939 | @item | |
940 | @uref{#sparc-sun-solaris2.7,,sparc-sun-solaris2.7} | |
941 | @item | |
942 | @uref{#*-sun-solaris2.8,,*-sun-solaris2.8} | |
943 | @item | |
944 | @uref{#sunv5,,Sun V5.0 Compiler Bugs} | |
945 | @item | |
946 | @uref{#sparc-sun-sunos*,,sparc-sun-sunos*} | |
947 | @item | |
948 | @uref{#sparc-unknown-linux-gnulibc1,,sparc-unknown-linux-gnulibc1} | |
949 | @item | |
950 | @uref{#sparc64-*-*,,sparc64-*-*} | |
951 | @item | |
952 | @uref{#windows,,Microsoft Windows} | |
953 | @item | |
954 | @uref{#os2,,OS/2} | |
955 | @item | |
956 | @uref{#older,,Older systems} | |
957 | @end itemize | |
958 | ||
959 | @itemize | |
960 | @item | |
961 | @uref{#elf_targets,,all ELF targets} (SVR4, Solaris, etc.) | |
962 | @end itemize | |
963 | ||
964 | ||
965 | @html | |
966 | <!-- -------- host/target specific issues start here ---------------- --> | |
967 | <hr> | |
968 | <h3><a name="alpha*-dec-linux*">alpha*-dec-linux*</a></h3> | |
969 | @end html | |
970 | ||
e427d51a RH |
971 | We require binutils 2.10 or newer. Upgrading to binutils 2.11 |
972 | or newer is strongly recommended, as it will result in more | |
973 | compact debugging and exception handling information. | |
f42974dc DW |
974 | |
975 | @html | |
976 | </p> | |
977 | <hr> | |
978 | <h3><a name="alpha*-dec-osf*">alpha*-dec-osf*</a></h3> | |
979 | @end html | |
980 | ||
981 | If you install a shared libstdc++ and, when you link a non-trivial C++ | |
982 | program (for example, @code{gcc/testsuite/g++.other/delete3.C}), | |
983 | the linker reports a couple of errors about multiply-defined symbols | |
984 | (for example, @code{nothrow}, @code{__throw} and | |
985 | @code{terminate(void)}), you've probably got a linker bug, for | |
986 | which there's no known fix. The officially recommended work-around is | |
987 | to remove the shared libstdc++. | |
988 | ||
989 | An alternative solution is to arrange that all symbols from | |
990 | @code{libgcc} get copied to the shared @code{libstdc++}; | |
991 | see detailed solution below. (Surprising as it may seem, this does | |
992 | indeed fix the problem!) @emph{Beware} that this may bring you | |
993 | binary-compatibility problems in the future, if you don't use the same | |
994 | work-around next time you build @code{libstdc++}: if programs | |
995 | start to depend on @code{libstdc++} to provide symbols that used | |
996 | to be only in @code{libgcc}, you must arrange that | |
997 | @code{libstdc++} keeps providing them, otherwise the programs | |
998 | will have to be relinked. | |
999 | ||
1000 | The magic spell is to add @code{-Wl,-all,-lgcc,-none} to the | |
1001 | definition of macro @code{SHDEPS} in | |
1002 | @code{libstdc++/config/dec-osf.ml} @emph{before} | |
1003 | @code{alpha*-dec-osf*/libstdc++/Makefile} is created (a | |
1004 | @uref{dec-osf-shlibstdc++.patch,,patch} | |
1005 | that does just that is available). If the Makefile already exists, run | |
1006 | @code{./config.status} within directory | |
1007 | @code{alpha*-dec-osf*/libstdc++} (and | |
1008 | @code{alpha*-dec-osf*/ieee/libstdc++}, if it also exists). | |
1009 | Remove any existing @code{libstdc++.so*} from such directories, | |
1010 | and run @code{make all-target-libstdc++} in the top-level | |
1011 | directory, then @code{make install-target-libstdc++}. | |
1012 | ||
1013 | If you have already removed the build tree, you may just remove | |
1014 | @code{libstdc++.so.2.10.0} from the install tree and re-create | |
1015 | it with the command | |
1016 | @code{gcc -shared -o libstdc++.so.2.10.0 -Wl,-all,-lstdc++,-lgcc,-none -lm}. | |
1017 | If the @code{ieee} | |
1018 | sub-directory exists, repeat this command in it, with the additional | |
1019 | flag @code{-mieee}. | |
1020 | ||
1021 | @html | |
1022 | </p> | |
1023 | <hr> | |
1024 | <h3><a name="avr">avr</a></h3> | |
1025 | @end html | |
1026 | ||
1027 | Use `@command{configure} @option{--target=avr} | |
1028 | @option{--enable-languages="c"}' to configure GCC. | |
1029 | ||
1030 | Further installation notes and other useful information about AVR tools | |
1031 | can also be obtained from: | |
1032 | ||
1033 | @itemize @bullet | |
1034 | @item | |
1035 | @uref{http://home.overta.ru/users/denisc,,http://home.overta.ru/users/denisc} | |
1036 | @item | |
1037 | @uref{http://www.itnet.pl/amelektr/avr,,http://www.itnet.pl/amelektr/avr} | |
1038 | @end itemize | |
1039 | ||
1040 | We strongly recommend to upgrade to binutils 2.11 | |
1041 | (or a current snapshot until 2.11 has been released). | |
1042 | ||
1043 | The following error: | |
1044 | @example | |
1045 | Error: register required | |
1046 | @end example | |
1047 | ||
1048 | indicates that you should upgrade to a newer version of the binutils. | |
1049 | ||
1050 | @html | |
1051 | </p> | |
1052 | <hr> | |
1053 | <h3><a name="dos">DOS</a></h3> | |
1054 | @end html | |
1055 | ||
1056 | Please have a look at our @uref{binaries.html,,binaries page}. | |
1057 | ||
1058 | @html | |
1059 | </p> | |
1060 | <hr> | |
1061 | <h3><a name="h8300-hms">h8300-hms</a></h3> | |
1062 | @end html | |
1063 | ||
1064 | Please have a look at our @uref{binaries.html,,binaries page}. | |
1065 | ||
1066 | @html | |
1067 | </p> | |
1068 | <hr> | |
1069 | <h3><a name="hppa*-hp-hpux*">hppa*-hp-hpux*</a></h3> | |
1070 | @end html | |
1071 | ||
1072 | We @emph{highly} recommend using gas/binutils-2.8 or newer on all hppa | |
1073 | platforms; you may encounter a variety of problems when using the HP | |
1074 | assembler. | |
1075 | ||
1076 | Specifically, @option{-g} does not work on HP-UX (since that system | |
1077 | uses a peculiar debugging format which GCC does not know about), unless you | |
1078 | use GAS and GDB and configure GCC with the @option{--with-gnu-as} | |
1079 | option. | |
1080 | ||
1081 | If you wish to use pa-risc 2.0 architecture support, you must use either | |
1082 | the HP assembler or a recent | |
1083 | @uref{ftp://sources.redhat.com/pub/binutils/snapshots,,snapshot of gas}. | |
1084 | ||
1085 | More specific information to hppa*-hp-hpux* targets follows. | |
1086 | ||
1087 | @html | |
1088 | </p> | |
1089 | <hr> | |
1090 | <h3><a name="hppa*-hp-hpux9">hppa*-hp-hpux9</a></h3> | |
1091 | @end html | |
1092 | ||
1093 | The HP assembler has major problems on this platform. We've tried to work | |
1094 | around the worst of the problems. However, those workarounds may be causing | |
1095 | linker crashes in some circumstances; the workarounds also probably prevent | |
1096 | shared libraries from working. Use the GNU assembler to avoid these problems. | |
1097 | ||
1098 | ||
1099 | The configuration scripts for GCC will also trigger a bug in the hpux9 | |
1100 | shell. To avoid this problem set CONFIG_SHELL to @file{/bin/ksh} and SHELL | |
1101 | to @file{/bin/ksh} in your environment. | |
1102 | ||
1103 | ||
1104 | @html | |
1105 | </p> | |
1106 | <hr> | |
1107 | <h3><a name="hppa*-hp-hpux10">hppa*-hp-hpux10</a></h3> | |
1108 | @end html | |
1109 | ||
1110 | For hpux10.20, we @emph{highly} recommend you pick up the latest sed patch | |
1111 | @code{PHCO_19798} from HP. HP has two sites which provide patches free of | |
1112 | charge: | |
1113 | ||
1114 | @itemize @bullet | |
1115 | @item | |
1116 | @html | |
1117 | <a href="http://us-support.external.hp.com">US, Canada, Asia-Pacific, and | |
1118 | Latin-America</a> | |
1119 | @end html | |
1120 | @ifnothtml | |
1121 | @uref{http://us-support.external.hp.com,,}US, Canada, Asia-Pacific, and | |
1122 | Latin-America | |
1123 | @end ifnothtml | |
1124 | @item | |
1125 | @uref{http://europe-support.external.hp.com,,Europe} | |
1126 | @end itemize | |
1127 | ||
1128 | The HP assembler on these systems is much better than the hpux9 assembler, | |
1129 | but still has some problems. Most notably the assembler inserts timestamps | |
1130 | into each object file it creates, causing the 3-stage comparison test to fail | |
1131 | during a `@code{make bootstrap}'. You should be able to continue by | |
1132 | saying `@code{make all}' after getting the failure from `@code{make | |
1133 | bootstrap}'. | |
1134 | ||
1135 | ||
1136 | @html | |
1137 | </p> | |
1138 | <hr> | |
1139 | <h3><a name="hppa*-hp-hpux11">hppa*-hp-hpux11</a></h3> | |
1140 | @end html | |
1141 | ||
1142 | GCC 2.95.2 does not support HP-UX 11, and it cannot generate 64-bit | |
1143 | object files. Current (as of late 2000) snapshots and GCC 3.0 do support | |
1144 | HP-UX 11. | |
1145 | ||
1146 | ||
1147 | @html | |
1148 | </p> | |
1149 | <hr> | |
1150 | <h3><a name="*-*-linux-gnu">*-*-linux-gnu</a></h3> | |
1151 | @end html | |
1152 | ||
1153 | If you use glibc 2.2 (or 2.1.9x), GCC 2.95.2 won't install | |
1154 | out-of-the-box. You'll get compile errors while building libstdc++. | |
1155 | The patch @uref{glibc-2.2.patch,,glibc-2.2.patch}, that is to be | |
1156 | applied in the GCC source tree, fixes the compatibility problems. | |
1157 | ||
1158 | @html | |
1159 | </p> | |
1160 | <hr> | |
1161 | <h3><a name="ix86-*-linux*">i?86-*-linux*</a></h3> | |
1162 | @end html | |
1163 | ||
1164 | You will need binutils-2.9.1.0.15 or newer for exception handling to work. | |
1165 | ||
1166 | If you receive Signal 11 errors when building on GNU/Linux, then it is | |
1167 | possible you have a hardware problem. Further information on this can be | |
1168 | found on @uref{http://www.bitwizard.nl/sig11/,,www.bitwizard.nl}. | |
1169 | ||
1170 | @html | |
1171 | </p> | |
1172 | <hr> | |
1173 | <h3><a name="ix86-*-sco3.2v5*">i?86-*-sco3.2v5*</a></h3> | |
1174 | @end html | |
1175 | ||
1176 | Unlike earlier versions of GCC, the ability to generate COFF with this | |
1177 | target is no longer provided. | |
1178 | ||
1179 | Earlier versions of GCC emitted Dwarf-1 when generating ELF to allow | |
1180 | the system debugger to be used. That support was too burdensome to | |
1181 | maintain. GCC now emits only dwarf-2 for this target. This means you | |
1182 | may use either the UDK debugger or GDB to debug programs built by this | |
1183 | version of GCC. | |
1184 | ||
1185 | If you are building languages other than C, you must follow the instructions | |
1186 | about invoking `@code{make bootstrap}' because the native OpenServer | |
1187 | compiler will build a @code{cc1plus} that will not correctly parse many | |
1188 | valid C++ programs including those in @code{libgcc.a}. | |
1189 | @strong{You must do a `@code{make bootstrap}' if you are building with the | |
1190 | native compiler.} | |
1191 | ||
1192 | Use of the `@option{-march-pentiumpro}' flag can result in | |
1193 | unrecognized opcodes when using the native assembler on OS versions before | |
1194 | 5.0.6. (Support for P6 opcodes was added to the native ELF assembler in | |
1195 | that version.) While it's rather rare to see these emitted by GCC yet, | |
1196 | errors of the basic form: | |
1197 | ||
1198 | @example | |
1199 | /usr/tmp/ccaNlqBc.s:22:unknown instruction: fcomip | |
1200 | /usr/tmp/ccaNlqBc.s:50:unknown instruction: fucomip | |
1201 | @end example | |
1202 | ||
1203 | are symptoms of this problem. You may work around this by not | |
1204 | building affected files with that flag, by using the GNU assembler, or | |
1205 | by using the assembler provided with the current version of the OS. | |
1206 | Users of GNU assembler should see the note below for hazards on doing | |
1207 | so. | |
1208 | ||
1209 | The native SCO assembler that is provided with the OS at no | |
1210 | charge is normally required. If, however, you must be able to use | |
1211 | the GNU assembler (perhaps you're compiling code with asms that | |
1212 | require GAS syntax) you may configure this package using the flags | |
1213 | @option{--with-gnu-as}. You must use a recent version of GNU | |
1214 | binutils; versions past 2.9.1 seem to work well. | |
1215 | ||
1216 | In general, the @option{--with-gnu-as} option isn't as well tested | |
1217 | as the native assembler. | |
1218 | ||
1219 | Look in @file{gcc/config/i386/sco5.h} (search for "messy") for | |
1220 | additional OpenServer-specific flags. | |
1221 | ||
1222 | Systems based on OpenServer before 5.0.4 (`@code{uname -X}' | |
1223 | will tell you what you're running) require TLS597 from ftp.sco.com/TLS | |
1224 | for C++ constructors and destructors to work right. | |
1225 | ||
1226 | The system linker in (at least) 5.0.4 and 5.0.5 will sometimes | |
1227 | do the wrong thing for a construct that GCC will emit for PIC | |
1228 | code. This can be seen as execution testsuite failures when using | |
1229 | -fPIC on 921215-1.c, 931002-1.c, nestfunc-1.c, and gcov-1.c. | |
1230 | For 5.0.5, an updated linker that will cure this problem is | |
1231 | available. You must install both | |
1232 | @uref{ftp://ftp.sco.com/Supplements/rs505a/,,ftp://ftp.sco.com/Supplements/rs505a/} | |
1233 | and @uref{ftp://ftp.sco.com/SLS/,,OSS499A}. | |
1234 | ||
1235 | The dynamic linker in OpenServer 5.0.5 (earlier versions may show | |
1236 | the same problem) aborts on certain g77-compiled programs. It's particularly | |
1237 | likely to be triggered by building Fortran code with the @option{-fPIC} flag. | |
1238 | Although it's conceivable that the error could be triggered by other | |
1239 | code, only G77-compiled code has been observed to cause this abort. | |
1240 | If you are getting core dumps immediately upon execution of your | |
1241 | g77 program - and especially if it's compiled with -fPIC - try applying | |
1242 | @uref{sco_osr5_g77.patch,,@code{`sco_osr5_g77.patch'}} to your libf2c and | |
1243 | rebuilding GCC. | |
1244 | Affected faults, when analyzed in a debugger, will show a stack | |
1245 | backtrace with a fault occurring in @code{rtld()} and the program | |
1246 | running as @code{/usr/lib/ld.so.1}. This problem has been reported to SCO | |
1247 | engineering and will hopefully be addressed in later releases. | |
1248 | ||
1249 | ||
1250 | @html | |
1251 | </p> | |
1252 | <hr> | |
1253 | <h3><a name="ix86-*-solaris*">i?86-*-solaris*</a></h3> | |
1254 | @end html | |
1255 | ||
1256 | GCC 2.95.2, when configured to use the GNU assembler, would invoke | |
1257 | it with the @code{-s} switch, that GNU as up to 2.9.5.0.12 does | |
1258 | not support. If you'd rather not use a newer GNU as nor the native | |
1259 | assembler, you'll need the patch | |
1260 | @uref{x86-sol2-gas.patch,,@code{`x86-sol2-gas.patch'}}. | |
1261 | ||
1262 | ||
1263 | @html | |
1264 | </p> | |
1265 | <hr> | |
1266 | <h3><a name="ix86-*-udk">i?86-*-udk</a></h3> | |
1267 | @end html | |
1268 | ||
1269 | This target emulates the SCO Universal Development Kit and requires that | |
1270 | package be installed. (If it is installed, you will have a | |
1271 | @file{/udk/usr/ccs/bin/cc } file present.) It's very much like the | |
1272 | @code{i?86-*-unixware7*} target | |
1273 | but is meant to be used when hosting on a system where UDK isn't the | |
1274 | default compiler such as OpenServer 5 or Unixware 2. This target will | |
1275 | generate binaries that will run on OpenServer, Unixware 2, or Unixware 7, | |
1276 | with the same warnings and caveats as the SCO UDK. | |
1277 | ||
1278 | You can stage1 with either your native compiler or with UDK. If you | |
1279 | don't do a full bootstrap when initially building with your native compiler | |
1280 | you will have an utterly unusable pile of bits as your reward. | |
1281 | ||
1282 | This target is a little tricky to build because we have to distinguish | |
1283 | it from the native tools (so it gets headers, startups, and libraries | |
1284 | from the right place) while making the tools not think we're actually | |
1285 | building a cross compiler. The easiest way to do this is with a configure | |
1286 | command like this: | |
1287 | ||
1288 | @command{ CC=/udk/usr/ccs/bin/cc <i>/your/path/to/</i>gcc/configure | |
1289 | --host=i686-pc-udk --target=i686-pc-udk --program-prefix=udk-} | |
1290 | ||
1291 | @emph{You should substitute 'i686' in the above command with the appropriate | |
1292 | processor for your host.} | |
1293 | ||
1294 | You should follow this with a `@command{make bootstrap}' then | |
1295 | `@command{make install}'. You can then access the UDK-targeted GCC | |
1296 | tools by adding @code{udk-} before the commonly known name. For example, to | |
1297 | invoke the C compiler, you would use `@code{udk-gcc}'. They will coexist | |
1298 | peacefully with any native-target GCC tools you may have installed. | |
1299 | ||
1300 | ||
1301 | @html | |
1302 | </p> | |
1303 | <hr> | |
1304 | <h3><a name="*-ibm-aix*">*-ibm-aix*</a></h3> | |
1305 | <!-- rs6000-ibm-aix*, powerpc-ibm-aix* --> | |
1306 | @end html | |
1307 | ||
1308 | AIX Make frequently has problems with GCC makefiles. GNU Make 3.76 or | |
1309 | newer is recommended to build on this platform. | |
1310 | ||
1311 | Errors involving "alloca" when building GCC generally are due | |
1312 | to an incorrect definition of @command{CC} in the Makefile or mixing files | |
1313 | compiled with the native C compiler and GCC. During the stage1 phase of | |
1314 | the build, the native AIX compiler @strong{must} be invoked as "cc" | |
1315 | (not "xlc"). Once @command{configure} has been informed of | |
1316 | "xlc", one needs to use "make distclean" to remove the | |
df002c7d | 1317 | configure cache files and ensure that @command{CC} environment variable |
f42974dc DW |
1318 | does not provide a definition that will confuse @command{configure}. |
1319 | If this error occurs during stage2 or later, then the problem most likely | |
1320 | is the version of Make (see above). | |
1321 | ||
df002c7d DE |
1322 | Binutils 2.10 does not support AIX 4.3. Binutils available from the |
1323 | @uref{http://www-1.ibm.com/servers/aix/products/aixos/linux/,,AIX Toolbox for Linux: GNU and Open Source tools for AIX}; | |
1324 | website does work. Binutils 2.11 is expected to include AIX 4.3 | |
1325 | support. The GNU Assembler is necessary for libstdc++ to build. The | |
1326 | AIX native ld still is recommended. The native AIX tools do | |
1327 | interoperate with GCC. | |
1328 | ||
1329 | Linking executables and shared libraries may produce warnings of | |
1330 | duplicate symbols. The assembly files generated by GCC for AIX always | |
1331 | have included multiple symbol definitions for certain global variable | |
1332 | and function declarations in the original program. The warnings should | |
1333 | not prevent the linker from producing a correct library or runnable | |
1334 | executable. | |
1335 | ||
1336 | AIX 4.3 utilizes a "large format" archive to support both 32-bit and | |
1337 | 64-bit object modules. The routines provided in AIX 4.3.0 and AIX 4.3.1 | |
1338 | to parse archive libraries did not handle the new format correctly. | |
1339 | These routines are used by GCC and result in error messages during | |
1340 | linking such as "not a COFF file". The version of the routines shipped | |
1341 | with AIX 4.3.1 should work for a 32-bit environment. The @option{-g} | |
1342 | option of the archive command may be used to create archives of 32-bit | |
1343 | objects using the original "small format". A correct version of the | |
1344 | routines is shipped with AIX 4.3.2. | |
1345 | ||
f42974dc DW |
1346 | Some versions of the AIX binder (linker) can fail with a relocation |
1347 | overflow severe error when the @option{-bbigtoc} option is used to link | |
1348 | GCC-produced object files into an executable that overflows the TOC. A fix | |
1349 | for APAR IX75823 (OVERFLOW DURING LINK WHEN USING GCC AND -BBIGTOC) is | |
1350 | available from IBM Customer Support and from its | |
1351 | @uref{http://service.boulder.ibm.com/,,service.boulder.ibm.com} | |
1352 | website as PTF U455193. | |
1353 | ||
df002c7d DE |
1354 | The AIX 4.3.2.1 linker (bos.rte.bind_cmds Level 4.3.2.1) will dump core |
1355 | with a segmentation fault when invoked by any version of GCC. A fix for | |
1356 | APAR IX87327 is available from IBM Customer Support and from its | |
1357 | @uref{http://service.boulder.ibm.com/,,service.boulder.ibm.com} | |
1358 | website as PTF U461879. This fix is incorporated in AIX 4.3.3 and above. | |
f42974dc DW |
1359 | |
1360 | The initial assembler shipped with AIX 4.3.0 generates incorrect object | |
1361 | files. A fix for APAR IX74254 (64BIT DISASSEMBLED OUTPUT FROM COMPILER FAILS | |
1362 | TO ASSEMBLE/BIND) is available from IBM Customer Support and from its | |
1363 | @uref{http://service.boulder.ibm.com/,,service.boulder.ibm.com} | |
1364 | website as PTF U453956. This fix is incorporated in AIX 4.3.1 and above. | |
1365 | ||
df002c7d DE |
1366 | AIX provides National Language Support (NLS). Compilers and assemblers |
1367 | use NLS to support locale-specific representations of various data | |
1368 | formats including floating-point numbers (e.g., "." vs "," for | |
1369 | separating decimal fractions). There have been problems reported where | |
1370 | GCC does not produce the same floating-point formats that the assembler | |
1371 | expects. If one encouters this problem, set the @command{LANG} | |
1372 | environment variable to "C" or "En_US". | |
f42974dc DW |
1373 | |
1374 | ||
1375 | @html | |
1376 | </p> | |
1377 | <hr> | |
1378 | <h3><a name="m68k-*-nextstep*">m68k-*-nextstep*</a></h3> | |
1379 | @end html | |
1380 | ||
1381 | You absolutely @strong{must} use GNU sed and GNU make on this platform. | |
1382 | ||
1383 | ||
1384 | On NEXTSTEP 3.x where x < 3 the build of GCC will abort during | |
1385 | stage1 with an error message like this: | |
1386 | ||
1387 | @example | |
1388 | _eh | |
1389 | /usr/tmp/ccbbsZ0U.s:987:Unknown pseudo-op: .section | |
1390 | /usr/tmp/ccbbsZ0U.s:987:Rest of line ignored. 1st junk character | |
1391 | valued 95 (_). | |
1392 | @end example | |
1393 | ||
1394 | The reason for this is the fact that NeXT's assembler for these | |
1395 | versions of the operating system does not support the .section | |
1396 | pseudo op that's needed for full C++ exception functionality. | |
1397 | ||
1398 | As NeXT's assembler is a derived work from GNU as, a free | |
1399 | replacement that does can be obtained at | |
1400 | @uref{ftp://ftp.next.peak.org:/next-ftp/next/apps/devtools/as.3.3.NIHS.s.tar.gz,,ftp://ftp.next.peak.org:/next-ftp/next/apps/devtools/as.3.3.NIHS.s.tar.gz}. | |
1401 | ||
1402 | If you try to build the integrated C++ & C++ runtime libraries on this system | |
1403 | you will run into trouble with include files. The way to get around this is | |
1404 | to use the following sequence. Note you must have write permission to | |
1405 | the directory @emph{prefix} you specified in the configuration process of GCC | |
1406 | for this sequence to work. | |
1407 | ||
1408 | @example | |
1409 | cd bld-gcc | |
1410 | make all-texinfo all-bison all-byacc all-binutils all-gas all-ld | |
1411 | cd gcc | |
1412 | make bootstrap | |
1413 | make install-headers-tar | |
1414 | cd .. | |
1415 | make bootstrap3 | |
1416 | @end example | |
1417 | ||
1418 | ||
1419 | @html | |
1420 | </p> | |
1421 | <hr> | |
1422 | <h3><a name="m68k-sun-sunos4.1.1">m68k-sun-sunos4.1.1</a></h3> | |
1423 | @end html | |
1424 | ||
1425 | It is reported that you may need the GNU assembler on this platform. | |
1426 | ||
1427 | ||
1428 | @html | |
1429 | </p> | |
1430 | <hr> | |
1431 | <h3><a name="mips*-sgi-irix[45]">mips*-sgi-irix[45]</a></h3> | |
1432 | @end html | |
1433 | ||
1434 | You must use GAS on these platforms, as the native assembler can not handle | |
1435 | the code for exception handling support. Either of these messages indicates | |
1436 | that you are using the MIPS assembler when instead you should be using GAS: | |
1437 | ||
1438 | @samp{ as0: Error: ./libgcc2.c, line 1:Badly delimited numeric literal | |
1439 | .4byte $LECIE1-$LSCIE1 | |
1440 | as0: Error: ./libgcc2.c, line 1:malformed statement} | |
1441 | ||
1442 | or: | |
1443 | ||
1444 | @samp{ as0: Error: /src/bld-gcc/gcc/libgcc2.c, line 1:undefined symbol in expression | |
1445 | .word $LECIE1-$LSCIE1} | |
1446 | ||
1447 | These systems don't have ranlib, which various components in GCC need; you | |
1448 | should be able to avoid this problem by installing GNU binutils, which includes | |
1449 | a functional ranlib for this system. | |
1450 | ||
1451 | You may get the following warning on irix4 platforms, it can be safely | |
1452 | ignored. | |
1453 | @example | |
1454 | warning: foo.o does not have gp tables for all its sections. | |
1455 | @end example | |
1456 | ||
1457 | When building GCC, the build process loops rebuilding cc1 over and | |
1458 | over again. This happens on mips-sgi-irix5.2, and possibly other platforms.@* | |
1459 | It has been reported that this is a known bug in the make shipped with | |
1460 | IRIX 5.2. We recommend you use GNU make instead of the vendor supplied | |
1461 | make program; however, you may have success with "smake" on IRIX 5.2 if | |
1462 | you do not have GNU make available. | |
1463 | ||
1464 | See @uref{http://reality.sgi.com/ariel/freeware/,,http://reality.sgi.com/ariel/freeware} for more information about | |
1465 | using GCC on IRIX platforms. | |
1466 | ||
1467 | ||
1468 | @html | |
1469 | </p> | |
1470 | <hr> | |
1471 | <h3><a name="mips*-sgi-irix6">mips*-sgi-irix6</a></h3> | |
1472 | @end html | |
1473 | ||
1474 | You must @emph{not} use GAS on irix6 platforms; doing so will only | |
1475 | cause problems. | |
1476 | ||
1477 | These systems don't have ranlib, which various components in GCC need; you | |
1478 | should be able to avoid this problem by making a dummy script called ranlib | |
1479 | which just exits with zero status and placing it in your path. | |
1480 | ||
1481 | If you are using Irix cc as your bootstrap compiler, you must | |
1482 | ensure that the N32 ABI is in use. To test this, compile a simple C | |
1483 | file with @command{cc} and then run @command{file} on the | |
1484 | resulting object file. The output should look like: | |
1485 | ||
1486 | @example | |
1487 | @code{ test.o: ELF N32 MSB ...} | |
1488 | @end example | |
1489 | ||
1490 | If you see: | |
1491 | @example | |
1492 | @code{ test.o: ELF 32-bit MSB} | |
1493 | @end example | |
1494 | ||
1495 | then your version of @command{cc} uses the O32 ABI default. You | |
1496 | should set the environment variable @command{CC} to 'cc -n32' | |
1497 | before configuring GCC. | |
1498 | ||
1499 | GCC does not currently support generating O32 ABI binaries in the | |
1500 | mips-sgi-irix6 configurations. It used to be possible to create a GCC | |
1501 | with O32 ABI only support by configuring it for the mips-sgi-irix5 | |
1502 | target. See the link below for details. | |
1503 | ||
1504 | GCC does not correctly pass/return structures which are | |
1505 | smaller than 16 bytes and which are not 8 bytes. The problem is very | |
1506 | involved and difficult to fix. It affects a number of other targets also, | |
1507 | but IRIX 6 is affected the most, because it is a 64 bit target, and 4 byte | |
1508 | structures are common. The exact problem is that structures are being padded | |
1509 | at the wrong end, e.g. a 4 byte structure is loaded into the lower 4 bytes | |
1510 | of the register when it should be loaded into the upper 4 bytes of the | |
1511 | register. | |
1512 | ||
1513 | GCC is consistent with itself, but not consistent with the SGI C compiler | |
1514 | (and the SGI supplied runtime libraries), so the only failures that can | |
1515 | happen are when there are library functions that take/return such | |
1516 | structures. There are very few such library functions. I can only recall | |
1517 | seeing two of them: inet_ntoa, and semctl. | |
1518 | ||
1519 | See @uref{http://reality.sgi.com/ariel/freeware/,,http://reality.sgi.com/ariel/freeware} for more information about | |
1520 | using GCC on IRIX platforms. | |
1521 | ||
1522 | ||
1523 | @html | |
1524 | </p> | |
1525 | <hr> | |
1526 | <h3><a name="powerpc-*-linux-gnu*">powerpc-*-linux-gnu*</a></h3> | |
1527 | @end html | |
1528 | ||
1529 | You will need | |
1530 | @uref{ftp://ftp.varesearch.com/pub/support/hjl/binutils,,binutils-2.9.4.0.8} | |
1531 | or newer for a working GCC. It is strongly recommended to recompile binutils | |
1532 | if you initially built it with gcc-2.7.2.x. | |
1533 | ||
1534 | ||
1535 | @html | |
1536 | </p> | |
1537 | <hr> | |
1538 | <h3><a name="*-*-solaris*">*-*-solaris*</a></h3> | |
1539 | @end html | |
1540 | ||
1541 | Starting with Solaris, Sun does not ship a C compiler any more. To | |
1542 | bootstrap and install GCC you first have to install a pre-built | |
1543 | compiler, see our @uref{binaries.html,,binaries page} for | |
1544 | details. | |
1545 | ||
e6855a2d MM |
1546 | You must use GNU Make to build GCC on Solaris 2. If you don't have GNU |
1547 | Make installed, you can use the prebuilt compiler mentioned above to | |
1548 | build it. | |
1549 | ||
f42974dc DW |
1550 | Sun as 4.X is broken in that it cannot cope with long symbol names. |
1551 | A typical error message might look similar to the following: | |
1552 | ||
1553 | @samp{/usr/ccs/bin/as: "/var/tmp/ccMsw135.s", line 11041: | |
1554 | error: can't compute value of an expression involving an external symbol.} | |
1555 | ||
e6855a2d MM |
1556 | This is Sun bug 4237974. This is fixed with patch 108908-02 and has |
1557 | been fixed in later (5.x) versions of the assembler. | |
f42974dc DW |
1558 | @html |
1559 | <p> | |
1560 | <hr> | |
1561 | <h3><a name="sparc-sun-solaris*">sparc-sun-solaris*</a></h3> | |
1562 | @end html | |
1563 | ||
1564 | binutils 2.9.1 has known bugs on this platform. We recommend to use | |
1565 | binutils 2.10 or the vendor tools (Sun as, Sun ld). | |
1566 | ||
1567 | Unfortunately, C++ shared libraries, including libstdc++, won't work | |
1568 | properly if assembled with Sun as: the linker will complain about | |
1569 | relocations in read-only sections, in the definition of virtual | |
1570 | tables. Also, Sun as fails to process long symbols resulting from | |
1571 | mangling template-heavy C++ function names. | |
1572 | ||
1573 | ||
1574 | @html | |
1575 | </p> | |
1576 | <hr> | |
1577 | <h3><a name="sparc-sun-solaris2.7">sparc-sun-solaris2.7</a></h3> | |
1578 | @end html | |
1579 | ||
1580 | Sun patch 107058-01 (1999-01-13) for SPARC Solaris 7 triggers a bug in | |
1581 | the dynamic linker. This problem (Sun bug 4210064) affects GCC 2.8 | |
1582 | and later, including all EGCS releases. Sun formerly recommended | |
1583 | 107058-01 for all Solaris 7 users, but around 1999-09-01 it started to | |
1584 | recommend it only for people who use Sun's compilers. | |
1585 | ||
1586 | Here are some workarounds to this problem: | |
1587 | @itemize @bullet | |
1588 | @item | |
1589 | Do not install Sun patch 107058-01 until after Sun releases a | |
1590 | complete patch for bug 4210064. This is the simplest course to take, | |
1591 | unless you must also use Sun's C compiler. Unfortunately 107058-01 | |
1592 | is preinstalled on some new Solaris-based hosts, so you may have to | |
1593 | back it out. | |
1594 | ||
1595 | @item | |
1596 | Copy the original, unpatched Solaris 7 | |
1597 | @command{/usr/ccs/bin/as} into | |
1598 | @command{/usr/local/lib/gcc-lib/sparc-sun-solaris2.7/2.95.1/as}, | |
1599 | adjusting the latter name to fit your local conventions and software | |
1600 | version numbers. | |
1601 | ||
1602 | @item | |
1603 | Install Sun patch 106950-03 (1999-05-25) or later. Nobody with | |
1604 | both 107058-01 and 106950-03 installed has reported the bug with GCC | |
1605 | and Sun's dynamic linker. This last course of action is riskiest, | |
1606 | for two reasons. First, you must install 106950 on all hosts that | |
1607 | run code generated by GCC; it doesn't suffice to install it only on | |
1608 | the hosts that run GCC itself. Second, Sun says that 106950-03 is | |
1609 | only a partial fix for bug 4210064, but Sun doesn't know whether the | |
1610 | partial fix is adequate for GCC. Revision -08 or later should fix | |
1611 | the bug, but (as of 1999-10-06) it is still being tested. | |
1612 | @end itemize | |
1613 | ||
1614 | ||
1615 | @html | |
1616 | <p> | |
1617 | <hr> | |
1618 | <h3><a name="*-sun-solaris2.8">*-sun-solaris2.8</a></h3> | |
1619 | <!-- ripped from the same FAQ that I answered --> | |
1620 | @end html | |
1621 | ||
1622 | Sun bug 4296832 turns up when compiling X11 headers with GCC 2.95 or | |
1623 | newer: g++ will complain that types are missing. These headers assume | |
1624 | that omitting the type means 'int'; this assumption worked for C89 but | |
1625 | is wrong for C++, and is now wrong for C99 also. | |
1626 | ||
1627 | g++ accepts such (illegal) constructs with the option @option{-fpermissive}; it | |
1628 | will assume that any missing type is 'int' (as defined by C89). | |
1629 | ||
9a3db543 | 1630 | For Solaris 8, this is fixed by revision 24 or later of patch 108652 |
f42974dc DW |
1631 | (for SPARCs) or 108653 (for Intels). |
1632 | ||
1633 | ||
1634 | @html | |
1635 | <p> | |
1636 | <hr> | |
1637 | <h3><a name="sunv5">Sun V5.0 Compiler Bugs</a></h3> | |
1638 | @end html | |
1639 | ||
1640 | The Sun V5.0 compilers are known to mis-compile GCC 2.95 and GCC 2.95.1, | |
1641 | which in turn causes GCC to fail its bootstrap comparison test. | |
1642 | GCC 2.95.2 has a workaround. | |
1643 | ||
1644 | ||
1645 | @html | |
1646 | </p> | |
1647 | <hr> | |
1648 | <h3><a name="sparc-sun-sunos*">sparc-sun-sunos*</a></h3> | |
1649 | @end html | |
1650 | ||
1651 | A bug in the SunOS4 linker will cause it to crash when linking | |
1652 | -fPIC compiled objects (and will therefore not allow you to build | |
1653 | shared libraries). | |
1654 | ||
1655 | To fix this problem you can either use the most recent version of | |
1656 | binutils or get the latest SunOS4 linker patch (patch ID 100170-10) | |
1657 | from Sun's patch site. | |
1658 | ||
1659 | ||
1660 | @html | |
1661 | </p> | |
1662 | <hr> | |
1663 | <h3><a name="sparc-unknown-linux-gnulibc1">sparc-unknown-linux-gnulibc1</a></h3> | |
1664 | @end html | |
1665 | ||
1666 | It has been reported that you might need | |
1667 | @uref{ftp://ftp.yggdrasil.com/private/hjl,,binutils-2.8.1.0.23} | |
1668 | for this platform, too. | |
1669 | ||
1670 | ||
1671 | @html | |
1672 | </p> | |
1673 | <hr> | |
1674 | <h3><a name="sparc64-*-*">sparc64-*-*</a></h3> | |
1675 | @end html | |
1676 | ||
1677 | GCC version 2.95 is not able to compile code correctly for | |
1678 | @code{sparc64} targets. Users of the Linux kernel, at least, | |
1679 | 12~can use the @code{sparc32} program to start up a new shell | |
1680 | invocation with an environment that causes @command{configure} to | |
1681 | recognize (via @command{uname -a}) the system as @command{sparc-*-*} instead. | |
1682 | ||
1683 | ||
1684 | @html | |
1685 | </p> | |
1686 | <hr> | |
1687 | <h3><a name="windows"></a>Microsoft Windows (32 bit)</h3> | |
1688 | @end html | |
1689 | ||
1690 | A port of GCC 2.95.x is included with the | |
1691 | @uref{http://www.cygwin.com/,,Cygwin environment}. | |
1692 | ||
1693 | Current (as of early 2001) snapshots of GCC will build under Cygwin | |
1694 | without modification. | |
1695 | ||
1696 | @html | |
1697 | </p> | |
1698 | <hr> | |
1699 | <h3><a name="os2"></a>OS/2</h3> | |
1700 | @end html | |
1701 | ||
1702 | GCC does not currently support OS/2. However, Andrew Zabolotny has been | |
1703 | working on a generic OS/2 port with pgcc. The current code code can be found | |
1704 | at @uref{http://www.goof.com/pcg/os2/,,http://www.goof.com/pcg/os2/}. | |
1705 | ||
1706 | An older copy of GCC 2.8.1 is included with the EMX tools available at | |
1707 | @uref{ftp://ftp.leo.org/pub/comp/os/os2/leo/devtools/emx+gcc/,, | |
1708 | ftp://ftp.leo.org/pub/comp/os/os2/leo/devtools/emx+gcc/}. | |
1709 | ||
1710 | @html | |
1711 | </p> | |
1712 | <hr> | |
1713 | <h3><a name="older"></a>Older systems</h3> | |
1714 | @end html | |
1715 | ||
1716 | GCC contains support files for many older (1980s and early | |
1717 | 1990s) Unix variants. For the most part, support for these systems | |
1718 | has not been deliberately removed, but it has not been maintained for | |
1719 | several years and may suffer from bitrot. Support from some systems | |
1720 | has been removed from GCC 3: fx80, ns32-ns-genix, pyramid, tahoe, | |
1721 | gmicro, spur; most of these targets had not been updated since GCC | |
1722 | version 1. | |
1723 | ||
1724 | Support for older systems as targets for cross-compilation is less | |
1725 | problematic than support for them as hosts for GCC; if an enthusiast | |
1726 | wishes to make such a target work again (including resurrecting any | |
1727 | of the targets that never worked with GCC 2, starting from the last | |
1728 | CVS version before they were removed), patches | |
1729 | @uref{../contribute.html,,following the usual requirements} | |
1730 | would be likely to be accepted, since they should not affect the | |
1731 | support for more modern targets. | |
1732 | ||
1733 | Support for old systems as hosts for GCC can cause problems if the | |
1734 | workarounds for compiler, library and operating system bugs affect the | |
1735 | cleanliness or maintainability of the rest of GCC. In some cases, to | |
1736 | bring GCC up on such a system, if still possible with current GCC, may | |
1737 | require first installing an old version of GCC which did work on that | |
1738 | system, and using it to compile a more recent GCC, to avoid bugs in | |
1739 | the vendor compiler. Old releases of GCC 1 and GCC 2 are available in | |
1740 | the old-releases directory on the | |
1741 | @uref{../mirrors.html,,GCC mirror sites}. Header bugs may generally | |
1742 | be avoided using @code{fixincludes}, but bugs or deficiencies in libraries and | |
1743 | the operating system may still cause problems. | |
1744 | ||
1745 | For some systems, old versions of GNU binutils may also be useful, | |
1746 | and are available from pub/binutils/old-releases on | |
1747 | @uref{http://sources.redhat.com/mirrors.html,,sources.redhat.com mirror sites}. | |
1748 | ||
1749 | Some of the information on specific systems above relates to | |
1750 | such older systems, but much of the information | |
1751 | about GCC on such systems (which may no longer be applicable to | |
1752 | current GCC) is to be found in the GCC texinfo manual. | |
1753 | ||
1754 | @html | |
1755 | </p> | |
1756 | <hr> | |
1757 | <h3><a name="elf_targets">all ELF targets (SVR4, Solaris, etc.)</a></h3> | |
1758 | @end html | |
1759 | ||
1760 | C++ support is significantly better on ELF targets if you use the GNU | |
1761 | linker; duplicate copies of inlines, vtables and template instantiations | |
1762 | will be discarded automatically. | |
1763 | ||
1764 | ||
1765 | @html | |
1766 | </p> | |
1767 | <hr> | |
1768 | <p> | |
1769 | @end html | |
1770 | @ifhtml | |
1771 | @uref{./index.html,,Return to the GCC Installation page} | |
1772 | @end ifhtml | |
1773 | @end ifset | |
1774 | ||
1775 | @c *************************************************************************** | |
1776 | @c Part 6 The End of the Document | |
1777 | @ifinfo | |
1778 | @comment node-name, next, previous, up | |
1779 | @node Concept Index, , Specific, Top | |
1780 | @end ifinfo | |
1781 | ||
1782 | @ifinfo | |
1783 | @unnumbered Concept Index | |
1784 | ||
1785 | @printindex cp | |
1786 | ||
1787 | @contents | |
1788 | @end ifinfo | |
1789 | @bye |