Deleted Added
full compact
flags.h (107604) flags.h (117404)
1/* Compilation switch flag definitions for GCC.
1/* Compilation switch flag definitions for GCC.
2 Copyright (C) 1987, 1988, 1994, 1995, 1996, 1997, 1998, 1999, 2000
2 Copyright (C) 1987, 1988, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2002
3 Free Software Foundation, Inc.
4
5This file is part of GCC.
6
7GCC is free software; you can redistribute it and/or modify it under
8the terms of the GNU General Public License as published by the Free
9Software Foundation; either version 2, or (at your option) any later
10version.
11
12GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13WARRANTY; without even the implied warranty of MERCHANTABILITY or
14FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
15for more details.
16
17You should have received a copy of the GNU General Public License
18along with GCC; see the file COPYING. If not, write to the Free
19Software Foundation, 59 Temple Place - Suite 330, Boston, MA
2002111-1307, USA. */
21
22#ifndef GCC_FLAGS_H
23#define GCC_FLAGS_H
24
25/* Name of the input .c file being compiled. */
26extern const char *main_input_filename;
27
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). */
33 DWARF_DEBUG, /* Write Dwarf debug info (using dwarfout.c). */
34 DWARF2_DEBUG, /* Write Dwarf v2 debug info (using dwarf2out.c). */
35 XCOFF_DEBUG, /* Write IBM/Xcoff debug info (using dbxout.c). */
36 VMS_DEBUG, /* Write VMS debug info (using vmsdbgout.c). */
37 VMS_AND_DWARF2_DEBUG /* Write VMS debug info (using vmsdbgout.c).
38 and DWARF v2 debug info (using dwarf2out.c). */
39};
40
41/* Specify which kind of debugging info to generate. */
42extern enum debug_info_type write_symbols;
43
44enum debug_info_level
45{
46 DINFO_LEVEL_NONE, /* Write no debugging info. */
47 DINFO_LEVEL_TERSE, /* Write minimal info to support tracebacks only. */
48 DINFO_LEVEL_NORMAL, /* Write info for all declarations (and line table). */
49 DINFO_LEVEL_VERBOSE /* Write normal info plus #define/#undef info. */
50};
51
52/* Specify how much debugging info to generate. */
53extern enum debug_info_level debug_info_level;
54
55/* Nonzero means use GNU-only extensions in the generated symbolic
56 debugging information. */
57extern int use_gnu_debug_info_extensions;
58
59/* Nonzero means do optimizations. -opt. */
60
61extern int optimize;
62
63/* Nonzero means optimize for size. -Os. */
64
65extern int optimize_size;
66
67/* Don't print functions as they are compiled and don't print
68 times taken by the various passes. -quiet. */
69
70extern int quiet_flag;
71
72/* Print times taken by the various passes. -ftime-report. */
73
74extern int time_report;
75
76/* Print memory still in use at end of compilation (which may have little
77 to do with peak memory consumption). -fmem-report. */
78
79extern int mem_report;
80
81/* Don't print warning messages. -w. */
82
83extern int inhibit_warnings;
84
85/* Don't suppress warnings from system headers. -Wsystem-headers. */
86
87extern int warn_system_headers;
88
89/* Do print extra warnings (such as for uninitialized variables). -W. */
90
91extern int extra_warnings;
92
93/* Nonzero to warn about unused variables, functions et.al. Use
94 set_Wunused() to update the -Wunused-* flags that correspond to the
95 -Wunused option. */
96
97extern void set_Wunused PARAMS ((int setting));
98
99extern int warn_unused_function;
100extern int warn_unused_label;
101extern int warn_unused_parameter;
102extern int warn_unused_variable;
103extern int warn_unused_value;
104
105/* Nonzero to warn about code which is never reached. */
106
107extern int warn_notreached;
108
109/* Nonzero means warn if inline function is too large. */
110
111extern int warn_inline;
112
113/* Nonzero to warn about variables used before they are initialized. */
114
115extern int warn_uninitialized;
116
117/* Zero if unknown pragmas are ignored
118 One if the compiler should warn about an unknown pragma not in
119 a system include file.
120 Greater than one if the compiler should warn for all unknown
121 pragmas. */
122
123extern int warn_unknown_pragmas;
124
125/* Nonzero means warn about all declarations which shadow others. */
126
127extern int warn_shadow;
128
3 Free Software Foundation, Inc.
4
5This file is part of GCC.
6
7GCC is free software; you can redistribute it and/or modify it under
8the terms of the GNU General Public License as published by the Free
9Software Foundation; either version 2, or (at your option) any later
10version.
11
12GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13WARRANTY; without even the implied warranty of MERCHANTABILITY or
14FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
15for more details.
16
17You should have received a copy of the GNU General Public License
18along with GCC; see the file COPYING. If not, write to the Free
19Software Foundation, 59 Temple Place - Suite 330, Boston, MA
2002111-1307, USA. */
21
22#ifndef GCC_FLAGS_H
23#define GCC_FLAGS_H
24
25/* Name of the input .c file being compiled. */
26extern const char *main_input_filename;
27
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). */
33 DWARF_DEBUG, /* Write Dwarf debug info (using dwarfout.c). */
34 DWARF2_DEBUG, /* Write Dwarf v2 debug info (using dwarf2out.c). */
35 XCOFF_DEBUG, /* Write IBM/Xcoff debug info (using dbxout.c). */
36 VMS_DEBUG, /* Write VMS debug info (using vmsdbgout.c). */
37 VMS_AND_DWARF2_DEBUG /* Write VMS debug info (using vmsdbgout.c).
38 and DWARF v2 debug info (using dwarf2out.c). */
39};
40
41/* Specify which kind of debugging info to generate. */
42extern enum debug_info_type write_symbols;
43
44enum debug_info_level
45{
46 DINFO_LEVEL_NONE, /* Write no debugging info. */
47 DINFO_LEVEL_TERSE, /* Write minimal info to support tracebacks only. */
48 DINFO_LEVEL_NORMAL, /* Write info for all declarations (and line table). */
49 DINFO_LEVEL_VERBOSE /* Write normal info plus #define/#undef info. */
50};
51
52/* Specify how much debugging info to generate. */
53extern enum debug_info_level debug_info_level;
54
55/* Nonzero means use GNU-only extensions in the generated symbolic
56 debugging information. */
57extern int use_gnu_debug_info_extensions;
58
59/* Nonzero means do optimizations. -opt. */
60
61extern int optimize;
62
63/* Nonzero means optimize for size. -Os. */
64
65extern int optimize_size;
66
67/* Don't print functions as they are compiled and don't print
68 times taken by the various passes. -quiet. */
69
70extern int quiet_flag;
71
72/* Print times taken by the various passes. -ftime-report. */
73
74extern int time_report;
75
76/* Print memory still in use at end of compilation (which may have little
77 to do with peak memory consumption). -fmem-report. */
78
79extern int mem_report;
80
81/* Don't print warning messages. -w. */
82
83extern int inhibit_warnings;
84
85/* Don't suppress warnings from system headers. -Wsystem-headers. */
86
87extern int warn_system_headers;
88
89/* Do print extra warnings (such as for uninitialized variables). -W. */
90
91extern int extra_warnings;
92
93/* Nonzero to warn about unused variables, functions et.al. Use
94 set_Wunused() to update the -Wunused-* flags that correspond to the
95 -Wunused option. */
96
97extern void set_Wunused PARAMS ((int setting));
98
99extern int warn_unused_function;
100extern int warn_unused_label;
101extern int warn_unused_parameter;
102extern int warn_unused_variable;
103extern int warn_unused_value;
104
105/* Nonzero to warn about code which is never reached. */
106
107extern int warn_notreached;
108
109/* Nonzero means warn if inline function is too large. */
110
111extern int warn_inline;
112
113/* Nonzero to warn about variables used before they are initialized. */
114
115extern int warn_uninitialized;
116
117/* Zero if unknown pragmas are ignored
118 One if the compiler should warn about an unknown pragma not in
119 a system include file.
120 Greater than one if the compiler should warn for all unknown
121 pragmas. */
122
123extern int warn_unknown_pragmas;
124
125/* Nonzero means warn about all declarations which shadow others. */
126
127extern int warn_shadow;
128
129/* Warn if a switch on an enum fails to have a case for every enum value. */
129/* Warn if a switch on an enum, that does not have a default case,
130 fails to have a case for every enum value. */
130
131extern int warn_switch;
132
131
132extern int warn_switch;
133
134/* Warn if a switch does not have a default case. */
135
136extern int warn_switch_default;
137
138/* Warn if a switch on an enum fails to have a case for every enum
139 value (regardless of the presence or otherwise of a default case). */
140
141extern int warn_switch_enum;
142
133/* Nonzero means warn about function definitions that default the return type
134 or that use a null return and have a return-type other than void. */
135
136extern int warn_return_type;
137
138/* Warn about functions which might be candidates for attribute noreturn. */
139
140extern int warn_missing_noreturn;
141
142/* Nonzero means warn about pointer casts that increase the required
143 alignment of the target type (and might therefore lead to a crash
144 due to a misaligned access). */
145
146extern int warn_cast_align;
147
148/* Nonzero means warn about any objects definitions whose size is larger
149 than N bytes. Also want about function definitions whose returned
150 values are larger than N bytes. The value N is in `larger_than_size'. */
151
152extern int warn_larger_than;
153extern HOST_WIDE_INT larger_than_size;
154
155/* Warn if a function returns an aggregate,
156 since there are often incompatible calling conventions for doing this. */
157
158extern int warn_aggregate_return;
159
160/* Warn if packed attribute on struct is unnecessary and inefficient. */
161
162extern int warn_packed;
163
164/* Warn when gcc pads a structure to an alignment boundary. */
165
166extern int warn_padded;
167
168/* Warn when an optimization pass is disabled. */
169
170extern int warn_disabled_optimization;
171
172/* Nonzero means warn about uses of __attribute__((deprecated))
173 declarations. */
174
175extern int warn_deprecated_decl;
176
143/* Nonzero means warn about function definitions that default the return type
144 or that use a null return and have a return-type other than void. */
145
146extern int warn_return_type;
147
148/* Warn about functions which might be candidates for attribute noreturn. */
149
150extern int warn_missing_noreturn;
151
152/* Nonzero means warn about pointer casts that increase the required
153 alignment of the target type (and might therefore lead to a crash
154 due to a misaligned access). */
155
156extern int warn_cast_align;
157
158/* Nonzero means warn about any objects definitions whose size is larger
159 than N bytes. Also want about function definitions whose returned
160 values are larger than N bytes. The value N is in `larger_than_size'. */
161
162extern int warn_larger_than;
163extern HOST_WIDE_INT larger_than_size;
164
165/* Warn if a function returns an aggregate,
166 since there are often incompatible calling conventions for doing this. */
167
168extern int warn_aggregate_return;
169
170/* Warn if packed attribute on struct is unnecessary and inefficient. */
171
172extern int warn_packed;
173
174/* Warn when gcc pads a structure to an alignment boundary. */
175
176extern int warn_padded;
177
178/* Warn when an optimization pass is disabled. */
179
180extern int warn_disabled_optimization;
181
182/* Nonzero means warn about uses of __attribute__((deprecated))
183 declarations. */
184
185extern int warn_deprecated_decl;
186
187/* Nonzero means warn about constructs which might not be strict
188 aliasing safe. */
189
190extern int warn_strict_aliasing;
191
177/* Nonzero if generating code to do profiling. */
178
179extern int profile_flag;
180
181/* Nonzero if generating code to profile program flow graph arcs. */
182
183extern int profile_arc_flag;
184
185/* Nonzero if generating info for gcov to calculate line test coverage. */
186
187extern int flag_test_coverage;
188
189/* Nonzero indicates that branch taken probabilities should be calculated. */
190
191extern int flag_branch_probabilities;
192
193/* Nonzero if basic blocks should be reordered. */
194
195extern int flag_reorder_blocks;
196
192/* Nonzero if generating code to do profiling. */
193
194extern int profile_flag;
195
196/* Nonzero if generating code to profile program flow graph arcs. */
197
198extern int profile_arc_flag;
199
200/* Nonzero if generating info for gcov to calculate line test coverage. */
201
202extern int flag_test_coverage;
203
204/* Nonzero indicates that branch taken probabilities should be calculated. */
205
206extern int flag_branch_probabilities;
207
208/* Nonzero if basic blocks should be reordered. */
209
210extern int flag_reorder_blocks;
211
212/* Nonzero if functions should be reordered. */
213
214extern int flag_reorder_functions;
215
197/* Nonzero if registers should be renamed. */
198
199extern int flag_rename_registers;
200
201/* Nonzero for -pedantic switch: warn about anything
202 that standard C forbids. */
203
204extern int pedantic;
205
206/* Temporarily suppress certain warnings.
207 This is set while reading code from a system header file. */
208
209extern int in_system_header;
210
211/* Nonzero for -dp: annotate the assembly with a comment describing the
212 pattern and alternative used. */
213
214extern int flag_print_asm_name;
215
216/* Now the symbols that are set with `-f' switches. */
217
218/* Nonzero means `char' should be signed. */
219
220extern int flag_signed_char;
221
222/* Nonzero means give an enum type only as many bytes as it needs. */
223
224extern int flag_short_enums;
225
226/* Nonzero for -fcaller-saves: allocate values in regs that need to
227 be saved across function calls, if that produces overall better code.
228 Optional now, so people can test it. */
229
230extern int flag_caller_saves;
231
232/* Nonzero for -fpcc-struct-return: return values the same way PCC does. */
233
234extern int flag_pcc_struct_return;
235
236/* Nonzero for -fforce-mem: load memory value into a register
237 before arithmetic on it. This makes better cse but slower compilation. */
238
239extern int flag_force_mem;
240
241/* Nonzero for -fforce-addr: load memory address into a register before
242 reference to memory. This makes better cse but slower compilation. */
243
244extern int flag_force_addr;
245
246/* Nonzero for -fdefer-pop: don't pop args after each function call;
247 instead save them up to pop many calls' args with one insns. */
248
249extern int flag_defer_pop;
250
251/* Nonzero for -ffloat-store: don't allocate floats and doubles
252 in extended-precision registers. */
253
254extern int flag_float_store;
255
256/* Nonzero enables strength-reduction in loop.c. */
257
258extern int flag_strength_reduce;
259
260/* Nonzero enables loop unrolling in unroll.c. Only loops for which the
261 number of iterations can be calculated at compile-time (UNROLL_COMPLETELY,
262 UNROLL_MODULO) or at run-time (preconditioned to be UNROLL_MODULO) are
263 unrolled. */
264
265extern int flag_unroll_loops;
266
267/* Nonzero enables loop unrolling in unroll.c. All loops are unrolled.
268 This is generally not a win. */
269
270extern int flag_unroll_all_loops;
271
272/* Nonzero forces all invariant computations in loops to be moved
273 outside the loop. */
274
275extern int flag_move_all_movables;
276
277/* Nonzero enables prefetch optimizations for arrays in loops. */
278
279extern int flag_prefetch_loop_arrays;
280
281/* Nonzero forces all general induction variables in loops to be
282 strength reduced. */
283
284extern int flag_reduce_all_givs;
285
286/* Nonzero for -fcse-follow-jumps:
287 have cse follow jumps to do a more extensive job. */
288
289extern int flag_cse_follow_jumps;
290
291/* Nonzero for -fcse-skip-blocks:
292 have cse follow a branch around a block. */
293
294extern int flag_cse_skip_blocks;
295
296/* Nonzero for -fexpensive-optimizations:
297 perform miscellaneous relatively-expensive optimizations. */
298extern int flag_expensive_optimizations;
299
300/* Nonzero for -fwritable-strings:
301 store string constants in data segment and don't uniquize them. */
302
303extern int flag_writable_strings;
304
305/* Nonzero means don't put addresses of constant functions in registers.
306 Used for compiling the Unix kernel, where strange substitutions are
307 done on the assembly output. */
308
309extern int flag_no_function_cse;
310
311/* Nonzero for -fomit-frame-pointer:
312 don't make a frame pointer in simple functions that don't require one. */
313
314extern int flag_omit_frame_pointer;
315
316/* Nonzero to inhibit use of define_optimization peephole opts. */
317
318extern int flag_no_peephole;
319
320/* Nonzero means all references through pointers are volatile. */
321
322extern int flag_volatile;
323
324/* Nonzero means treat all global and extern variables as volatile. */
325
326extern int flag_volatile_global;
327
328/* Nonzero means treat all static variables as volatile. */
329
330extern int flag_volatile_static;
331
332/* Nonzero allows GCC to optimize sibling and tail recursive calls. */
333
334extern int flag_optimize_sibling_calls;
335
336/* Nonzero means the front end generally wants `errno' maintained by math
337 operations, like built-in SQRT. */
338
339extern int flag_errno_math;
340
341/* Nonzero means that unsafe floating-point math optimizations are allowed
342 for the sake of speed. IEEE compliance is not guaranteed, and operations
343 are allowed to assume that their arguments and results are "normal"
344 (e.g., nonnegative for SQRT). */
345
346extern int flag_unsafe_math_optimizations;
347
216/* Nonzero if registers should be renamed. */
217
218extern int flag_rename_registers;
219
220/* Nonzero for -pedantic switch: warn about anything
221 that standard C forbids. */
222
223extern int pedantic;
224
225/* Temporarily suppress certain warnings.
226 This is set while reading code from a system header file. */
227
228extern int in_system_header;
229
230/* Nonzero for -dp: annotate the assembly with a comment describing the
231 pattern and alternative used. */
232
233extern int flag_print_asm_name;
234
235/* Now the symbols that are set with `-f' switches. */
236
237/* Nonzero means `char' should be signed. */
238
239extern int flag_signed_char;
240
241/* Nonzero means give an enum type only as many bytes as it needs. */
242
243extern int flag_short_enums;
244
245/* Nonzero for -fcaller-saves: allocate values in regs that need to
246 be saved across function calls, if that produces overall better code.
247 Optional now, so people can test it. */
248
249extern int flag_caller_saves;
250
251/* Nonzero for -fpcc-struct-return: return values the same way PCC does. */
252
253extern int flag_pcc_struct_return;
254
255/* Nonzero for -fforce-mem: load memory value into a register
256 before arithmetic on it. This makes better cse but slower compilation. */
257
258extern int flag_force_mem;
259
260/* Nonzero for -fforce-addr: load memory address into a register before
261 reference to memory. This makes better cse but slower compilation. */
262
263extern int flag_force_addr;
264
265/* Nonzero for -fdefer-pop: don't pop args after each function call;
266 instead save them up to pop many calls' args with one insns. */
267
268extern int flag_defer_pop;
269
270/* Nonzero for -ffloat-store: don't allocate floats and doubles
271 in extended-precision registers. */
272
273extern int flag_float_store;
274
275/* Nonzero enables strength-reduction in loop.c. */
276
277extern int flag_strength_reduce;
278
279/* Nonzero enables loop unrolling in unroll.c. Only loops for which the
280 number of iterations can be calculated at compile-time (UNROLL_COMPLETELY,
281 UNROLL_MODULO) or at run-time (preconditioned to be UNROLL_MODULO) are
282 unrolled. */
283
284extern int flag_unroll_loops;
285
286/* Nonzero enables loop unrolling in unroll.c. All loops are unrolled.
287 This is generally not a win. */
288
289extern int flag_unroll_all_loops;
290
291/* Nonzero forces all invariant computations in loops to be moved
292 outside the loop. */
293
294extern int flag_move_all_movables;
295
296/* Nonzero enables prefetch optimizations for arrays in loops. */
297
298extern int flag_prefetch_loop_arrays;
299
300/* Nonzero forces all general induction variables in loops to be
301 strength reduced. */
302
303extern int flag_reduce_all_givs;
304
305/* Nonzero for -fcse-follow-jumps:
306 have cse follow jumps to do a more extensive job. */
307
308extern int flag_cse_follow_jumps;
309
310/* Nonzero for -fcse-skip-blocks:
311 have cse follow a branch around a block. */
312
313extern int flag_cse_skip_blocks;
314
315/* Nonzero for -fexpensive-optimizations:
316 perform miscellaneous relatively-expensive optimizations. */
317extern int flag_expensive_optimizations;
318
319/* Nonzero for -fwritable-strings:
320 store string constants in data segment and don't uniquize them. */
321
322extern int flag_writable_strings;
323
324/* Nonzero means don't put addresses of constant functions in registers.
325 Used for compiling the Unix kernel, where strange substitutions are
326 done on the assembly output. */
327
328extern int flag_no_function_cse;
329
330/* Nonzero for -fomit-frame-pointer:
331 don't make a frame pointer in simple functions that don't require one. */
332
333extern int flag_omit_frame_pointer;
334
335/* Nonzero to inhibit use of define_optimization peephole opts. */
336
337extern int flag_no_peephole;
338
339/* Nonzero means all references through pointers are volatile. */
340
341extern int flag_volatile;
342
343/* Nonzero means treat all global and extern variables as volatile. */
344
345extern int flag_volatile_global;
346
347/* Nonzero means treat all static variables as volatile. */
348
349extern int flag_volatile_static;
350
351/* Nonzero allows GCC to optimize sibling and tail recursive calls. */
352
353extern int flag_optimize_sibling_calls;
354
355/* Nonzero means the front end generally wants `errno' maintained by math
356 operations, like built-in SQRT. */
357
358extern int flag_errno_math;
359
360/* Nonzero means that unsafe floating-point math optimizations are allowed
361 for the sake of speed. IEEE compliance is not guaranteed, and operations
362 are allowed to assume that their arguments and results are "normal"
363 (e.g., nonnegative for SQRT). */
364
365extern int flag_unsafe_math_optimizations;
366
367/* Nonzero means that no NaNs or +-Infs are expected. */
368
369extern int flag_finite_math_only;
370
348/* Zero means that floating-point math operations cannot generate a
349 (user-visible) trap. This is the case, for example, in nonstop
350 IEEE 754 arithmetic. */
351
352extern int flag_trapping_math;
353
354/* 0 means straightforward implementation of complex divide acceptable.
355 1 means wide ranges of inputs must work for complex divide.
356 2 means C99-like requirements for complex divide (not yet implemented). */
357
358extern int flag_complex_divide_method;
359
360/* Nonzero means to run loop optimizations twice. */
361
362extern int flag_rerun_loop_opt;
363
364/* Nonzero means make functions that look like good inline candidates
365 go inline. */
366
367extern int flag_inline_functions;
368
369/* Nonzero for -fkeep-inline-functions: even if we make a function
370 go inline everywhere, keep its definition around for debugging
371 purposes. */
372
373extern int flag_keep_inline_functions;
374
375/* Nonzero means that functions declared `inline' will be treated
376 as `static'. Prevents generation of zillions of copies of unused
377 static inline functions; instead, `inlines' are written out
378 only when actually used. Used in conjunction with -g. Also
379 does the right thing with #pragma interface. */
380
381extern int flag_no_inline;
382
383/* Nonzero means that we don't want inlining by virtue of -fno-inline,
384 not just because the tree inliner turned us off. */
385
386extern int flag_really_no_inline;
387
388/* Nonzero if we are only using compiler to check syntax errors. */
389
390extern int flag_syntax_only;
391
392/* Nonzero means we should save auxiliary info into a .X file. */
393
394extern int flag_gen_aux_info;
395
396/* Nonzero means make the text shared if supported. */
397
398extern int flag_shared_data;
399
400/* flag_schedule_insns means schedule insns within basic blocks (before
401 local_alloc).
402 flag_schedule_insns_after_reload means schedule insns after
403 global_alloc. */
404
405extern int flag_schedule_insns;
406extern int flag_schedule_insns_after_reload;
407
408/* The following flags have effect only for scheduling before register
409 allocation:
410
371/* Zero means that floating-point math operations cannot generate a
372 (user-visible) trap. This is the case, for example, in nonstop
373 IEEE 754 arithmetic. */
374
375extern int flag_trapping_math;
376
377/* 0 means straightforward implementation of complex divide acceptable.
378 1 means wide ranges of inputs must work for complex divide.
379 2 means C99-like requirements for complex divide (not yet implemented). */
380
381extern int flag_complex_divide_method;
382
383/* Nonzero means to run loop optimizations twice. */
384
385extern int flag_rerun_loop_opt;
386
387/* Nonzero means make functions that look like good inline candidates
388 go inline. */
389
390extern int flag_inline_functions;
391
392/* Nonzero for -fkeep-inline-functions: even if we make a function
393 go inline everywhere, keep its definition around for debugging
394 purposes. */
395
396extern int flag_keep_inline_functions;
397
398/* Nonzero means that functions declared `inline' will be treated
399 as `static'. Prevents generation of zillions of copies of unused
400 static inline functions; instead, `inlines' are written out
401 only when actually used. Used in conjunction with -g. Also
402 does the right thing with #pragma interface. */
403
404extern int flag_no_inline;
405
406/* Nonzero means that we don't want inlining by virtue of -fno-inline,
407 not just because the tree inliner turned us off. */
408
409extern int flag_really_no_inline;
410
411/* Nonzero if we are only using compiler to check syntax errors. */
412
413extern int flag_syntax_only;
414
415/* Nonzero means we should save auxiliary info into a .X file. */
416
417extern int flag_gen_aux_info;
418
419/* Nonzero means make the text shared if supported. */
420
421extern int flag_shared_data;
422
423/* flag_schedule_insns means schedule insns within basic blocks (before
424 local_alloc).
425 flag_schedule_insns_after_reload means schedule insns after
426 global_alloc. */
427
428extern int flag_schedule_insns;
429extern int flag_schedule_insns_after_reload;
430
431/* The following flags have effect only for scheduling before register
432 allocation:
433
411 flag_schedule_interblock means schedule insns accross basic blocks.
434 flag_schedule_interblock means schedule insns across basic blocks.
412 flag_schedule_speculative means allow speculative motion of non-load insns.
413 flag_schedule_speculative_load means allow speculative motion of some
414 load insns.
415 flag_schedule_speculative_load_dangerous allows speculative motion of more
416 load insns. */
417
418extern int flag_schedule_interblock;
419extern int flag_schedule_speculative;
420extern int flag_schedule_speculative_load;
421extern int flag_schedule_speculative_load_dangerous;
422
423/* flag_branch_on_count_reg means try to replace add-1,compare,branch tupple
424 by a cheaper branch, on a count register. */
425extern int flag_branch_on_count_reg;
426
427/* This option is set to 1 on -fsingle-precision-constant option which is
428 used to convert the floating point constants to single precision
429 constants. */
430
431extern int flag_single_precision_constant;
432
433/* Nonzero means put things in delayed-branch slots if supported. */
434
435extern int flag_delayed_branch;
436
437/* Nonzero means suppress output of instruction numbers and line number
438 notes in debugging dumps. */
439
440extern int flag_dump_unnumbered;
441
435 flag_schedule_speculative means allow speculative motion of non-load insns.
436 flag_schedule_speculative_load means allow speculative motion of some
437 load insns.
438 flag_schedule_speculative_load_dangerous allows speculative motion of more
439 load insns. */
440
441extern int flag_schedule_interblock;
442extern int flag_schedule_speculative;
443extern int flag_schedule_speculative_load;
444extern int flag_schedule_speculative_load_dangerous;
445
446/* flag_branch_on_count_reg means try to replace add-1,compare,branch tupple
447 by a cheaper branch, on a count register. */
448extern int flag_branch_on_count_reg;
449
450/* This option is set to 1 on -fsingle-precision-constant option which is
451 used to convert the floating point constants to single precision
452 constants. */
453
454extern int flag_single_precision_constant;
455
456/* Nonzero means put things in delayed-branch slots if supported. */
457
458extern int flag_delayed_branch;
459
460/* Nonzero means suppress output of instruction numbers and line number
461 notes in debugging dumps. */
462
463extern int flag_dump_unnumbered;
464
442/* Nonzero means pretend it is OK to examine bits of target floats,
443 even if that isn't true. The resulting code will have incorrect constants,
444 but the same series of instructions that the native compiler would make. */
445
446extern int flag_pretend_float;
447
448/* Nonzero means change certain warnings into errors.
449 Usually these are warnings about failure to conform to some standard. */
450
451extern int flag_pedantic_errors;
452
465/* Nonzero means change certain warnings into errors.
466 Usually these are warnings about failure to conform to some standard. */
467
468extern int flag_pedantic_errors;
469
453/* Nonzero means generate position-independent code.
454 This is not fully implemented yet. */
470/* Nonzero means generate position-independent code. 1 vs 2 for a
471 target-dependent "small" or "large" mode. */
455
456extern int flag_pic;
457
458/* Nonzero means generate extra code for exception handling and enable
459 exception handling. */
460
461extern int flag_exceptions;
462
463/* Nonzero means generate frame unwind info table when supported */
464
465extern int flag_unwind_tables;
466
467/* Nonzero means generate frame unwind info table exact at each insn boundary */
468
469extern int flag_asynchronous_unwind_tables;
470
471/* Nonzero means don't place uninitialized global data in common storage
472 by default. */
473
474extern int flag_no_common;
475
476/* -finhibit-size-directive inhibits output of .size for ELF.
477 This is used only for compiling crtstuff.c,
478 and it may be extended to other effects
479 needed for crtstuff.c on other systems. */
480extern int flag_inhibit_size_directive;
481
482/* Nonzero means place each function into its own section on those platforms
483 which support arbitrary section names and unlimited numbers of sections. */
484
485extern int flag_function_sections;
486
487/* ... and similar for data. */
488
489extern int flag_data_sections;
490
491/* -fverbose-asm causes extra commentary information to be produced in
492 the generated assembly code (to make it more readable). This option
493 is generally only of use to those who actually need to read the
494 generated assembly code (perhaps while debugging the compiler itself).
495 -fno-verbose-asm, the default, causes the extra information
496 to not be added and is useful when comparing two assembler files. */
497
498extern int flag_verbose_asm;
499
500/* -dA causes debug information to be produced in
501 the generated assembly code (to make it more readable). This option
502 is generally only of use to those who actually need to read the
503 generated assembly code (perhaps while debugging the compiler itself).
504 Currently, this switch is only used by dwarfout.c; however, it is intended
505 to be a catchall for printing debug information in the assembler file. */
506
507extern int flag_debug_asm;
508
509extern int flag_dump_rtl_in_asm;
510
511/* -fgnu-linker specifies use of the GNU linker for initializations.
512 -fno-gnu-linker says that collect will be used. */
513extern int flag_gnu_linker;
514
515/* Tag all structures with __attribute__(packed) */
516extern int flag_pack_struct;
517
518/* This flag is only tested if alias checking is enabled.
519 0 if pointer arguments may alias each other. True in C.
520 1 if pointer arguments may not alias each other but may alias
521 global variables.
522 2 if pointer arguments may not alias each other and may not
523 alias global variables. True in Fortran.
524 The value is ignored if flag_alias_check is 0. */
525extern int flag_argument_noalias;
526
527/* Nonzero if we should do (language-dependent) alias analysis.
528 Typically, this analysis will assume that expressions of certain
529 types do not alias expressions of certain other types. Only used
530 if alias analysis (in general) is enabled. */
531extern int flag_strict_aliasing;
532
533/* Emit code to probe the stack, to help detect stack overflow; also
534 may cause large objects to be allocated dynamically. */
535extern int flag_stack_check;
536
537/* Do the full regmove optimization pass. */
538extern int flag_regmove;
539
540/* Instrument functions with calls at entry and exit, for profiling. */
541extern int flag_instrument_function_entry_exit;
542
543/* Perform a peephole pass before sched2. */
544extern int flag_peephole2;
545
546/* Try to guess branch probablities. */
547extern int flag_guess_branch_prob;
548
472
473extern int flag_pic;
474
475/* Nonzero means generate extra code for exception handling and enable
476 exception handling. */
477
478extern int flag_exceptions;
479
480/* Nonzero means generate frame unwind info table when supported */
481
482extern int flag_unwind_tables;
483
484/* Nonzero means generate frame unwind info table exact at each insn boundary */
485
486extern int flag_asynchronous_unwind_tables;
487
488/* Nonzero means don't place uninitialized global data in common storage
489 by default. */
490
491extern int flag_no_common;
492
493/* -finhibit-size-directive inhibits output of .size for ELF.
494 This is used only for compiling crtstuff.c,
495 and it may be extended to other effects
496 needed for crtstuff.c on other systems. */
497extern int flag_inhibit_size_directive;
498
499/* Nonzero means place each function into its own section on those platforms
500 which support arbitrary section names and unlimited numbers of sections. */
501
502extern int flag_function_sections;
503
504/* ... and similar for data. */
505
506extern int flag_data_sections;
507
508/* -fverbose-asm causes extra commentary information to be produced in
509 the generated assembly code (to make it more readable). This option
510 is generally only of use to those who actually need to read the
511 generated assembly code (perhaps while debugging the compiler itself).
512 -fno-verbose-asm, the default, causes the extra information
513 to not be added and is useful when comparing two assembler files. */
514
515extern int flag_verbose_asm;
516
517/* -dA causes debug information to be produced in
518 the generated assembly code (to make it more readable). This option
519 is generally only of use to those who actually need to read the
520 generated assembly code (perhaps while debugging the compiler itself).
521 Currently, this switch is only used by dwarfout.c; however, it is intended
522 to be a catchall for printing debug information in the assembler file. */
523
524extern int flag_debug_asm;
525
526extern int flag_dump_rtl_in_asm;
527
528/* -fgnu-linker specifies use of the GNU linker for initializations.
529 -fno-gnu-linker says that collect will be used. */
530extern int flag_gnu_linker;
531
532/* Tag all structures with __attribute__(packed) */
533extern int flag_pack_struct;
534
535/* This flag is only tested if alias checking is enabled.
536 0 if pointer arguments may alias each other. True in C.
537 1 if pointer arguments may not alias each other but may alias
538 global variables.
539 2 if pointer arguments may not alias each other and may not
540 alias global variables. True in Fortran.
541 The value is ignored if flag_alias_check is 0. */
542extern int flag_argument_noalias;
543
544/* Nonzero if we should do (language-dependent) alias analysis.
545 Typically, this analysis will assume that expressions of certain
546 types do not alias expressions of certain other types. Only used
547 if alias analysis (in general) is enabled. */
548extern int flag_strict_aliasing;
549
550/* Emit code to probe the stack, to help detect stack overflow; also
551 may cause large objects to be allocated dynamically. */
552extern int flag_stack_check;
553
554/* Do the full regmove optimization pass. */
555extern int flag_regmove;
556
557/* Instrument functions with calls at entry and exit, for profiling. */
558extern int flag_instrument_function_entry_exit;
559
560/* Perform a peephole pass before sched2. */
561extern int flag_peephole2;
562
563/* Try to guess branch probablities. */
564extern int flag_guess_branch_prob;
565
549/* -fbounded-pointers causes gcc to compile pointers as composite
550 objects occupying three words: the pointer value, the base address
551 of the referent object, and the address immediately beyond the end
552 of the referent object. The base and extent allow us to perform
553 runtime bounds checking. -fbounded-pointers implies -fcheck-bounds. */
554extern int flag_bounded_pointers;
555
556/* -fcheck-bounds causes gcc to generate array bounds checks.
566/* -fcheck-bounds causes gcc to generate array bounds checks.
557 For C, C++: defaults to value of flag_bounded_pointers.
558 For ObjC: defaults to off.
567 For C, C++ and ObjC: defaults off.
559 For Java: defaults to on.
568 For Java: defaults to on.
560 For Fortran: defaults to off.
561 For CHILL: defaults to off. */
569 For Fortran: defaults to off. */
562extern int flag_bounds_check;
563
564/* This will attempt to merge constant section constants, if 1 only
565 string constants and constants from constant pool, if 2 also constant
566 variables. */
567extern int flag_merge_constants;
568
569/* If one, renumber instruction UIDs to reduce the number of
570 unused UIDs if there are a lot of instructions. If greater than
571 one, unconditionally renumber instruction UIDs. */
572extern int flag_renumber_insns;
573
574/* Other basic status info about current function. */
575
576/* Nonzero means current function must be given a frame pointer.
577 Set in stmt.c if anything is allocated on the stack there.
578 Set in reload1.c if anything is allocated on the stack there. */
579
580extern int frame_pointer_needed;
581
582/* Nonzero if the generated code should trap on signed overflow
583 for PLUS / SUB / MULT. */
584extern int flag_trapv;
585
586/* Value of the -G xx switch, and whether it was passed or not. */
587extern int g_switch_value;
588extern int g_switch_set;
589
590/* Values of the -falign-* flags: how much to align labels in code.
591 0 means `use default', 1 means `don't align'.
592 For each variable, there is an _log variant which is the power
593 of two not less than the variable, for .align output. */
594
595extern int align_loops;
596extern int align_loops_log;
597extern int align_loops_max_skip;
598extern int align_jumps;
599extern int align_jumps_log;
600extern int align_jumps_max_skip;
601extern int align_labels;
602extern int align_labels_log;
603extern int align_labels_max_skip;
604extern int align_functions;
605extern int align_functions_log;
606
607/* Like align_functions_log above, but used by front-ends to force the
608 minimum function alignment. Zero means no alignment is forced. */
609extern int force_align_functions_log;
610
611/* Nonzero if we dump in VCG format, not plain text. */
612extern int dump_for_graph;
613
614/* Selection of the graph form. */
615enum graph_dump_types
616{
617 no_graph = 0,
618 vcg
619};
620extern enum graph_dump_types graph_dump_format;
621
622/* Nonzero means ignore `#ident' directives. 0 means handle them.
623 On SVR4 targets, it also controls whether or not to emit a
624 string identifying the compiler. */
625
626extern int flag_no_ident;
627
628/* Nonzero if we want to perform enhanced load motion during gcse. */
629
630extern int flag_gcse_lm;
631
632/* Nonzero if we want to perform store motion after gcse. */
633
634extern int flag_gcse_sm;
635
636
637/* Nonzero means we should do dwarf2 duplicate elimination. */
638
639extern int flag_eliminate_dwarf2_dups;
640
570extern int flag_bounds_check;
571
572/* This will attempt to merge constant section constants, if 1 only
573 string constants and constants from constant pool, if 2 also constant
574 variables. */
575extern int flag_merge_constants;
576
577/* If one, renumber instruction UIDs to reduce the number of
578 unused UIDs if there are a lot of instructions. If greater than
579 one, unconditionally renumber instruction UIDs. */
580extern int flag_renumber_insns;
581
582/* Other basic status info about current function. */
583
584/* Nonzero means current function must be given a frame pointer.
585 Set in stmt.c if anything is allocated on the stack there.
586 Set in reload1.c if anything is allocated on the stack there. */
587
588extern int frame_pointer_needed;
589
590/* Nonzero if the generated code should trap on signed overflow
591 for PLUS / SUB / MULT. */
592extern int flag_trapv;
593
594/* Value of the -G xx switch, and whether it was passed or not. */
595extern int g_switch_value;
596extern int g_switch_set;
597
598/* Values of the -falign-* flags: how much to align labels in code.
599 0 means `use default', 1 means `don't align'.
600 For each variable, there is an _log variant which is the power
601 of two not less than the variable, for .align output. */
602
603extern int align_loops;
604extern int align_loops_log;
605extern int align_loops_max_skip;
606extern int align_jumps;
607extern int align_jumps_log;
608extern int align_jumps_max_skip;
609extern int align_labels;
610extern int align_labels_log;
611extern int align_labels_max_skip;
612extern int align_functions;
613extern int align_functions_log;
614
615/* Like align_functions_log above, but used by front-ends to force the
616 minimum function alignment. Zero means no alignment is forced. */
617extern int force_align_functions_log;
618
619/* Nonzero if we dump in VCG format, not plain text. */
620extern int dump_for_graph;
621
622/* Selection of the graph form. */
623enum graph_dump_types
624{
625 no_graph = 0,
626 vcg
627};
628extern enum graph_dump_types graph_dump_format;
629
630/* Nonzero means ignore `#ident' directives. 0 means handle them.
631 On SVR4 targets, it also controls whether or not to emit a
632 string identifying the compiler. */
633
634extern int flag_no_ident;
635
636/* Nonzero if we want to perform enhanced load motion during gcse. */
637
638extern int flag_gcse_lm;
639
640/* Nonzero if we want to perform store motion after gcse. */
641
642extern int flag_gcse_sm;
643
644
645/* Nonzero means we should do dwarf2 duplicate elimination. */
646
647extern int flag_eliminate_dwarf2_dups;
648
641/* Non-zero means to collect statistics which might be expensive
649/* Nonzero means to collect statistics which might be expensive
642 and to print them when we are done. */
643extern int flag_detailed_statistics;
644
645/* Nonzero means enable synchronous exceptions for non-call instructions. */
646extern int flag_non_call_exceptions;
647
650 and to print them when we are done. */
651extern int flag_detailed_statistics;
652
653/* Nonzero means enable synchronous exceptions for non-call instructions. */
654extern int flag_non_call_exceptions;
655
656/* Nonzero means put zero initialized data in the bss section. */
657extern int flag_zero_initialized_in_bss;
658
659/* Nonzero means disable transformations observable by signaling NaNs. */
660extern int flag_signaling_nans;
661
662/* A string that's used when a random name is required. NULL means
663 to make it really random. */
664
665extern const char *flag_random_seed;
666
667/* True if the given mode has a NaN representation and the treatment of
668 NaN operands is important. Certain optimizations, such as folding
669 x * 0 into x, are not correct for NaN operands, and are normally
670 disabled for modes with NaNs. The user can ask for them to be
671 done anyway using the -funsafe-math-optimizations switch. */
672#define HONOR_NANS(MODE) \
673 (MODE_HAS_NANS (MODE) && !flag_finite_math_only)
674
675/* Like HONOR_NANs, but true if we honor signaling NaNs (or sNaNs). */
676#define HONOR_SNANS(MODE) (flag_signaling_nans && HONOR_NANS (MODE))
677
678/* As for HONOR_NANS, but true if the mode can represent infinity and
679 the treatment of infinite values is important. */
680#define HONOR_INFINITIES(MODE) \
681 (MODE_HAS_INFINITIES (MODE) && !flag_finite_math_only)
682
683/* Like HONOR_NANS, but true if the given mode distinguishes between
684 postive and negative zero, and the sign of zero is important. */
685#define HONOR_SIGNED_ZEROS(MODE) \
686 (MODE_HAS_SIGNED_ZEROS (MODE) && !flag_unsafe_math_optimizations)
687
688/* Like HONOR_NANS, but true if given mode supports sign-dependent rounding,
689 and the rounding mode is important. */
690#define HONOR_SIGN_DEPENDENT_ROUNDING(MODE) \
691 (MODE_HAS_SIGN_DEPENDENT_ROUNDING (MODE) && !flag_unsafe_math_optimizations)
692
648#endif /* ! GCC_FLAGS_H */
693#endif /* ! GCC_FLAGS_H */