]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/flags.h
./:
[thirdparty/gcc.git] / gcc / flags.h
CommitLineData
f12b58b3 1/* Compilation switch flag definitions for GCC.
bc233f0c 2 Copyright (C) 1987, 1988, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2002,
981eb798 3 2003, 2004, 2005, 2006, 2007
b278476e 4 Free Software Foundation, Inc.
addd8f36 5
f12b58b3 6This file is part of GCC.
addd8f36 7
f12b58b3 8GCC is free software; you can redistribute it and/or modify it under
9the terms of the GNU General Public License as published by the Free
10Software Foundation; either version 2, or (at your option) any later
11version.
addd8f36 12
f12b58b3 13GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14WARRANTY; without even the implied warranty of MERCHANTABILITY or
15FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16for more details.
addd8f36 17
18You should have received a copy of the GNU General Public License
f12b58b3 19along with GCC; see the file COPYING. If not, write to the Free
67ce556b 20Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
2102110-1301, USA. */
addd8f36 22
518796ad 23#ifndef GCC_FLAGS_H
24#define GCC_FLAGS_H
25
2e9da478 26#include "options.h"
27
addd8f36 28enum debug_info_type
29{
30 NO_DEBUG, /* Write no debug info. */
31 DBX_DEBUG, /* Write BSD .stabs for DBX (using dbxout.c). */
32 SDB_DEBUG, /* Write COFF for (old) SDB (using sdbout.c). */
be6eb971 33 DWARF2_DEBUG, /* Write Dwarf v2 debug info (using dwarf2out.c). */
8d60d2bc 34 XCOFF_DEBUG, /* Write IBM/Xcoff debug info (using dbxout.c). */
00e0eb3d 35 VMS_DEBUG, /* Write VMS debug info (using vmsdbgout.c). */
8d60d2bc 36 VMS_AND_DWARF2_DEBUG /* Write VMS debug info (using vmsdbgout.c).
00e0eb3d 37 and DWARF v2 debug info (using dwarf2out.c). */
addd8f36 38};
39
40/* Specify which kind of debugging info to generate. */
41extern enum debug_info_type write_symbols;
42
cc4ca723 43/* Names of debug_info_type, for error messages. */
44extern const char *const debug_type_names[];
45
addd8f36 46enum debug_info_level
47{
48 DINFO_LEVEL_NONE, /* Write no debugging info. */
49 DINFO_LEVEL_TERSE, /* Write minimal info to support tracebacks only. */
a7dce381 50 DINFO_LEVEL_NORMAL, /* Write info for all declarations (and line table). */
addd8f36 51 DINFO_LEVEL_VERBOSE /* Write normal info plus #define/#undef info. */
52};
53
54/* Specify how much debugging info to generate. */
55extern enum debug_info_level debug_info_level;
56
51d7935f 57/* Nonzero means use GNU-only extensions in the generated symbolic
58 debugging information. */
b0e56fb1 59extern bool use_gnu_debug_info_extensions;
addd8f36 60
4a2849cb 61/* Enumerate visibility settings. This is deliberately ordered from most
62 to least visibility. */
b212f378 63#ifndef SYMBOL_VISIBILITY_DEFINED
64#define SYMBOL_VISIBILITY_DEFINED
65enum symbol_visibility
66{
67 VISIBILITY_DEFAULT,
4a2849cb 68 VISIBILITY_PROTECTED,
b212f378 69 VISIBILITY_HIDDEN,
4a2849cb 70 VISIBILITY_INTERNAL
b212f378 71};
72#endif
73
74/* The default visibility for all symbols (unless overridden). */
75extern enum symbol_visibility default_visibility;
76
77struct visibility_flags
78{
79 unsigned inpragma : 1; /* True when in #pragma GCC visibility. */
80 unsigned inlines_hidden : 1; /* True when -finlineshidden in effect. */
81};
82
83/* Global visibility options. */
84extern struct visibility_flags visibility_options;
85
addd8f36 86/* Nonzero means do optimizations. -opt. */
87
88extern int optimize;
89
57361983 90/* Nonzero means optimize for size. -Os. */
91
92extern int optimize_size;
93
56421f52 94/* Do print extra warnings (such as for uninitialized variables).
95 -W/-Wextra. */
addd8f36 96
6f2f567f 97extern bool extra_warnings;
98
6dfd0eba 99/* Nonzero to warn about unused variables, functions et.al. Use
100 set_Wunused() to update the -Wunused-* flags that correspond to the
a7dce381 101 -Wunused option. */
addd8f36 102
8a82c3cf 103extern void set_Wunused (int setting);
6dfd0eba 104
75db8365 105/* Nonzero means warn about any objects definitions whose size is larger
106 than N bytes. Also want about function definitions whose returned
107 values are larger than N bytes. The value N is in `larger_than_size'. */
108
6f2f567f 109extern bool warn_larger_than;
b278476e 110extern HOST_WIDE_INT larger_than_size;
addd8f36 111
812f3fa9 112/* Nonzero means warn about constructs which might not be strict
113 aliasing safe. */
114
c1628b55 115extern int warn_strict_aliasing;
812f3fa9 116
add6ee5e 117/* Nonzero means warn about optimizations which rely on undefined
118 signed overflow. */
119
120extern int warn_strict_overflow;
121
addd8f36 122/* Temporarily suppress certain warnings.
123 This is set while reading code from a system header file. */
124
125extern int in_system_header;
126
127/* Nonzero for -dp: annotate the assembly with a comment describing the
128 pattern and alternative used. */
129
130extern int flag_print_asm_name;
131\f
132/* Now the symbols that are set with `-f' switches. */
133
134/* Nonzero means `char' should be signed. */
135
136extern int flag_signed_char;
137
5bf3fee3 138/* Nonzero means give an enum type only as many bytes as it needs. A value
139 of 2 means it has not yet been initialized. */
addd8f36 140
141extern int flag_short_enums;
142
addd8f36 143/* Nonzero for -fpcc-struct-return: return values the same way PCC does. */
144
145extern int flag_pcc_struct_return;
146
27bc6aee 147/* 0 means straightforward implementation of complex divide acceptable.
148 1 means wide ranges of inputs must work for complex divide.
0dfc45b5 149 2 means C99-like requirements for complex multiply and divide. */
27bc6aee 150
0dfc45b5 151extern int flag_complex_method;
27bc6aee 152
c31da6e7 153/* Nonzero means that we don't want inlining by virtue of -fno-inline,
154 not just because the tree inliner turned us off. */
155
156extern int flag_really_no_inline;
157
addd8f36 158/* Nonzero if we are only using compiler to check syntax errors. */
159
a49a878f 160extern int rtl_dump_and_exit;
addd8f36 161
f9e15121 162/* Nonzero means we should save auxiliary info into a .X file. */
addd8f36 163
164extern int flag_gen_aux_info;
165
fd63ca43 166/* Nonzero means suppress output of instruction numbers and line number
167 notes in debugging dumps. */
168
169extern int flag_dump_unnumbered;
170
addd8f36 171/* Nonzero means change certain warnings into errors.
172 Usually these are warnings about failure to conform to some standard. */
173
174extern int flag_pedantic_errors;
175
c3ce66b0 176/* Nonzero if we are compiling code for a shared library, zero for
177 executable. */
178
179extern int flag_shlib;
180
4f96aab5 181/* -dA causes debug information to be produced in
182 the generated assembly code (to make it more readable). This option
183 is generally only of use to those who actually need to read the
184 generated assembly code (perhaps while debugging the compiler itself).
185 Currently, this switch is only used by dwarfout.c; however, it is intended
186 to be a catchall for printing debug information in the assembler file. */
187
188extern int flag_debug_asm;
189
66575a0b 190/* Generate code for GNU or NeXT Objective-C runtime environment. */
191
192extern int flag_next_runtime;
193
af5e5fd0 194extern int flag_dump_rtl_in_asm;
addd8f36 195\f
196/* Other basic status info about current function. */
197
198/* Nonzero means current function must be given a frame pointer.
199 Set in stmt.c if anything is allocated on the stack there.
200 Set in reload1.c if anything is allocated on the stack there. */
201
202extern int frame_pointer_needed;
203
3541e113 204/* Nonzero if subexpressions must be evaluated from left-to-right. */
205extern int flag_evaluation_order;
206
a9fa9190 207/* Value of the -G xx switch, and whether it was passed or not. */
3be2f219 208extern unsigned HOST_WIDE_INT g_switch_value;
e690b385 209extern bool g_switch_set;
3eaf50a4 210
61e95947 211/* Values of the -falign-* flags: how much to align labels in code.
212 0 means `use default', 1 means `don't align'.
213 For each variable, there is an _log variant which is the power
214 of two not less than the variable, for .align output. */
215
61e95947 216extern int align_loops_log;
93429286 217extern int align_loops_max_skip;
61e95947 218extern int align_jumps_log;
93429286 219extern int align_jumps_max_skip;
61e95947 220extern int align_labels_log;
93429286 221extern int align_labels_max_skip;
61e95947 222extern int align_functions_log;
223
fc5cb4c0 224/* Like align_functions_log above, but used by front-ends to force the
225 minimum function alignment. Zero means no alignment is forced. */
226extern int force_align_functions_log;
227
3eaf50a4 228/* Nonzero if we dump in VCG format, not plain text. */
229extern int dump_for_graph;
230
231/* Selection of the graph form. */
232enum graph_dump_types
233{
234 no_graph = 0,
235 vcg
236};
237extern enum graph_dump_types graph_dump_format;
5bbb9f06 238
6ef828f9 239/* Nonzero means to collect statistics which might be expensive
518796ad 240 and to print them when we are done. */
241extern int flag_detailed_statistics;
242
19489abd 243/* Nonzero means that we defer emitting functions until they are actually
244 used. */
245extern int flag_remove_unreachable_functions;
246
5923a5e7 247/* Nonzero if we should track variables. */
248extern int flag_var_tracking;
249
8a5df2ce 250/* True if flag_speculative_prefetching was set by user. Used to suppress
251 warning message in case flag was set by -fprofile-{generate,use}. */
252extern bool flag_speculative_prefetching_set;
253
e100aadc 254/* Returns TRUE if generated code should match ABI version N or
255 greater is in use. */
256
257#define abi_version_at_least(N) \
258 (flag_abi_version == 0 || flag_abi_version >= (N))
259
920d0fb5 260/* True if the given mode has a NaN representation and the treatment of
261 NaN operands is important. Certain optimizations, such as folding
64a46f56 262 x * 0 into 0, are not correct for NaN operands, and are normally
920d0fb5 263 disabled for modes with NaNs. The user can ask for them to be
264 done anyway using the -funsafe-math-optimizations switch. */
265#define HONOR_NANS(MODE) \
7eece8c3 266 (MODE_HAS_NANS (MODE) && !flag_finite_math_only)
920d0fb5 267
0a8176f3 268/* Like HONOR_NANs, but true if we honor signaling NaNs (or sNaNs). */
269#define HONOR_SNANS(MODE) (flag_signaling_nans && HONOR_NANS (MODE))
270
920d0fb5 271/* As for HONOR_NANS, but true if the mode can represent infinity and
272 the treatment of infinite values is important. */
273#define HONOR_INFINITIES(MODE) \
7eece8c3 274 (MODE_HAS_INFINITIES (MODE) && !flag_finite_math_only)
920d0fb5 275
276/* Like HONOR_NANS, but true if the given mode distinguishes between
98667efb 277 positive and negative zero, and the sign of zero is important. */
920d0fb5 278#define HONOR_SIGNED_ZEROS(MODE) \
893038cd 279 (MODE_HAS_SIGNED_ZEROS (MODE) && flag_signed_zeros)
920d0fb5 280
281/* Like HONOR_NANS, but true if given mode supports sign-dependent rounding,
282 and the rounding mode is important. */
283#define HONOR_SIGN_DEPENDENT_ROUNDING(MODE) \
5466f589 284 (MODE_HAS_SIGN_DEPENDENT_ROUNDING (MODE) && flag_rounding_math)
920d0fb5 285
981eb798 286/* True if overflow wraps around for the given integral type. That
287 is, TYPE_MAX + 1 == TYPE_MIN. */
288#define TYPE_OVERFLOW_WRAPS(TYPE) \
289 (TYPE_UNSIGNED (TYPE) || flag_wrapv)
290
291/* True if overflow is undefined for the given integral type. We may
add6ee5e 292 optimize on the assumption that values in the type never overflow.
293
294 IMPORTANT NOTE: Any optimization based on TYPE_OVERFLOW_UNDEFINED
295 must issue a warning based on warn_strict_overflow. In some cases
296 it will be appropriate to issue the warning immediately, and in
297 other cases it will be appropriate to simply set a flag and let the
298 caller decide whether a warning is appropriate or not. */
981eb798 299#define TYPE_OVERFLOW_UNDEFINED(TYPE) \
300 (!TYPE_UNSIGNED (TYPE) && !flag_wrapv && !flag_trapv && flag_strict_overflow)
301
302/* True if overflow for the given integral type should issue a
303 trap. */
304#define TYPE_OVERFLOW_TRAPS(TYPE) \
305 (!TYPE_UNSIGNED (TYPE) && flag_trapv)
306
add6ee5e 307/* Names for the different levels of -Wstrict-overflow=N. The numeric
308 values here correspond to N. */
309
310enum warn_strict_overflow_code
311{
312 /* Overflow warning that should be issued with -Wall: a questionable
313 construct that is easy to avoid even when using macros. Example:
314 folding (x + CONSTANT > x) to 1. */
315 WARN_STRICT_OVERFLOW_ALL = 1,
316 /* Overflow warning about folding a comparison to a constant because
317 of undefined signed overflow, other than cases covered by
318 WARN_STRICT_OVERFLOW_ALL. Example: folding (abs (x) >= 0) to 1
319 (this is false when x == INT_MIN). */
320 WARN_STRICT_OVERFLOW_CONDITIONAL = 2,
321 /* Overflow warning about changes to comparisons other than folding
322 them to a constant. Example: folding (x + 1 > 1) to (x > 0). */
323 WARN_STRICT_OVERFLOW_COMPARISON = 3,
324 /* Overflow warnings not covered by the above cases. Example:
325 folding ((x * 10) / 5) to (x * 2). */
326 WARN_STRICT_OVERFLOW_MISC = 4,
327 /* Overflow warnings about reducing magnitude of constants in
328 comparison. Example: folding (x + 2 > y) to (x + 1 >= y). */
329 WARN_STRICT_OVERFLOW_MAGNITUDE = 5
330};
331
332/* Whether to emit an overflow warning whose code is C. */
184c9ca9 333#define issue_strict_overflow_warning(c) (warn_strict_overflow >= (int) (c))
add6ee5e 334
2a281353 335#endif /* ! GCC_FLAGS_H */