|
|
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: Bug Reporting, Next: Sending Patches, Prev: Bug Lists, Up: Bugs
32:
33: How to Report Bugs
34: ==================
35:
36: The fundamental principle of reporting bugs usefully is this:
37: *report all the facts*. If you are not sure whether to state a fact or
38: leave it out, state it!
39:
40: Often people omit facts because they think they know what causes the
41: problem and they conclude that some details don't matter. Thus, you
42: might assume that the name of the variable you use in an example does
43: not matter. Well, probably it doesn't, but one cannot be sure.
44: Perhaps the bug is a stray memory reference which happens to fetch from
45: the location where that name is stored in memory; perhaps, if the name
46: were different, the contents of that location would fool the compiler
47: into doing the right thing despite the bug. Play it safe and give a
48: specific, complete example. That is the easiest thing for you to do,
49: and the most helpful.
50:
51: Keep in mind that the purpose of a bug report is to enable someone to
52: fix the bug if it is not known. It isn't very important what happens if
53: the bug is already known. Therefore, always write your bug reports on
54: the assumption that the bug is not known.
55:
56: Sometimes people give a few sketchy facts and ask, "Does this ring a
57: bell?" This cannot help us fix a bug, so it is basically useless. We
58: respond by asking for enough details to enable us to investigate. You
59: might as well expedite matters by sending them to begin with.
60:
61: Try to make your bug report self-contained. If we have to ask you
62: for more information, it is best if you include all the previous
63: information in your response, as well as the information that was
64: missing.
65:
66: To enable someone to investigate the bug, you should include all
67: these things:
68:
69: * The version of GNU CC. You can get this by running it with the
70: `-v' option.
71:
72: Without this, we won't know whether there is any point in looking
73: for the bug in the current version of GNU CC.
74:
75: * A complete input file that will reproduce the bug. If the bug is
76: in the C preprocessor, send a source file and any header files
77: that it requires. If the bug is in the compiler proper (`cc1'),
78: run your source file through the C preprocessor by doing `gcc -E
79: SOURCEFILE > OUTFILE', then include the contents of OUTFILE in the
80: bug report. (When you do this, use the same `-I', `-D' or `-U'
81: options that you used in actual compilation.)
82:
83: A single statement is not enough of an example. In order to
84: compile it, it must be embedded in a complete file of compiler
85: input; and the bug might depend on the details of how this is done.
86:
87: Without a real example one can compile, all anyone can do about
88: your bug report is wish you luck. It would be futile to try to
89: guess how to provoke the bug. For example, bugs in register
90: allocation and reloading frequently depend on every little detail
91: of the function they happen in.
92:
93: Even if the input file that fails comes from a GNU program, you
94: should still send the complete test case. Don't ask the GNU CC
95: maintainers to do the extra work of obtaining the program in
96: question--they are all overworked as it is. Also, the problem may
97: depend on what is in the header files on your system; it is
98: unreliable for the GNU CC maintainers to try the problem with the
99: header files available to them. By sending CPP output, you can
100: eliminate this source of uncertainty and save us a certain
101: percentage of wild goose chases.
102:
103: * The command arguments you gave GNU CC or GNU C++ to compile that
104: example and observe the bug. For example, did you use `-O'? To
105: guarantee you won't omit something important, list all the options.
106:
107: If we were to try to guess the arguments, we would probably guess
108: wrong and then we would not encounter the bug.
109:
110: * The type of machine you are using, and the operating system name
111: and version number.
112:
113: * The operands you gave to the `configure' command when you installed
114: the compiler.
115:
116: * A complete list of any modifications you have made to the compiler
117: source. (We don't promise to investigate the bug unless it
118: happens in an unmodified compiler. But if you've made
119: modifications and don't tell us, then you are sending us on a wild
120: goose chase.)
121:
122: Be precise about these changes. A description in English is not
123: enough--send a context diff for them.
124:
125: Adding files of your own (such as a machine description for a
126: machine we don't support) is a modification of the compiler source.
127:
128: * Details of any other deviations from the standard procedure for
129: installing GNU CC.
130:
131: * A description of what behavior you observe that you believe is
132: incorrect. For example, "The compiler gets a fatal signal," or,
133: "The assembler instruction at line 208 in the output is incorrect."
134:
135: Of course, if the bug is that the compiler gets a fatal signal,
136: then one can't miss it. But if the bug is incorrect output, the
137: maintainer might not notice unless it is glaringly wrong. None of
138: us has time to study all the assembler code from a 50-line C
139: program just on the chance that one instruction might be wrong.
140: We need *you* to do this part!
141:
142: Even if the problem you experience is a fatal signal, you should
143: still say so explicitly. Suppose something strange is going on,
144: such as, your copy of the compiler is out of synch, or you have
145: encountered a bug in the C library on your system. (This has
146: happened!) Your copy might crash and the copy here would not. If
147: you said to expect a crash, then when the compiler here fails to
148: crash, we would know that the bug was not happening. If you don't
149: say to expect a crash, then we would not know whether the bug was
150: happening. We would not be able to draw any conclusion from our
151: observations.
152:
153: If the problem is a diagnostic when compiling GNU CC with some
154: other compiler, say whether it is a warning or an error.
155:
156: Often the observed symptom is incorrect output when your program
157: is run. Sad to say, this is not enough information unless the
158: program is short and simple. None of us has time to study a large
159: program to figure out how it would work if compiled correctly,
160: much less which line of it was compiled wrong. So you will have
161: to do that. Tell us which source line it is, and what incorrect
162: result happens when that line is executed. A person who
163: understands the program can find this as easily as finding a bug
164: in the program itself.
165:
166: * If you send examples of assembler code output from GNU CC or GNU
167: C++, please use `-g' when you make them. The debugging information
168: includes source line numbers which are essential for correlating
169: the output with the input.
170:
171: * If you wish to mention something in the GNU CC source, refer to it
172: by context, not by line number.
173:
174: The line numbers in the development sources don't match those in
175: your sources. Your line numbers would convey no useful
176: information to the maintainers.
177:
178: * Additional information from a debugger might enable someone to
179: find a problem on a machine which he does not have available.
180: However, you need to think when you collect this information if
181: you want it to have any chance of being useful.
182:
183: For example, many people send just a backtrace, but that is never
184: useful by itself. A simple backtrace with arguments conveys little
185: about GNU CC because the compiler is largely data-driven; the same
186: functions are called over and over for different RTL insns, doing
187: different things depending on the details of the insn.
188:
189: Most of the arguments listed in the backtrace are useless because
190: they are pointers to RTL list structure. The numeric values of the
191: pointers, which the debugger prints in the backtrace, have no
192: significance whatever; all that matters is the contents of the
193: objects they point to (and most of the contents are other such
194: pointers).
195:
196: In addition, most compiler passes consist of one or more loops that
197: scan the RTL insn sequence. The most vital piece of information
198: about such a loop--which insn it has reached--is usually in a
199: local variable, not in an argument.
200:
201: What you need to provide in addition to a backtrace are the values
202: of the local variables for several stack frames up. When a local
203: variable or an argument is an RTX, first print its value and then
204: use the GDB command `pr' to print the RTL expression that it points
205: to. (If GDB doesn't run on your machine, use your debugger to call
206: the function `debug_rtx' with the RTX as an argument.) In
207: general, whenever a variable is a pointer, its value is no use
208: without the data it points to.
209:
210: Here are some things that are not necessary:
211:
212: * A description of the envelope of the bug.
213:
214: Often people who encounter a bug spend a lot of time investigating
215: which changes to the input file will make the bug go away and which
216: changes will not affect it.
217:
218: This is often time consuming and not very useful, because the way
219: we will find the bug is by running a single example under the
220: debugger with breakpoints, not by pure deduction from a series of
221: examples. You might as well save your time for something else.
222:
223: Of course, if you can find a simpler example to report *instead* of
224: the original one, that is a convenience. Errors in the output
225: will be easier to spot, running under the debugger will take less
226: time, etc. Most GNU CC bugs involve just one function, so the
227: most straightforward way to simplify an example is to delete all
228: the function definitions except the one where the bug occurs.
229: Those earlier in the file may be replaced by external declarations
230: if the crucial function depends on them. (Exception: inline
231: functions may affect compilation of functions defined later in the
232: file.)
233:
234: However, simplification is not vital; if you don't want to do this,
235: report the bug anyway and send the entire test case you used.
236:
237: * In particular, some people insert conditionals `#ifdef BUG' around
238: a statement which, if removed, makes the bug not happen. These
239: are just clutter; we won't pay any attention to them anyway.
240: Besides, you should send us cpp output, and that can't have
241: conditionals.
242:
243: * A patch for the bug.
244:
245: A patch for the bug is useful if it is a good one. But don't omit
246: the necessary information, such as the test case, on the
247: assumption that a patch is all we need. We might see problems
248: with your patch and decide to fix the problem another way, or we
249: might not understand it at all.
250:
251: Sometimes with a program as complicated as GNU CC it is very hard
252: to construct an example that will make the program follow a
253: certain path through the code. If you don't send the example, we
254: won't be able to construct one, so we won't be able to verify that
255: the bug is fixed.
256:
257: And if we can't understand what bug you are trying to fix, or why
258: your patch should be an improvement, we won't install it. A test
259: case will help us to understand.
260:
261: *Note Sending Patches::, for guidelines on how to make it easy for
262: us to understand and install your patches.
263:
264: * A guess about what the bug is or what it depends on.
265:
266: Such guesses are usually wrong. Even I can't guess right about
267: such things without first using the debugger to find the facts.
268:
269: * A core dump file.
270:
271: We have no way of examining a core dump for your type of machine
272: unless we have an identical system--and if we do have one, we
273: should be able to reproduce the crash ourselves.
274:
275:
276: File: gcc.info, Node: Sending Patches, Prev: Bug Reporting, Up: Bugs
277:
278: Sending Patches for GNU CC
279: ==========================
280:
281: If you would like to write bug fixes or improvements for the GNU C
282: compiler, that is very helpful. When you send your changes, please
283: follow these guidelines to avoid causing extra work for us in studying
284: the patches.
285:
286: If you don't follow these guidelines, your information might still be
287: useful, but using it will take extra work. Maintaining GNU C is a lot
288: of work in the best of circumstances, and we can't keep up unless you do
289: your best to help.
290:
291: * Send an explanation with your changes of what problem they fix or
292: what improvement they bring about. For a bug fix, just include a
293: copy of the bug report, and explain why the change fixes the bug.
294:
295: (Referring to a bug report is not as good as including it, because
296: then we will have to look it up, and we have probably already
297: deleted it if we've already fixed the bug.)
298:
299: * Always include a proper bug report for the problem you think you
300: have fixed. We need to convince ourselves that the change is
301: right before installing it. Even if it is right, we might have
302: trouble judging it if we don't have a way to reproduce the problem.
303:
304: * Include all the comments that are appropriate to help people
305: reading the source in the future understand why this change was
306: needed.
307:
308: * Don't mix together changes made for different reasons. Send them
309: *individually*.
310:
311: If you make two changes for separate reasons, then we might not
312: want to install them both. We might want to install just one. If
313: you send them all jumbled together in a single set of diffs, we
314: have to do extra work to disentangle them--to figure out which
315: parts of the change serve which purpose. If we don't have time
316: for this, we might have to ignore your changes entirely.
317:
318: If you send each change as soon as you have written it, with its
319: own explanation, then the two changes never get tangled up, and we
320: can consider each one properly without any extra work to
321: disentangle them.
322:
323: Ideally, each change you send should be impossible to subdivide
324: into parts that we might want to consider separately, because each
325: of its parts gets its motivation from the other parts.
326:
327: * Send each change as soon as that change is finished. Sometimes
328: people think they are helping us by accumulating many changes to
329: send them all together. As explained above, this is absolutely
330: the worst thing you could do.
331:
332: Since you should send each change separately, you might as well
333: send it right away. That gives us the option of installing it
334: immediately if it is important.
335:
336: * Use `diff -c' to make your diffs. Diffs without context are hard
337: for us to install reliably. More than that, they make it hard for
338: us to study the diffs to decide whether we want to install them.
339: Unidiff format is better than contextless diffs, but not as easy
340: to read as `-c' format.
341:
342: If you have GNU diff, use `diff -cp', which shows the name of the
343: function that each change occurs in.
344:
345: * Write the change log entries for your changes. We get lots of
346: changes, and we don't have time to do all the change log writing
347: ourselves.
348:
349: Read the `ChangeLog' file to see what sorts of information to put
350: in, and to learn the style that we use. The purpose of the change
351: log is to show people where to find what was changed. So you need
352: to be specific about what functions you changed; in large
353: functions, it's often helpful to indicate where within the
354: function the change was.
355:
356: On the other hand, once you have shown people where to find the
357: change, you need not explain its purpose. Thus, if you add a new
358: function, all you need to say about it is that it is new. If you
359: feel that the purpose needs explaining, it probably does--but the
360: explanation will be much more useful if you put it in comments in
361: the code.
362:
363: If you would like your name to appear in the header line for who
364: made the change, send us the header line.
365:
366: * When you write the fix, keep in mind that we can't install a
367: change that would break other systems.
368:
369: People often suggest fixing a problem by changing
370: machine-independent files such as `toplev.c' to do something
371: special that a particular system needs. Sometimes it is totally
372: obvious that such changes would break GNU CC for almost all users.
373: We can't possibly make a change like that. At best it might tell
374: us how to write another patch that would solve the problem
375: acceptably.
376:
377: Sometimes people send fixes that *might* be an improvement in
378: general--but it is hard to be sure of this. It's hard to install
379: such changes because we have to study them very carefully. Of
380: course, a good explanation of the reasoning by which you concluded
381: the change was correct can help convince us.
382:
383: The safest changes are changes to the configuration files for a
384: particular machine. These are safe because they can't create new
385: bugs on other machines.
386:
387: Please help us keep up with the workload by designing the patch in
388: a form that is good to install.
389:
390:
391: File: gcc.info, Node: Service, Next: VMS, Prev: Bugs, Up: Top
392:
393: How To Get Help with GNU CC
394: ***************************
395:
396: If you need help installing, using or changing GNU CC, there are two
397: ways to find it:
398:
399: * Send a message to a suitable network mailing list. First try
400: `[email protected]', and if that brings no response, try
401: `[email protected]'.
402:
403: * Look in the service directory for someone who might help you for a
404: fee. The service directory is found in the file named `SERVICE'
405: in the GNU CC distribution.
406:
407:
408: File: gcc.info, Node: VMS, Next: Portability, Prev: Service, Up: Top
409:
410: Using GNU CC on VMS
411: *******************
412:
413: * Menu:
414:
415: * Include Files and VMS:: Where the preprocessor looks for the include files.
416: * Global Declarations:: How to do globaldef, globalref and globalvalue with
417: GNU CC.
418: * VMS Misc:: Misc information.
419:
420:
421: File: gcc.info, Node: Include Files and VMS, Next: Global Declarations, Up: VMS
422:
423: Include Files and VMS
424: =====================
425:
426: Due to the differences between the filesystems of Unix and VMS, GNU
427: CC attempts to translate file names in `#include' into names that VMS
428: will understand. The basic strategy is to prepend a prefix to the
429: specification of the include file, convert the whole filename to a VMS
430: filename, and then try to open the file. GNU CC tries various prefixes
431: one by one until one of them succeeds:
432:
433: 1. The first prefix is the `GNU_CC_INCLUDE:' logical name: this is
434: where GNU C header files are traditionally stored. If you wish to
435: store header files in non-standard locations, then you can assign
436: the logical `GNU_CC_INCLUDE' to be a search list, where each
437: element of the list is suitable for use with a rooted logical.
438:
439: 2. The next prefix tried is `SYS$SYSROOT:[SYSLIB.]'. This is where
440: VAX-C header files are traditionally stored.
441:
442: 3. If the include file specification by itself is a valid VMS
443: filename, the preprocessor then uses this name with no prefix in
444: an attempt to open the include file.
445:
446: 4. If the file specification is not a valid VMS filename (i.e. does
447: not contain a device or a directory specifier, and contains a `/'
448: character), the preprocessor tries to convert it from Unix syntax
449: to VMS syntax.
450:
451: Conversion works like this: the first directory name becomes a
452: device, and the rest of the directories are converted into
453: VMS-format directory names. For example, the name `X11/foobar.h'
454: is translated to `X11:[000000]foobar.h' or `X11:foobar.h',
455: whichever one can be opened. This strategy allows you to assign a
456: logical name to point to the actual location of the header files.
457:
458: 5. If none of these strategies succeeds, the `#include' fails.
459:
460: Include directives of the form:
461:
462: #include foobar
463:
464: are a common source of incompatibility between VAX-C and GNU CC. VAX-C
465: treats this much like a standard `#include <foobar.h>' directive. That
466: is incompatible with the ANSI C behavior implemented by GNU CC: to
467: expand the name `foobar' as a macro. Macro expansion should eventually
468: yield one of the two standard formats for `#include':
469:
470: #include "FILE"
471: #include <FILE>
472:
473: If you have this problem, the best solution is to modify the source
474: to convert the `#include' directives to one of the two standard forms.
475: That will work with either compiler. If you want a quick and dirty fix,
476: define the file names as macros with the proper expansion, like this:
477:
478: #define stdio <stdio.h>
479:
480: This will work, as long as the name doesn't conflict with anything else
481: in the program.
482:
483: Another source of incompatibility is that VAX-C assumes that:
484:
485: #include "foobar"
486:
487: is actually asking for the file `foobar.h'. GNU CC does not make this
488: assumption, and instead takes what you ask for literally; it tries to
489: read the file `foobar'. The best way to avoid this problem is to
490: always specify the desired file extension in your include directives.
491:
492: GNU CC for VMS is distributed with a set of include files that is
493: sufficient to compile most general purpose programs. Even though the
494: GNU CC distribution does not contain header files to define constants
495: and structures for some VMS system-specific functions, there is no
496: reason why you cannot use GNU CC with any of these functions. You first
497: may have to generate or create header files, either by using the public
498: domain utility `UNSDL' (which can be found on a DECUS tape), or by
499: extracting the relevant modules from one of the system macro libraries,
500: and using an editor to construct a C header file.
501:
502: A `#include' file name cannot contain a DECNET node name. The
503: preprocessor reports an I/O error if you attempt to use a node name,
504: whether explicitly, or implicitly via a logical name.
505:
506:
507: File: gcc.info, Node: Global Declarations, Next: VMS Misc, Prev: Include Files and VMS, Up: VMS
508:
509: Global Declarations and VMS
510: ===========================
511:
512: GNU CC does not provide the `globalref', `globaldef' and
513: `globalvalue' keywords of VAX-C. You can get the same effect with an
514: obscure feature of GAS, the GNU assembler. (This requires GAS version
515: 1.39 or later.) The following macros allow you to use this feature in
516: a fairly natural way:
517:
518: #ifdef __GNUC__
519: #define GLOBALREF(TYPE,NAME) \
520: TYPE NAME \
521: asm ("_$$PsectAttributes_GLOBALSYMBOL$$" #NAME)
522: #define GLOBALDEF(TYPE,NAME,VALUE) \
523: TYPE NAME \
524: asm ("_$$PsectAttributes_GLOBALSYMBOL$$" #NAME) \
525: = VALUE
526: #define GLOBALVALUEREF(TYPE,NAME) \
527: const TYPE NAME[1] \
528: asm ("_$$PsectAttributes_GLOBALVALUE$$" #NAME)
529: #define GLOBALVALUEDEF(TYPE,NAME,VALUE) \
530: const TYPE NAME[1] \
531: asm ("_$$PsectAttributes_GLOBALVALUE$$" #NAME) \
532: = {VALUE}
533: #else
534: #define GLOBALREF(TYPE,NAME) \
535: globalref TYPE NAME
536: #define GLOBALDEF(TYPE,NAME,VALUE) \
537: globaldef TYPE NAME = VALUE
538: #define GLOBALVALUEDEF(TYPE,NAME,VALUE) \
539: globalvalue TYPE NAME = VALUE
540: #define GLOBALVALUEREF(TYPE,NAME) \
541: globalvalue TYPE NAME
542: #endif
543:
544: (The `_$$PsectAttributes_GLOBALSYMBOL' prefix at the start of the name
545: is removed by the assembler, after it has modified the attributes of
546: the symbol). These macros are provided in the VMS binaries
547: distribution in a header file `GNU_HACKS.H'. An example of the usage
548: is:
549:
550: GLOBALREF (int, ijk);
551: GLOBALDEF (int, jkl, 0);
552:
553: The macros `GLOBALREF' and `GLOBALDEF' cannot be used
554: straightforwardly for arrays, since there is no way to insert the array
555: dimension into the declaration at the right place. However, you can
556: declare an array with these macros if you first define a typedef for the
557: array type, like this:
558:
559: typedef int intvector[10];
560: GLOBALREF (intvector, foo);
561:
562: Array and structure initializers will also break the macros; you can
563: define the initializer to be a macro of its own, or you can expand the
564: `GLOBALDEF' macro by hand. You may find a case where you wish to use
565: the `GLOBALDEF' macro with a large array, but you are not interested in
566: explicitly initializing each element of the array. In such cases you
567: can use an initializer like: `{0,}', which will initialize the entire
568: array to `0'.
569:
570: A shortcoming of this implementation is that a variable declared with
571: `GLOBALVALUEREF' or `GLOBALVALUEDEF' is always an array. For example,
572: the declaration:
573:
574: GLOBALVALUEREF(int, ijk);
575:
576: declares the variable `ijk' as an array of type `int [1]'. This is
577: done because a globalvalue is actually a constant; its "value" is what
578: the linker would normally consider an address. That is not how an
579: integer value works in C, but it is how an array works. So treating
580: the symbol as an array name gives consistent results--with the
581: exception that the value seems to have the wrong type. *Don't try to
582: access an element of the array.* It doesn't have any elements. The
583: array "address" may not be the address of actual storage.
584:
585: The fact that the symbol is an array may lead to warnings where the
586: variable is used. Insert type casts to avoid the warnings. Here is an
587: example; it takes advantage of the ANSI C feature allowing macros that
588: expand to use the same name as the macro itself.
589:
590: GLOBALVALUEREF (int, ss$_normal);
591: GLOBALVALUEDEF (int, xyzzy,123);
592: #ifdef __GNUC__
593: #define ss$_normal ((int) ss$_normal)
594: #define xyzzy ((int) xyzzy)
595: #endif
596:
597: Don't use `globaldef' or `globalref' with a variable whose type is
598: an enumeration type; this is not implemented. Instead, make the
599: variable an integer, and use a `globalvaluedef' for each of the
600: enumeration values. An example of this would be:
601:
602: #ifdef __GNUC__
603: GLOBALDEF (int, color, 0);
604: GLOBALVALUEDEF (int, RED, 0);
605: GLOBALVALUEDEF (int, BLUE, 1);
606: GLOBALVALUEDEF (int, GREEN, 3);
607: #else
608: enum globaldef color {RED, BLUE, GREEN = 3};
609: #endif
610:
611:
612: File: gcc.info, Node: VMS Misc, Prev: Global Declarations, Up: VMS
613:
614: Other VMS Issues
615: ================
616:
617: GNU CC automatically arranges for `main' to return 1 by default if
618: you fail to specify an explicit return value. This will be interpreted
619: by VMS as a status code indicating a normal successful completion.
620: Version 1 of GNU CC did not provide this default.
621:
622: GNU CC on VMS works only with the GNU assembler, GAS. You need
623: version 1.37 or later of GAS in order to produce value debugging
624: information for the VMS debugger. Use the ordinary VMS linker with the
625: object files produced by GAS.
626:
627: Under previous versions of GNU CC, the generated code would
628: occasionally give strange results when linked to the sharable `VAXCRTL'
629: library. Now this should work.
630:
631: A caveat for use of `const' global variables: the `const' modifier
632: must be specified in every external declaration of the variable in all
633: of the source files that use that variable. Otherwise the linker will
634: issue warnings about conflicting attributes for the variable. Your
635: program will still work despite the warnings, but the variable will be
636: placed in writable storage.
637:
638: Although the VMS linker does distinguish between upper and lower case
639: letters in global symbols, most VMS compilers convert all such symbols
640: into upper case and most run-time library routines also have upper case
641: names. To be able to reliably call such routines, GNU CC (by means of
642: the assembler GAS) converts global symbols into upper case like other
643: VMS compilers. However, since the usual practice in C is to distinguish
644: case, GNU CC (via GAS) tries to preserve usual C behavior by augmenting
645: each name that is not all lower case. This means truncating the name
646: to at most 23 characters and then adding more characters at the end
647: which encode the case pattern of those 23. Names which contain at
648: least one dollar sign are an exception; they are converted directly into
649: upper case without augmentation.
650:
651: Name augmentation yields bad results for programs that use
652: precompiled libraries (such as Xlib) which were generated by another
653: compiler. You can use the compiler option `/NOCASE_HACK' to inhibit
654: augmentation; it makes external C functions and variables
655: case-independent as is usual on VMS. Alternatively, you could write
656: all references to the functions and variables in such libraries using
657: lower case; this will work on VMS, but is not portable to other
658: systems. The compiler option `/NAMES' also provides control over
659: global name handling.
660:
661: Function and variable names are handled somewhat differently with GNU
662: C++. The GNU C++ compiler performs "name mangling" on function names,
663: which means that it adds information to the function name to describe
664: the data types of the arguments that the function takes. One result of
665: this is that the name of a function can become very long. Since the
666: VMS linker only recognizes the first 31 characters in a name, special
667: action is taken to ensure that each function and variable has a unique
668: name that can be represented in 31 characters.
669:
670: If the name (plus a name augmentation, if required) is less than 32
671: characters in length, then no special action is performed. If the name
672: is longer than 31 characters, the assembler (GAS) will generate a hash
673: string based upon the function name, truncate the function name to 23
674: characters, and append the hash string to the truncated name. If the
675: `/VERBOSE' compiler option is used, the assembler will print both the
676: full and truncated names of each symbol that is truncated.
677:
678: The `/NOCASE_HACK' compiler option should not be used when you are
679: compiling programs that use libg++. libg++ has several instances of
680: objects (i.e. `Filebuf' and `filebuf') which become indistinguishable
681: in a case-insensitive environment. This leads to cases where you need
682: to inhibit augmentation selectively (if you were using libg++ and Xlib
683: in the same program, for example). There is no special feature for
684: doing this, but you can get the result by defining a macro for each
685: mixed case symbol for which you wish to inhibit augmentation. The
686: macro should expand into the lower case equivalent of itself. For
687: example:
688:
689: #define StuDlyCapS studlycaps
690:
691: These macro definitions can be placed in a header file to minimize
692: the number of changes to your source code.
693:
694:
695: File: gcc.info, Node: Portability, Next: Interface, Prev: VMS, Up: Top
696:
697: GNU CC and Portability
698: **********************
699:
700: The main goal of GNU CC was to make a good, fast compiler for
701: machines in the class that the GNU system aims to run on: 32-bit
702: machines that address 8-bit bytes and have several general registers.
703: Elegance, theoretical power and simplicity are only secondary.
704:
705: GNU CC gets most of the information about the target machine from a
706: machine description which gives an algebraic formula for each of the
707: machine's instructions. This is a very clean way to describe the
708: target. But when the compiler needs information that is difficult to
709: express in this fashion, I have not hesitated to define an ad-hoc
710: parameter to the machine description. The purpose of portability is to
711: reduce the total work needed on the compiler; it was not of interest
712: for its own sake.
713:
714: GNU CC does not contain machine dependent code, but it does contain
715: code that depends on machine parameters such as endianness (whether the
716: most significant byte has the highest or lowest address of the bytes in
717: a word) and the availability of autoincrement addressing. In the
718: RTL-generation pass, it is often necessary to have multiple strategies
719: for generating code for a particular kind of syntax tree, strategies
720: that are usable for different combinations of parameters. Often I have
721: not tried to address all possible cases, but only the common ones or
722: only the ones that I have encountered. As a result, a new target may
723: require additional strategies. You will know if this happens because
724: the compiler will call `abort'. Fortunately, the new strategies can be
725: added in a machine-independent fashion, and will affect only the target
726: machines that need them.
727:
728:
729: File: gcc.info, Node: Interface, Next: Passes, Prev: Portability, Up: Top
730:
731: Interfacing to GNU CC Output
732: ****************************
733:
734: GNU CC is normally configured to use the same function calling
735: convention normally in use on the target system. This is done with the
736: machine-description macros described (*note Target Macros::.).
737:
738: However, returning of structure and union values is done differently
739: on some target machines. As a result, functions compiled with PCC
740: returning such types cannot be called from code compiled with GNU CC,
741: and vice versa. This does not cause trouble often because few Unix
742: library routines return structures or unions.
743:
744: GNU CC code returns structures and unions that are 1, 2, 4 or 8 bytes
745: long in the same registers used for `int' or `double' return values.
746: (GNU CC typically allocates variables of such types in registers also.)
747: Structures and unions of other sizes are returned by storing them into
748: an address passed by the caller (usually in a register). The
749: machine-description macros `STRUCT_VALUE' and `STRUCT_INCOMING_VALUE'
750: tell GNU CC where to pass this address.
751:
752: By contrast, PCC on most target machines returns structures and
753: unions of any size by copying the data into an area of static storage,
754: and then returning the address of that storage as if it were a pointer
755: value. The caller must copy the data from that memory area to the
756: place where the value is wanted. This is slower than the method used
757: by GNU CC, and fails to be reentrant.
758:
759: On some target machines, such as RISC machines and the 80386, the
760: standard system convention is to pass to the subroutine the address of
761: where to return the value. On these machines, GNU CC has been
762: configured to be compatible with the standard compiler, when this method
763: is used. It may not be compatible for structures of 1, 2, 4 or 8 bytes.
764:
765: GNU CC uses the system's standard convention for passing arguments.
766: On some machines, the first few arguments are passed in registers; in
767: others, all are passed on the stack. It would be possible to use
768: registers for argument passing on any machine, and this would probably
769: result in a significant speedup. But the result would be complete
770: incompatibility with code that follows the standard convention. So this
771: change is practical only if you are switching to GNU CC as the sole C
772: compiler for the system. We may implement register argument passing on
773: certain machines once we have a complete GNU system so that we can
774: compile the libraries with GNU CC.
775:
776: On some machines (particularly the Sparc), certain types of arguments
777: are passed "by invisible reference". This means that the value is
778: stored in memory, and the address of the memory location is passed to
779: the subroutine.
780:
781: If you use `longjmp', beware of automatic variables. ANSI C says
782: that automatic variables that are not declared `volatile' have undefined
783: values after a `longjmp'. And this is all GNU CC promises to do,
784: because it is very difficult to restore register variables correctly,
785: and one of GNU CC's features is that it can put variables in registers
786: without your asking it to.
787:
788: If you want a variable to be unaltered by `longjmp', and you don't
789: want to write `volatile' because old C compilers don't accept it, just
790: take the address of the variable. If a variable's address is ever
791: taken, even if just to compute it and ignore it, then the variable
792: cannot go in a register:
793:
794: {
795: int careful;
796: &careful;
797: ...
798: }
799:
800: Code compiled with GNU CC may call certain library routines. Most of
801: them handle arithmetic for which there are no instructions. This
802: includes multiply and divide on some machines, and floating point
803: operations on any machine for which floating point support is disabled
804: with `-msoft-float'. Some standard parts of the C library, such as
805: `bcopy' or `memcpy', are also called automatically. The usual function
806: call interface is used for calling the library routines.
807:
808: These library routines should be defined in the library `libgcc.a',
809: which GNU CC automatically searches whenever it links a program. On
810: machines that have multiply and divide instructions, if hardware
811: floating point is in use, normally `libgcc.a' is not needed, but it is
812: searched just in case.
813:
814: Each arithmetic function is defined in `libgcc1.c' to use the
815: corresponding C arithmetic operator. As long as the file is compiled
816: with another C compiler, which supports all the C arithmetic operators,
817: this file will work portably. However, `libgcc1.c' does not work if
818: compiled with GNU CC, because each arithmetic function would compile
819: into a call to itself!
820:
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.