]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/flags.h
PR target/29169
[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,
43d2dc74 3 2003, 2004, 2005
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
addd8f36 117/* Temporarily suppress certain warnings.
118 This is set while reading code from a system header file. */
119
120extern int in_system_header;
121
122/* Nonzero for -dp: annotate the assembly with a comment describing the
123 pattern and alternative used. */
124
125extern int flag_print_asm_name;
126\f
127/* Now the symbols that are set with `-f' switches. */
128
129/* Nonzero means `char' should be signed. */
130
131extern int flag_signed_char;
132
5bf3fee3 133/* Nonzero means give an enum type only as many bytes as it needs. A value
134 of 2 means it has not yet been initialized. */
addd8f36 135
136extern int flag_short_enums;
137
addd8f36 138/* Nonzero for -fpcc-struct-return: return values the same way PCC does. */
139
140extern int flag_pcc_struct_return;
141
27bc6aee 142/* 0 means straightforward implementation of complex divide acceptable.
143 1 means wide ranges of inputs must work for complex divide.
0dfc45b5 144 2 means C99-like requirements for complex multiply and divide. */
27bc6aee 145
0dfc45b5 146extern int flag_complex_method;
27bc6aee 147
c31da6e7 148/* Nonzero means that we don't want inlining by virtue of -fno-inline,
149 not just because the tree inliner turned us off. */
150
151extern int flag_really_no_inline;
152
addd8f36 153/* Nonzero if we are only using compiler to check syntax errors. */
154
a49a878f 155extern int rtl_dump_and_exit;
addd8f36 156
f9e15121 157/* Nonzero means we should save auxiliary info into a .X file. */
addd8f36 158
159extern int flag_gen_aux_info;
160
fd63ca43 161/* Nonzero means suppress output of instruction numbers and line number
162 notes in debugging dumps. */
163
164extern int flag_dump_unnumbered;
165
addd8f36 166/* Nonzero means change certain warnings into errors.
167 Usually these are warnings about failure to conform to some standard. */
168
169extern int flag_pedantic_errors;
170
c3ce66b0 171/* Nonzero if we are compiling code for a shared library, zero for
172 executable. */
173
174extern int flag_shlib;
175
4f96aab5 176/* -dA causes debug information to be produced in
177 the generated assembly code (to make it more readable). This option
178 is generally only of use to those who actually need to read the
179 generated assembly code (perhaps while debugging the compiler itself).
180 Currently, this switch is only used by dwarfout.c; however, it is intended
181 to be a catchall for printing debug information in the assembler file. */
182
183extern int flag_debug_asm;
184
66575a0b 185/* Generate code for GNU or NeXT Objective-C runtime environment. */
186
187extern int flag_next_runtime;
188
af5e5fd0 189extern int flag_dump_rtl_in_asm;
190
214d02d0 191/* If one, renumber instruction UIDs to reduce the number of
192 unused UIDs if there are a lot of instructions. If greater than
193 one, unconditionally renumber instruction UIDs. */
194extern int flag_renumber_insns;
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
eb54bdbd 254/* A string that's used when a random name is required. NULL means
255 to make it really random. */
256
257extern const char *flag_random_seed;
258
e100aadc 259/* Returns TRUE if generated code should match ABI version N or
260 greater is in use. */
261
262#define abi_version_at_least(N) \
263 (flag_abi_version == 0 || flag_abi_version >= (N))
264
920d0fb5 265/* True if the given mode has a NaN representation and the treatment of
266 NaN operands is important. Certain optimizations, such as folding
267 x * 0 into x, are not correct for NaN operands, and are normally
268 disabled for modes with NaNs. The user can ask for them to be
269 done anyway using the -funsafe-math-optimizations switch. */
270#define HONOR_NANS(MODE) \
7eece8c3 271 (MODE_HAS_NANS (MODE) && !flag_finite_math_only)
920d0fb5 272
0a8176f3 273/* Like HONOR_NANs, but true if we honor signaling NaNs (or sNaNs). */
274#define HONOR_SNANS(MODE) (flag_signaling_nans && HONOR_NANS (MODE))
275
920d0fb5 276/* As for HONOR_NANS, but true if the mode can represent infinity and
277 the treatment of infinite values is important. */
278#define HONOR_INFINITIES(MODE) \
7eece8c3 279 (MODE_HAS_INFINITIES (MODE) && !flag_finite_math_only)
920d0fb5 280
281/* Like HONOR_NANS, but true if the given mode distinguishes between
98667efb 282 positive and negative zero, and the sign of zero is important. */
920d0fb5 283#define HONOR_SIGNED_ZEROS(MODE) \
284 (MODE_HAS_SIGNED_ZEROS (MODE) && !flag_unsafe_math_optimizations)
285
286/* Like HONOR_NANS, but true if given mode supports sign-dependent rounding,
287 and the rounding mode is important. */
288#define HONOR_SIGN_DEPENDENT_ROUNDING(MODE) \
5466f589 289 (MODE_HAS_SIGN_DEPENDENT_ROUNDING (MODE) && flag_rounding_math)
920d0fb5 290
2a281353 291#endif /* ! GCC_FLAGS_H */