re PR c/2291 (Pedantic may be too pedantic)
authorJoseph Myers <jsm28@cam.ac.uk>
Sun, 20 May 2001 12:49:31 +0000 (13:49 +0100)
committerJoseph Myers <jsm28@gcc.gnu.org>
Sun, 20 May 2001 12:49:31 +0000 (13:49 +0100)
* invoke.texi: Document meaning of -pedantic when -std=gnu* is
used.  Fixes PR c/2291.
* gcc.1: Regenerate.

From-SVN: r42340

gcc/ChangeLog
gcc/gcc.1
gcc/invoke.texi

index 8b2d873767d4676410fcfeeebb7bb02197218742..98651ea719ad0e2486affb4322b3eca579127fce 100644 (file)
@@ -1,3 +1,9 @@
+2001-05-20  Joseph S. Myers  <jsm28@cam.ac.uk>
+
+       * invoke.texi: Document meaning of -pedantic when -std=gnu* is
+       used.  Fixes PR c/2291.
+       * gcc.1: Regenerate.
+
 2001-05-20  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
 
        * config/m68hc11/m68hc11.c (m68hc11_override_options): Ignore
index 4a87440e3d87d8819e7dede42fa6e3234e8ea8d1..98fbab9b6592ad06b8e61738bf96bc3d6ee6e530 100644 (file)
--- a/gcc/gcc.1
+++ b/gcc/gcc.1
@@ -1,5 +1,5 @@
 .\" Automatically generated by Pod::Man version 1.15
-.\" Wed Apr 25 21:39:15 2001
+.\" Sun May 20 12:45:49 2001
 .\"
 .\" Standard preamble:
 .\" ======================================================================
 .\" ======================================================================
 .\"
 .IX Title "GCC 1"
-.TH GCC 1 "gcc-3.1" "2001-04-25" "GNU"
+.TH GCC 1 "gcc-3.1" "2001-05-20" "GNU"
 .UC
 .SH "NAME"
 gcc \- \s-1GNU\s0 project C and \*(C+ compiler
@@ -227,6 +227,11 @@ in the following sections.
 \&\-Wno-non-template-friend  \-Wold-style-cast 
 \&\-Woverloaded-virtual  \-Wno-pmf-conversions 
 \&\-Wsign-promo  \-Wsynth\fR
+.Ip "\fIObjective-C Language Options\fR" 4
+.IX Item "Objective-C Language Options"
+\&\fB\-fconstant-string-class=\fR\fIclass name\fR 
+\&\fB\-fgnu-runtime  \-fnext-runtime  \-gen-decls
+\&\-Wno-protocol  \-Wselector\fR
 .Ip "\fILanguage Independent Options\fR" 4
 .IX Item "Language Independent Options"
 \&\fB\-fmessage-length=\fR\fIn\fR  
@@ -486,11 +491,10 @@ in the following sections.
 \&\fB\-mintel-syntax \-mieee-fp  \-mno-fancy-math-387 
 \&\-mno-fp-ret-in-387  \-msoft-float  \-msvr3\-shlib 
 \&\-mno-wide-multiply  \-mrtd  \-malign-double 
-\&\-malign-jumps=\fR\fInum\fR  \fB\-malign-loops=\fR\fInum\fR 
-\&\fB\-malign-functions=\fR\fInum\fR \fB\-mpreferred-stack-boundary=\fR\fInum\fR 
+\&\-mpreferred-stack-boundary=\fR\fInum\fR 
 \&\fB\-mthreads \-mno-align-stringops \-minline-all-stringops 
 \&\-mpush-args \-maccumulate-outgoing-args \-m128bit-long-double 
-\&\-m96bit-long-double \-mregparm=\fR\fInum\fR
+\&\-m96bit-long-double \-mregparm=\fR\fInum\fR \fB\-momit-leaf-frame-pointer\fR
 .Sp
 \&\fI\s-1HPPA\s0 Options\fR
 .Sp
@@ -833,7 +837,7 @@ C (when compiling C code), or of standard \*(C+ (when compiling \*(C+ code),
 such as the \f(CW\*(C`asm\*(C'\fR and \f(CW\*(C`typeof\*(C'\fR keywords, and
 predefined macros such as \f(CW\*(C`unix\*(C'\fR and \f(CW\*(C`vax\*(C'\fR that identify the
 type of system you are using.  It also enables the undesirable and
-rarely used \s-1ISO\s0 trigraph feature.  For the C compiler, 
+rarely used \s-1ISO\s0 trigraph feature.  For the C compiler,
 it disables recognition of \*(C+ style \fB//\fR comments as well as
 the \f(CW\*(C`inline\*(C'\fR keyword.
 .Sp
@@ -861,7 +865,7 @@ functions with \fB\-ansi\fR is used.
 .Ip "\fB\-std=\fR" 4
 .IX Item "-std="
 Determine the language standard.  A value for this option must be provided;
-possible values are 
+possible values are
 .RS 4
 .Ip "\fBiso9899:1990\fR" 4
 .IX Item "iso9899:1990"
@@ -1160,6 +1164,17 @@ two definitions were merged.
 .Sp
 This option is no longer useful on most targets, now that support has
 been added for putting variables into \s-1BSS\s0 without making them common.
+.Ip "\fB\-fno-const-strings\fR" 4
+.IX Item "-fno-const-strings"
+Give string constants type \f(CW\*(C`char *\*(C'\fR instead of type \f(CW\*(C`const
+char *\*(C'\fR.  By default, G++ uses type \f(CW\*(C`const char *\*(C'\fR as required by
+the standard.  Even if you use \fB\-fno-const-strings\fR, you cannot
+actually modify the value of a string constant, unless you also use
+\&\fB\-fwritable-strings\fR.
+.Sp
+This option might be removed in a future release of G++.  For maximum
+portability, you should structure your code so that it works with
+string constants that have type \f(CW\*(C`const char *\*(C'\fR.
 .Ip "\fB\-fdollars-in-identifiers\fR" 4
 .IX Item "-fdollars-in-identifiers"
 Accept \fB$\fR in identifiers.  You can also explicitly prohibit use of
@@ -1212,7 +1227,7 @@ otherwise be invalid, or have different behavior.
 .Ip "\fB\-fno-gnu-keywords\fR" 4
 .IX Item "-fno-gnu-keywords"
 Do not recognize \f(CW\*(C`typeof\*(C'\fR as a keyword, so that code can use this
-word as an identifier. You can use the keyword \f(CW\*(C`_\|_typeof_\|_\*(C'\fR instead.  
+word as an identifier. You can use the keyword \f(CW\*(C`_\|_typeof_\|_\*(C'\fR instead.
 \&\fB\-ansi\fR implies \fB\-fno-gnu-keywords\fR.
 .Ip "\fB\-fhonor-std\fR" 4
 .IX Item "-fhonor-std"
@@ -1249,6 +1264,11 @@ errors if these functions are not inlined everywhere they are called.
 .IX Item "-fms-extensions"
 Disable pedantic warnings about constructs used in \s-1MFC\s0, such as implicit
 int and getting a pointer to member function via non-standard syntax.
+.Ip "\fB\-fno-nonansi-builtins\fR" 4
+.IX Item "-fno-nonansi-builtins"
+Disable builtin declarations of functions that are not mandated by
+\&\s-1ANSI/ISO\s0 C.  These include \f(CW\*(C`ffs\*(C'\fR, \f(CW\*(C`alloca\*(C'\fR, \f(CW\*(C`_exit\*(C'\fR,
+\&\f(CW\*(C`index\*(C'\fR, \f(CW\*(C`bzero\*(C'\fR, \f(CW\*(C`conjf\*(C'\fR, and other related functions.
 .Ip "\fB\-fno-operator-names\fR" 4
 .IX Item "-fno-operator-names"
 Do not treat the operator name keywords \f(CW\*(C`and\*(C'\fR, \f(CW\*(C`bitand\*(C'\fR,
@@ -1277,6 +1297,10 @@ functions for use by the \*(C+ runtime type identification features
 of the language, you can save some space by using this flag.  Note that
 exception handling uses the same information, but it will generate it as
 needed.
+.Ip "\fB\-fstats\fR" 4
+.IX Item "-fstats"
+Emit statistics about front-end processing at the end of the compilation.
+This information is generally only useful to the G++ development team.
 .Ip "\fB\-ftemplate-depth-\fR\fIn\fR" 4
 .IX Item "-ftemplate-depth-n"
 Set the maximum instantiation depth for template classes to \fIn\fR.
@@ -1306,6 +1330,13 @@ those.
 .Sp
 Like all options that change the \s-1ABI\s0, all \*(C+ code, \fIincluding
 libgcc.a\fR must be built with the same setting of this option.
+.Ip "\fB\-fno-weak\fR" 4
+.IX Item "-fno-weak"
+Do not use weak symbol support, even if it is provied by the linker.
+By default, G++ will use weak symbols if they are available.  This
+option exists only for testing, and should not be used by end-users;
+it will result in inferior code and has no benefits.  This option may
+be removed in a future release of G++.
 .Ip "\fB\-nostdinc++\fR" 4
 .IX Item "-nostdinc++"
 Do not search for header files in the standard directories specific to
@@ -1428,6 +1459,46 @@ instance:
 .Ve
 In this example, g++ will synthesize a default \fBA& operator =
 (const A&);\fR, while cfront will use the user-defined \fBoperator =\fR.
+.Sh "Options Controlling Objective-C Dialect"
+.IX Subsection "Options Controlling Objective-C Dialect"
+This section describes the command-line options that are only meaningful
+for Objective-C programs; but you can also use most of the \s-1GNU\s0 compiler
+options regardless of what language your program is in.  For example,
+you might compile a file \f(CW\*(C`some_class.m\*(C'\fR like this:
+.PP
+.Vb 1
+\&        gcc -g -fgnu-runtime -O -c some_class.m
+.Ve
+In this example, only \fB\-fgnu-runtime\fR is an option meant only for
+Objective-C programs; you can use the other options with any language
+supported by \s-1GCC\s0.
+.PP
+Here is a list of options that are \fIonly\fR for compiling Objective-C
+programs:
+.Ip "\fB\-fconstant-string-class=\fR\fIclass name\fR" 4
+.IX Item "-fconstant-string-class=class name"
+Use \fIclass name\fR as the name of the class to instantiate for each
+literal string specified with the syntax \f(CW\*(C`@"..."\*(C'\fR.  The default
+class name is \f(CW\*(C`NXConstantString\*(C'\fR.
+.Ip "\fB\-fgnu-runtime\fR" 4
+.IX Item "-fgnu-runtime"
+Generate object code compatible with the standard \s-1GNU\s0 Objective-C
+runtime.  This is the default for most types of systems.
+.Ip "\fB\-fnext-runtime\fR" 4
+.IX Item "-fnext-runtime"
+Generate output compatible with the NeXT runtime.  This is the default
+for NeXT-based systems, including Darwin and Mac \s-1OS\s0 X.
+.Ip "\fB\-gen-decls\fR" 4
+.IX Item "-gen-decls"
+Dump interface declarations for all classes seen in the source file to a
+file named \fI\fIsourcename\fI.decl\fR.
+.Ip "\fB\-Wno-protocol\fR" 4
+.IX Item "-Wno-protocol"
+Do not warn if methods required by a protocol are not implemented
+in the class adopting it.
+.Ip "\fB\-Wselector\fR" 4
+.IX Item "-Wselector"
+Warn if a selector has multiple methods of different types defined.
 .Sh "Options to Control Diagnostic Messages Formatting"
 .IX Subsection "Options to Control Diagnostic Messages Formatting"
 Traditionally, diagnostic messages have been formatted irrespective of
@@ -1436,13 +1507,13 @@ below can be used to control the diagnostic messages formatting
 algorithm, e.g. how many characters per line, how often source location
 information should be reported.  Right now, only the \*(C+ front-end can
 honor these options.  However it is expected, in the near future, that
-the remaining front-ends would be able to digest them correctly. 
+the remaining front-ends would be able to digest them correctly.
 .Ip "\fB\-fmessage-length=\fR\fIn\fR" 4
 .IX Item "-fmessage-length=n"
 Try to format error messages so that they fit on lines of about \fIn\fR
 characters.  The default is 72 characters for g++ and 0 for the rest of
 the front-ends supported by \s-1GCC\s0.  If \fIn\fR is zero, then no
-line-wrapping will be done; each error message will appear on a single 
+line-wrapping will be done; each error message will appear on a single
 line.
 .Ip "\fB\-fdiagnostics-show-location=once\fR" 4
 .IX Item "-fdiagnostics-show-location=once"
@@ -1451,7 +1522,7 @@ reporter to emit \fIonce\fR source location information; that is, in
 case the message is too long to fit on a single physical line and has to
 be wrapped, the source location won't be emitted (as prefix) again,
 over and over, in subsequent continuation lines.  This is the default
-behaviour. 
+behaviour.
 .Ip "\fB\-fdiagnostics-show-location=every-line\fR" 4
 .IX Item "-fdiagnostics-show-location=every-line"
 Only meaningful in line-wrapping mode.  Instructs the diagnostic
@@ -1504,6 +1575,16 @@ A feature to report any failure to conform to \s-1ISO\s0 C might be useful in
 some instances, but would require considerable additional work and would
 be quite different from \fB\-pedantic\fR.  We don't have plans to
 support such a feature in the near future.
+.Sp
+Where the standard specified with \fB\-std\fR represents a \s-1GNU\s0
+extended dialect of C, such as \fBgnu89\fR or \fBgnu99\fR, there is a
+corresponding \fIbase standard\fR, the version of \s-1ISO\s0 C on which the \s-1GNU\s0
+extended dialect is based.  Warnings from \fB\-pedantic\fR are given
+where they are required by the base standard.  (It would not make sense
+for such warnings to be given only for features not in the specified \s-1GNU\s0
+C dialect, since by definition the \s-1GNU\s0 dialects of C include all
+features the compiler supports with the given option, and there would be
+nothing to warn about.)
 .Ip "\fB\-pedantic-errors\fR" 4
 .IX Item "-pedantic-errors"
 Like \fB\-pedantic\fR, except that errors are produced rather than
@@ -1706,7 +1787,7 @@ D. Hugh Redelmeier
 .IX Item "-Wreturn-type"
 Warn whenever a function is defined with a return-type that defaults to
 \&\f(CW\*(C`int\*(C'\fR.  Also warn about any \f(CW\*(C`return\*(C'\fR statement with no
-return-value in a function whose return-type is not \f(CW\*(C`void\*(C'\fR. 
+return-value in a function whose return-type is not \f(CW\*(C`void\*(C'\fR.
 .Sp
 For \*(C+, a function without return type always produces a diagnostic
 message, even when \fB\-Wno-return-type\fR is specified. The only
@@ -2107,7 +2188,7 @@ appropriate may not be detected.  This option has no effect unless
 .Ip "\fB\-Wpacked\fR" 4
 .IX Item "-Wpacked"
 Warn if a structure is given the packed attribute, but the packed
-attribute has no effect on the layout or size of the structure.  
+attribute has no effect on the layout or size of the structure.
 Such structures may be mis-aligned for little benefit.  For
 instance, in this code, the variable \f(CW\*(C`f.x\*(C'\fR in \f(CW\*(C`struct bar\*(C'\fR
 will be misaligned even though \f(CW\*(C`struct bar\*(C'\fR does not itself
@@ -2150,7 +2231,7 @@ are circumstances under which part of the affected line can be executed,
 so care should be taken when removing apparently-unreachable code.
 .Sp
 For instance, when a function is inlined, a warning may mean that the
-line is unreachable in only one inlined copy of the function.  
+line is unreachable in only one inlined copy of the function.
 .Sp
 This option is not made part of \fB\-Wall\fR because in a debugging
 version of a program there is often substantial code which checks
@@ -2456,7 +2537,7 @@ block and arc execution counts from the information in the
 Says to make debugging dumps during compilation at times specified by
 \&\fIletters\fR.  This is used for debugging the compiler.  The file names
 for most of the dumps are made by appending a pass number and a word to
-the source file name (e.g.  \fIfoo.c.00.rtl\fR or \fIfoo.c.01.sibling\fR). 
+the source file name (e.g.  \fIfoo.c.00.rtl\fR or \fIfoo.c.01.sibling\fR).
 Here are the possible letters for use in \fIletters\fR, and their meanings:
 .RS 4
 .Ip "\fBA\fR" 4
@@ -2524,7 +2605,7 @@ Dump after loop optimization, to \fI\fIfile\fI.09.loop\fR.
 .Ip "\fBM\fR" 4
 .IX Item "M"
 Dump after performing the machine dependent reorganisation pass, to
-\&\fI\fIfile\fI.28.mach\fR. 
+\&\fI\fIfile\fI.28.mach\fR.
 .Ip "\fBn\fR" 4
 .IX Item "n"
 Dump after register renumbering, to \fI\fIfile\fI.23.rnreg\fR.
@@ -2541,7 +2622,7 @@ Dump after the second instruction scheduling pass, to
 .Ip "\fBs\fR" 4
 .IX Item "s"
 Dump after \s-1CSE\s0 (including the jump optimization that sometimes follows
-\&\s-1CSE\s0), to \fI\fIfile\fI.03.cse\fR. 
+\&\s-1CSE\s0), to \fI\fIfile\fI.03.cse\fR.
 .Ip "\fBS\fR" 4
 .IX Item "S"
 Dump after the first instruction scheduling pass, to
@@ -2822,13 +2903,13 @@ assembler code in its own right.
 .IX Item "-finline-limit=n"
 By default, gcc limits the size of functions that can be inlined.  This flag
 allows the control of this limit for functions that are explicitly marked as
-inline (ie marked with the inline keyword or defined within the class 
-definition in c++).  \fIn\fR is the size of functions that can be inlined in 
+inline (ie marked with the inline keyword or defined within the class
+definition in c++).  \fIn\fR is the size of functions that can be inlined in
 number of pseudo instructions (not counting parameter handling).  The default
 value of n is 10000.  Increasing this value can result in more inlined code at
 the cost of compilation time and memory consumption.  Decreasing usually makes
-the compilation faster and less code will be inlined (which presumably 
-means slower programs).  This option is particularly useful for programs that 
+the compilation faster and less code will be inlined (which presumably
+means slower programs).  This option is particularly useful for programs that
 use inlining heavily such as those based on recursive templates with c++.
 .Sp
 \&\fINote:\fR pseudo instruction represents, in this particular context, an
@@ -2886,7 +2967,7 @@ sets \fB\-fno-math-errno\fR.
 .IX Item "-funsafe-math-optimizations"
 Allow optimizations for floating-point arithmetic that (a) assume
 that arguments and results are valid and (b) may violate \s-1IEEE\s0 or
-\&\s-1ANSI\s0 standards.  
+\&\s-1ANSI\s0 standards.
 .Sp
 This option should never be turned on by any \fB\-O\fR option since
 it can result in incorrect output for programs which depend on
@@ -2958,10 +3039,10 @@ This pass also performs global constant and copy propagation.
 When \-fgcse-lm is enabled, global common subexpression elimination will
 attempt to move loads which are only killed by stores into themselves. This
 allows a loop containing a load/store sequence to be changed to a load outside
-the loop, and a copy/store within the loop. 
+the loop, and a copy/store within the loop.
 .Ip "\fB\-fgcse-sm\fR" 4
 .IX Item "-fgcse-sm"
-When \-fgcse-sm is enabled, A store motion pass is run after global common 
+When \-fgcse-sm is enabled, A store motion pass is run after global common
 subexpression elimination. This pass will attempt to move stores out of loops.
 When used in conjunction with \-fgcse-lm, loops containing a load/store sequence
 can be changed to a load before the loop and a store after the loop.
@@ -3104,12 +3185,12 @@ object of one type is assumed never to reside at the same address as an
 object of a different type, unless the types are almost the same.  For
 example, an \f(CW\*(C`unsigned int\*(C'\fR can alias an \f(CW\*(C`int\*(C'\fR, but not a
 \&\f(CW\*(C`void*\*(C'\fR or a \f(CW\*(C`double\*(C'\fR.  A character type may alias any other
-type.  
+type.
 .Sp
 Pay special attention to code like this:
 .Sp
 .Vb 4
-\&        union a_union { 
+\&        union a_union {
 \&          int i;
 \&          double d;
 \&        };
@@ -3128,7 +3209,7 @@ is accessed through the union type.  So, the code above will work as
 expected.  However, this code might not:
 .Sp
 .Vb 7
-\&        int f() { 
+\&        int f() {
 \&          a_union t;
 \&          int* ip;
 \&          t.d = 3.0;
@@ -3222,22 +3303,38 @@ In some places, \s-1GCC\s0 uses various constants to control the amount of
 optimization that is done.  For example, \s-1GCC\s0 will not inline functions
 that contain more that a certain number of instructions.  You can
 control some of these constants on the command-line using the
-\&\fB\*(--param\fR option.  
+\&\fB\*(--param\fR option.
 .Sp
 In each case, the \fIvalue\fR is a integer.  The allowable choices for
 \&\fIname\fR are given in the following table:
 .RS 4
-.Ip "\fBmax-inline-insns\fR" 4
-.IX Item "max-inline-insns"
-If an function contains more than this many instructions, it
-will not be inlined.  This option is precisely equivalent to
-\&\fB\-finline-limit\fR.
+.Ip "\fBmax-delay-slot-insn-search\fR" 4
+.IX Item "max-delay-slot-insn-search"
+The maximum number of instructions to consider when looking for an
+instruction to fill a delay slot.  If more than this arbitrary number of
+instructions is searched, the time savings from filling the delay slot
+will be minimal so stop searching.  Increasing values mean more
+aggressive optimization, making the compile time increase with probably
+small improvement in executable run time.
+.Ip "\fBmax-delay-slot-live-search\fR" 4
+.IX Item "max-delay-slot-live-search"
+When trying to fill delay slots, the maximum number of instructions to
+consider when searching for a block with valid live register
+information.  Increasing this arbitrarily chosen value means more
+aggressive optimization, increasing the compile time.  This parameter
+should be removed when the delay slot code is rewritten to maintain the
+control-flow graph.
 .Ip "\fBmax-gcse-memory\fR" 4
 .IX Item "max-gcse-memory"
 The approximate maximum amount of memory that will be allocated in
 order to perform the global common subexpression elimination
 optimization.  If more memory than specified is required, the
 optimization will not be done.
+.Ip "\fBmax-inline-insns\fR" 4
+.IX Item "max-inline-insns"
+If an function contains more than this many instructions, it
+will not be inlined.  This option is precisely equivalent to
+\&\fB\-finline-limit\fR.
 .RE
 .RS 4
 .RE
@@ -3547,10 +3644,16 @@ If any of these options is used, then the linker is not run, and
 object file names should not be used as arguments.  
 .Ip "\fB\-l\fR\fIlibrary\fR" 4
 .IX Item "-llibrary"
-Search the library named \fIlibrary\fR when linking.
+.PD 0
+.Ip "\fB\-l\fR \fIlibrary\fR" 4
+.IX Item "-l library"
+.PD
+Search the library named \fIlibrary\fR when linking.  (The second
+alternative with the library as a separate argument is only for
+\&\s-1POSIX\s0 compliance and is not recommended.)
 .Sp
 It makes a difference where in the command you write this option; the
-linker searches processes libraries and object files in the order they
+linker searches and processes libraries and object files in the order they
 are specified.  Thus, \fBfoo.o \-lz bar.o\fR searches library \fBz\fR
 after file \fIfoo.o\fR but before \fIbar.o\fR.  If \fIbar.o\fR refers
 to functions in \fBz\fR, those functions may not be loaded.
@@ -3621,7 +3724,7 @@ libraries.  On other systems, this option has no effect.
 .IX Item "-shared"
 Produce a shared object which can then be linked with other objects to
 form an executable.  Not all systems support this option.  For predictable
-results, you must also specify the same set of options that were used to 
+results, you must also specify the same set of options that were used to
 generate code (\fB\-fpic\fR, \fB\-fPIC\fR, or model suboptions)
 when you specify this option.[1]
 .Ip "\fB\-shared-libgcc\fR" 4
@@ -3915,7 +4018,7 @@ Use this option for microcontrollers with a
 Generate output for a 520X \*(L"coldfire\*(R" family cpu.  This is the default
 when the compiler is configured for 520X-based systems.
 .Sp
-Use this option for microcontroller with a 5200 core, including 
+Use this option for microcontroller with a 5200 core, including
 the \s-1MCF5202\s0, \s-1MCF5203\s0, \s-1MCF5204\s0 and \s-1MCF5202\s0.
 .Ip "\fB\-m68020\-40\fR" 4
 .IX Item "-m68020-40"
@@ -3982,7 +4085,7 @@ The \f(CW\*(C`rtd\*(C'\fR instruction is supported by the 68010, 68020, 68030,
 .Ip "\fB\-mno-align-int\fR" 4
 .IX Item "-mno-align-int"
 .PD
-Control whether \s-1GCC\s0 aligns \f(CW\*(C`int\*(C'\fR, \f(CW\*(C`long\*(C'\fR, \f(CW\*(C`long long\*(C'\fR, 
+Control whether \s-1GCC\s0 aligns \f(CW\*(C`int\*(C'\fR, \f(CW\*(C`long\*(C'\fR, \f(CW\*(C`long long\*(C'\fR,
 \&\f(CW\*(C`float\*(C'\fR, \f(CW\*(C`double\*(C'\fR, and \f(CW\*(C`long double\*(C'\fR variables on a 32\-bit
 boundary (\fB\-malign-int\fR) or a 16\-bit boundary (\fB\-mno-align-int\fR).
 Aligning variables on 32\-bit boundaries produces code that runs somewhat
@@ -4011,7 +4114,7 @@ the system.
 .IX Subsection "M68hc1x Options"
 .PP
 These are the \fB\-m\fR options defined for the 68hc11 and 68hc12
-microcontrollers.  The default values for these options depends on 
+microcontrollers.  The default values for these options depends on
 which style of microcontroller was selected when the compiler was configured;
 the defaults for the most common choices are given below.
 .Ip "\fB\-m6811\fR" 4
@@ -4272,7 +4375,7 @@ overflow trap handler will properly handle this case as will interrupt
 handlers.
 .PP
 These \fB\-m\fR switches are supported in addition to the above
-on \s-1SPARC\s0 V9 processors in 64 bit environments.
+on \s-1SPARC\s0 V9 processors in 64\-bit environments.
 .Ip "\fB\-mlittle-endian\fR" 4
 .IX Item "-mlittle-endian"
 Generate code for a processor running in little-endian mode.
@@ -4282,9 +4385,9 @@ Generate code for a processor running in little-endian mode.
 .Ip "\fB\-m64\fR" 4
 .IX Item "-m64"
 .PD
-Generate code for a 32 bit or 64 bit environment.
-The 32 bit environment sets int, long and pointer to 32 bits.
-The 64 bit environment sets int to 32 bits and long and pointer
+Generate code for a 32\-bit or 64\-bit environment.
+The 32\-bit environment sets int, long and pointer to 32 bits.
+The 64\-bit environment sets int to 32 bits and long and pointer
 to 64 bits.
 .Ip "\fB\-mcmodel=medlow\fR" 4
 .IX Item "-mcmodel=medlow"
@@ -4306,9 +4409,9 @@ Pointers are 64 bits.
 .Ip "\fB\-mcmodel=embmedany\fR" 4
 .IX Item "-mcmodel=embmedany"
 Generate code for the Medium/Anywhere code model for embedded systems:
-assume a 32 bit text and a 32 bit data segment, both starting anywhere
+assume a 32\-bit text and a 32\-bit data segment, both starting anywhere
 (determined at link time).  Register \f(CW%g4\fR points to the base of the
-data segment.  Pointers still 64 bits.
+data segment.  Pointers are still 64 bits.
 Programs are statically linked, \s-1PIC\s0 is not supported.
 .Ip "\fB\-mstack-bias\fR" 4
 .IX Item "-mstack-bias"
@@ -4591,21 +4694,21 @@ address is aligned to a word boundary.
 .Sp
 This option is ignored when compiling for \s-1ARM\s0 architecture 4 or later,
 since these processors have instructions to directly access half-word
-objects in memory. 
+objects in memory.
 .Ip "\fB\-mno-alignment-traps\fR" 4
 .IX Item "-mno-alignment-traps"
 Generate code that assumes that the \s-1MMU\s0 will not trap unaligned
 accesses.  This produces better code when the target instruction set
 does not have half-word memory operations (implementations prior to
-ARMv4). 
+ARMv4).
 .Sp
 Note that you cannot use this option to access unaligned word objects,
 since the processor will only fetch one 32\-bit aligned object from
-memory. 
+memory.
 .Sp
 The default setting for most targets is \-mno-alignment-traps, since
 this produces better code when there are no half-word memory
-instructions available. 
+instructions available.
 .Ip "\fB\-mshort-load-bytes\fR" 4
 .IX Item "-mshort-load-bytes"
 This is a deprecated alias for \fB\-malignment-traps\fR.
@@ -4695,7 +4798,7 @@ Tells the compiler to perform function calls by first loading the
 address of the function into a register and then performing a subroutine
 call on this register.  This switch is needed if the target function
 will lie outside of the 64 megabyte addressing range of the offset based
-version of subroutine call instruction. 
+version of subroutine call instruction.
 .Sp
 Even if this switch is enabled, not all function calls will be turned
 into long calls.  The heuristic is that static functions, functions
@@ -4713,7 +4816,7 @@ This feature is not enabled by default.  Specifying
 placing the function calls within the scope of a \fB#pragma
 long_calls_off\fR directive.  Note these switches have no effect on how
 the compiler generates code to handle function calls via function
-pointers.  
+pointers.
 .Ip "\fB\-mnop-fun-dllimport\fR" 4
 .IX Item "-mnop-fun-dllimport"
 Disable the support for the \fIdllimport\fR attribute.
@@ -4741,12 +4844,12 @@ with this option.
 .IX Item "-mtpcs-frame"
 Generate a stack frame that is compliant with the Thumb Procedure Call
 Standard for all non-leaf functions.  (A leaf function is one that does
-not call any other functions).  The default is \fB\-mno-apcs-frame\fR. 
+not call any other functions).  The default is \fB\-mno-apcs-frame\fR.
 .Ip "\fB\-mtpcs-leaf-frame\fR" 4
 .IX Item "-mtpcs-leaf-frame"
 Generate a stack frame that is compliant with the Thumb Procedure Call
 Standard for all leaf functions.  (A leaf function is one that does
-not call any other functions).  The default is \fB\-mno-apcs-leaf-frame\fR. 
+not call any other functions).  The default is \fB\-mno-apcs-leaf-frame\fR.
 .Ip "\fB\-mlittle-endian\fR" 4
 .IX Item "-mlittle-endian"
 Generate code for a processor running in little-endian mode.  This is
@@ -4801,7 +4904,7 @@ Indicate to the linker that it should perform a relaxation optimization pass
 to shorten branches, calls and absolute memory addresses.  This option only
 has an effect when used on the command line for the final link step.
 .Sp
-This option makes symbolic debugging impossible. 
+This option makes symbolic debugging impossible.
 .PP
 .I "\s-1MN10300\s0 Options"
 .IX Subsection "MN10300 Options"
@@ -4828,7 +4931,7 @@ Indicate to the linker that it should perform a relaxation optimization pass
 to shorten branches, calls and absolute memory addresses.  This option only
 has an effect when used on the command line for the final link step.
 .Sp
-This option makes symbolic debugging impossible. 
+This option makes symbolic debugging impossible.
 .PP
 .I "M32R/D Options"
 .IX Subsection "M32R/D Options"
@@ -4845,12 +4948,12 @@ The addressability of a particular object can be set with the
 \&\f(CW\*(C`model\*(C'\fR attribute.
 .Ip "\fB\-mcode-model=medium\fR" 4
 .IX Item "-mcode-model=medium"
-Assume objects may be anywhere in the 32 bit address space (the compiler
+Assume objects may be anywhere in the 32\-bit address space (the compiler
 will generate \f(CW\*(C`seth/add3\*(C'\fR instructions to load their addresses), and
 assume all subroutines are reachable with the \f(CW\*(C`bl\*(C'\fR instruction.
 .Ip "\fB\-mcode-model=large\fR" 4
 .IX Item "-mcode-model=large"
-Assume objects may be anywhere in the 32 bit address space (the compiler
+Assume objects may be anywhere in the 32\-bit address space (the compiler
 will generate \f(CW\*(C`seth/add3\*(C'\fR instructions to load their addresses), and
 assume subroutines may not be reachable with the \f(CW\*(C`bl\*(C'\fR instruction
 (the compiler will generate the much slower \f(CW\*(C`seth/add3/jl\*(C'\fR
@@ -5193,19 +5296,19 @@ specify generic \s-1POWER\s0, \s-1POWER2\s0, pure 32\-bit PowerPC (i.e., not \s-
 and 64\-bit PowerPC architecture machine types, with an appropriate,
 generic processor model assumed for scheduling purposes.
 .Sp
-Specifying any of the following options: 
+Specifying any of the following options:
 \&\fB\-mcpu=rios1\fR, \fB\-mcpu=rios2\fR, \fB\-mcpu=rsc\fR,
-\&\fB\-mcpu=power\fR, or \fB\-mcpu=power2\fR  
-enables the \fB\-mpower\fR option and disables the \fB\-mpowerpc\fR option; 
+\&\fB\-mcpu=power\fR, or \fB\-mcpu=power2\fR
+enables the \fB\-mpower\fR option and disables the \fB\-mpowerpc\fR option;
 \&\fB\-mcpu=601\fR enables both the \fB\-mpower\fR and \fB\-mpowerpc\fR options.
 All of \fB\-mcpu=rs64a\fR, \fB\-mcpu=602\fR, \fB\-mcpu=603\fR,
 \&\fB\-mcpu=603e\fR, \fB\-mcpu=604\fR, \fB\-mcpu=620\fR, \fB\-mcpu=630\fR,
 \&\fB\-mcpu=740\fR, and \fB\-mcpu=750\fR
-enable the \fB\-mpowerpc\fR option and disable the \fB\-mpower\fR option.  
+enable the \fB\-mpowerpc\fR option and disable the \fB\-mpower\fR option.
 Exactly similarly, all of \fB\-mcpu=403\fR,
-\&\fB\-mcpu=505\fR, \fB\-mcpu=821\fR, \fB\-mcpu=860\fR and \fB\-mcpu=powerpc\fR 
+\&\fB\-mcpu=505\fR, \fB\-mcpu=821\fR, \fB\-mcpu=860\fR and \fB\-mcpu=powerpc\fR
 enable the \fB\-mpowerpc\fR option and disable the \fB\-mpower\fR option.
-\&\fB\-mcpu=common\fR disables both the 
+\&\fB\-mcpu=common\fR disables both the
 \&\fB\-mpower\fR and \fB\-mpowerpc\fR options.
 .Sp
 \&\s-1AIX\s0 versions 4 or greater selects \fB\-mcpu=common\fR by default, so
@@ -5656,7 +5759,7 @@ root instructions).  \fBr6000\fR is the default \fIcpu type\fR at this
 \&\s-1ISA\s0 level.
 .Ip "\fB\-mips3\fR" 4
 .IX Item "-mips3"
-Issue instructions from level 3 of the \s-1MIPS\s0 \s-1ISA\s0 (64 bit instructions).
+Issue instructions from level 3 of the \s-1MIPS\s0 \s-1ISA\s0 (64\-bit instructions).
 \&\fBr4000\fR is the default \fIcpu type\fR at this \s-1ISA\s0 level.
 .Ip "\fB\-mips4\fR" 4
 .IX Item "-mips4"
@@ -5950,7 +6053,7 @@ is equivalent to \fBpentiumpro\fR.  \fBk6\fR and \fBathlon\fR are the
 .Ip "\fB\-march=\fR\fIcpu type\fR" 4
 .IX Item "-march=cpu type"
 Generate instructions for the machine type \fIcpu type\fR.  The choices
-for \fIcpu type\fR are the same as for \fB\-mcpu\fR.  Moreover, 
+for \fIcpu type\fR are the same as for \fB\-mcpu\fR.  Moreover,
 specifying \fB\-march=\fR\fIcpu type\fR implies \fB\-mcpu=\fR\fIcpu type\fR.
 .Ip "\fB\-m386\fR" 4
 .IX Item "-m386"
@@ -6031,7 +6134,7 @@ impossible to reach with 12 byte long doubles in the array accesses.
 \&\fBWarning:\fR if you use the \fB\-m128bit-long-double\fR switch, the
 structures and arrays containing \f(CW\*(C`long double\*(C'\fR will change their size as
 well as function calling convention for function taking \f(CW\*(C`long double\*(C'\fR
-will be modified. 
+will be modified.
 .Ip "\fB\-m96bit-long-double\fR" 4
 .IX Item "-m96bit-long-double"
 .PD 0
@@ -6056,7 +6159,7 @@ These options are meaningful only on System V Release 3.
 .IX Item "-mwide-multiply"
 .PD
 Control whether \s-1GCC\s0 uses the \f(CW\*(C`mul\*(C'\fR and \f(CW\*(C`imul\*(C'\fR that produce
-64 bit results in \f(CW\*(C`eax:edx\*(C'\fR from 32 bit operands to do \f(CW\*(C`long
+64\-bit results in \f(CW\*(C`eax:edx\*(C'\fR from 32\-bit operands to do \f(CW\*(C`long
 long\*(C'\fR multiplies and 32\-bit division by constants.
 .Ip "\fB\-mrtd\fR" 4
 .IX Item "-mrtd"
@@ -6094,26 +6197,6 @@ function by using the function attribute \fBregparm\fR.
 \&\fInum\fR is nonzero, then you must build all modules with the same
 value, including any libraries.  This includes the system libraries and
 startup modules.
-.Ip "\fB\-malign-loops=\fR\fInum\fR" 4
-.IX Item "-malign-loops=num"
-Align loops to a 2 raised to a \fInum\fR byte boundary.  If
-\&\fB\-malign-loops\fR is not specified, the default is 2 unless
-gas 2.8 (or later) is being used in which case the default is
-to align the loop on a 16 byte boundary if it is less than 8
-bytes away.
-.Ip "\fB\-malign-jumps=\fR\fInum\fR" 4
-.IX Item "-malign-jumps=num"
-Align instructions that are only jumped to to a 2 raised to a \fInum\fR
-byte boundary.  If \fB\-malign-jumps\fR is not specified, the default is
-2 if optimizing for a 386, and 4 if optimizing for a 486 unless
-gas 2.8 (or later) is being used in which case the default is
-to align the instruction on a 16 byte boundary if it is less
-than 8 bytes away.
-.Ip "\fB\-malign-functions=\fR\fInum\fR" 4
-.IX Item "-malign-functions=num"
-Align the start of functions to a 2 raised to \fInum\fR byte boundary.
-If \fB\-malign-functions\fR is not specified, the default is 2 if optimizing
-for a 386, and 4 if optimizing for a 486.
 .Ip "\fB\-mpreferred-stack-boundary=\fR\fInum\fR" 4
 .IX Item "-mpreferred-stack-boundary=num"
 Attempt to keep the stack boundary aligned to a 2 raised to \fInum\fR
@@ -6128,7 +6211,7 @@ Streaming \s-1SIMD\s0 Extension (\s-1SSE\s0) data type \f(CW\*(C`_\|_m128\*(C'\f
 penalties if it is not 16 byte aligned.
 .Sp
 To ensure proper alignment of this values on the stack, the stack boundary
-must be as aligned as that required by any value stored on the stack. 
+must be as aligned as that required by any value stored on the stack.
 Further, every function must be generated such that it keeps the stack
 aligned.  Thus calling a function compiled with a higher preferred
 stack boundary from a function compiled with a lower preferred stack
@@ -6154,10 +6237,10 @@ when preferred stack boundary is not equal to 2.  The drawback is a notable
 increase in code size. This switch implies \-mno-push-args.
 .Ip "\fB\-mthreads\fR" 4
 .IX Item "-mthreads"
-Support thread-safe exception handling on \fBMingw32\fR. Code that relies 
-on thread-safe exception handling must compile and link all code with the 
-\&\fB\-mthreads\fR option. When compiling, \fB\-mthreads\fR defines 
-\&\fB\-D_MT\fR; when linking, it links in a special thread helper library 
+Support thread-safe exception handling on \fBMingw32\fR. Code that relies
+on thread-safe exception handling must compile and link all code with the
+\&\fB\-mthreads\fR option. When compiling, \fB\-mthreads\fR defines
+\&\fB\-D_MT\fR; when linking, it links in a special thread helper library
 \&\fB\-lmingwthrd\fR which cleans up per thread exception handling data.
 .Ip "\fB\-mno-align-stringops\fR" 4
 .IX Item "-mno-align-stringops"
@@ -6170,6 +6253,13 @@ By default \s-1GCC\s0 inlines string operations only when destination is known t
 aligned at least to 4 byte boundary. This enables more inlining, increase code
 size, but may improve performance of code that depends on fast memcpy, strlen
 and memset for short lengths.
+.Ip "\fB\-momit-leaf-frame-pointer\fR" 4
+.IX Item "-momit-leaf-frame-pointer"
+Don't keep the frame pointer in a register for leaf functions.  This
+avoids the instructions to save, set up and restore frame pointers and
+makes an extra register available in leaf functions.  The option
+\&\fB\-fomit-frame-pointer\fR removes the frame pointer for all functions
+which might make debugging harder.
 .PP
 .I "\s-1HPPA\s0 Options"
 .IX Subsection "HPPA Options"
@@ -6187,7 +6277,7 @@ other way around.
 .Sp
 \&\s-1PA\s0 2.0 support currently requires gas snapshot 19990413 or later.  The
 next release of binutils (current is 2.9.1) will probably contain \s-1PA\s0 2.0
-support.  
+support.
 .Ip "\fB\-mpa-risc-1\-0\fR" 4
 .IX Item "-mpa-risc-1-0"
 .PD 0
@@ -6244,8 +6334,8 @@ Enable the use of assembler directives only \s-1GAS\s0 understands.
 .Ip "\fB\-mschedule=\fR\fIcpu type\fR" 4
 .IX Item "-mschedule=cpu type"
 Schedule code according to the constraints for the machine type
-\&\fIcpu type\fR.  The choices for \fIcpu type\fR are \fB700\fR 
-\&\fB7100\fR, \fB7100LC\fR, \fB7200\fR, and \fB8000\fR.  Refer to 
+\&\fIcpu type\fR.  The choices for \fIcpu type\fR are \fB700\fR
+\&\fB7100\fR, \fB7100LC\fR, \fB7200\fR, and \fB8000\fR.  Refer to
 \&\fI/usr/lib/sched.models\fR on an \s-1HP-UX\s0 system to determine the
 proper scheduling option for your machine.
 .Ip "\fB\-mlinker-opt\fR" 4
@@ -6381,7 +6471,7 @@ These \fB\-m\fR options are defined for the \s-1DEC\s0 Alpha implementations:
 .PD
 Use (do not use) the hardware floating-point instructions for
 floating-point operations.  When \fB\-msoft-float\fR is specified,
-functions in \fIlibgcc1.c\fR will be used to perform floating-point
+functions in \fIlibgcc.a\fR will be used to perform floating-point
 operations.  Unless they are replaced by routines that emulate the
 floating-point operations, or compiled in such a way as to call such
 emulations routines, these routines will issue floating-point
@@ -6429,8 +6519,8 @@ This is like \fB\-mieee\fR except the generated code also maintains the
 code to implement fully-compliant \s-1IEEE\s0 math.  The option is a shorthand
 for \fB\-D_IEEE_FP \-D_IEEE_FP_INEXACT\fR plus the three following:
 \&\fB\-mieee-conformant\fR,
-\&\fB\-mfp-trap-mode=sui\fR, 
-and \fB\-mtrap-precision=i\fR.  
+\&\fB\-mfp-trap-mode=sui\fR,
+and \fB\-mtrap-precision=i\fR.
 On some Alpha implementations the resulting code may execute
 significantly slower than the code generated by default.  Since there
 is very little code that depends on the \fIinexact flag\fR, you should
@@ -6724,7 +6814,7 @@ Compile code for the processor in big endian mode.
 Compile code for the processor in little endian mode.
 .Ip "\fB\-mdalign\fR" 4
 .IX Item "-mdalign"
-Align doubles at 64 bit boundaries.  Note that this changes the calling
+Align doubles at 64\-bit boundaries.  Note that this changes the calling
 conventions, and thus some functions from the standard C library will
 not work unless you recompile it first with \-mdalign.
 .Ip "\fB\-mrelax\fR" 4
@@ -6826,7 +6916,7 @@ memory access.
 .IX Item "-mno-bk"
 .PD
 Allow (disallow) allocation of general integer operands into the block
-count register \s-1BK\s0. 
+count register \s-1BK\s0.
 .Ip "\fB\-mdb\fR" 4
 .IX Item "-mdb"
 .PD 0
@@ -7213,7 +7303,7 @@ Change only the low 8 bits of the stack pointer.
 .IX Subsection "MCore Options"
 .PP
 These are the \fB\-m\fR options defined for the Motorola M*Core
-processors.  
+processors.
 .Ip "\fB\-mhardlit\fR" 4
 .IX Item "-mhardlit"
 .PD 0
index 3f639b8ff8dc7c15f085a1c0586a927d4f3612cf..63b31152885b85339e22be03da8634c6ca73a914 100644 (file)
@@ -1695,6 +1695,16 @@ some instances, but would require considerable additional work and would
 be quite different from @samp{-pedantic}.  We don't have plans to
 support such a feature in the near future.
 
+Where the standard specified with @option{-std} represents a GNU
+extended dialect of C, such as @samp{gnu89} or @samp{gnu99}, there is a
+corresponding @dfn{base standard}, the version of ISO C on which the GNU
+extended dialect is based.  Warnings from @option{-pedantic} are given
+where they are required by the base standard.  (It would not make sense
+for such warnings to be given only for features not in the specified GNU
+C dialect, since by definition the GNU dialects of C include all
+features the compiler supports with the given option, and there would be
+nothing to warn about.)
+
 @item -pedantic-errors
 Like @samp{-pedantic}, except that errors are produced rather than
 warnings.