Annotation of GNUtools/cc/gcc.info-8, revision 1.1.1.1

1.1       root        1: This is Info file gcc.info, produced by Makeinfo-1.54 from the input
                      2: file gcc.texi.
                      3: 
                      4:    This file documents the use and the internals of the GNU compiler.
                      5: 
                      6:    Published by the Free Software Foundation 675 Massachusetts Avenue
                      7: Cambridge, MA 02139 USA
                      8: 
                      9:    Copyright (C) 1988, 1989, 1992, 1993 Free Software Foundation, Inc.
                     10: 
                     11:    Permission is granted to make and distribute verbatim copies of this
                     12: manual provided the copyright notice and this permission notice are
                     13: preserved on all copies.
                     14: 
                     15:    Permission is granted to copy and distribute modified versions of
                     16: this manual under the conditions for verbatim copying, provided also
                     17: that the sections entitled "GNU General Public License" and "Protect
                     18: Your Freedom--Fight `Look And Feel'" are included exactly as in the
                     19: original, and provided that the entire resulting derived work is
                     20: distributed under the terms of a permission notice identical to this
                     21: one.
                     22: 
                     23:    Permission is granted to copy and distribute translations of this
                     24: manual into another language, under the above conditions for modified
                     25: versions, except that the sections entitled "GNU General Public
                     26: License" and "Protect Your Freedom--Fight `Look And Feel'", and this
                     27: permission notice, may be included in translations approved by the Free
                     28: Software Foundation instead of in the original English.
                     29: 
                     30: 
                     31: File: gcc.info,  Node: C++ Extensions,  Next: Trouble,  Prev: C Extensions,  Up: Top
                     32: 
                     33: Extensions to the C++ Language
                     34: ******************************
                     35: 
                     36:    The GNU compiler provides these extensions to the C++ language (and
                     37: you can also use most of the C language extensions in your C++
                     38: programs).  If you want to write code that checks whether these
                     39: features are available, you can test for the GNU compiler the same way
                     40: as for C programs: check for a predefined macro `__GNUC__'.  You can
                     41: also use `__GNUG__' to test specifically for GNU C++ (*note Standard
                     42: Predefined Macros: (cpp.info)Standard Predefined.).
                     43: 
                     44: * Menu:
                     45: 
                     46: * Naming Results::      Giving a name to C++ function return values.
                     47: * Min and Max::                C++ Minimum and maximum operators.
                     48: * Destructors and Goto:: Goto is safe to use in C++ even when destructors
                     49:                            are needed.
                     50: * C++ Interface::       You can use a single C++ header file for both
                     51:                          declarations and definitions.
                     52: 
                     53: 
                     54: File: gcc.info,  Node: Naming Results,  Next: Min and Max,  Up: C++ Extensions
                     55: 
                     56: Named Return Values in C++
                     57: ==========================
                     58: 
                     59:    GNU C++ extends the function-definition syntax to allow you to
                     60: specify a name for the result of a function outside the body of the
                     61: definition, in C++ programs:
                     62: 
                     63:      TYPE
                     64:      FUNCTIONNAME (ARGS) return RESULTNAME;
                     65:      {
                     66:        ...
                     67:        BODY
                     68:        ...
                     69:      }
                     70: 
                     71:    You can use this feature to avoid an extra constructor call when a
                     72: function result has a class type.  For example, consider a function
                     73: `m', declared as `X v = m ();', whose result is of class `X':
                     74: 
                     75:      X
                     76:      m ()
                     77:      {
                     78:        X b;
                     79:        b.a = 23;
                     80:        return b;
                     81:      }
                     82: 
                     83:    Although `m' appears to have no arguments, in fact it has one
                     84: implicit argument: the address of the return value.  At invocation, the
                     85: address of enough space to hold `v' is sent in as the implicit argument.
                     86: Then `b' is constructed and its `a' field is set to the value 23.
                     87: Finally, a copy constructor (a constructor of the form `X(X&)') is
                     88: applied to `b', with the (implicit) return value location as the
                     89: target, so that `v' is now bound to the return value.
                     90: 
                     91:    But this is wasteful.  The local `b' is declared just to hold
                     92: something that will be copied right out.  While a compiler that
                     93: combined an "elision" algorithm with interprocedural data flow analysis
                     94: could conceivably eliminate all of this, it is much more practical to
                     95: allow you to assist the compiler in generating efficient code by
                     96: manipulating the return value explicitly, thus avoiding the local
                     97: variable and copy constructor altogether.
                     98: 
                     99:    Using the extended GNU C++ function-definition syntax, you can avoid
                    100: the temporary allocation and copying by naming `r' as your return value
                    101: as the outset, and assigning to its `a' field directly:
                    102: 
                    103:      X
                    104:      m () return r;
                    105:      {
                    106:        r.a = 23;
                    107:      }
                    108: 
                    109: The declaration of `r' is a standard, proper declaration, whose effects
                    110: are executed *before* any of the body of `m'.
                    111: 
                    112:    Functions of this type impose no additional restrictions; in
                    113: particular, you can execute `return' statements, or return implicitly by
                    114: reaching the end of the function body ("falling off the edge").  Cases
                    115: like
                    116: 
                    117:      X
                    118:      m () return r (23);
                    119:      {
                    120:        return;
                    121:      }
                    122: 
                    123: (or even `X m () return r (23); { }') are unambiguous, since the return
                    124: value `r' has been initialized in either case.  The following code may
                    125: be hard to read, but also works predictably:
                    126: 
                    127:      X
                    128:      m () return r;
                    129:      {
                    130:        X b;
                    131:        return b;
                    132:      }
                    133: 
                    134:    The return value slot denoted by `r' is initialized at the outset,
                    135: but the statement `return b;' overrides this value.  The compiler deals
                    136: with this by destroying `r' (calling the destructor if there is one, or
                    137: doing nothing if there is not), and then reinitializing `r' with `b'.
                    138: 
                    139:    This extension is provided primarily to help people who use
                    140: overloaded operators, where there is a great need to control not just
                    141: the arguments, but the return values of functions.  For classes where
                    142: the copy constructor incurs a heavy performance penalty (especially in
                    143: the common case where there is a quick default constructor), this is a
                    144: major savings.  The disadvantage of this extension is that you do not
                    145: control when the default constructor for the return value is called: it
                    146: is always called at the beginning.
                    147: 
                    148: 
                    149: File: gcc.info,  Node: Min and Max,  Next: Destructors and Goto,  Prev: Naming Results,  Up: C++ Extensions
                    150: 
                    151: Minimum and Maximum Operators in C++
                    152: ====================================
                    153: 
                    154:    It is very convenient to have operators which return the "minimum"
                    155: or the "maximum" of two arguments.  In GNU C++ (but not in GNU C),
                    156: 
                    157: `A <? B'
                    158:      is the "minimum", returning the smaller of the numeric values A
                    159:      and B;
                    160: 
                    161: `A >? B'
                    162:      is the "maximum", returning the larger of the numeric values A and
                    163:      B.
                    164: 
                    165:    These operations are not primitive in ordinary C++, since you can
                    166: use a macro to return the minimum of two things in C++, as in the
                    167: following example.
                    168: 
                    169:      #define MIN(X,Y) ((X) < (Y) ? : (X) : (Y))
                    170: 
                    171: You might then use `int min = MIN (i, j);' to set MIN to the minimum
                    172: value of variables I and J.
                    173: 
                    174:    However, side effects in `X' or `Y' may cause unintended behavior.
                    175: For example, `MIN (i++, j++)' will fail, incrementing the smaller
                    176: counter twice.  A GNU C extension allows you to write safe macros that
                    177: avoid this kind of problem (*note Naming an Expression's Type: Naming
                    178: Types.).  However, writing `MIN' and `MAX' as macros also forces you to
                    179: use function-call notation notation for a fundamental arithmetic
                    180: operation.  Using GNU C++ extensions, you can write `int min = i <? j;'
                    181: instead.
                    182: 
                    183:    Since `<?' and `>?' are built into the compiler, they properly
                    184: handle expressions with side-effects;  `int min = i++ <? j++;' works
                    185: correctly.
                    186: 
                    187: 
                    188: File: gcc.info,  Node: Destructors and Goto,  Next: C++ Interface,  Prev: Min and Max,  Up: C++ Extensions
                    189: 
                    190: `goto' and Destructors in GNU C++
                    191: =================================
                    192: 
                    193:    In C++ programs, you can safely use the `goto' statement.  When you
                    194: use it to exit a block which contains aggregates requiring destructors,
                    195: the destructors will run before the `goto' transfers control.  (In ANSI
                    196: C++, `goto' is restricted to targets within the current block.)
                    197: 
                    198:    The compiler still forbids using `goto' to *enter* a scope that
                    199: requires constructors.
                    200: 
                    201: 
                    202: File: gcc.info,  Node: C++ Interface,  Prev: Destructors and Goto,  Up: C++ Extensions
                    203: 
                    204: Declarations and Definitions in One Header
                    205: ==========================================
                    206: 
                    207:    C++ object definitions can be quite complex.  In principle, your
                    208: source code will need two kinds of things for each object that you use
                    209: across more than one source file.  First, you need an "interface"
                    210: specification, describing its structure with type declarations and
                    211: function prototypes.  Second, you need the "implementation" itself.  It
                    212: can be tedious to maintain a separate interface description in a header
                    213: file, in parallel to the actual implementation.  It is also dangerous,
                    214: since separate interface and implementation definitions may not remain
                    215: parallel.
                    216: 
                    217:    With GNU C++, you can use a single header file for both purposes.
                    218: 
                    219:      *Warning:* The mechanism to specify this is in transition.  For the
                    220:      nonce, you must use one of two `#pragma' commands; in a future
                    221:      release of GNU C++, an alternative mechanism will make these
                    222:      `#pragma' commands unnecessary.
                    223: 
                    224:    The header file contains the full definitions, but is marked with
                    225: `#pragma interface' in the source code.  This allows the compiler to
                    226: use the header file only as an interface specification when ordinary
                    227: source files incorporate it with `#include'.  In the single source file
                    228: where the full implementation belongs, you can use either a naming
                    229: convention or `#pragma implementation' to indicate this alternate use
                    230: of the header file.
                    231: 
                    232: `#pragma interface'
                    233:      Use this directive in *header files* that define object classes,
                    234:      to save space in most of the object files that use those classes.
                    235:      Normally, local copies of certain information (backup copies of
                    236:      inline member functions, debugging information, and the internal
                    237:      tables that implement virtual functions) must be kept in each
                    238:      object file that includes class definitions.  You can use this
                    239:      pragma to avoid such duplication.  When a header file containing
                    240:      `#pragma interface' is included in a compilation, this auxiliary
                    241:      information will not be generated (unless the main input source
                    242:      file itself uses `#pragma implementation').  Instead, the object
                    243:      files will contain references to be resolved at link time.
                    244: 
                    245: `#pragma implementation'
                    246: `#pragma implementation "OBJECTS.h"'
                    247:      Use this pragma in a *main input file*, when you want full output
                    248:      from included header files to be generated (and made globally
                    249:      visible).  The included header file, in turn, should use `#pragma
                    250:      interface'.  Backup copies of inline member functions, debugging
                    251:      information, and the internal tables used to implement virtual
                    252:      functions are all generated in implementation files.
                    253: 
                    254:      `#pragma implementation' is *implied* whenever the basename(1) of
                    255:      your source file matches the basename of a header file it
                    256:      includes.  There is no way to turn this off (other than using a
                    257:      different name for one of the two files).  In the same vein, if
                    258:      you use `#pragma implementation' with no argument, it applies to an
                    259:      include file with the same basename as your source file.  For
                    260:      example, in `allclass.cc', `#pragma implementation' by itself is
                    261:      equivalent to `#pragma implementation "allclass.h"'; but even if
                    262:      you do not say `#pragma implementation' at all, `allclass.h' is
                    263:      treated as an implementation file whenever you include it from
                    264:      `allclass.cc'.
                    265: 
                    266:      If you use an explicit `#pragma implementation', it must appear in
                    267:      your source file *before* you include the affected header files.
                    268: 
                    269:      Use the string argument if you want a single implementation file to
                    270:      include code from multiple header files.  (You must also use
                    271:      `#include' to include the header file; `#pragma implementation'
                    272:      only specifies how to use the file--it doesn't actually include
                    273:      it.)
                    274: 
                    275:      There is no way to split up the contents of a single header file
                    276:      into multiple implementation files.
                    277: 
                    278:    `#pragma implementation' and `#pragma interface' also have an effect
                    279: on function inlining.
                    280: 
                    281:    If you define a class in a header file marked with `#pragma
                    282: interface', the effect on a function defined in that class is similar to
                    283: an explicit `extern' declaration--the compiler emits no code at all to
                    284: define an independent version of the function.  Its definition is used
                    285: only for inlining with its callers.
                    286: 
                    287:    Conversely, when you include the same header file in a main source
                    288: file that declares it as `#pragma implementation', the compiler emits
                    289: code for the function itself; this defines a version of the function
                    290: that can be found via pointers (or by callers compiled without
                    291: inlining).
                    292: 
                    293:    ---------- Footnotes ----------
                    294: 
                    295:    (1)  A file's "basename" is the name stripped of all leading path
                    296: information and of trailing suffixes, such as `.h' or `.C' or `.cc'.
                    297: 
                    298: 
                    299: File: gcc.info,  Node: Trouble,  Next: Bugs,  Prev: C++ Extensions,  Up: Top
                    300: 
                    301: Known Causes of Trouble with GNU CC
                    302: ***********************************
                    303: 
                    304:    This section describes known problems that affect users of GNU CC.
                    305: Most of these are not GNU CC bugs per se--if they were, we would fix
                    306: them.  But the result for a user may be like the result of a bug.
                    307: 
                    308:    Some of these problems are due to bugs in other software, some are
                    309: missing features that are too much work to add, and some are places
                    310: where people's opinions differ as to what is best.
                    311: 
                    312: * Menu:
                    313: 
                    314: * Actual Bugs::                      Bugs we will fix later.
                    315: * Installation Problems::     Problems that manifest when you install GNU CC.
                    316: * Cross-Compiler Problems::   Common problems of cross compiling with GNU CC.
                    317: * Interoperation::      Problems using GNU CC with other compilers,
                    318:                           and with certain linkers, assemblers and debuggers.
                    319: * External Bugs::      Problems compiling certain programs.
                    320: * Incompatibilities::   GNU CC is incompatible with traditional C.
                    321: * Fixed Headers::       GNU C uses corrected versions of system header files.
                    322:                            This is necessary, but doesn't always work smoothly.
                    323: * Disappointments::     Regrettable things we can't change, but not quite bugs.
                    324: * C++ Misunderstandings::     Common misunderstandings with GNU C++.
                    325: * Protoize Caveats::    Things to watch out for when using `protoize'.
                    326: * Non-bugs::           Things we think are right, but some others disagree.
                    327: * Warnings and Errors:: Which problems in your code get warnings,
                    328:                          and which get errors.
                    329: 
                    330: 
                    331: File: gcc.info,  Node: Actual Bugs,  Next: Installation Problems,  Up: Trouble
                    332: 
                    333: Actual Bugs We Haven't Fixed Yet
                    334: ================================
                    335: 
                    336:    * The `fixincludes' script interacts badly with automounters; if the
                    337:      directory of system header files is automounted, it tends to be
                    338:      unmounted while `fixincludes' is running.  This would seem to be a
                    339:      bug in the automounter.  We don't know any good way to work around
                    340:      it.
                    341: 
                    342:    * Loop unrolling doesn't work properly for certain C++ programs.
                    343:      This is because of difficulty in updating the debugging
                    344:      information within the loop being unrolled.  We plan to revamp the
                    345:      representation of debugging information so that this will work
                    346:      properly, but we have not done this in version 2.5 because we
                    347:      don't want to delay it any further.
                    348: 
                    349: 
                    350: File: gcc.info,  Node: Installation Problems,  Next: Cross-Compiler Problems,  Prev: Actual Bugs,  Up: Trouble
                    351: 
                    352: Installation Problems
                    353: =====================
                    354: 
                    355:    This is a list of problems (and some apparent problems which don't
                    356: really mean anything is wrong) that show up during installation of GNU
                    357: CC.
                    358: 
                    359:    * On certain systems, defining certain environment variables such as
                    360:      `CC' can interfere with the functioning of `make'.
                    361: 
                    362:    * If you encounter seemingly strange errors when trying to build the
                    363:      compiler in a directory other than the source directory, it could
                    364:      be because you have previously configured the compiler in the
                    365:      source directory.  Make sure you have done all the necessary
                    366:      preparations.  *Note Other Dir::.
                    367: 
                    368:    * In previous versions of GNU CC, the `gcc' driver program looked for
                    369:      `as' and `ld' in various places; for example, in files beginning
                    370:      with `/usr/local/lib/gcc-'.  GNU CC version 2 looks for them in
                    371:      the directory `/usr/local/lib/gcc-lib/TARGET/VERSION'.
                    372: 
                    373:      Thus, to use a version of `as' or `ld' that is not the system
                    374:      default, for example `gas' or GNU `ld', you must put them in that
                    375:      directory (or make links to them from that directory).
                    376: 
                    377:    * Some commands executed when making the compiler may fail (return a
                    378:      non-zero status) and be ignored by `make'.  These failures, which
                    379:      are often due to files that were not found, are expected, and can
                    380:      safely be ignored.
                    381: 
                    382:    * It is normal to have warnings in compiling certain files about
                    383:      unreachable code and about enumeration type clashes.  These files'
                    384:      names begin with `insn-'.  Also, `real.c' may get some warnings
                    385:      that you can ignore.
                    386: 
                    387:    * Sometimes `make' recompiles parts of the compiler when installing
                    388:      the compiler.  In one case, this was traced down to a bug in
                    389:      `make'.  Either ignore the problem or switch to GNU Make.
                    390: 
                    391:    * If you have installed a program known as purify, you may find that
                    392:      it causes errors while linking `enquire', which is part of building
                    393:      GNU CC.  The fix is to get rid of the file `real-ld' which purify
                    394:      installs--so that GNU CC won't try to use it.
                    395: 
                    396:    * On Linux SLS 1.01, there is a problem with `libc.a': it does not
                    397:      contain the obstack functions.  However, GNU CC assumes that the
                    398:      obstack functions are in `libc.a' when it is the GNU C library.
                    399:      To work around this problem, change the `__GNU_LIBRARY__'
                    400:      conditional around line 31 to `#if 1'.
                    401: 
                    402:    * On some 386 systems, building the compiler never finishes because
                    403:      `enquire' hangs due to a hardware problem in the motherboard--it
                    404:      reports floating point exceptions to the kernel incorrectly.  You
                    405:      can install GNU CC except for `float.h' by patching out the
                    406:      command to run `enquire'.  You may also be able to fix the problem
                    407:      for real by getting a replacement motherboard.  This problem was
                    408:      observed in Revision E of the Micronics motherboard, and is fixed
                    409:      in Revision F.  It has also been observed in the MYLEX MXA-33
                    410:      motherboard.
                    411: 
                    412:      If you encounter this problem, you may also want to consider
                    413:      removing the FPU from the socket during the compilation.
                    414:      Alternatively, if you are running SCO Unix, you can reboot and
                    415:      force the FPU to be ignored.  To do this, type `hd(40)unix auto
                    416:      ignorefpu'.
                    417: 
                    418:    * On some 386 systems, GNU CC crashes trying to compile `enquire.c'.
                    419:      This happens on machines that don't have a 387 FPU chip.  On 386
                    420:      machines, the system kernel is supposed to emulate the 387 when you
                    421:      don't have one.  The crash is due to a bug in the emulator.
                    422: 
                    423:      One of these systems is the Unix from Interactive Systems: 386/ix.
                    424:      On this system, an alternate emulator is provided, and it does
                    425:      work.  To use it, execute this command as super-user:
                    426: 
                    427:           ln /etc/emulator.rel1 /etc/emulator
                    428: 
                    429:      and then reboot the system.  (The default emulator file remains
                    430:      present under the name `emulator.dflt'.)
                    431: 
                    432:      Try using `/etc/emulator.att', if you have such a problem on the
                    433:      SCO system.
                    434: 
                    435:      Another system which has this problem is Esix.  We don't know
                    436:      whether it has an alternate emulator that works.
                    437: 
                    438:      On NetBSD 0.8, a similar problem manifests itself as these error
                    439:      messages:
                    440: 
                    441:           enquire.c: In function `fprop':
                    442:           enquire.c:2328: floating overflow
                    443: 
                    444:    * On SCO systems, when compiling GNU CC with the system's compiler,
                    445:      do not use `-O'.  Some versions of the system's compiler miscompile
                    446:      GNU CC with `-O'.
                    447: 
                    448:    * Sometimes on a Sun 4 you may observe a crash in the program
                    449:      `genflags' or `genoutput' while building GNU CC.  This is said to
                    450:      be due to a bug in `sh'.  You can probably get around it by running
                    451:      `genflags' or `genoutput' manually and then retrying the `make'.
                    452: 
                    453:    * On Solaris 2, executables of GNU CC version 2.0.2 are commonly
                    454:      available, but they have a bug that shows up when compiling current
                    455:      versions of GNU CC: undefined symbol errors occur during assembly
                    456:      if you use `-g'.
                    457: 
                    458:      The solution is to compile the current version of GNU CC without
                    459:      `-g'.  That makes a working compiler which you can use to recompile
                    460:      with `-g'.
                    461: 
                    462:    * Solaris 2 comes with a number of optional OS packages.  Some of
                    463:      these packages are needed to use GNU CC fully.  If you did not
                    464:      install all optional packages when installing Solaris, you will
                    465:      need to verify that the packages that GNU CC needs are installed.
                    466: 
                    467:      To check whether an optional package is installed, use the
                    468:      `pkginfo' command.  To add an optional package, use the `pkgadd'
                    469:      command.  For further details, see the Solaris documentation.
                    470: 
                    471:      For Solaris 2.0 and 2.1, GNU CC needs six packages: `SUNWarc',
                    472:      `SUNWbtool', `SUNWesu', `SUNWhea', `SUNWlibm', and `SUNWtoo'.
                    473: 
                    474:      For Solaris 2.2, GNU CC needs an additional seventh package:
                    475:      `SUNWsprot'.
                    476: 
                    477:    * On Solaris 2, trying to use the linker and other tools in
                    478:      `/usr/ucb' to install GNU CC has been observed to cause trouble.
                    479:      For example, the linker may hang indefinitely.  The fix is to
                    480:      remove `/usr/ucb' from your `PATH'.
                    481: 
                    482:    * If you use the 1.31 version of the MIPS assembler (such as was
                    483:      shipped with Ultrix 3.1), you will need to use the
                    484:      -fno-delayed-branch switch when optimizing floating point code.
                    485:      Otherwise, the assembler will complain when the GCC compiler fills
                    486:      a branch delay slot with a floating point instruction, such as
                    487:      add.d.
                    488: 
                    489:    * If on a MIPS system you get an error message saying "does not have
                    490:      gp sections for all it's [sic] sectons [sic]", don't worry about
                    491:      it.  This happens whenever you use GAS with the MIPS linker, but
                    492:      there is not really anything wrong, and it is okay to use the
                    493:      output file.  You can stop such warnings by installing the GNU
                    494:      linker.
                    495: 
                    496:      It would be nice to extend GAS to produce the gp tables, but they
                    497:      are optional, and there should not be a warning about their
                    498:      absence.
                    499: 
                    500:    * Users have reported some problems with version 2.0 of the MIPS
                    501:      compiler tools that were shipped with Ultrix 4.1.  Version 2.10
                    502:      which came with Ultrix 4.2 seems to work fine.
                    503: 
                    504:    * Some versions of the MIPS linker will issue an assertion failure
                    505:      when linking code that uses `alloca' against shared libraries on
                    506:      RISC-OS 5.0, and DEC's OSF/1 systems.  This is a bug in the
                    507:      linker, that is supposed to be fixed in future revisions.  To
                    508:      protect against this, GCC passes `-non_shared' to the linker
                    509:      unless you pass an explicit `-shared' or `-call_shared' switch.
                    510: 
                    511:    * On System V release 3, you may get this error message while
                    512:      linking:
                    513: 
                    514:           ld fatal: failed to write symbol name SOMETHING
                    515:            in strings table for file WHATEVER
                    516: 
                    517:      This probably indicates that the disk is full or your ULIMIT won't
                    518:      allow the file to be as large as it needs to be.
                    519: 
                    520:      This problem can also result because the kernel parameter `MAXUMEM'
                    521:      is too small.  If so, you must regenerate the kernel and make the
                    522:      value much larger.  The default value is reported to be 1024; a
                    523:      value of 32768 is said to work.  Smaller values may also work.
                    524: 
                    525:    * On System V, if you get an error like this,
                    526: 
                    527:           /usr/local/lib/bison.simple: In function `yyparse':
                    528:           /usr/local/lib/bison.simple:625: virtual memory exhausted
                    529: 
                    530:      that too indicates a problem with disk space, ULIMIT, or `MAXUMEM'.
                    531: 
                    532:    * Current GNU CC versions probably do not work on version 2 of the
                    533:      NeXT operating system.
                    534: 
                    535:    * On the Tower models 4N0 and 6N0, by default a process is not
                    536:      allowed to have more than one megabyte of memory.  GNU CC cannot
                    537:      compile itself (or many other programs) with `-O' in that much
                    538:      memory.
                    539: 
                    540:      To solve this problem, reconfigure the kernel adding the following
                    541:      line to the configuration file:
                    542: 
                    543:           MAXUMEM = 4096
                    544: 
                    545:    * On HP 9000 series 300 or 400 running HP-UX release 8.0, there is a
                    546:      bug in the assembler that must be fixed before GNU CC can be
                    547:      built.  This bug manifests itself during the first stage of
                    548:      compilation, while building `libgcc2.a':
                    549: 
                    550:           _floatdisf
                    551:           cc1: warning: `-g' option not supported on this version of GCC
                    552:           cc1: warning: `-g1' option not supported on this version of GCC
                    553:           ./xgcc: Internal compiler error: program as got fatal signal 11
                    554: 
                    555:      A patched version of the assembler is available by anonymous ftp
                    556:      from `altdorf.ai.mit.edu' as the file
                    557:      `archive/cph/hpux-8.0-assembler'.  If you have HP software support,
                    558:      the patch can also be obtained directly from HP, as described in
                    559:      the following note:
                    560: 
                    561:           This is the patched assembler, to patch SR#1653-010439, where
                    562:           the assembler aborts on floating point constants.
                    563: 
                    564:           The bug is not really in the assembler, but in the shared
                    565:           library version of the function "cvtnum(3c)".  The bug on
                    566:           "cvtnum(3c)" is SR#4701-078451.  Anyway, the attached
                    567:           assembler uses the archive library version of "cvtnum(3c)"
                    568:           and thus does not exhibit the bug.
                    569: 
                    570:      This patch is also known as PHCO_0800.
                    571: 
                    572:    * Some versions of the Pyramid C compiler are reported to be unable
                    573:      to compile GNU CC.  You must use an older version of GNU CC for
                    574:      bootstrapping.  One indication of this problem is if you get a
                    575:      crash when GNU CC compiles the function `muldi3' in file
                    576:      `libgcc2.c'.
                    577: 
                    578:      You may be able to succeed by getting GNU CC version 1, installing
                    579:      it, and using it to compile GNU CC version 2.  The bug in the
                    580:      Pyramid C compiler does not seem to affect GNU CC version 1.
                    581: 
                    582:    * There may be similar problems on System V Release 3.1 on 386
                    583:      systems.
                    584: 
                    585:    * On the Altos 3068, programs compiled with GNU CC won't work unless
                    586:      you fix a kernel bug.  This happens using system versions V.2.2
                    587:      1.0gT1 and V.2.2 1.0e and perhaps later versions as well.  See the
                    588:      file `README.ALTOS'.
                    589: 
                    590:    * You will get several sorts of compilation and linking errors on the
                    591:      we32k if you don't follow the special instructions.  *Note WE32K
                    592:      Install::.
                    593: 
                    594: 
                    595: File: gcc.info,  Node: Cross-Compiler Problems,  Next: Interoperation,  Prev: Installation Problems,  Up: Trouble
                    596: 
                    597: Cross-Compiler Problems
                    598: =======================
                    599: 
                    600:    You may run into problems with cross compilation on certain machines,
                    601: for several reasons.
                    602: 
                    603:    * Cross compilation can run into trouble for certain machines because
                    604:      some target machines' assemblers require floating point numbers to
                    605:      be written as *integer* constants in certain contexts.
                    606: 
                    607:      The compiler writes these integer constants by examining the
                    608:      floating point value as an integer and printing that integer,
                    609:      because this is simple to write and independent of the details of
                    610:      the floating point representation.  But this does not work if the
                    611:      compiler is running on a different machine with an incompatible
                    612:      floating point format, or even a different byte-ordering.
                    613: 
                    614:      In addition, correct constant folding of floating point values
                    615:      requires representing them in the target machine's format.  (The C
                    616:      standard does not quite require this, but in practice it is the
                    617:      only way to win.)
                    618: 
                    619:      It is now possible to overcome these problems by defining macros
                    620:      such as `REAL_VALUE_TYPE'.  But doing so is a substantial amount of
                    621:      work for each target machine.  *Note Cross-compilation::.
                    622: 
                    623:    * At present, the program `mips-tfile' which adds debug support to
                    624:      object files on MIPS systems does not work in a cross compile
                    625:      environment.
                    626: 
                    627: 
                    628: File: gcc.info,  Node: Interoperation,  Next: External Bugs,  Prev: Cross-Compiler Problems,  Up: Trouble
                    629: 
                    630: Interoperation
                    631: ==============
                    632: 
                    633:    This section lists various difficulties encountered in using GNU C or
                    634: GNU C++ together with other compilers or with the assemblers, linkers,
                    635: libraries and debuggers on certain systems.
                    636: 
                    637:    * If you are using version 2.3 of libg++, you need to rebuild it with
                    638:      `make CC=gcc' to avoid mismatches in the definition of `size_t'.
                    639: 
                    640:    * Objective C does not work on the RS/6000 or the Alpha.
                    641: 
                    642:    * GNU C++ does not do name mangling in the same way as other C++
                    643:      compilers.  This means that object files compiled with one compiler
                    644:      cannot be used with another.
                    645: 
                    646:      This effect is intentional, to protect you from more subtle
                    647:      problems.  Compilers differ as to many internal details of C++
                    648:      implementation, including: how class instances are laid out, how
                    649:      multiple inheritance is implemented, and how virtual function
                    650:      calls are handled.  If the name encoding were made the same, your
                    651:      programs would link against libraries provided from other
                    652:      compilers--but the programs would then crash when run.
                    653:      Incompatible libraries are then detected at link time, rather than
                    654:      at run time.
                    655: 
                    656:    * Older GDB versions sometimes fail to read the output of GNU CC
                    657:      version 2.  If you have trouble, get GDB version 4.4 or later.
                    658: 
                    659:    * DBX rejects some files produced by GNU CC, though it accepts
                    660:      similar constructs in output from PCC.  Until someone can supply a
                    661:      coherent description of what is valid DBX input and what is not,
                    662:      there is nothing I can do about these problems.  You are on your
                    663:      own.
                    664: 
                    665:    * The GNU assembler (GAS) does not support PIC.  To generate PIC
                    666:      code, you must use some other assembler, such as `/bin/as'.
                    667: 
                    668:    * On some BSD systems including some versions of Ultrix, use of
                    669:      profiling causes static variable destructors (currently used only
                    670:      in C++) not to be run.
                    671: 
                    672:    * Use of `-I/usr/include' may cause trouble.
                    673: 
                    674:      Many systems come with header files that won't work with GNU CC
                    675:      unless corrected by `fixincludes'.  The corrected header files go
                    676:      in a new directory; GNU CC searches this directory before
                    677:      `/usr/include'.  If you use `-I/usr/include', this tells GNU CC to
                    678:      search `/usr/include' earlier on, before the corrected headers.
                    679:      The result is that you get the uncorrected header files.
                    680: 
                    681:      Instead, you should use these options (when compiling C programs):
                    682: 
                    683:           -I/usr/local/lib/gcc-lib/TARGET/VERSION/include -I/usr/include
                    684: 
                    685:      For C++ programs, GNU CC also uses a special directory that
                    686:      defines C++ interfaces to standard C subroutines.  This directory
                    687:      is meant to be searched *before* other standard include
                    688:      directories, so that it takes precedence.  If you are compiling
                    689:      C++ programs and specifying include directories explicitly, use
                    690:      this option first, then the two options above:
                    691: 
                    692:           -I/usr/local/lib/g++-include
                    693: 
                    694:    * On a Sparc, GNU CC aligns all values of type `double' on an 8-byte
                    695:      boundary, and it expects every `double' to be so aligned.  The Sun
                    696:      compiler usually gives `double' values 8-byte alignment, with one
                    697:      exception: function arguments of type `double' may not be aligned.
                    698: 
                    699:      As a result, if a function compiled with Sun CC takes the address
                    700:      of an argument of type `double' and passes this pointer of type
                    701:      `double *' to a function compiled with GNU CC, dereferencing the
                    702:      pointer may cause a fatal signal.
                    703: 
                    704:      One way to solve this problem is to compile your entire program
                    705:      with GNU CC.  Another solution is to modify the function that is
                    706:      compiled with Sun CC to copy the argument into a local variable;
                    707:      local variables are always properly aligned.  A third solution is
                    708:      to modify the function that uses the pointer to dereference it via
                    709:      the following function `access_double' instead of directly with
                    710:      `*':
                    711: 
                    712:           inline double
                    713:           access_double (double *unaligned_ptr)
                    714:           {
                    715:             union d2i { double d; int i[2]; };
                    716:           
                    717:             union d2i *p = (union d2i *) unaligned_ptr;
                    718:             union d2i u;
                    719:           
                    720:             u.i[0] = p->i[0];
                    721:             u.i[1] = p->i[1];
                    722:           
                    723:             return u.d;
                    724:           }
                    725: 
                    726:      Storing into the pointer can be done likewise with the same union.
                    727: 
                    728:    * On Solaris, the `malloc' function in the `libmalloc.a' library may
                    729:      allocate memory that is only 4 byte aligned.  Since GNU CC on the
                    730:      Sparc assumes that doubles are 8 byte aligned, this may result in a
                    731:      fatal signal if doubles are stored in memory allocated by the
                    732:      `libmalloc.a' library.
                    733: 
                    734:      The solution is to not use the `libmalloc.a' library.  Use instead
                    735:      `malloc' and related functions from `libc.a'; they do not have
                    736:      this problem.
                    737: 
                    738:    * On a Sun, linking using GNU CC fails to find a shared library and
                    739:      reports that the library doesn't exist at all.
                    740: 
                    741:      This happens if you are using the GNU linker, because it does only
                    742:      static linking and looks only for unshared libraries.  If you have
                    743:      a shared library with no unshared counterpart, the GNU linker
                    744:      won't find anything.
                    745: 
                    746:      We hope to make a linker which supports Sun shared libraries, but
                    747:      please don't ask when it will be finished--we don't know.
                    748: 
                    749:    * Sun forgot to include a static version of `libdl.a' with some
                    750:      versions of SunOS (mainly 4.1).  This results in undefined symbols
                    751:      when linking static binaries (that is, if you use `-static').  If
                    752:      you see undefined symbols `_dlclose', `_dlsym' or `_dlopen' when
                    753:      linking, compile and link against the file `mit/util/misc/dlsym.c'
                    754:      from the MIT version of X windows.
                    755: 
                    756:    * The 128-bit long double format that the Sparc port supports
                    757:      currently works by using the architecturally defined quad-word
                    758:      floating point instructions.  Since there is no hardware that
                    759:      supports these instructions they must be emulated by the operating
                    760:      system.  Long doubles do not work in Sun OS versions 4.0.3 and
                    761:      earlier, because the kernel eumulator uses an obsolete and
                    762:      incompatible format.  Long doubles do not work in Sun OS versions
                    763:      4.1.1 to 4.1.3 because of emululator bugs that cause random
                    764:      unpredicatable failures.  Long doubles appear to work in Sun OS 5.x
                    765:      (Solaris 2.x).
                    766: 
                    767:      A future implementation of the sparc long double support will use
                    768:      functions calls to library routines instead of the quad-word
                    769:      floating point instructions.  This will allow long doubles to work
                    770:      in more situtations, since one can then substitute a working
                    771:      library if the kernel emulator is buggy.
                    772: 
                    773:    * On HP-UX version 9.01 on the HP PA, the HP compiler `cc' does not
                    774:      compile GNU CC correctly.  We do not yet know why.  However, GNU CC
                    775:      compiled on earlier HP-UX versions works properly on HP-UX 9.01
                    776:      and can compile itself properly on 9.01.
                    777: 
                    778:    * On the HP PA machine, ADB sometimes fails to work on functions
                    779:      compiled with GNU CC.  Specifically, it fails to work on functions
                    780:      that use `alloca' or variable-size arrays.  This is because GNU CC
                    781:      doesn't generate HP-UX unwind descriptors for such functions.  It
                    782:      may even be impossible to generate them.
                    783: 
                    784:    * Debugging (`-g') is not supported on the HP PA machine, unless you
                    785:      use the preliminary GNU tools (*note Installation::.).
                    786: 
                    787:    * Taking the address of a label may generate errors from the HP-UX
                    788:      PA assembler.  GAS for the PA does not have this problem.
                    789: 
                    790:    * Using floating point parameters for indirect calls to static
                    791:      functions will not work when using the HP assembler.  There simply
                    792:      is no way for GCC to specify what registers hold arguments for
                    793:      static functions when using the HP assembler.  GAS for the PA does
                    794:      not have this problem.
                    795: 
                    796:    * For some very large functions you may receive errors from the HP
                    797:      linker complaining about an out of bounds unconditional branch
                    798:      offset.  Fixing this problem correctly requires fixing problems in
                    799:      GNU CC and GAS.  We hope to fix this in time for GNU CC 2.6.
                    800:      Until then you can work around by making your function smaller,
                    801:      and if you are using GAS, splitting the function into multiple
                    802:      source files may be necessary.
                    803: 
                    804:    * GNU CC compiled code sometimes emits warnings from the HP-UX
                    805:      assembler of the form:
                    806: 
                    807:           (warning) Use of GR3 when
                    808:             frame >= 8192 may cause conflict.
                    809: 
                    810:      These warnings are harmless and can be safely ignored.
                    811: 
                    812:    * The current version of the assembler (`/bin/as') for the RS/6000
                    813:      has certain problems that prevent the `-g' option in GCC from
                    814:      working.  Note that `Makefile.in' uses `-g' by default when
                    815:      compiling `libgcc2.c'.
                    816: 
                    817:      IBM has produced a fixed version of the assembler.  The upgraded
                    818:      assembler unfortunately was not included in any of the AIX 3.2
                    819:      update PTF releases (3.2.2, 3.2.3, or 3.2.3e).  Users of AIX 3.1
                    820:      should request PTF U403044 from IBM and users of AIX 3.2 should
                    821:      request PTF U416277.  See the file `README.RS6000' for more
                    822:      details on these updates.
                    823: 
                    824:      You can test for the presense of a fixed assembler by using the
                    825:      command
                    826: 
                    827:           as -u < /dev/null
                    828: 
                    829:      If the command exits normally, the assembler fix already is
                    830:      installed.  If the assembler complains that "-u" is an unknown
                    831:      flag, you need to order the fix.
                    832: 
                    833:    * On the IBM RS/6000, compiling code of the form
                    834: 
                    835:           extern int foo;
                    836:           
                    837:           ... foo ...
                    838:           
                    839:           static int foo;
                    840: 
                    841:      will cause the linker to report an undefined symbol `foo'.
                    842:      Although this behavior differs from most other systems, it is not a
                    843:      bug because redefining an `extern' variable as `static' is
                    844:      undefined in ANSI C.
                    845: 
                    846:    * AIX on the RS/6000 provides support (NLS) for environments outside
                    847:      of the United States.  Compilers and assemblers use NLS to support
                    848:      locale-specific representations of various objects including
                    849:      floating-point numbers ("." vs "," for separating decimal
                    850:      fractions).  There have been problems reported where the library
                    851:      linked with GCC does not produce the same floating-point formats
                    852:      that the assembler accepts.  If you have this problem, set the
                    853:      LANG environment variable to "C" or "En_US".
                    854: 
                    855:    * On the RS/6000, XLC version 1.3.0.0 will miscompile `jump.c'.  XLC
                    856:      version 1.3.0.1 or later fixes this problem.  We do not yet have a
                    857:      PTF number for this fix.
                    858: 
                    859:    * There is an assembler bug in versions of DG/UX prior to 5.4.2.01
                    860:      that occurs when the `fldcr' instruction is used.  GNU CC uses
                    861:      `fldcr' on the 88100 to serialize volatile memory references.  Use
                    862:      the option `-mno-serialize-volatile' if your version of the
                    863:      assembler has this bug.
                    864: 
                    865:    * On VMS, GAS versions 1.38.1 and earlier may cause spurious warning
                    866:      messages from the linker.  These warning messages complain of
                    867:      mismatched psect attributes.  You can ignore them.  *Note VMS
                    868:      Install::.
                    869: 
                    870:    * On NewsOS version 3, if you include both of the files `stddef.h'
                    871:      and `sys/types.h', you get an error because there are two typedefs
                    872:      of `size_t'.  You should change `sys/types.h' by adding these
                    873:      lines around the definition of `size_t':
                    874: 
                    875:           #ifndef _SIZE_T
                    876:           #define _SIZE_T
                    877:           ACTUAL TYPEDEF HERE
                    878:           #endif
                    879: 
                    880:    * On the Alliant, the system's own convention for returning
                    881:      structures and unions is unusual, and is not compatible with GNU
                    882:      CC no matter what options are used.
                    883: 
                    884:    * On the IBM RT PC, the MetaWare HighC compiler (hc) uses a different
                    885:      convention for structure and union returning.  Use the option
                    886:      `-mhc-struct-return' to tell GNU CC to use a convention compatible
                    887:      with it.
                    888: 
                    889:    * On Ultrix, the Fortran compiler expects registers 2 through 5 to
                    890:      be saved by function calls.  However, the C compiler uses
                    891:      conventions compatible with BSD Unix: registers 2 through 5 may be
                    892:      clobbered by function calls.
                    893: 
                    894:      GNU CC uses the same convention as the Ultrix C compiler.  You can
                    895:      use these options to produce code compatible with the Fortran
                    896:      compiler:
                    897: 
                    898:           -fcall-saved-r2 -fcall-saved-r3 -fcall-saved-r4 -fcall-saved-r5
                    899: 
                    900:    * On the WE32k, you may find that programs compiled with GNU CC do
                    901:      not work with the standard shared C ilbrary.  You may need to link
                    902:      with the ordinary C compiler.  If you do so, you must specify the
                    903:      following options:
                    904: 
                    905:           -L/usr/local/lib/gcc-lib/we32k-att-sysv/2.5 -lgcc -lc_s
                    906: 
                    907:      The first specifies where to find the library `libgcc.a' specified
                    908:      with the `-lgcc' option.
                    909: 
                    910:      GNU CC does linking by invoking `ld', just as `cc' does, and there
                    911:      is no reason why it *should* matter which compilation program you
                    912:      use to invoke `ld'.  If someone tracks this problem down, it can
                    913:      probably be fixed easily.
                    914: 
                    915:    * On the Alpha, you may get assembler errors about invalid syntax as
                    916:      a result of floating point constants.  This is due to a bug in the
                    917:      C library functions `ecvt', `fcvt' and `gcvt'.  Given valid
                    918:      floating point numbers, they sometimes print `NaN'.
                    919: 
                    920:    * On Irix 4.0.5F (and perhaps in some other versions), an assembler
                    921:      bug sometimes reorders instructions incorrectly when optimization
                    922:      is turned on.  If you think this may be happening to you, try
                    923:      using the GNU assembler; GAS version 2.1 supports ECOFF on Irix.
                    924: 
                    925:      Or use the `-noasmopt' option when you compile GNU CC with itself,
                    926:      and then again when you compile your program.  (This is a temporary
                    927:      kludge to turn off assembler optimization on Irix.)  If this
                    928:      proves to be what you need, edit the assembler spec in the file
                    929:      `specs' so that it unconditionally passes `-O0' to the assembler,
                    930:      and never passes `-O2' or `-O3'.
                    931: 
                    932: 
                    933: File: gcc.info,  Node: External Bugs,  Next: Incompatibilities,  Prev: Interoperation,  Up: Trouble
                    934: 
                    935: Problems Compiling Certain Programs
                    936: ===================================
                    937: 
                    938:    * Parse errors may occur compiling X11 on a Decstation running
                    939:      Ultrix 4.2 because of problems in DEC's versions of the X11 header
                    940:      files `X11/Xlib.h' and `X11/Xutil.h'.  People recommend adding
                    941:      `-I/usr/include/mit' to use the MIT versions of the header files,
                    942:      using the `-traditional' switch to turn off ANSI C, or fixing the
                    943:      header files by adding this:
                    944: 
                    945:           #ifdef __STDC__
                    946:           #define NeedFunctionPrototypes 0
                    947:           #endif
                    948: 
                    949:    * If you have trouble compiling Perl on a SunOS 4 system, it may be
                    950:      because Perl specifies `-I/usr/ucbinclude'.  This accesses the
                    951:      unfixed header files.  Perl specifies the options
                    952: 
                    953:           -traditional -Dvolatile=__volatile__
                    954:           -I/usr/include/sun -I/usr/ucbinclude
                    955:           -fpcc-struct-return
                    956: 
                    957:      all of which are unnecessary with GCC 2.4.5 and newer versions.
                    958:      You can make a properly working Perl by setting `ccflags' and
                    959:      `cppflags' to empty values in `config.sh', then typing `./doSH;
                    960:      make depend; make'.
                    961: 
                    962:    * On various 386 Unix systems derived from System V, including SCO,
                    963:      ISC, and ESIX, you may get error messages about running out of
                    964:      virtual memory while compiling certain programs.
                    965: 
                    966:      You can prevent this problem by linking GNU CC with the GNU malloc
                    967:      (which thus replaces the malloc that comes with the system).  GNU
                    968:      malloc is available as a separate package, and also in the file
                    969:      `src/gmalloc.c' in the GNU Emacs 19 distribution.
                    970: 
                    971:      If you have installed GNU malloc as a separate library package,
                    972:      use this option when you relink GNU CC:
                    973: 
                    974:           MALLOC=/usr/local/lib/libgmalloc.a
                    975: 
                    976:      Alternatively, if you have compiled `gmalloc.c' from Emacs 19, copy
                    977:      the object file to `gmalloc.o' and use this option when you relink
                    978:      GNU CC:
                    979: 
                    980:           MALLOC=gmalloc.o
                    981: 

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.