[AArch64][2/14] Refactor arches handling, add arch enum identifier
[official-gcc.git] / gcc / opts.c
blob468a802250ed755da7f0a433fbfc01a9ed5d85b5
1 /* Command line option handling.
2 Copyright (C) 2002-2015 Free Software Foundation, Inc.
3 Contributed by Neil Booth.
5 This file is part of GCC.
7 GCC is free software; you can redistribute it and/or modify it under
8 the terms of the GNU General Public License as published by the Free
9 Software Foundation; either version 3, or (at your option) any later
10 version.
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
15 for more details.
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING3. If not see
19 <http://www.gnu.org/licenses/>. */
21 #include "config.h"
22 #include "system.h"
23 #include "intl.h"
24 #include "coretypes.h"
25 #include "opts.h"
26 #include "tm.h"
27 #include "flags.h"
28 #include "params.h"
29 #include "diagnostic.h"
30 #include "opts-diagnostic.h"
31 #include "insn-attr-common.h"
32 #include "common/common-target.h"
34 static void set_Wstrict_aliasing (struct gcc_options *opts, int onoff);
36 /* Indexed by enum debug_info_type. */
37 const char *const debug_type_names[] =
39 "none", "stabs", "coff", "dwarf-2", "xcoff", "vms"
42 /* Parse the -femit-struct-debug-detailed option value
43 and set the flag variables. */
45 #define MATCH( prefix, string ) \
46 ((strncmp (prefix, string, sizeof prefix - 1) == 0) \
47 ? ((string += sizeof prefix - 1), 1) : 0)
49 void
50 set_struct_debug_option (struct gcc_options *opts, location_t loc,
51 const char *spec)
53 /* various labels for comparison */
54 static const char dfn_lbl[] = "dfn:", dir_lbl[] = "dir:", ind_lbl[] = "ind:";
55 static const char ord_lbl[] = "ord:", gen_lbl[] = "gen:";
56 static const char none_lbl[] = "none", any_lbl[] = "any";
57 static const char base_lbl[] = "base", sys_lbl[] = "sys";
59 enum debug_struct_file files = DINFO_STRUCT_FILE_ANY;
60 /* Default is to apply to as much as possible. */
61 enum debug_info_usage usage = DINFO_USAGE_NUM_ENUMS;
62 int ord = 1, gen = 1;
64 /* What usage? */
65 if (MATCH (dfn_lbl, spec))
66 usage = DINFO_USAGE_DFN;
67 else if (MATCH (dir_lbl, spec))
68 usage = DINFO_USAGE_DIR_USE;
69 else if (MATCH (ind_lbl, spec))
70 usage = DINFO_USAGE_IND_USE;
72 /* Generics or not? */
73 if (MATCH (ord_lbl, spec))
74 gen = 0;
75 else if (MATCH (gen_lbl, spec))
76 ord = 0;
78 /* What allowable environment? */
79 if (MATCH (none_lbl, spec))
80 files = DINFO_STRUCT_FILE_NONE;
81 else if (MATCH (any_lbl, spec))
82 files = DINFO_STRUCT_FILE_ANY;
83 else if (MATCH (sys_lbl, spec))
84 files = DINFO_STRUCT_FILE_SYS;
85 else if (MATCH (base_lbl, spec))
86 files = DINFO_STRUCT_FILE_BASE;
87 else
88 error_at (loc,
89 "argument %qs to %<-femit-struct-debug-detailed%> "
90 "not recognized",
91 spec);
93 /* Effect the specification. */
94 if (usage == DINFO_USAGE_NUM_ENUMS)
96 if (ord)
98 opts->x_debug_struct_ordinary[DINFO_USAGE_DFN] = files;
99 opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE] = files;
100 opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE] = files;
102 if (gen)
104 opts->x_debug_struct_generic[DINFO_USAGE_DFN] = files;
105 opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE] = files;
106 opts->x_debug_struct_generic[DINFO_USAGE_IND_USE] = files;
109 else
111 if (ord)
112 opts->x_debug_struct_ordinary[usage] = files;
113 if (gen)
114 opts->x_debug_struct_generic[usage] = files;
117 if (*spec == ',')
118 set_struct_debug_option (opts, loc, spec+1);
119 else
121 /* No more -femit-struct-debug-detailed specifications.
122 Do final checks. */
123 if (*spec != '\0')
124 error_at (loc,
125 "argument %qs to %<-femit-struct-debug-detailed%> unknown",
126 spec);
127 if (opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE]
128 < opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE]
129 || opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE]
130 < opts->x_debug_struct_generic[DINFO_USAGE_IND_USE])
131 error_at (loc,
132 "%<-femit-struct-debug-detailed=dir:...%> must allow "
133 "at least as much as "
134 "%<-femit-struct-debug-detailed=ind:...%>");
138 /* Strip off a legitimate source ending from the input string NAME of
139 length LEN. Rather than having to know the names used by all of
140 our front ends, we strip off an ending of a period followed by
141 up to five characters. (Java uses ".class".) */
143 void
144 strip_off_ending (char *name, int len)
146 int i;
147 for (i = 2; i < 6 && len > i; i++)
149 if (name[len - i] == '.')
151 name[len - i] = '\0';
152 break;
157 /* Find the base name of a path, stripping off both directories and
158 a single final extension. */
160 base_of_path (const char *path, const char **base_out)
162 const char *base = path;
163 const char *dot = 0;
164 const char *p = path;
165 char c = *p;
166 while (c)
168 if (IS_DIR_SEPARATOR (c))
170 base = p + 1;
171 dot = 0;
173 else if (c == '.')
174 dot = p;
175 c = *++p;
177 if (!dot)
178 dot = p;
179 *base_out = base;
180 return dot - base;
183 /* What to print when a switch has no documentation. */
184 static const char undocumented_msg[] = N_("This switch lacks documentation");
186 typedef char *char_p; /* For DEF_VEC_P. */
188 static void handle_param (struct gcc_options *opts,
189 struct gcc_options *opts_set, location_t loc,
190 const char *carg);
191 static void set_debug_level (enum debug_info_type type, int extended,
192 const char *arg, struct gcc_options *opts,
193 struct gcc_options *opts_set,
194 location_t loc);
195 static void set_fast_math_flags (struct gcc_options *opts, int set);
196 static void decode_d_option (const char *arg, struct gcc_options *opts,
197 location_t loc, diagnostic_context *dc);
198 static void set_unsafe_math_optimizations_flags (struct gcc_options *opts,
199 int set);
200 static void enable_warning_as_error (const char *arg, int value,
201 unsigned int lang_mask,
202 const struct cl_option_handlers *handlers,
203 struct gcc_options *opts,
204 struct gcc_options *opts_set,
205 location_t loc,
206 diagnostic_context *dc);
208 /* Handle a back-end option; arguments and return value as for
209 handle_option. */
211 bool
212 target_handle_option (struct gcc_options *opts,
213 struct gcc_options *opts_set,
214 const struct cl_decoded_option *decoded,
215 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
216 location_t loc,
217 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
218 diagnostic_context *dc)
220 gcc_assert (dc == global_dc);
221 gcc_assert (kind == DK_UNSPECIFIED);
222 return targetm_common.handle_option (opts, opts_set, decoded, loc);
225 /* Add comma-separated strings to a char_p vector. */
227 static void
228 add_comma_separated_to_vector (void **pvec, const char *arg)
230 char *tmp;
231 char *r;
232 char *w;
233 char *token_start;
234 vec<char_p> *v = (vec<char_p> *) *pvec;
236 vec_check_alloc (v, 1);
238 /* We never free this string. */
239 tmp = xstrdup (arg);
241 r = tmp;
242 w = tmp;
243 token_start = tmp;
245 while (*r != '\0')
247 if (*r == ',')
249 *w++ = '\0';
250 ++r;
251 v->safe_push (token_start);
252 token_start = w;
254 if (*r == '\\' && r[1] == ',')
256 *w++ = ',';
257 r += 2;
259 else
260 *w++ = *r++;
262 if (*token_start != '\0')
263 v->safe_push (token_start);
265 *pvec = v;
268 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
270 void
271 init_options_struct (struct gcc_options *opts, struct gcc_options *opts_set)
273 size_t num_params = get_num_compiler_params ();
275 gcc_obstack_init (&opts_obstack);
277 *opts = global_options_init;
279 if (opts_set)
280 memset (opts_set, 0, sizeof (*opts_set));
282 opts->x_param_values = XNEWVEC (int, num_params);
284 if (opts_set)
285 opts_set->x_param_values = XCNEWVEC (int, num_params);
287 init_param_values (opts->x_param_values);
289 /* Initialize whether `char' is signed. */
290 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
291 /* Set this to a special "uninitialized" value. The actual default
292 is set after target options have been processed. */
293 opts->x_flag_short_enums = 2;
295 /* Initialize target_flags before default_options_optimization
296 so the latter can modify it. */
297 opts->x_target_flags = targetm_common.default_target_flags;
299 /* Some targets have ABI-specified unwind tables. */
300 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
302 /* Some targets have other target-specific initialization. */
303 targetm_common.option_init_struct (opts);
306 /* Release any allocations owned by OPTS. */
308 void
309 finalize_options_struct (struct gcc_options *opts)
311 XDELETEVEC (opts->x_param_values);
314 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
315 -Ofast if FAST is set, -Og if DEBUG is set), apply the option DEFAULT_OPT
316 to OPTS and OPTS_SET, diagnostic context DC, location LOC, with language
317 mask LANG_MASK and option handlers HANDLERS. */
319 static void
320 maybe_default_option (struct gcc_options *opts,
321 struct gcc_options *opts_set,
322 const struct default_options *default_opt,
323 int level, bool size, bool fast, bool debug,
324 unsigned int lang_mask,
325 const struct cl_option_handlers *handlers,
326 location_t loc,
327 diagnostic_context *dc)
329 const struct cl_option *option = &cl_options[default_opt->opt_index];
330 bool enabled;
332 if (size)
333 gcc_assert (level == 2);
334 if (fast)
335 gcc_assert (level == 3);
336 if (debug)
337 gcc_assert (level == 1);
339 switch (default_opt->levels)
341 case OPT_LEVELS_ALL:
342 enabled = true;
343 break;
345 case OPT_LEVELS_0_ONLY:
346 enabled = (level == 0);
347 break;
349 case OPT_LEVELS_1_PLUS:
350 enabled = (level >= 1);
351 break;
353 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
354 enabled = (level >= 1 && !size && !debug);
355 break;
357 case OPT_LEVELS_1_PLUS_NOT_DEBUG:
358 enabled = (level >= 1 && !debug);
359 break;
361 case OPT_LEVELS_2_PLUS:
362 enabled = (level >= 2);
363 break;
365 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
366 enabled = (level >= 2 && !size && !debug);
367 break;
369 case OPT_LEVELS_3_PLUS:
370 enabled = (level >= 3);
371 break;
373 case OPT_LEVELS_3_PLUS_AND_SIZE:
374 enabled = (level >= 3 || size);
375 break;
377 case OPT_LEVELS_SIZE:
378 enabled = size;
379 break;
381 case OPT_LEVELS_FAST:
382 enabled = fast;
383 break;
385 case OPT_LEVELS_NONE:
386 default:
387 gcc_unreachable ();
390 if (enabled)
391 handle_generated_option (opts, opts_set, default_opt->opt_index,
392 default_opt->arg, default_opt->value,
393 lang_mask, DK_UNSPECIFIED, loc,
394 handlers, dc);
395 else if (default_opt->arg == NULL
396 && !option->cl_reject_negative)
397 handle_generated_option (opts, opts_set, default_opt->opt_index,
398 default_opt->arg, !default_opt->value,
399 lang_mask, DK_UNSPECIFIED, loc,
400 handlers, dc);
403 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
404 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
405 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
406 language mask LANG_MASK and option handlers HANDLERS. */
408 static void
409 maybe_default_options (struct gcc_options *opts,
410 struct gcc_options *opts_set,
411 const struct default_options *default_opts,
412 int level, bool size, bool fast, bool debug,
413 unsigned int lang_mask,
414 const struct cl_option_handlers *handlers,
415 location_t loc,
416 diagnostic_context *dc)
418 size_t i;
420 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
421 maybe_default_option (opts, opts_set, &default_opts[i],
422 level, size, fast, debug,
423 lang_mask, handlers, loc, dc);
426 /* Table of options enabled by default at different levels. */
428 static const struct default_options default_options_table[] =
430 /* -O1 optimizations. */
431 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
432 #ifdef DELAY_SLOTS
433 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
434 #endif
435 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
436 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
437 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
438 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion, NULL, 1 },
439 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion2, NULL, 1 },
440 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
441 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
442 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
443 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
444 { OPT_LEVELS_1_PLUS, OPT_fshrink_wrap, NULL, 1 },
445 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
446 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
447 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_bit_ccp, NULL, 1 },
448 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
449 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
450 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
451 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
452 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_sra, NULL, 1 },
453 { OPT_LEVELS_1_PLUS, OPT_ftree_copyrename, NULL, 1 },
454 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
455 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
456 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
457 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
458 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
459 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
460 { OPT_LEVELS_1_PLUS, OPT_ftree_slsr, NULL, 1 },
461 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fbranch_count_reg, NULL, 1 },
462 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fmove_loop_invariants, NULL, 1 },
463 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_pta, NULL, 1 },
464 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fssa_phiopt, NULL, 1 },
466 /* -O2 optimizations. */
467 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
468 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
469 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
470 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
471 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
472 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
473 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
474 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
475 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
476 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
477 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
478 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
479 #ifdef INSN_SCHEDULING
480 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
481 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
482 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
483 #endif
484 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_freorder_blocks, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
488 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
489 { OPT_LEVELS_2_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
490 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
491 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
492 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
493 { OPT_LEVELS_2_PLUS, OPT_fipa_cp_alignment, NULL, 1 },
494 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
495 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
496 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
497 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
498 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
499 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
500 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
501 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
502 { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
503 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
504 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
505 { OPT_LEVELS_2_PLUS, OPT_fipa_icf, NULL, 1 },
506 { OPT_LEVELS_2_PLUS, OPT_fisolate_erroneous_paths_dereference, NULL, 1 },
507 { OPT_LEVELS_2_PLUS, OPT_fipa_ra, NULL, 1 },
508 { OPT_LEVELS_2_PLUS, OPT_flra_remat, NULL, 1 },
510 /* -O3 optimizations. */
511 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
512 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
513 /* Inlining of functions reducing size is a good idea with -Os
514 regardless of them being declared inline. */
515 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
516 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
517 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
518 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
519 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
520 { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
521 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
522 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
523 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
525 /* -Ofast adds optimizations to -O3. */
526 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
528 { OPT_LEVELS_NONE, 0, NULL, 0 }
531 /* Default the options in OPTS and OPTS_SET based on the optimization
532 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
533 void
534 default_options_optimization (struct gcc_options *opts,
535 struct gcc_options *opts_set,
536 struct cl_decoded_option *decoded_options,
537 unsigned int decoded_options_count,
538 location_t loc,
539 unsigned int lang_mask,
540 const struct cl_option_handlers *handlers,
541 diagnostic_context *dc)
543 unsigned int i;
544 int opt2;
546 /* Scan to see what optimization level has been specified. That will
547 determine the default value of many flags. */
548 for (i = 1; i < decoded_options_count; i++)
550 struct cl_decoded_option *opt = &decoded_options[i];
551 switch (opt->opt_index)
553 case OPT_O:
554 if (*opt->arg == '\0')
556 opts->x_optimize = 1;
557 opts->x_optimize_size = 0;
558 opts->x_optimize_fast = 0;
559 opts->x_optimize_debug = 0;
561 else
563 const int optimize_val = integral_argument (opt->arg);
564 if (optimize_val == -1)
565 error_at (loc, "argument to %<-O%> should be a non-negative "
566 "integer, %<g%>, %<s%> or %<fast%>");
567 else
569 opts->x_optimize = optimize_val;
570 if ((unsigned int) opts->x_optimize > 255)
571 opts->x_optimize = 255;
572 opts->x_optimize_size = 0;
573 opts->x_optimize_fast = 0;
574 opts->x_optimize_debug = 0;
577 break;
579 case OPT_Os:
580 opts->x_optimize_size = 1;
582 /* Optimizing for size forces optimize to be 2. */
583 opts->x_optimize = 2;
584 opts->x_optimize_fast = 0;
585 opts->x_optimize_debug = 0;
586 break;
588 case OPT_Ofast:
589 /* -Ofast only adds flags to -O3. */
590 opts->x_optimize_size = 0;
591 opts->x_optimize = 3;
592 opts->x_optimize_fast = 1;
593 opts->x_optimize_debug = 0;
594 break;
596 case OPT_Og:
597 /* -Og selects optimization level 1. */
598 opts->x_optimize_size = 0;
599 opts->x_optimize = 1;
600 opts->x_optimize_fast = 0;
601 opts->x_optimize_debug = 1;
602 break;
604 default:
605 /* Ignore other options in this prescan. */
606 break;
610 maybe_default_options (opts, opts_set, default_options_table,
611 opts->x_optimize, opts->x_optimize_size,
612 opts->x_optimize_fast, opts->x_optimize_debug,
613 lang_mask, handlers, loc, dc);
615 /* -O2 param settings. */
616 opt2 = (opts->x_optimize >= 2);
618 /* Track fields in field-sensitive alias analysis. */
619 maybe_set_param_value
620 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
621 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
622 opts->x_param_values, opts_set->x_param_values);
624 /* For -O1 only do loop invariant motion for very small loops. */
625 maybe_set_param_value
626 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
627 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
628 opts->x_param_values, opts_set->x_param_values);
630 /* At -Ofast, allow store motion to introduce potential race conditions. */
631 maybe_set_param_value
632 (PARAM_ALLOW_STORE_DATA_RACES,
633 opts->x_optimize_fast ? 1
634 : default_param_value (PARAM_ALLOW_STORE_DATA_RACES),
635 opts->x_param_values, opts_set->x_param_values);
637 if (opts->x_optimize_size)
638 /* We want to crossjump as much as possible. */
639 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
640 opts->x_param_values, opts_set->x_param_values);
641 else
642 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
643 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
644 opts->x_param_values, opts_set->x_param_values);
646 /* Restrict the amount of work combine does at -Og while retaining
647 most of its useful transforms. */
648 if (opts->x_optimize_debug)
649 maybe_set_param_value (PARAM_MAX_COMBINE_INSNS, 2,
650 opts->x_param_values, opts_set->x_param_values);
652 /* Allow default optimizations to be specified on a per-machine basis. */
653 maybe_default_options (opts, opts_set,
654 targetm_common.option_optimization_table,
655 opts->x_optimize, opts->x_optimize_size,
656 opts->x_optimize_fast, opts->x_optimize_debug,
657 lang_mask, handlers, loc, dc);
660 /* After all options at LOC have been read into OPTS and OPTS_SET,
661 finalize settings of those options and diagnose incompatible
662 combinations. */
663 void
664 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
665 location_t loc)
667 enum unwind_info_type ui_except;
669 if (opts->x_dump_base_name
670 && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name)
671 && ! opts->x_dump_base_name_prefixed)
673 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
674 OPTS->X_DUMP_DIR_NAME directory. Then try to make
675 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
676 directory, typically the directory to contain the object
677 file. */
678 if (opts->x_dump_dir_name)
679 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
680 opts->x_dump_base_name, NULL);
681 else if (opts->x_aux_base_name
682 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
684 const char *aux_base;
686 base_of_path (opts->x_aux_base_name, &aux_base);
687 if (opts->x_aux_base_name != aux_base)
689 int dir_len = aux_base - opts->x_aux_base_name;
690 char *new_dump_base_name
691 = XOBNEWVEC (&opts_obstack, char,
692 strlen (opts->x_dump_base_name) + dir_len + 1);
694 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
695 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
696 /* Append existing OPTS->X_DUMP_BASE_NAME. */
697 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
698 opts->x_dump_base_name = new_dump_base_name;
701 opts->x_dump_base_name_prefixed = true;
704 /* Handle related options for unit-at-a-time, toplevel-reorder, and
705 section-anchors. */
706 if (!opts->x_flag_unit_at_a_time)
708 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
709 error_at (loc, "section anchors must be disabled when unit-at-a-time "
710 "is disabled");
711 opts->x_flag_section_anchors = 0;
712 if (opts->x_flag_toplevel_reorder == 1)
713 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
714 "is disabled");
715 opts->x_flag_toplevel_reorder = 0;
718 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
719 sorry ("transactional memory is not supported with non-call exceptions");
721 /* Unless the user has asked for section anchors, we disable toplevel
722 reordering at -O0 to disable transformations that might be surprising
723 to end users and to get -fno-toplevel-reorder tested. */
724 if (!opts->x_optimize
725 && opts->x_flag_toplevel_reorder == 2
726 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
728 opts->x_flag_toplevel_reorder = 0;
729 opts->x_flag_section_anchors = 0;
731 if (!opts->x_flag_toplevel_reorder)
733 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
734 error_at (loc, "section anchors must be disabled when toplevel reorder"
735 " is disabled");
736 opts->x_flag_section_anchors = 0;
739 if (!opts->x_flag_opts_finished)
741 /* We initialize opts->x_flag_pie to -1 so that targets can set a
742 default value. */
743 if (opts->x_flag_pie == -1)
745 if (opts->x_flag_pic == 0)
746 opts->x_flag_pie = DEFAULT_FLAG_PIE;
747 else
748 opts->x_flag_pie = 0;
750 if (opts->x_flag_pie)
751 opts->x_flag_pic = opts->x_flag_pie;
752 if (opts->x_flag_pic && !opts->x_flag_pie)
753 opts->x_flag_shlib = 1;
754 opts->x_flag_opts_finished = true;
757 if (opts->x_optimize == 0)
759 /* Inlining does not work if not optimizing,
760 so force it not to be done. */
761 opts->x_warn_inline = 0;
762 opts->x_flag_no_inline = 1;
765 /* The optimization to partition hot and cold basic blocks into separate
766 sections of the .o and executable files does not work (currently)
767 with exception handling. This is because there is no support for
768 generating unwind info. If opts->x_flag_exceptions is turned on
769 we need to turn off the partitioning optimization. */
771 ui_except = targetm_common.except_unwind_info (opts);
773 if (opts->x_flag_exceptions
774 && opts->x_flag_reorder_blocks_and_partition
775 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
777 if (opts_set->x_flag_reorder_blocks_and_partition)
778 inform (loc,
779 "-freorder-blocks-and-partition does not work "
780 "with exceptions on this architecture");
781 opts->x_flag_reorder_blocks_and_partition = 0;
782 opts->x_flag_reorder_blocks = 1;
785 /* If user requested unwind info, then turn off the partitioning
786 optimization. */
788 if (opts->x_flag_unwind_tables
789 && !targetm_common.unwind_tables_default
790 && opts->x_flag_reorder_blocks_and_partition
791 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
793 if (opts_set->x_flag_reorder_blocks_and_partition)
794 inform (loc,
795 "-freorder-blocks-and-partition does not support "
796 "unwind info on this architecture");
797 opts->x_flag_reorder_blocks_and_partition = 0;
798 opts->x_flag_reorder_blocks = 1;
801 /* If the target requested unwind info, then turn off the partitioning
802 optimization with a different message. Likewise, if the target does not
803 support named sections. */
805 if (opts->x_flag_reorder_blocks_and_partition
806 && (!targetm_common.have_named_sections
807 || (opts->x_flag_unwind_tables
808 && targetm_common.unwind_tables_default
809 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
811 if (opts_set->x_flag_reorder_blocks_and_partition)
812 inform (loc,
813 "-freorder-blocks-and-partition does not work "
814 "on this architecture");
815 opts->x_flag_reorder_blocks_and_partition = 0;
816 opts->x_flag_reorder_blocks = 1;
819 if (opts->x_flag_reorder_blocks_and_partition
820 && !opts_set->x_flag_reorder_functions)
821 opts->x_flag_reorder_functions = 1;
823 /* Pipelining of outer loops is only possible when general pipelining
824 capabilities are requested. */
825 if (!opts->x_flag_sel_sched_pipelining)
826 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
828 if (opts->x_flag_conserve_stack)
830 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
831 opts->x_param_values, opts_set->x_param_values);
832 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
833 opts->x_param_values, opts_set->x_param_values);
836 if (opts->x_flag_lto)
838 #ifdef ENABLE_LTO
839 opts->x_flag_generate_lto = 1;
841 /* When generating IL, do not operate in whole-program mode.
842 Otherwise, symbols will be privatized too early, causing link
843 errors later. */
844 opts->x_flag_whole_program = 0;
845 #else
846 error_at (loc, "LTO support has not been enabled in this configuration");
847 #endif
848 if (!opts->x_flag_fat_lto_objects
849 && (!HAVE_LTO_PLUGIN
850 || (opts_set->x_flag_use_linker_plugin
851 && !opts->x_flag_use_linker_plugin)))
853 if (opts_set->x_flag_fat_lto_objects)
854 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin");
855 opts->x_flag_fat_lto_objects = 1;
859 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
860 default value if they choose based on other options. */
861 if (opts->x_flag_split_stack == -1)
862 opts->x_flag_split_stack = 0;
863 else if (opts->x_flag_split_stack)
865 if (!targetm_common.supports_split_stack (true, opts))
867 error_at (loc, "%<-fsplit-stack%> is not supported by "
868 "this compiler configuration");
869 opts->x_flag_split_stack = 0;
873 /* Tune vectorization related parametees according to cost model. */
874 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
876 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
877 6, opts->x_param_values, opts_set->x_param_values);
878 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
879 0, opts->x_param_values, opts_set->x_param_values);
880 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
881 0, opts->x_param_values, opts_set->x_param_values);
884 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
885 is disabled. */
886 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
887 || !opts->x_flag_tree_loop_if_convert)
888 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
889 opts->x_param_values, opts_set->x_param_values);
891 /* The -gsplit-dwarf option requires -ggnu-pubnames. */
892 if (opts->x_dwarf_split_debug_info)
893 opts->x_debug_generate_pub_sections = 2;
895 /* Userspace and kernel ASan conflict with each other. */
897 if ((opts->x_flag_sanitize & SANITIZE_USER_ADDRESS)
898 && (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS))
899 error_at (loc,
900 "-fsanitize=address is incompatible with "
901 "-fsanitize=kernel-address");
903 /* And with TSan. */
905 if ((opts->x_flag_sanitize & SANITIZE_ADDRESS)
906 && (opts->x_flag_sanitize & SANITIZE_THREAD))
907 error_at (loc,
908 "-fsanitize=address and -fsanitize=kernel-address "
909 "are incompatible with -fsanitize=thread");
911 /* Error recovery is not allowed for ASan and TSan. */
913 if (opts->x_flag_sanitize_recover & SANITIZE_USER_ADDRESS)
914 error_at (loc, "-fsanitize-recover=address is not supported");
916 if (opts->x_flag_sanitize_recover & SANITIZE_THREAD)
917 error_at (loc, "-fsanitize-recover=thread is not supported");
919 if (opts->x_flag_sanitize_recover & SANITIZE_LEAK)
920 error_at (loc, "-fsanitize-recover=leak is not supported");
922 /* When instrumenting the pointers, we don't want to remove
923 the null pointer checks. */
924 if (opts->x_flag_sanitize & (SANITIZE_NULL | SANITIZE_NONNULL_ATTRIBUTE
925 | SANITIZE_RETURNS_NONNULL_ATTRIBUTE))
926 opts->x_flag_delete_null_pointer_checks = 0;
928 /* Aggressive compiler optimizations may cause false negatives. */
929 if (opts->x_flag_sanitize)
931 opts->x_flag_aggressive_loop_optimizations = 0;
932 opts->x_flag_strict_overflow = 0;
936 #define LEFT_COLUMN 27
938 /* Output ITEM, of length ITEM_WIDTH, in the left column,
939 followed by word-wrapped HELP in a second column. */
940 static void
941 wrap_help (const char *help,
942 const char *item,
943 unsigned int item_width,
944 unsigned int columns)
946 unsigned int col_width = LEFT_COLUMN;
947 unsigned int remaining, room, len;
949 remaining = strlen (help);
953 room = columns - 3 - MAX (col_width, item_width);
954 if (room > columns)
955 room = 0;
956 len = remaining;
958 if (room < len)
960 unsigned int i;
962 for (i = 0; help[i]; i++)
964 if (i >= room && len != remaining)
965 break;
966 if (help[i] == ' ')
967 len = i;
968 else if ((help[i] == '-' || help[i] == '/')
969 && help[i + 1] != ' '
970 && i > 0 && ISALPHA (help[i - 1]))
971 len = i + 1;
975 printf (" %-*.*s %.*s\n", col_width, item_width, item, len, help);
976 item_width = 0;
977 while (help[len] == ' ')
978 len++;
979 help += len;
980 remaining -= len;
982 while (remaining);
985 /* Print help for a specific front-end, etc. */
986 static void
987 print_filtered_help (unsigned int include_flags,
988 unsigned int exclude_flags,
989 unsigned int any_flags,
990 unsigned int columns,
991 struct gcc_options *opts,
992 unsigned int lang_mask)
994 unsigned int i;
995 const char *help;
996 bool found = false;
997 bool displayed = false;
998 char new_help[128];
1000 if (include_flags == CL_PARAMS)
1002 for (i = 0; i < LAST_PARAM; i++)
1004 const char *param = compiler_params[i].option;
1006 help = compiler_params[i].help;
1007 if (help == NULL || *help == '\0')
1009 if (exclude_flags & CL_UNDOCUMENTED)
1010 continue;
1011 help = undocumented_msg;
1014 /* Get the translation. */
1015 help = _(help);
1017 if (!opts->x_quiet_flag)
1019 snprintf (new_help, sizeof (new_help),
1020 _("default %d minimum %d maximum %d"),
1021 compiler_params[i].default_value,
1022 compiler_params[i].min_value,
1023 compiler_params[i].max_value);
1024 help = new_help;
1026 wrap_help (help, param, strlen (param), columns);
1028 putchar ('\n');
1029 return;
1032 if (!opts->x_help_printed)
1033 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
1035 if (!opts->x_help_enum_printed)
1036 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
1038 for (i = 0; i < cl_options_count; i++)
1040 const struct cl_option *option = cl_options + i;
1041 unsigned int len;
1042 const char *opt;
1043 const char *tab;
1045 if (include_flags == 0
1046 || ((option->flags & include_flags) != include_flags))
1048 if ((option->flags & any_flags) == 0)
1049 continue;
1052 /* Skip unwanted switches. */
1053 if ((option->flags & exclude_flags) != 0)
1054 continue;
1056 /* The driver currently prints its own help text. */
1057 if ((option->flags & CL_DRIVER) != 0
1058 && (option->flags & (((1U << cl_lang_count) - 1)
1059 | CL_COMMON | CL_TARGET)) == 0)
1060 continue;
1062 found = true;
1063 /* Skip switches that have already been printed. */
1064 if (opts->x_help_printed[i])
1065 continue;
1067 opts->x_help_printed[i] = true;
1069 help = option->help;
1070 if (help == NULL)
1072 if (exclude_flags & CL_UNDOCUMENTED)
1073 continue;
1074 help = undocumented_msg;
1077 /* Get the translation. */
1078 help = _(help);
1080 /* Find the gap between the name of the
1081 option and its descriptive text. */
1082 tab = strchr (help, '\t');
1083 if (tab)
1085 len = tab - help;
1086 opt = help;
1087 help = tab + 1;
1089 else
1091 opt = option->opt_text;
1092 len = strlen (opt);
1095 /* With the -Q option enabled we change the descriptive text associated
1096 with an option to be an indication of its current setting. */
1097 if (!opts->x_quiet_flag)
1099 void *flag_var = option_flag_var (i, opts);
1101 if (len < (LEFT_COLUMN + 2))
1102 strcpy (new_help, "\t\t");
1103 else
1104 strcpy (new_help, "\t");
1106 if (flag_var != NULL
1107 && option->var_type != CLVC_DEFER)
1109 if (option->flags & CL_JOINED)
1111 if (option->var_type == CLVC_STRING)
1113 if (* (const char **) flag_var != NULL)
1114 snprintf (new_help + strlen (new_help),
1115 sizeof (new_help) - strlen (new_help),
1116 "%s", * (const char **) flag_var);
1118 else if (option->var_type == CLVC_ENUM)
1120 const struct cl_enum *e = &cl_enums[option->var_enum];
1121 int value;
1122 const char *arg = NULL;
1124 value = e->get (flag_var);
1125 enum_value_to_arg (e->values, &arg, value, lang_mask);
1126 if (arg == NULL)
1127 arg = _("[default]");
1128 snprintf (new_help + strlen (new_help),
1129 sizeof (new_help) - strlen (new_help),
1130 "%s", arg);
1132 else
1133 sprintf (new_help + strlen (new_help),
1134 "%#x", * (int *) flag_var);
1136 else
1137 strcat (new_help, option_enabled (i, opts)
1138 ? _("[enabled]") : _("[disabled]"));
1141 help = new_help;
1144 wrap_help (help, opt, len, columns);
1145 displayed = true;
1147 if (option->var_type == CLVC_ENUM
1148 && opts->x_help_enum_printed[option->var_enum] != 2)
1149 opts->x_help_enum_printed[option->var_enum] = 1;
1152 if (! found)
1154 unsigned int langs = include_flags & CL_LANG_ALL;
1156 if (langs == 0)
1157 printf (_(" No options with the desired characteristics were found\n"));
1158 else
1160 unsigned int i;
1162 /* PR 31349: Tell the user how to see all of the
1163 options supported by a specific front end. */
1164 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1165 if ((1U << i) & langs)
1166 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end\n"),
1167 lang_names[i], lang_names[i]);
1171 else if (! displayed)
1172 printf (_(" All options with the desired characteristics have already been displayed\n"));
1174 putchar ('\n');
1176 /* Print details of enumerated option arguments, if those
1177 enumerations have help text headings provided. If no help text
1178 is provided, presume that the possible values are listed in the
1179 help text for the relevant options. */
1180 for (i = 0; i < cl_enums_count; i++)
1182 unsigned int j, pos;
1184 if (opts->x_help_enum_printed[i] != 1)
1185 continue;
1186 if (cl_enums[i].help == NULL)
1187 continue;
1188 printf (" %s\n ", _(cl_enums[i].help));
1189 pos = 4;
1190 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1192 unsigned int len = strlen (cl_enums[i].values[j].arg);
1194 if (pos > 4 && pos + 1 + len <= columns)
1196 printf (" %s", cl_enums[i].values[j].arg);
1197 pos += 1 + len;
1199 else
1201 if (pos > 4)
1203 printf ("\n ");
1204 pos = 4;
1206 printf ("%s", cl_enums[i].values[j].arg);
1207 pos += len;
1210 printf ("\n\n");
1211 opts->x_help_enum_printed[i] = 2;
1215 /* Display help for a specified type of option.
1216 The options must have ALL of the INCLUDE_FLAGS set
1217 ANY of the flags in the ANY_FLAGS set
1218 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1219 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1220 static void
1221 print_specific_help (unsigned int include_flags,
1222 unsigned int exclude_flags,
1223 unsigned int any_flags,
1224 struct gcc_options *opts,
1225 unsigned int lang_mask)
1227 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1228 const char * description = NULL;
1229 const char * descrip_extra = "";
1230 size_t i;
1231 unsigned int flag;
1233 /* Sanity check: Make sure that we do not have more
1234 languages than we have bits available to enumerate them. */
1235 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1237 /* If we have not done so already, obtain
1238 the desired maximum width of the output. */
1239 if (opts->x_help_columns == 0)
1241 opts->x_help_columns = get_terminal_width ();
1242 if (opts->x_help_columns == INT_MAX)
1243 /* Use a reasonable default. */
1244 opts->x_help_columns = 80;
1247 /* Decide upon the title for the options that we are going to display. */
1248 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1250 switch (flag & include_flags)
1252 case 0:
1253 case CL_DRIVER:
1254 break;
1256 case CL_TARGET:
1257 description = _("The following options are target specific");
1258 break;
1259 case CL_WARNING:
1260 description = _("The following options control compiler warning messages");
1261 break;
1262 case CL_OPTIMIZATION:
1263 description = _("The following options control optimizations");
1264 break;
1265 case CL_COMMON:
1266 description = _("The following options are language-independent");
1267 break;
1268 case CL_PARAMS:
1269 description = _("The --param option recognizes the following as parameters");
1270 break;
1271 default:
1272 if (i >= cl_lang_count)
1273 break;
1274 if (exclude_flags & all_langs_mask)
1275 description = _("The following options are specific to just the language ");
1276 else
1277 description = _("The following options are supported by the language ");
1278 descrip_extra = lang_names [i];
1279 break;
1283 if (description == NULL)
1285 if (any_flags == 0)
1287 if (include_flags & CL_UNDOCUMENTED)
1288 description = _("The following options are not documented");
1289 else if (include_flags & CL_SEPARATE)
1290 description = _("The following options take separate arguments");
1291 else if (include_flags & CL_JOINED)
1292 description = _("The following options take joined arguments");
1293 else
1295 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1296 include_flags);
1297 return;
1300 else
1302 if (any_flags & all_langs_mask)
1303 description = _("The following options are language-related");
1304 else
1305 description = _("The following options are language-independent");
1309 printf ("%s%s:\n", description, descrip_extra);
1310 print_filtered_help (include_flags, exclude_flags, any_flags,
1311 opts->x_help_columns, opts, lang_mask);
1314 /* Enable FDO-related flags. */
1316 static void
1317 enable_fdo_optimizations (struct gcc_options *opts,
1318 struct gcc_options *opts_set,
1319 int value)
1321 if (!opts_set->x_flag_branch_probabilities)
1322 opts->x_flag_branch_probabilities = value;
1323 if (!opts_set->x_flag_profile_values)
1324 opts->x_flag_profile_values = value;
1325 if (!opts_set->x_flag_unroll_loops)
1326 opts->x_flag_unroll_loops = value;
1327 if (!opts_set->x_flag_peel_loops)
1328 opts->x_flag_peel_loops = value;
1329 if (!opts_set->x_flag_tracer)
1330 opts->x_flag_tracer = value;
1331 if (!opts_set->x_flag_value_profile_transformations)
1332 opts->x_flag_value_profile_transformations = value;
1333 if (!opts_set->x_flag_inline_functions)
1334 opts->x_flag_inline_functions = value;
1335 if (!opts_set->x_flag_ipa_cp)
1336 opts->x_flag_ipa_cp = value;
1337 if (!opts_set->x_flag_ipa_cp_clone
1338 && value && opts->x_flag_ipa_cp)
1339 opts->x_flag_ipa_cp_clone = value;
1340 if (!opts_set->x_flag_ipa_cp_alignment
1341 && value && opts->x_flag_ipa_cp)
1342 opts->x_flag_ipa_cp_alignment = value;
1343 if (!opts_set->x_flag_predictive_commoning)
1344 opts->x_flag_predictive_commoning = value;
1345 if (!opts_set->x_flag_unswitch_loops)
1346 opts->x_flag_unswitch_loops = value;
1347 if (!opts_set->x_flag_gcse_after_reload)
1348 opts->x_flag_gcse_after_reload = value;
1349 if (!opts_set->x_flag_tree_loop_vectorize
1350 && !opts_set->x_flag_tree_vectorize)
1351 opts->x_flag_tree_loop_vectorize = value;
1352 if (!opts_set->x_flag_tree_slp_vectorize
1353 && !opts_set->x_flag_tree_vectorize)
1354 opts->x_flag_tree_slp_vectorize = value;
1355 if (!opts_set->x_flag_vect_cost_model)
1356 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1357 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1358 opts->x_flag_tree_loop_distribute_patterns = value;
1361 /* Handle target- and language-independent options. Return zero to
1362 generate an "unknown option" message. Only options that need
1363 extra handling need to be listed here; if you simply want
1364 DECODED->value assigned to a variable, it happens automatically. */
1366 bool
1367 common_handle_option (struct gcc_options *opts,
1368 struct gcc_options *opts_set,
1369 const struct cl_decoded_option *decoded,
1370 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1371 location_t loc,
1372 const struct cl_option_handlers *handlers,
1373 diagnostic_context *dc)
1375 size_t scode = decoded->opt_index;
1376 const char *arg = decoded->arg;
1377 int value = decoded->value;
1378 enum opt_code code = (enum opt_code) scode;
1380 gcc_assert (decoded->canonical_option_num_elements <= 2);
1382 switch (code)
1384 case OPT__param:
1385 handle_param (opts, opts_set, loc, arg);
1386 break;
1388 case OPT__help:
1390 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1391 unsigned int undoc_mask;
1392 unsigned int i;
1394 if (lang_mask == CL_DRIVER)
1395 break;
1397 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1399 : CL_UNDOCUMENTED);
1400 /* First display any single language specific options. */
1401 for (i = 0; i < cl_lang_count; i++)
1402 print_specific_help
1403 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1404 lang_mask);
1405 /* Next display any multi language specific options. */
1406 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1407 /* Then display any remaining, non-language options. */
1408 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1409 if (i != CL_DRIVER)
1410 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1411 opts->x_exit_after_options = true;
1412 break;
1415 case OPT__target_help:
1416 if (lang_mask == CL_DRIVER)
1417 break;
1419 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1420 opts->x_exit_after_options = true;
1421 break;
1423 case OPT__help_:
1425 const char * a = arg;
1426 unsigned int include_flags = 0;
1427 /* Note - by default we include undocumented options when listing
1428 specific classes. If you only want to see documented options
1429 then add ",^undocumented" to the --help= option. E.g.:
1431 --help=target,^undocumented */
1432 unsigned int exclude_flags = 0;
1434 if (lang_mask == CL_DRIVER)
1435 break;
1437 /* Walk along the argument string, parsing each word in turn.
1438 The format is:
1439 arg = [^]{word}[,{arg}]
1440 word = {optimizers|target|warnings|undocumented|
1441 params|common|<language>} */
1442 while (* a != 0)
1444 static const struct
1446 const char * string;
1447 unsigned int flag;
1449 specifics[] =
1451 { "optimizers", CL_OPTIMIZATION },
1452 { "target", CL_TARGET },
1453 { "warnings", CL_WARNING },
1454 { "undocumented", CL_UNDOCUMENTED },
1455 { "params", CL_PARAMS },
1456 { "joined", CL_JOINED },
1457 { "separate", CL_SEPARATE },
1458 { "common", CL_COMMON },
1459 { NULL, 0 }
1461 unsigned int * pflags;
1462 const char * comma;
1463 unsigned int lang_flag, specific_flag;
1464 unsigned int len;
1465 unsigned int i;
1467 if (* a == '^')
1469 ++ a;
1470 pflags = & exclude_flags;
1472 else
1473 pflags = & include_flags;
1475 comma = strchr (a, ',');
1476 if (comma == NULL)
1477 len = strlen (a);
1478 else
1479 len = comma - a;
1480 if (len == 0)
1482 a = comma + 1;
1483 continue;
1486 /* Check to see if the string matches an option class name. */
1487 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1488 if (strncasecmp (a, specifics[i].string, len) == 0)
1490 specific_flag = specifics[i].flag;
1491 break;
1494 /* Check to see if the string matches a language name.
1495 Note - we rely upon the alpha-sorted nature of the entries in
1496 the lang_names array, specifically that shorter names appear
1497 before their longer variants. (i.e. C before C++). That way
1498 when we are attempting to match --help=c for example we will
1499 match with C first and not C++. */
1500 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1501 if (strncasecmp (a, lang_names[i], len) == 0)
1503 lang_flag = 1U << i;
1504 break;
1507 if (specific_flag != 0)
1509 if (lang_flag == 0)
1510 * pflags |= specific_flag;
1511 else
1513 /* The option's argument matches both the start of a
1514 language name and the start of an option class name.
1515 We have a special case for when the user has
1516 specified "--help=c", but otherwise we have to issue
1517 a warning. */
1518 if (strncasecmp (a, "c", len) == 0)
1519 * pflags |= lang_flag;
1520 else
1521 warning_at (loc, 0,
1522 "--help argument %q.*s is ambiguous, "
1523 "please be more specific",
1524 len, a);
1527 else if (lang_flag != 0)
1528 * pflags |= lang_flag;
1529 else
1530 warning_at (loc, 0,
1531 "unrecognized argument to --help= option: %q.*s",
1532 len, a);
1534 if (comma == NULL)
1535 break;
1536 a = comma + 1;
1539 if (include_flags)
1540 print_specific_help (include_flags, exclude_flags, 0, opts,
1541 lang_mask);
1542 opts->x_exit_after_options = true;
1543 break;
1546 case OPT__version:
1547 if (lang_mask == CL_DRIVER)
1548 break;
1550 opts->x_exit_after_options = true;
1551 break;
1553 case OPT_fsanitize_:
1554 case OPT_fsanitize_recover_:
1556 const char *p = arg;
1557 unsigned int *flag
1558 = code == OPT_fsanitize_ ? &opts->x_flag_sanitize
1559 : &opts->x_flag_sanitize_recover;
1560 while (*p != 0)
1562 static const struct
1564 const char *const name;
1565 unsigned int flag;
1566 size_t len;
1567 } spec[] =
1569 { "address", SANITIZE_ADDRESS | SANITIZE_USER_ADDRESS,
1570 sizeof "address" - 1 },
1571 { "kernel-address", SANITIZE_ADDRESS | SANITIZE_KERNEL_ADDRESS,
1572 sizeof "kernel-address" - 1 },
1573 { "thread", SANITIZE_THREAD, sizeof "thread" - 1 },
1574 { "leak", SANITIZE_LEAK, sizeof "leak" - 1 },
1575 { "shift", SANITIZE_SHIFT, sizeof "shift" - 1 },
1576 { "integer-divide-by-zero", SANITIZE_DIVIDE,
1577 sizeof "integer-divide-by-zero" - 1 },
1578 { "undefined", SANITIZE_UNDEFINED, sizeof "undefined" - 1 },
1579 { "unreachable", SANITIZE_UNREACHABLE,
1580 sizeof "unreachable" - 1 },
1581 { "vla-bound", SANITIZE_VLA, sizeof "vla-bound" - 1 },
1582 { "return", SANITIZE_RETURN, sizeof "return" - 1 },
1583 { "null", SANITIZE_NULL, sizeof "null" - 1 },
1584 { "signed-integer-overflow", SANITIZE_SI_OVERFLOW,
1585 sizeof "signed-integer-overflow" -1 },
1586 { "bool", SANITIZE_BOOL, sizeof "bool" - 1 },
1587 { "enum", SANITIZE_ENUM, sizeof "enum" - 1 },
1588 { "float-divide-by-zero", SANITIZE_FLOAT_DIVIDE,
1589 sizeof "float-divide-by-zero" - 1 },
1590 { "float-cast-overflow", SANITIZE_FLOAT_CAST,
1591 sizeof "float-cast-overflow" - 1 },
1592 { "bounds", SANITIZE_BOUNDS, sizeof "bounds" - 1 },
1593 { "bounds-strict", SANITIZE_BOUNDS | SANITIZE_BOUNDS_STRICT,
1594 sizeof "bounds-strict" - 1 },
1595 { "alignment", SANITIZE_ALIGNMENT, sizeof "alignment" - 1 },
1596 { "nonnull-attribute", SANITIZE_NONNULL_ATTRIBUTE,
1597 sizeof "nonnull-attribute" - 1 },
1598 { "returns-nonnull-attribute",
1599 SANITIZE_RETURNS_NONNULL_ATTRIBUTE,
1600 sizeof "returns-nonnull-attribute" - 1 },
1601 { "object-size", SANITIZE_OBJECT_SIZE,
1602 sizeof "object-size" - 1 },
1603 { "vptr", SANITIZE_VPTR, sizeof "vptr" - 1 },
1604 { "all", ~0, sizeof "all" - 1 },
1605 { NULL, 0, 0 }
1607 const char *comma;
1608 size_t len, i;
1609 bool found = false;
1611 comma = strchr (p, ',');
1612 if (comma == NULL)
1613 len = strlen (p);
1614 else
1615 len = comma - p;
1616 if (len == 0)
1618 p = comma + 1;
1619 continue;
1622 /* Check to see if the string matches an option class name. */
1623 for (i = 0; spec[i].name != NULL; ++i)
1624 if (len == spec[i].len
1625 && memcmp (p, spec[i].name, len) == 0)
1627 /* Handle both -fsanitize and -fno-sanitize cases. */
1628 if (value && spec[i].flag == ~0U)
1630 if (code == OPT_fsanitize_)
1631 error_at (loc, "-fsanitize=all option is not valid");
1632 else
1633 *flag |= ~(SANITIZE_USER_ADDRESS | SANITIZE_THREAD
1634 | SANITIZE_LEAK);
1636 else if (value)
1637 *flag |= spec[i].flag;
1638 else
1639 *flag &= ~spec[i].flag;
1640 found = true;
1641 break;
1644 if (! found)
1645 error_at (loc,
1646 "unrecognized argument to -fsanitize%s= option: %q.*s",
1647 code == OPT_fsanitize_ ? "" : "-recover", (int) len, p);
1649 if (comma == NULL)
1650 break;
1651 p = comma + 1;
1654 if (code != OPT_fsanitize_)
1655 break;
1657 /* Kernel ASan implies normal ASan but does not yet support
1658 all features. */
1659 if (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS)
1661 maybe_set_param_value (PARAM_ASAN_INSTRUMENTATION_WITH_CALL_THRESHOLD, 0,
1662 opts->x_param_values,
1663 opts_set->x_param_values);
1664 maybe_set_param_value (PARAM_ASAN_GLOBALS, 0,
1665 opts->x_param_values,
1666 opts_set->x_param_values);
1667 maybe_set_param_value (PARAM_ASAN_STACK, 0,
1668 opts->x_param_values,
1669 opts_set->x_param_values);
1670 maybe_set_param_value (PARAM_ASAN_USE_AFTER_RETURN, 0,
1671 opts->x_param_values,
1672 opts_set->x_param_values);
1675 break;
1678 case OPT_fasan_shadow_offset_:
1679 /* Deferred. */
1680 break;
1682 case OPT_fsanitize_recover:
1683 if (value)
1684 opts->x_flag_sanitize_recover
1685 |= SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT;
1686 else
1687 opts->x_flag_sanitize_recover
1688 &= ~(SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT);
1689 break;
1691 case OPT_O:
1692 case OPT_Os:
1693 case OPT_Ofast:
1694 case OPT_Og:
1695 /* Currently handled in a prescan. */
1696 break;
1698 case OPT_Werror:
1699 dc->warning_as_error_requested = value;
1700 break;
1702 case OPT_Werror_:
1703 if (lang_mask == CL_DRIVER)
1704 break;
1706 enable_warning_as_error (arg, value, lang_mask, handlers,
1707 opts, opts_set, loc, dc);
1708 break;
1710 case OPT_Wlarger_than_:
1711 opts->x_larger_than_size = value;
1712 opts->x_warn_larger_than = value != -1;
1713 break;
1715 case OPT_Wfatal_errors:
1716 dc->fatal_errors = value;
1717 break;
1719 case OPT_Wframe_larger_than_:
1720 opts->x_frame_larger_than_size = value;
1721 opts->x_warn_frame_larger_than = value != -1;
1722 break;
1724 case OPT_Wstack_usage_:
1725 opts->x_warn_stack_usage = value;
1726 opts->x_flag_stack_usage_info = value != -1;
1727 break;
1729 case OPT_Wstrict_aliasing:
1730 set_Wstrict_aliasing (opts, value);
1731 break;
1733 case OPT_Wstrict_overflow:
1734 opts->x_warn_strict_overflow = (value
1735 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1736 : 0);
1737 break;
1739 case OPT_Wsystem_headers:
1740 dc->dc_warn_system_headers = value;
1741 break;
1743 case OPT_aux_info:
1744 opts->x_flag_gen_aux_info = 1;
1745 break;
1747 case OPT_auxbase_strip:
1749 char *tmp = xstrdup (arg);
1750 strip_off_ending (tmp, strlen (tmp));
1751 if (tmp[0])
1752 opts->x_aux_base_name = tmp;
1753 else
1754 free (tmp);
1756 break;
1758 case OPT_d:
1759 decode_d_option (arg, opts, loc, dc);
1760 break;
1762 case OPT_fcall_used_:
1763 case OPT_fcall_saved_:
1764 /* Deferred. */
1765 break;
1767 case OPT_fdbg_cnt_:
1768 /* Deferred. */
1769 break;
1771 case OPT_fdbg_cnt_list:
1772 /* Deferred. */
1773 opts->x_exit_after_options = true;
1774 break;
1776 case OPT_fdebug_prefix_map_:
1777 /* Deferred. */
1778 break;
1780 case OPT_fdiagnostics_show_location_:
1781 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1782 break;
1784 case OPT_fdiagnostics_show_caret:
1785 dc->show_caret = value;
1786 break;
1788 case OPT_fdiagnostics_color_:
1789 diagnostic_color_init (dc, value);
1790 break;
1792 case OPT_fdiagnostics_show_option:
1793 dc->show_option_requested = value;
1794 break;
1796 case OPT_fdump_:
1797 /* Deferred. */
1798 break;
1800 case OPT_ffast_math:
1801 set_fast_math_flags (opts, value);
1802 break;
1804 case OPT_funsafe_math_optimizations:
1805 set_unsafe_math_optimizations_flags (opts, value);
1806 break;
1808 case OPT_ffixed_:
1809 /* Deferred. */
1810 break;
1812 case OPT_finline_limit_:
1813 set_param_value ("max-inline-insns-single", value / 2,
1814 opts->x_param_values, opts_set->x_param_values);
1815 set_param_value ("max-inline-insns-auto", value / 2,
1816 opts->x_param_values, opts_set->x_param_values);
1817 break;
1819 case OPT_finstrument_functions_exclude_function_list_:
1820 add_comma_separated_to_vector
1821 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1822 break;
1824 case OPT_finstrument_functions_exclude_file_list_:
1825 add_comma_separated_to_vector
1826 (&opts->x_flag_instrument_functions_exclude_files, arg);
1827 break;
1829 case OPT_fmessage_length_:
1830 pp_set_line_maximum_length (dc->printer, value);
1831 diagnostic_set_caret_max_width (dc, value);
1832 break;
1834 case OPT_fopt_info:
1835 case OPT_fopt_info_:
1836 /* Deferred. */
1837 break;
1839 case OPT_foffload_:
1840 /* Deferred. */
1841 break;
1843 #ifndef ACCEL_COMPILER
1844 case OPT_foffload_abi_:
1845 error_at (loc, "-foffload-abi option can be specified only for "
1846 "offload compiler");
1847 break;
1848 #endif
1850 case OPT_fpack_struct_:
1851 if (value <= 0 || (value & (value - 1)) || value > 16)
1852 error_at (loc,
1853 "structure alignment must be a small power of two, not %d",
1854 value);
1855 else
1856 opts->x_initial_max_fld_align = value;
1857 break;
1859 case OPT_fplugin_:
1860 case OPT_fplugin_arg_:
1861 /* Deferred. */
1862 break;
1864 case OPT_fprofile_use_:
1865 opts->x_profile_data_prefix = xstrdup (arg);
1866 opts->x_flag_profile_use = true;
1867 value = true;
1868 /* No break here - do -fprofile-use processing. */
1869 case OPT_fprofile_use:
1870 enable_fdo_optimizations (opts, opts_set, value);
1871 if (!opts_set->x_flag_profile_reorder_functions)
1872 opts->x_flag_profile_reorder_functions = value;
1873 /* Indirect call profiling should do all useful transformations
1874 speculative devirtualization does. */
1875 if (!opts_set->x_flag_devirtualize_speculatively
1876 && opts->x_flag_value_profile_transformations)
1877 opts->x_flag_devirtualize_speculatively = false;
1878 break;
1880 case OPT_fauto_profile_:
1881 opts->x_auto_profile_file = xstrdup (arg);
1882 opts->x_flag_auto_profile = true;
1883 value = true;
1884 /* No break here - do -fauto-profile processing. */
1885 case OPT_fauto_profile:
1886 enable_fdo_optimizations (opts, opts_set, value);
1887 if (!opts_set->x_flag_profile_correction)
1888 opts->x_flag_profile_correction = value;
1889 maybe_set_param_value (
1890 PARAM_EARLY_INLINER_MAX_ITERATIONS, 10,
1891 opts->x_param_values, opts_set->x_param_values);
1892 break;
1894 case OPT_fprofile_generate_:
1895 opts->x_profile_data_prefix = xstrdup (arg);
1896 value = true;
1897 /* No break here - do -fprofile-generate processing. */
1898 case OPT_fprofile_generate:
1899 if (!opts_set->x_profile_arc_flag)
1900 opts->x_profile_arc_flag = value;
1901 if (!opts_set->x_flag_profile_values)
1902 opts->x_flag_profile_values = value;
1903 if (!opts_set->x_flag_inline_functions)
1904 opts->x_flag_inline_functions = value;
1905 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1906 quadratic. Disable the pass until better memory representation
1907 is done. */
1908 if (!opts_set->x_flag_ipa_reference)
1909 opts->x_flag_ipa_reference = false;
1910 break;
1912 case OPT_ftree_vectorize:
1913 if (!opts_set->x_flag_tree_loop_vectorize)
1914 opts->x_flag_tree_loop_vectorize = value;
1915 if (!opts_set->x_flag_tree_slp_vectorize)
1916 opts->x_flag_tree_slp_vectorize = value;
1917 break;
1918 case OPT_fshow_column:
1919 dc->show_column = value;
1920 break;
1922 case OPT_frandom_seed:
1923 /* The real switch is -fno-random-seed. */
1924 if (value)
1925 return false;
1926 /* Deferred. */
1927 break;
1929 case OPT_frandom_seed_:
1930 /* Deferred. */
1931 break;
1933 case OPT_fsched_verbose_:
1934 #ifdef INSN_SCHEDULING
1935 /* Handled with Var in common.opt. */
1936 break;
1937 #else
1938 return false;
1939 #endif
1941 case OPT_fsched_stalled_insns_:
1942 opts->x_flag_sched_stalled_insns = value;
1943 if (opts->x_flag_sched_stalled_insns == 0)
1944 opts->x_flag_sched_stalled_insns = -1;
1945 break;
1947 case OPT_fsched_stalled_insns_dep_:
1948 opts->x_flag_sched_stalled_insns_dep = value;
1949 break;
1951 case OPT_fstack_check_:
1952 if (!strcmp (arg, "no"))
1953 opts->x_flag_stack_check = NO_STACK_CHECK;
1954 else if (!strcmp (arg, "generic"))
1955 /* This is the old stack checking method. */
1956 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1957 ? FULL_BUILTIN_STACK_CHECK
1958 : GENERIC_STACK_CHECK;
1959 else if (!strcmp (arg, "specific"))
1960 /* This is the new stack checking method. */
1961 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1962 ? FULL_BUILTIN_STACK_CHECK
1963 : STACK_CHECK_STATIC_BUILTIN
1964 ? STATIC_BUILTIN_STACK_CHECK
1965 : GENERIC_STACK_CHECK;
1966 else
1967 warning_at (loc, 0, "unknown stack check parameter %qs", arg);
1968 break;
1970 case OPT_fstack_limit:
1971 /* The real switch is -fno-stack-limit. */
1972 if (value)
1973 return false;
1974 /* Deferred. */
1975 break;
1977 case OPT_fstack_limit_register_:
1978 case OPT_fstack_limit_symbol_:
1979 /* Deferred. */
1980 break;
1982 case OPT_fstack_usage:
1983 opts->x_flag_stack_usage = value;
1984 opts->x_flag_stack_usage_info = value != 0;
1985 break;
1987 case OPT_g:
1988 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
1989 loc);
1990 break;
1992 case OPT_gcoff:
1993 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
1994 break;
1996 case OPT_gdwarf:
1997 if (arg && strlen (arg) != 0)
1999 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
2000 "use %<-gdwarf-%s%> for DWARF version "
2001 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
2002 break;
2004 else
2005 value = opts->x_dwarf_version;
2007 /* FALLTHRU */
2008 case OPT_gdwarf_:
2009 if (value < 2 || value > 5)
2010 error_at (loc, "dwarf version %d is not supported", value);
2011 else
2012 opts->x_dwarf_version = value;
2013 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
2014 break;
2016 case OPT_gsplit_dwarf:
2017 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
2018 loc);
2019 break;
2021 case OPT_ggdb:
2022 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
2023 break;
2025 case OPT_gstabs:
2026 case OPT_gstabs_:
2027 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
2028 loc);
2029 break;
2031 case OPT_gvms:
2032 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
2033 break;
2035 case OPT_gxcoff:
2036 case OPT_gxcoff_:
2037 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
2038 loc);
2039 break;
2041 case OPT_gz:
2042 case OPT_gz_:
2043 /* Handled completely via specs. */
2044 break;
2046 case OPT_pedantic_errors:
2047 dc->pedantic_errors = 1;
2048 control_warning_option (OPT_Wpedantic, DK_ERROR, value,
2049 loc, lang_mask,
2050 handlers, opts, opts_set,
2051 dc);
2052 break;
2054 case OPT_flto:
2055 opts->x_flag_lto = value ? "" : NULL;
2056 break;
2058 case OPT_w:
2059 dc->dc_inhibit_warnings = true;
2060 break;
2062 case OPT_fmax_errors_:
2063 dc->max_errors = value;
2064 break;
2066 case OPT_fuse_ld_bfd:
2067 case OPT_fuse_ld_gold:
2068 case OPT_fuse_linker_plugin:
2069 /* No-op. Used by the driver and passed to us because it starts with f.*/
2070 break;
2072 case OPT_fwrapv:
2073 if (value)
2074 opts->x_flag_trapv = 0;
2075 break;
2077 case OPT_ftrapv:
2078 if (value)
2079 opts->x_flag_wrapv = 0;
2080 break;
2082 case OPT_fipa_icf:
2083 opts->x_flag_ipa_icf_functions = value;
2084 opts->x_flag_ipa_icf_variables = value;
2085 break;
2087 default:
2088 /* If the flag was handled in a standard way, assume the lack of
2089 processing here is intentional. */
2090 gcc_assert (option_flag_var (scode, opts));
2091 break;
2094 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
2095 loc, handlers, dc);
2096 return true;
2099 /* Handle --param NAME=VALUE. */
2100 static void
2101 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
2102 location_t loc, const char *carg)
2104 char *equal, *arg;
2105 int value;
2107 arg = xstrdup (carg);
2108 equal = strchr (arg, '=');
2109 if (!equal)
2110 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
2111 arg);
2112 else
2114 value = integral_argument (equal + 1);
2115 if (value == -1)
2116 error_at (loc, "invalid --param value %qs", equal + 1);
2117 else
2119 *equal = '\0';
2120 set_param_value (arg, value,
2121 opts->x_param_values, opts_set->x_param_values);
2125 free (arg);
2128 /* Used to set the level of strict aliasing warnings in OPTS,
2129 when no level is specified (i.e., when -Wstrict-aliasing, and not
2130 -Wstrict-aliasing=level was given).
2131 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
2132 and 0 otherwise. After calling this function, wstrict_aliasing will be
2133 set to the default value of -Wstrict_aliasing=level, currently 3. */
2134 static void
2135 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
2137 gcc_assert (onoff == 0 || onoff == 1);
2138 if (onoff != 0)
2139 opts->x_warn_strict_aliasing = 3;
2140 else
2141 opts->x_warn_strict_aliasing = 0;
2144 /* The following routines are useful in setting all the flags that
2145 -ffast-math and -fno-fast-math imply. */
2146 static void
2147 set_fast_math_flags (struct gcc_options *opts, int set)
2149 if (!opts->frontend_set_flag_unsafe_math_optimizations)
2151 opts->x_flag_unsafe_math_optimizations = set;
2152 set_unsafe_math_optimizations_flags (opts, set);
2154 if (!opts->frontend_set_flag_finite_math_only)
2155 opts->x_flag_finite_math_only = set;
2156 if (!opts->frontend_set_flag_errno_math)
2157 opts->x_flag_errno_math = !set;
2158 if (set)
2160 if (!opts->frontend_set_flag_signaling_nans)
2161 opts->x_flag_signaling_nans = 0;
2162 if (!opts->frontend_set_flag_rounding_math)
2163 opts->x_flag_rounding_math = 0;
2164 if (!opts->frontend_set_flag_cx_limited_range)
2165 opts->x_flag_cx_limited_range = 1;
2169 /* When -funsafe-math-optimizations is set the following
2170 flags are set as well. */
2171 static void
2172 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
2174 if (!opts->frontend_set_flag_trapping_math)
2175 opts->x_flag_trapping_math = !set;
2176 if (!opts->frontend_set_flag_signed_zeros)
2177 opts->x_flag_signed_zeros = !set;
2178 if (!opts->frontend_set_flag_associative_math)
2179 opts->x_flag_associative_math = set;
2180 if (!opts->frontend_set_flag_reciprocal_math)
2181 opts->x_flag_reciprocal_math = set;
2184 /* Return true iff flags in OPTS are set as if -ffast-math. */
2185 bool
2186 fast_math_flags_set_p (const struct gcc_options *opts)
2188 return (!opts->x_flag_trapping_math
2189 && opts->x_flag_unsafe_math_optimizations
2190 && opts->x_flag_finite_math_only
2191 && !opts->x_flag_signed_zeros
2192 && !opts->x_flag_errno_math);
2195 /* Return true iff flags are set as if -ffast-math but using the flags stored
2196 in the struct cl_optimization structure. */
2197 bool
2198 fast_math_flags_struct_set_p (struct cl_optimization *opt)
2200 return (!opt->x_flag_trapping_math
2201 && opt->x_flag_unsafe_math_optimizations
2202 && opt->x_flag_finite_math_only
2203 && !opt->x_flag_signed_zeros
2204 && !opt->x_flag_errno_math);
2207 /* Handle a debug output -g switch for options OPTS
2208 (OPTS_SET->x_write_symbols storing whether a debug type was passed
2209 explicitly), location LOC. EXTENDED is true or false to support
2210 extended output (2 is special and means "-ggdb" was given). */
2211 static void
2212 set_debug_level (enum debug_info_type type, int extended, const char *arg,
2213 struct gcc_options *opts, struct gcc_options *opts_set,
2214 location_t loc)
2216 opts->x_use_gnu_debug_info_extensions = extended;
2218 if (type == NO_DEBUG)
2220 if (opts->x_write_symbols == NO_DEBUG)
2222 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
2224 if (extended == 2)
2226 #ifdef DWARF2_DEBUGGING_INFO
2227 opts->x_write_symbols = DWARF2_DEBUG;
2228 #elif defined DBX_DEBUGGING_INFO
2229 opts->x_write_symbols = DBX_DEBUG;
2230 #endif
2233 if (opts->x_write_symbols == NO_DEBUG)
2234 warning_at (loc, 0, "target system does not support debug output");
2237 else
2239 /* Does it conflict with an already selected type? */
2240 if (opts_set->x_write_symbols != NO_DEBUG
2241 && opts->x_write_symbols != NO_DEBUG
2242 && type != opts->x_write_symbols)
2243 error_at (loc, "debug format %qs conflicts with prior selection",
2244 debug_type_names[type]);
2245 opts->x_write_symbols = type;
2246 opts_set->x_write_symbols = type;
2249 /* A debug flag without a level defaults to level 2.
2250 If off or at level 1, set it to level 2, but if already
2251 at level 3, don't lower it. */
2252 if (*arg == '\0')
2254 if (opts->x_debug_info_level < DINFO_LEVEL_NORMAL)
2255 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2257 else
2259 int argval = integral_argument (arg);
2260 if (argval == -1)
2261 error_at (loc, "unrecognised debug output level %qs", arg);
2262 else if (argval > 3)
2263 error_at (loc, "debug output level %qs is too high", arg);
2264 else
2265 opts->x_debug_info_level = (enum debug_info_levels) argval;
2269 /* Arrange to dump core on error for diagnostic context DC. (The
2270 regular error message is still printed first, except in the case of
2271 abort ().) */
2273 static void
2274 setup_core_dumping (diagnostic_context *dc)
2276 #ifdef SIGABRT
2277 signal (SIGABRT, SIG_DFL);
2278 #endif
2279 #if defined(HAVE_SETRLIMIT)
2281 struct rlimit rlim;
2282 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2283 fatal_error (input_location, "getting core file size maximum limit: %m");
2284 rlim.rlim_cur = rlim.rlim_max;
2285 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2286 fatal_error (input_location,
2287 "setting core file size limit to maximum: %m");
2289 #endif
2290 diagnostic_abort_on_error (dc);
2293 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2294 diagnostic context DC. */
2296 static void
2297 decode_d_option (const char *arg, struct gcc_options *opts,
2298 location_t loc, diagnostic_context *dc)
2300 int c;
2302 while (*arg)
2303 switch (c = *arg++)
2305 case 'A':
2306 opts->x_flag_debug_asm = 1;
2307 break;
2308 case 'p':
2309 opts->x_flag_print_asm_name = 1;
2310 break;
2311 case 'P':
2312 opts->x_flag_dump_rtl_in_asm = 1;
2313 opts->x_flag_print_asm_name = 1;
2314 break;
2315 case 'x':
2316 opts->x_rtl_dump_and_exit = 1;
2317 break;
2318 case 'D': /* These are handled by the preprocessor. */
2319 case 'I':
2320 case 'M':
2321 case 'N':
2322 case 'U':
2323 break;
2324 case 'H':
2325 setup_core_dumping (dc);
2326 break;
2327 case 'a':
2328 opts->x_flag_dump_all_passed = true;
2329 break;
2331 default:
2332 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2333 break;
2337 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2338 mask LANG_MASK, option handlers HANDLERS) as an error for option
2339 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2340 NULL), location LOC. This is used by -Werror=. */
2342 static void
2343 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2344 const struct cl_option_handlers *handlers,
2345 struct gcc_options *opts,
2346 struct gcc_options *opts_set,
2347 location_t loc, diagnostic_context *dc)
2349 char *new_option;
2350 int option_index;
2352 new_option = XNEWVEC (char, strlen (arg) + 2);
2353 new_option[0] = 'W';
2354 strcpy (new_option + 1, arg);
2355 option_index = find_opt (new_option, lang_mask);
2356 if (option_index == OPT_SPECIAL_unknown)
2358 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2360 else
2362 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2364 control_warning_option (option_index, (int) kind, value,
2365 loc, lang_mask,
2366 handlers, opts, opts_set, dc);
2368 free (new_option);
2371 /* Return malloced memory for the name of the option OPTION_INDEX
2372 which enabled a diagnostic (context CONTEXT), originally of type
2373 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2374 as -Werror. */
2376 char *
2377 option_name (diagnostic_context *context, int option_index,
2378 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2380 if (option_index)
2382 /* A warning classified as an error. */
2383 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2384 && diag_kind == DK_ERROR)
2385 return concat (cl_options[OPT_Werror_].opt_text,
2386 /* Skip over "-W". */
2387 cl_options[option_index].opt_text + 2,
2388 NULL);
2389 /* A warning with option. */
2390 else
2391 return xstrdup (cl_options[option_index].opt_text);
2393 /* A warning without option classified as an error. */
2394 else if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2395 || diag_kind == DK_WARNING)
2396 && context->warning_as_error_requested)
2397 return xstrdup (cl_options[OPT_Werror].opt_text);
2398 else
2399 return NULL;