S/390: Add static OSC breaker if necessary.
[official-gcc.git] / gcc / opts.c
blob6b34473d1a460180cf2699aeba1158c8e0943d85
1 /* Command line option handling.
2 Copyright (C) 2002-2016 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 option lacks documentation.");
185 static const char use_diagnosed_msg[] = N_("Uses of this option are diagnosed.");
187 typedef char *char_p; /* For DEF_VEC_P. */
189 static void handle_param (struct gcc_options *opts,
190 struct gcc_options *opts_set, location_t loc,
191 const char *carg);
192 static void set_debug_level (enum debug_info_type type, int extended,
193 const char *arg, struct gcc_options *opts,
194 struct gcc_options *opts_set,
195 location_t loc);
196 static void set_fast_math_flags (struct gcc_options *opts, int set);
197 static void decode_d_option (const char *arg, struct gcc_options *opts,
198 location_t loc, diagnostic_context *dc);
199 static void set_unsafe_math_optimizations_flags (struct gcc_options *opts,
200 int set);
201 static void enable_warning_as_error (const char *arg, int value,
202 unsigned int lang_mask,
203 const struct cl_option_handlers *handlers,
204 struct gcc_options *opts,
205 struct gcc_options *opts_set,
206 location_t loc,
207 diagnostic_context *dc);
209 /* Handle a back-end option; arguments and return value as for
210 handle_option. */
212 bool
213 target_handle_option (struct gcc_options *opts,
214 struct gcc_options *opts_set,
215 const struct cl_decoded_option *decoded,
216 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
217 location_t loc,
218 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
219 diagnostic_context *dc)
221 gcc_assert (dc == global_dc);
222 gcc_assert (kind == DK_UNSPECIFIED);
223 return targetm_common.handle_option (opts, opts_set, decoded, loc);
226 /* Add comma-separated strings to a char_p vector. */
228 static void
229 add_comma_separated_to_vector (void **pvec, const char *arg)
231 char *tmp;
232 char *r;
233 char *w;
234 char *token_start;
235 vec<char_p> *v = (vec<char_p> *) *pvec;
237 vec_check_alloc (v, 1);
239 /* We never free this string. */
240 tmp = xstrdup (arg);
242 r = tmp;
243 w = tmp;
244 token_start = tmp;
246 while (*r != '\0')
248 if (*r == ',')
250 *w++ = '\0';
251 ++r;
252 v->safe_push (token_start);
253 token_start = w;
255 if (*r == '\\' && r[1] == ',')
257 *w++ = ',';
258 r += 2;
260 else
261 *w++ = *r++;
263 if (*token_start != '\0')
264 v->safe_push (token_start);
266 *pvec = v;
269 /* Initialize opts_obstack. */
271 void
272 init_opts_obstack (void)
274 gcc_obstack_init (&opts_obstack);
277 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
279 void
280 init_options_struct (struct gcc_options *opts, struct gcc_options *opts_set)
282 size_t num_params = get_num_compiler_params ();
284 /* Ensure that opts_obstack has already been initialized by the time
285 that we initialize any gcc_options instances (PR jit/68446). */
286 gcc_assert (opts_obstack.chunk_size > 0);
288 *opts = global_options_init;
290 if (opts_set)
291 memset (opts_set, 0, sizeof (*opts_set));
293 opts->x_param_values = XNEWVEC (int, num_params);
295 if (opts_set)
296 opts_set->x_param_values = XCNEWVEC (int, num_params);
298 init_param_values (opts->x_param_values);
300 /* Initialize whether `char' is signed. */
301 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
302 /* Set this to a special "uninitialized" value. The actual default
303 is set after target options have been processed. */
304 opts->x_flag_short_enums = 2;
306 /* Initialize target_flags before default_options_optimization
307 so the latter can modify it. */
308 opts->x_target_flags = targetm_common.default_target_flags;
310 /* Some targets have ABI-specified unwind tables. */
311 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
313 /* Some targets have other target-specific initialization. */
314 targetm_common.option_init_struct (opts);
317 /* Release any allocations owned by OPTS. */
319 void
320 finalize_options_struct (struct gcc_options *opts)
322 XDELETEVEC (opts->x_param_values);
325 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
326 -Ofast if FAST is set, -Og if DEBUG is set), apply the option DEFAULT_OPT
327 to OPTS and OPTS_SET, diagnostic context DC, location LOC, with language
328 mask LANG_MASK and option handlers HANDLERS. */
330 static void
331 maybe_default_option (struct gcc_options *opts,
332 struct gcc_options *opts_set,
333 const struct default_options *default_opt,
334 int level, bool size, bool fast, bool debug,
335 unsigned int lang_mask,
336 const struct cl_option_handlers *handlers,
337 location_t loc,
338 diagnostic_context *dc)
340 const struct cl_option *option = &cl_options[default_opt->opt_index];
341 bool enabled;
343 if (size)
344 gcc_assert (level == 2);
345 if (fast)
346 gcc_assert (level == 3);
347 if (debug)
348 gcc_assert (level == 1);
350 switch (default_opt->levels)
352 case OPT_LEVELS_ALL:
353 enabled = true;
354 break;
356 case OPT_LEVELS_0_ONLY:
357 enabled = (level == 0);
358 break;
360 case OPT_LEVELS_1_PLUS:
361 enabled = (level >= 1);
362 break;
364 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
365 enabled = (level >= 1 && !size && !debug);
366 break;
368 case OPT_LEVELS_1_PLUS_NOT_DEBUG:
369 enabled = (level >= 1 && !debug);
370 break;
372 case OPT_LEVELS_2_PLUS:
373 enabled = (level >= 2);
374 break;
376 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
377 enabled = (level >= 2 && !size && !debug);
378 break;
380 case OPT_LEVELS_3_PLUS:
381 enabled = (level >= 3);
382 break;
384 case OPT_LEVELS_3_PLUS_AND_SIZE:
385 enabled = (level >= 3 || size);
386 break;
388 case OPT_LEVELS_SIZE:
389 enabled = size;
390 break;
392 case OPT_LEVELS_FAST:
393 enabled = fast;
394 break;
396 case OPT_LEVELS_NONE:
397 default:
398 gcc_unreachable ();
401 if (enabled)
402 handle_generated_option (opts, opts_set, default_opt->opt_index,
403 default_opt->arg, default_opt->value,
404 lang_mask, DK_UNSPECIFIED, loc,
405 handlers, dc);
406 else if (default_opt->arg == NULL
407 && !option->cl_reject_negative)
408 handle_generated_option (opts, opts_set, default_opt->opt_index,
409 default_opt->arg, !default_opt->value,
410 lang_mask, DK_UNSPECIFIED, loc,
411 handlers, dc);
414 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
415 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
416 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
417 language mask LANG_MASK and option handlers HANDLERS. */
419 static void
420 maybe_default_options (struct gcc_options *opts,
421 struct gcc_options *opts_set,
422 const struct default_options *default_opts,
423 int level, bool size, bool fast, bool debug,
424 unsigned int lang_mask,
425 const struct cl_option_handlers *handlers,
426 location_t loc,
427 diagnostic_context *dc)
429 size_t i;
431 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
432 maybe_default_option (opts, opts_set, &default_opts[i],
433 level, size, fast, debug,
434 lang_mask, handlers, loc, dc);
437 /* Table of options enabled by default at different levels. */
439 static const struct default_options default_options_table[] =
441 /* -O1 optimizations. */
442 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
443 #if DELAY_SLOTS
444 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
445 #endif
446 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
447 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
448 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
449 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion, NULL, 1 },
450 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion2, NULL, 1 },
451 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
452 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
453 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
454 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
455 { OPT_LEVELS_1_PLUS, OPT_freorder_blocks, NULL, 1 },
456 { OPT_LEVELS_1_PLUS, OPT_fshrink_wrap, NULL, 1 },
457 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
458 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
459 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_bit_ccp, NULL, 1 },
460 { OPT_LEVELS_1_PLUS, OPT_ftree_coalesce_vars, NULL, 1 },
461 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
462 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
463 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
464 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
465 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_sra, NULL, 1 },
466 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
467 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
468 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
469 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
470 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
471 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
472 { OPT_LEVELS_1_PLUS, OPT_ftree_slsr, NULL, 1 },
473 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fbranch_count_reg, NULL, 1 },
474 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fmove_loop_invariants, NULL, 1 },
475 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_pta, NULL, 1 },
476 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fssa_phiopt, NULL, 1 },
477 { OPT_LEVELS_1_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
479 /* -O2 optimizations. */
480 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
481 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
482 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
483 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
484 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
488 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
489 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
490 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
491 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
492 #ifdef INSN_SCHEDULING
493 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
494 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
495 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
496 #endif
497 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
498 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
499 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
500 REORDER_BLOCKS_ALGORITHM_STC },
501 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
502 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
503 { OPT_LEVELS_2_PLUS, OPT_fcode_hoisting, NULL, 1 },
504 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
505 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
506 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
507 { OPT_LEVELS_2_PLUS, OPT_fipa_bit_cp, NULL, 1 },
508 { OPT_LEVELS_2_PLUS, OPT_fipa_vrp, NULL, 1 },
509 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
510 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
511 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
512 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
513 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
514 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
515 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
516 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
517 { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
518 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
519 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
520 { OPT_LEVELS_2_PLUS, OPT_fipa_icf, NULL, 1 },
521 { OPT_LEVELS_2_PLUS, OPT_fisolate_erroneous_paths_dereference, NULL, 1 },
522 { OPT_LEVELS_2_PLUS, OPT_fipa_ra, NULL, 1 },
523 { OPT_LEVELS_2_PLUS, OPT_flra_remat, NULL, 1 },
525 /* -O3 optimizations. */
526 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
527 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
528 { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
529 /* Inlining of functions reducing size is a good idea with -Os
530 regardless of them being declared inline. */
531 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
532 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
533 { OPT_LEVELS_3_PLUS, OPT_fsplit_loops, NULL, 1 },
534 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
535 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
536 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
537 { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
538 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
539 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
540 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
541 { OPT_LEVELS_3_PLUS, OPT_fpeel_loops, NULL, 1 },
543 /* -Ofast adds optimizations to -O3. */
544 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
546 { OPT_LEVELS_NONE, 0, NULL, 0 }
549 /* Default the options in OPTS and OPTS_SET based on the optimization
550 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
551 void
552 default_options_optimization (struct gcc_options *opts,
553 struct gcc_options *opts_set,
554 struct cl_decoded_option *decoded_options,
555 unsigned int decoded_options_count,
556 location_t loc,
557 unsigned int lang_mask,
558 const struct cl_option_handlers *handlers,
559 diagnostic_context *dc)
561 unsigned int i;
562 int opt2;
563 bool openacc_mode = false;
565 /* Scan to see what optimization level has been specified. That will
566 determine the default value of many flags. */
567 for (i = 1; i < decoded_options_count; i++)
569 struct cl_decoded_option *opt = &decoded_options[i];
570 switch (opt->opt_index)
572 case OPT_O:
573 if (*opt->arg == '\0')
575 opts->x_optimize = 1;
576 opts->x_optimize_size = 0;
577 opts->x_optimize_fast = 0;
578 opts->x_optimize_debug = 0;
580 else
582 const int optimize_val = integral_argument (opt->arg);
583 if (optimize_val == -1)
584 error_at (loc, "argument to %<-O%> should be a non-negative "
585 "integer, %<g%>, %<s%> or %<fast%>");
586 else
588 opts->x_optimize = optimize_val;
589 if ((unsigned int) opts->x_optimize > 255)
590 opts->x_optimize = 255;
591 opts->x_optimize_size = 0;
592 opts->x_optimize_fast = 0;
593 opts->x_optimize_debug = 0;
596 break;
598 case OPT_Os:
599 opts->x_optimize_size = 1;
601 /* Optimizing for size forces optimize to be 2. */
602 opts->x_optimize = 2;
603 opts->x_optimize_fast = 0;
604 opts->x_optimize_debug = 0;
605 break;
607 case OPT_Ofast:
608 /* -Ofast only adds flags to -O3. */
609 opts->x_optimize_size = 0;
610 opts->x_optimize = 3;
611 opts->x_optimize_fast = 1;
612 opts->x_optimize_debug = 0;
613 break;
615 case OPT_Og:
616 /* -Og selects optimization level 1. */
617 opts->x_optimize_size = 0;
618 opts->x_optimize = 1;
619 opts->x_optimize_fast = 0;
620 opts->x_optimize_debug = 1;
621 break;
623 case OPT_fopenacc:
624 if (opt->value)
625 openacc_mode = true;
626 break;
628 default:
629 /* Ignore other options in this prescan. */
630 break;
634 maybe_default_options (opts, opts_set, default_options_table,
635 opts->x_optimize, opts->x_optimize_size,
636 opts->x_optimize_fast, opts->x_optimize_debug,
637 lang_mask, handlers, loc, dc);
639 /* -O2 param settings. */
640 opt2 = (opts->x_optimize >= 2);
642 if (openacc_mode
643 && !opts_set->x_flag_ipa_pta)
644 opts->x_flag_ipa_pta = true;
646 /* Track fields in field-sensitive alias analysis. */
647 maybe_set_param_value
648 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
649 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
650 opts->x_param_values, opts_set->x_param_values);
652 /* For -O1 only do loop invariant motion for very small loops. */
653 maybe_set_param_value
654 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
655 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
656 opts->x_param_values, opts_set->x_param_values);
658 /* At -Ofast, allow store motion to introduce potential race conditions. */
659 maybe_set_param_value
660 (PARAM_ALLOW_STORE_DATA_RACES,
661 opts->x_optimize_fast ? 1
662 : default_param_value (PARAM_ALLOW_STORE_DATA_RACES),
663 opts->x_param_values, opts_set->x_param_values);
665 if (opts->x_optimize_size)
666 /* We want to crossjump as much as possible. */
667 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
668 opts->x_param_values, opts_set->x_param_values);
669 else
670 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
671 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
672 opts->x_param_values, opts_set->x_param_values);
674 /* Restrict the amount of work combine does at -Og while retaining
675 most of its useful transforms. */
676 if (opts->x_optimize_debug)
677 maybe_set_param_value (PARAM_MAX_COMBINE_INSNS, 2,
678 opts->x_param_values, opts_set->x_param_values);
680 /* Allow default optimizations to be specified on a per-machine basis. */
681 maybe_default_options (opts, opts_set,
682 targetm_common.option_optimization_table,
683 opts->x_optimize, opts->x_optimize_size,
684 opts->x_optimize_fast, opts->x_optimize_debug,
685 lang_mask, handlers, loc, dc);
688 /* After all options at LOC have been read into OPTS and OPTS_SET,
689 finalize settings of those options and diagnose incompatible
690 combinations. */
691 void
692 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
693 location_t loc)
695 enum unwind_info_type ui_except;
697 if (opts->x_dump_base_name
698 && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name)
699 && ! opts->x_dump_base_name_prefixed)
701 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
702 OPTS->X_DUMP_DIR_NAME directory. Then try to make
703 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
704 directory, typically the directory to contain the object
705 file. */
706 if (opts->x_dump_dir_name)
707 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
708 opts->x_dump_base_name, NULL);
709 else if (opts->x_aux_base_name
710 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
712 const char *aux_base;
714 base_of_path (opts->x_aux_base_name, &aux_base);
715 if (opts->x_aux_base_name != aux_base)
717 int dir_len = aux_base - opts->x_aux_base_name;
718 char *new_dump_base_name
719 = XOBNEWVEC (&opts_obstack, char,
720 strlen (opts->x_dump_base_name) + dir_len + 1);
722 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
723 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
724 /* Append existing OPTS->X_DUMP_BASE_NAME. */
725 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
726 opts->x_dump_base_name = new_dump_base_name;
729 opts->x_dump_base_name_prefixed = true;
732 /* Handle related options for unit-at-a-time, toplevel-reorder, and
733 section-anchors. */
734 if (!opts->x_flag_unit_at_a_time)
736 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
737 error_at (loc, "section anchors must be disabled when unit-at-a-time "
738 "is disabled");
739 opts->x_flag_section_anchors = 0;
740 if (opts->x_flag_toplevel_reorder == 1)
741 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
742 "is disabled");
743 opts->x_flag_toplevel_reorder = 0;
746 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
747 sorry ("transactional memory is not supported with non-call exceptions");
749 /* Unless the user has asked for section anchors, we disable toplevel
750 reordering at -O0 to disable transformations that might be surprising
751 to end users and to get -fno-toplevel-reorder tested. */
752 if (!opts->x_optimize
753 && opts->x_flag_toplevel_reorder == 2
754 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
756 opts->x_flag_toplevel_reorder = 0;
757 opts->x_flag_section_anchors = 0;
759 if (!opts->x_flag_toplevel_reorder)
761 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
762 error_at (loc, "section anchors must be disabled when toplevel reorder"
763 " is disabled");
764 opts->x_flag_section_anchors = 0;
767 if (!opts->x_flag_opts_finished)
769 /* We initialize opts->x_flag_pie to -1 so that targets can set a
770 default value. */
771 if (opts->x_flag_pie == -1)
773 /* We initialize opts->x_flag_pic to -1 so that we can tell if
774 -fpic, -fPIC, -fno-pic or -fno-PIC is used. */
775 if (opts->x_flag_pic == -1)
776 opts->x_flag_pie = DEFAULT_FLAG_PIE;
777 else
778 opts->x_flag_pie = 0;
780 /* If -fPIE or -fpie is used, turn on PIC. */
781 if (opts->x_flag_pie)
782 opts->x_flag_pic = opts->x_flag_pie;
783 else if (opts->x_flag_pic == -1)
784 opts->x_flag_pic = 0;
785 if (opts->x_flag_pic && !opts->x_flag_pie)
786 opts->x_flag_shlib = 1;
787 opts->x_flag_opts_finished = true;
790 /* We initialize opts->x_flag_stack_protect to -1 so that targets
791 can set a default value. */
792 if (opts->x_flag_stack_protect == -1)
793 opts->x_flag_stack_protect = DEFAULT_FLAG_SSP;
795 if (opts->x_optimize == 0)
797 /* Inlining does not work if not optimizing,
798 so force it not to be done. */
799 opts->x_warn_inline = 0;
800 opts->x_flag_no_inline = 1;
803 /* The optimization to partition hot and cold basic blocks into separate
804 sections of the .o and executable files does not work (currently)
805 with exception handling. This is because there is no support for
806 generating unwind info. If opts->x_flag_exceptions is turned on
807 we need to turn off the partitioning optimization. */
809 ui_except = targetm_common.except_unwind_info (opts);
811 if (opts->x_flag_exceptions
812 && opts->x_flag_reorder_blocks_and_partition
813 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
815 if (opts_set->x_flag_reorder_blocks_and_partition)
816 inform (loc,
817 "-freorder-blocks-and-partition does not work "
818 "with exceptions on this architecture");
819 opts->x_flag_reorder_blocks_and_partition = 0;
820 opts->x_flag_reorder_blocks = 1;
823 /* If user requested unwind info, then turn off the partitioning
824 optimization. */
826 if (opts->x_flag_unwind_tables
827 && !targetm_common.unwind_tables_default
828 && opts->x_flag_reorder_blocks_and_partition
829 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
831 if (opts_set->x_flag_reorder_blocks_and_partition)
832 inform (loc,
833 "-freorder-blocks-and-partition does not support "
834 "unwind info on this architecture");
835 opts->x_flag_reorder_blocks_and_partition = 0;
836 opts->x_flag_reorder_blocks = 1;
839 /* If the target requested unwind info, then turn off the partitioning
840 optimization with a different message. Likewise, if the target does not
841 support named sections. */
843 if (opts->x_flag_reorder_blocks_and_partition
844 && (!targetm_common.have_named_sections
845 || (opts->x_flag_unwind_tables
846 && targetm_common.unwind_tables_default
847 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
849 if (opts_set->x_flag_reorder_blocks_and_partition)
850 inform (loc,
851 "-freorder-blocks-and-partition does not work "
852 "on this architecture");
853 opts->x_flag_reorder_blocks_and_partition = 0;
854 opts->x_flag_reorder_blocks = 1;
857 /* Disable -freorder-blocks-and-partition when -fprofile-use is not in
858 effect. Function splitting was not actually being performed in that case,
859 as probably_never_executed_bb_p does not distinguish any basic blocks as
860 being cold vs hot when there is no profile data. Leaving it enabled,
861 however, causes the assembly code generator to create (empty) cold
862 sections and labels, leading to unnecessary size overhead. */
863 if (opts->x_flag_reorder_blocks_and_partition
864 && !opts_set->x_flag_profile_use)
865 opts->x_flag_reorder_blocks_and_partition = 0;
867 if (opts->x_flag_reorder_blocks_and_partition
868 && !opts_set->x_flag_reorder_functions)
869 opts->x_flag_reorder_functions = 1;
871 /* Pipelining of outer loops is only possible when general pipelining
872 capabilities are requested. */
873 if (!opts->x_flag_sel_sched_pipelining)
874 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
876 if (opts->x_flag_conserve_stack)
878 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
879 opts->x_param_values, opts_set->x_param_values);
880 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
881 opts->x_param_values, opts_set->x_param_values);
884 if (opts->x_flag_lto)
886 #ifdef ENABLE_LTO
887 opts->x_flag_generate_lto = 1;
889 /* When generating IL, do not operate in whole-program mode.
890 Otherwise, symbols will be privatized too early, causing link
891 errors later. */
892 opts->x_flag_whole_program = 0;
893 #else
894 error_at (loc, "LTO support has not been enabled in this configuration");
895 #endif
896 if (!opts->x_flag_fat_lto_objects
897 && (!HAVE_LTO_PLUGIN
898 || (opts_set->x_flag_use_linker_plugin
899 && !opts->x_flag_use_linker_plugin)))
901 if (opts_set->x_flag_fat_lto_objects)
902 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin");
903 opts->x_flag_fat_lto_objects = 1;
907 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
908 default value if they choose based on other options. */
909 if (opts->x_flag_split_stack == -1)
910 opts->x_flag_split_stack = 0;
911 else if (opts->x_flag_split_stack)
913 if (!targetm_common.supports_split_stack (true, opts))
915 error_at (loc, "%<-fsplit-stack%> is not supported by "
916 "this compiler configuration");
917 opts->x_flag_split_stack = 0;
921 /* Tune vectorization related parametees according to cost model. */
922 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
924 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
925 6, opts->x_param_values, opts_set->x_param_values);
926 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
927 0, opts->x_param_values, opts_set->x_param_values);
928 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
929 0, opts->x_param_values, opts_set->x_param_values);
932 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
933 is disabled. */
934 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
935 || !opts->x_flag_tree_loop_if_convert)
936 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
937 opts->x_param_values, opts_set->x_param_values);
939 /* The -gsplit-dwarf option requires -ggnu-pubnames. */
940 if (opts->x_dwarf_split_debug_info)
941 opts->x_debug_generate_pub_sections = 2;
943 /* Userspace and kernel ASan conflict with each other. */
944 if ((opts->x_flag_sanitize & SANITIZE_USER_ADDRESS)
945 && (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS))
946 error_at (loc,
947 "-fsanitize=address is incompatible with "
948 "-fsanitize=kernel-address");
950 /* And with TSan. */
951 if ((opts->x_flag_sanitize & SANITIZE_ADDRESS)
952 && (opts->x_flag_sanitize & SANITIZE_THREAD))
953 error_at (loc,
954 "-fsanitize=address and -fsanitize=kernel-address "
955 "are incompatible with -fsanitize=thread");
957 if ((opts->x_flag_sanitize & SANITIZE_LEAK)
958 && (opts->x_flag_sanitize & SANITIZE_THREAD))
959 error_at (loc,
960 "-fsanitize=leak is incompatible with -fsanitize=thread");
962 /* Check error recovery for -fsanitize-recover option. */
963 for (int i = 0; sanitizer_opts[i].name != NULL; ++i)
964 if ((opts->x_flag_sanitize_recover & sanitizer_opts[i].flag)
965 && !sanitizer_opts[i].can_recover)
966 error_at (loc, "-fsanitize-recover=%s is not supported",
967 sanitizer_opts[i].name);
969 /* When instrumenting the pointers, we don't want to remove
970 the null pointer checks. */
971 if (opts->x_flag_sanitize & (SANITIZE_NULL | SANITIZE_NONNULL_ATTRIBUTE
972 | SANITIZE_RETURNS_NONNULL_ATTRIBUTE))
973 opts->x_flag_delete_null_pointer_checks = 0;
975 /* Aggressive compiler optimizations may cause false negatives. */
976 if (opts->x_flag_sanitize & ~(SANITIZE_LEAK | SANITIZE_UNREACHABLE))
978 opts->x_flag_aggressive_loop_optimizations = 0;
979 opts->x_flag_strict_overflow = 0;
983 #define LEFT_COLUMN 27
985 /* Output ITEM, of length ITEM_WIDTH, in the left column,
986 followed by word-wrapped HELP in a second column. */
987 static void
988 wrap_help (const char *help,
989 const char *item,
990 unsigned int item_width,
991 unsigned int columns)
993 unsigned int col_width = LEFT_COLUMN;
994 unsigned int remaining, room, len;
996 remaining = strlen (help);
1000 room = columns - 3 - MAX (col_width, item_width);
1001 if (room > columns)
1002 room = 0;
1003 len = remaining;
1005 if (room < len)
1007 unsigned int i;
1009 for (i = 0; help[i]; i++)
1011 if (i >= room && len != remaining)
1012 break;
1013 if (help[i] == ' ')
1014 len = i;
1015 else if ((help[i] == '-' || help[i] == '/')
1016 && help[i + 1] != ' '
1017 && i > 0 && ISALPHA (help[i - 1]))
1018 len = i + 1;
1022 printf (" %-*.*s %.*s\n", col_width, item_width, item, len, help);
1023 item_width = 0;
1024 while (help[len] == ' ')
1025 len++;
1026 help += len;
1027 remaining -= len;
1029 while (remaining);
1032 /* Print help for a specific front-end, etc. */
1033 static void
1034 print_filtered_help (unsigned int include_flags,
1035 unsigned int exclude_flags,
1036 unsigned int any_flags,
1037 unsigned int columns,
1038 struct gcc_options *opts,
1039 unsigned int lang_mask)
1041 unsigned int i;
1042 const char *help;
1043 bool found = false;
1044 bool displayed = false;
1045 char new_help[256];
1047 if (include_flags == CL_PARAMS)
1049 for (i = 0; i < LAST_PARAM; i++)
1051 const char *param = compiler_params[i].option;
1053 help = compiler_params[i].help;
1054 if (help == NULL || *help == '\0')
1056 if (exclude_flags & CL_UNDOCUMENTED)
1057 continue;
1058 help = undocumented_msg;
1061 /* Get the translation. */
1062 help = _(help);
1064 if (!opts->x_quiet_flag)
1066 snprintf (new_help, sizeof (new_help),
1067 _("default %d minimum %d maximum %d"),
1068 compiler_params[i].default_value,
1069 compiler_params[i].min_value,
1070 compiler_params[i].max_value);
1071 help = new_help;
1073 wrap_help (help, param, strlen (param), columns);
1075 putchar ('\n');
1076 return;
1079 if (!opts->x_help_printed)
1080 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
1082 if (!opts->x_help_enum_printed)
1083 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
1085 for (i = 0; i < cl_options_count; i++)
1087 const struct cl_option *option = cl_options + i;
1088 unsigned int len;
1089 const char *opt;
1090 const char *tab;
1092 if (include_flags == 0
1093 || ((option->flags & include_flags) != include_flags))
1095 if ((option->flags & any_flags) == 0)
1096 continue;
1099 /* Skip unwanted switches. */
1100 if ((option->flags & exclude_flags) != 0)
1101 continue;
1103 /* The driver currently prints its own help text. */
1104 if ((option->flags & CL_DRIVER) != 0
1105 && (option->flags & (((1U << cl_lang_count) - 1)
1106 | CL_COMMON | CL_TARGET)) == 0)
1107 continue;
1109 found = true;
1110 /* Skip switches that have already been printed. */
1111 if (opts->x_help_printed[i])
1112 continue;
1114 opts->x_help_printed[i] = true;
1116 help = option->help;
1117 if (help == NULL)
1119 if (exclude_flags & CL_UNDOCUMENTED)
1120 continue;
1122 help = undocumented_msg;
1125 if (option->alias_target < N_OPTS
1126 && cl_options [option->alias_target].help)
1128 if (help == undocumented_msg)
1130 /* For undocumented options that are aliases for other options
1131 that are documented, point the reader to the other option in
1132 preference of the former. */
1133 snprintf (new_help, sizeof new_help,
1134 _("Same as %s. Use the latter option instead."),
1135 cl_options [option->alias_target].opt_text);
1137 else
1139 /* For documented options with aliases, mention the aliased
1140 option's name for reference. */
1141 snprintf (new_help, sizeof new_help,
1142 _("%s Same as %s."),
1143 help, cl_options [option->alias_target].opt_text);
1146 help = new_help;
1149 if (option->warn_message)
1151 /* Mention that the use of the option will trigger a warning. */
1152 if (help == new_help)
1153 snprintf (new_help + strlen (new_help),
1154 sizeof new_help - strlen (new_help),
1155 " %s", _(use_diagnosed_msg));
1156 else
1157 snprintf (new_help, sizeof new_help,
1158 "%s %s", help, _(use_diagnosed_msg));
1160 help = new_help;
1163 /* Get the translation. */
1164 help = _(help);
1166 /* Find the gap between the name of the
1167 option and its descriptive text. */
1168 tab = strchr (help, '\t');
1169 if (tab)
1171 len = tab - help;
1172 opt = help;
1173 help = tab + 1;
1175 else
1177 opt = option->opt_text;
1178 len = strlen (opt);
1181 /* With the -Q option enabled we change the descriptive text associated
1182 with an option to be an indication of its current setting. */
1183 if (!opts->x_quiet_flag)
1185 void *flag_var = option_flag_var (i, opts);
1187 if (len < (LEFT_COLUMN + 2))
1188 strcpy (new_help, "\t\t");
1189 else
1190 strcpy (new_help, "\t");
1192 if (flag_var != NULL
1193 && option->var_type != CLVC_DEFER)
1195 if (option->flags & CL_JOINED)
1197 if (option->var_type == CLVC_STRING)
1199 if (* (const char **) flag_var != NULL)
1200 snprintf (new_help + strlen (new_help),
1201 sizeof (new_help) - strlen (new_help),
1202 "%s", * (const char **) flag_var);
1204 else if (option->var_type == CLVC_ENUM)
1206 const struct cl_enum *e = &cl_enums[option->var_enum];
1207 int value;
1208 const char *arg = NULL;
1210 value = e->get (flag_var);
1211 enum_value_to_arg (e->values, &arg, value, lang_mask);
1212 if (arg == NULL)
1213 arg = _("[default]");
1214 snprintf (new_help + strlen (new_help),
1215 sizeof (new_help) - strlen (new_help),
1216 "%s", arg);
1218 else
1219 sprintf (new_help + strlen (new_help),
1220 "%#x", * (int *) flag_var);
1222 else
1223 strcat (new_help, option_enabled (i, opts)
1224 ? _("[enabled]") : _("[disabled]"));
1227 help = new_help;
1230 wrap_help (help, opt, len, columns);
1231 displayed = true;
1233 if (option->var_type == CLVC_ENUM
1234 && opts->x_help_enum_printed[option->var_enum] != 2)
1235 opts->x_help_enum_printed[option->var_enum] = 1;
1238 if (! found)
1240 unsigned int langs = include_flags & CL_LANG_ALL;
1242 if (langs == 0)
1243 printf (_(" No options with the desired characteristics were found\n"));
1244 else
1246 unsigned int i;
1248 /* PR 31349: Tell the user how to see all of the
1249 options supported by a specific front end. */
1250 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1251 if ((1U << i) & langs)
1252 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end.\n"),
1253 lang_names[i], lang_names[i]);
1257 else if (! displayed)
1258 printf (_(" All options with the desired characteristics have already been displayed\n"));
1260 putchar ('\n');
1262 /* Print details of enumerated option arguments, if those
1263 enumerations have help text headings provided. If no help text
1264 is provided, presume that the possible values are listed in the
1265 help text for the relevant options. */
1266 for (i = 0; i < cl_enums_count; i++)
1268 unsigned int j, pos;
1270 if (opts->x_help_enum_printed[i] != 1)
1271 continue;
1272 if (cl_enums[i].help == NULL)
1273 continue;
1274 printf (" %s\n ", _(cl_enums[i].help));
1275 pos = 4;
1276 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1278 unsigned int len = strlen (cl_enums[i].values[j].arg);
1280 if (pos > 4 && pos + 1 + len <= columns)
1282 printf (" %s", cl_enums[i].values[j].arg);
1283 pos += 1 + len;
1285 else
1287 if (pos > 4)
1289 printf ("\n ");
1290 pos = 4;
1292 printf ("%s", cl_enums[i].values[j].arg);
1293 pos += len;
1296 printf ("\n\n");
1297 opts->x_help_enum_printed[i] = 2;
1301 /* Display help for a specified type of option.
1302 The options must have ALL of the INCLUDE_FLAGS set
1303 ANY of the flags in the ANY_FLAGS set
1304 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1305 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1306 static void
1307 print_specific_help (unsigned int include_flags,
1308 unsigned int exclude_flags,
1309 unsigned int any_flags,
1310 struct gcc_options *opts,
1311 unsigned int lang_mask)
1313 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1314 const char * description = NULL;
1315 const char * descrip_extra = "";
1316 size_t i;
1317 unsigned int flag;
1319 /* Sanity check: Make sure that we do not have more
1320 languages than we have bits available to enumerate them. */
1321 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1323 /* If we have not done so already, obtain
1324 the desired maximum width of the output. */
1325 if (opts->x_help_columns == 0)
1327 opts->x_help_columns = get_terminal_width ();
1328 if (opts->x_help_columns == INT_MAX)
1329 /* Use a reasonable default. */
1330 opts->x_help_columns = 80;
1333 /* Decide upon the title for the options that we are going to display. */
1334 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1336 switch (flag & include_flags)
1338 case 0:
1339 case CL_DRIVER:
1340 break;
1342 case CL_TARGET:
1343 description = _("The following options are target specific");
1344 break;
1345 case CL_WARNING:
1346 description = _("The following options control compiler warning messages");
1347 break;
1348 case CL_OPTIMIZATION:
1349 description = _("The following options control optimizations");
1350 break;
1351 case CL_COMMON:
1352 description = _("The following options are language-independent");
1353 break;
1354 case CL_PARAMS:
1355 description = _("The --param option recognizes the following as parameters");
1356 break;
1357 default:
1358 if (i >= cl_lang_count)
1359 break;
1360 if (exclude_flags & all_langs_mask)
1361 description = _("The following options are specific to just the language ");
1362 else
1363 description = _("The following options are supported by the language ");
1364 descrip_extra = lang_names [i];
1365 break;
1369 if (description == NULL)
1371 if (any_flags == 0)
1373 if (include_flags & CL_UNDOCUMENTED)
1374 description = _("The following options are not documented");
1375 else if (include_flags & CL_SEPARATE)
1376 description = _("The following options take separate arguments");
1377 else if (include_flags & CL_JOINED)
1378 description = _("The following options take joined arguments");
1379 else
1381 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1382 include_flags);
1383 return;
1386 else
1388 if (any_flags & all_langs_mask)
1389 description = _("The following options are language-related");
1390 else
1391 description = _("The following options are language-independent");
1395 printf ("%s%s:\n", description, descrip_extra);
1396 print_filtered_help (include_flags, exclude_flags, any_flags,
1397 opts->x_help_columns, opts, lang_mask);
1400 /* Enable FDO-related flags. */
1402 static void
1403 enable_fdo_optimizations (struct gcc_options *opts,
1404 struct gcc_options *opts_set,
1405 int value)
1407 if (!opts_set->x_flag_branch_probabilities)
1408 opts->x_flag_branch_probabilities = value;
1409 if (!opts_set->x_flag_profile_values)
1410 opts->x_flag_profile_values = value;
1411 if (!opts_set->x_flag_unroll_loops)
1412 opts->x_flag_unroll_loops = value;
1413 if (!opts_set->x_flag_peel_loops)
1414 opts->x_flag_peel_loops = value;
1415 if (!opts_set->x_flag_tracer)
1416 opts->x_flag_tracer = value;
1417 if (!opts_set->x_flag_value_profile_transformations)
1418 opts->x_flag_value_profile_transformations = value;
1419 if (!opts_set->x_flag_inline_functions)
1420 opts->x_flag_inline_functions = value;
1421 if (!opts_set->x_flag_ipa_cp)
1422 opts->x_flag_ipa_cp = value;
1423 if (!opts_set->x_flag_ipa_cp_clone
1424 && value && opts->x_flag_ipa_cp)
1425 opts->x_flag_ipa_cp_clone = value;
1426 if (!opts_set->x_flag_ipa_bit_cp
1427 && value && opts->x_flag_ipa_cp)
1428 opts->x_flag_ipa_bit_cp = value;
1429 if (!opts_set->x_flag_predictive_commoning)
1430 opts->x_flag_predictive_commoning = value;
1431 if (!opts_set->x_flag_split_loops)
1432 opts->x_flag_split_loops = value;
1433 if (!opts_set->x_flag_unswitch_loops)
1434 opts->x_flag_unswitch_loops = value;
1435 if (!opts_set->x_flag_gcse_after_reload)
1436 opts->x_flag_gcse_after_reload = value;
1437 if (!opts_set->x_flag_tree_loop_vectorize
1438 && !opts_set->x_flag_tree_vectorize)
1439 opts->x_flag_tree_loop_vectorize = value;
1440 if (!opts_set->x_flag_tree_slp_vectorize
1441 && !opts_set->x_flag_tree_vectorize)
1442 opts->x_flag_tree_slp_vectorize = value;
1443 if (!opts_set->x_flag_vect_cost_model)
1444 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1445 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1446 opts->x_flag_tree_loop_distribute_patterns = value;
1449 /* -f{,no-}sanitize{,-recover}= suboptions. */
1450 const struct sanitizer_opts_s sanitizer_opts[] =
1452 #define SANITIZER_OPT(name, flags, recover) \
1453 { #name, flags, sizeof #name - 1, recover }
1454 SANITIZER_OPT (address, SANITIZE_ADDRESS | SANITIZE_USER_ADDRESS, true),
1455 SANITIZER_OPT (kernel-address, SANITIZE_ADDRESS | SANITIZE_KERNEL_ADDRESS,
1456 true),
1457 SANITIZER_OPT (thread, SANITIZE_THREAD, false),
1458 SANITIZER_OPT (leak, SANITIZE_LEAK, false),
1459 SANITIZER_OPT (shift, SANITIZE_SHIFT, true),
1460 SANITIZER_OPT (integer-divide-by-zero, SANITIZE_DIVIDE, true),
1461 SANITIZER_OPT (undefined, SANITIZE_UNDEFINED, true),
1462 SANITIZER_OPT (unreachable, SANITIZE_UNREACHABLE, false),
1463 SANITIZER_OPT (vla-bound, SANITIZE_VLA, true),
1464 SANITIZER_OPT (return, SANITIZE_RETURN, false),
1465 SANITIZER_OPT (null, SANITIZE_NULL, true),
1466 SANITIZER_OPT (signed-integer-overflow, SANITIZE_SI_OVERFLOW, true),
1467 SANITIZER_OPT (bool, SANITIZE_BOOL, true),
1468 SANITIZER_OPT (enum, SANITIZE_ENUM, true),
1469 SANITIZER_OPT (float-divide-by-zero, SANITIZE_FLOAT_DIVIDE, true),
1470 SANITIZER_OPT (float-cast-overflow, SANITIZE_FLOAT_CAST, true),
1471 SANITIZER_OPT (bounds, SANITIZE_BOUNDS, true),
1472 SANITIZER_OPT (bounds-strict, SANITIZE_BOUNDS | SANITIZE_BOUNDS_STRICT, true),
1473 SANITIZER_OPT (alignment, SANITIZE_ALIGNMENT, true),
1474 SANITIZER_OPT (nonnull-attribute, SANITIZE_NONNULL_ATTRIBUTE, true),
1475 SANITIZER_OPT (returns-nonnull-attribute, SANITIZE_RETURNS_NONNULL_ATTRIBUTE,
1476 true),
1477 SANITIZER_OPT (object-size, SANITIZE_OBJECT_SIZE, true),
1478 SANITIZER_OPT (vptr, SANITIZE_VPTR, true),
1479 SANITIZER_OPT (all, ~0U, true),
1480 #undef SANITIZER_OPT
1481 { NULL, 0U, 0UL, false }
1484 /* Parse comma separated sanitizer suboptions from P for option SCODE,
1485 adjust previous FLAGS and return new ones. If COMPLAIN is false,
1486 don't issue diagnostics. */
1488 unsigned int
1489 parse_sanitizer_options (const char *p, location_t loc, int scode,
1490 unsigned int flags, int value, bool complain)
1492 enum opt_code code = (enum opt_code) scode;
1493 while (*p != 0)
1495 size_t len, i;
1496 bool found = false;
1497 const char *comma = strchr (p, ',');
1499 if (comma == NULL)
1500 len = strlen (p);
1501 else
1502 len = comma - p;
1503 if (len == 0)
1505 p = comma + 1;
1506 continue;
1509 /* Check to see if the string matches an option class name. */
1510 for (i = 0; sanitizer_opts[i].name != NULL; ++i)
1511 if (len == sanitizer_opts[i].len
1512 && memcmp (p, sanitizer_opts[i].name, len) == 0)
1514 /* Handle both -fsanitize and -fno-sanitize cases. */
1515 if (value && sanitizer_opts[i].flag == ~0U)
1517 if (code == OPT_fsanitize_)
1519 if (complain)
1520 error_at (loc, "-fsanitize=all option is not valid");
1522 else
1523 flags |= ~(SANITIZE_THREAD | SANITIZE_LEAK
1524 | SANITIZE_UNREACHABLE | SANITIZE_RETURN);
1526 else if (value)
1528 /* Do not enable -fsanitize-recover=unreachable and
1529 -fsanitize-recover=return if -fsanitize-recover=undefined
1530 is selected. */
1531 if (sanitizer_opts[i].flag == SANITIZE_UNDEFINED)
1532 flags |= (SANITIZE_UNDEFINED
1533 & ~(SANITIZE_UNREACHABLE | SANITIZE_RETURN));
1534 else
1535 flags |= sanitizer_opts[i].flag;
1537 else
1538 flags &= ~sanitizer_opts[i].flag;
1539 found = true;
1540 break;
1543 if (! found && complain)
1544 error_at (loc, "unrecognized argument to -fsanitize%s= option: %q.*s",
1545 code == OPT_fsanitize_ ? "" : "-recover", (int) len, p);
1547 if (comma == NULL)
1548 break;
1549 p = comma + 1;
1551 return flags;
1554 /* Handle target- and language-independent options. Return zero to
1555 generate an "unknown option" message. Only options that need
1556 extra handling need to be listed here; if you simply want
1557 DECODED->value assigned to a variable, it happens automatically. */
1559 bool
1560 common_handle_option (struct gcc_options *opts,
1561 struct gcc_options *opts_set,
1562 const struct cl_decoded_option *decoded,
1563 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1564 location_t loc,
1565 const struct cl_option_handlers *handlers,
1566 diagnostic_context *dc)
1568 size_t scode = decoded->opt_index;
1569 const char *arg = decoded->arg;
1570 int value = decoded->value;
1571 enum opt_code code = (enum opt_code) scode;
1573 gcc_assert (decoded->canonical_option_num_elements <= 2);
1575 switch (code)
1577 case OPT__param:
1578 handle_param (opts, opts_set, loc, arg);
1579 break;
1581 case OPT__help:
1583 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1584 unsigned int undoc_mask;
1585 unsigned int i;
1587 if (lang_mask == CL_DRIVER)
1588 break;
1590 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1592 : CL_UNDOCUMENTED);
1593 /* First display any single language specific options. */
1594 for (i = 0; i < cl_lang_count; i++)
1595 print_specific_help
1596 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1597 lang_mask);
1598 /* Next display any multi language specific options. */
1599 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1600 /* Then display any remaining, non-language options. */
1601 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1602 if (i != CL_DRIVER)
1603 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1604 opts->x_exit_after_options = true;
1605 break;
1608 case OPT__target_help:
1609 if (lang_mask == CL_DRIVER)
1610 break;
1612 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1613 opts->x_exit_after_options = true;
1614 break;
1616 case OPT__help_:
1618 const char *a = arg;
1619 unsigned int include_flags = 0;
1620 /* Note - by default we include undocumented options when listing
1621 specific classes. If you only want to see documented options
1622 then add ",^undocumented" to the --help= option. E.g.:
1624 --help=target,^undocumented */
1625 unsigned int exclude_flags = 0;
1627 if (lang_mask == CL_DRIVER)
1628 break;
1630 /* Walk along the argument string, parsing each word in turn.
1631 The format is:
1632 arg = [^]{word}[,{arg}]
1633 word = {optimizers|target|warnings|undocumented|
1634 params|common|<language>} */
1635 while (*a != 0)
1637 static const struct
1639 const char *string;
1640 unsigned int flag;
1642 specifics[] =
1644 { "optimizers", CL_OPTIMIZATION },
1645 { "target", CL_TARGET },
1646 { "warnings", CL_WARNING },
1647 { "undocumented", CL_UNDOCUMENTED },
1648 { "params", CL_PARAMS },
1649 { "joined", CL_JOINED },
1650 { "separate", CL_SEPARATE },
1651 { "common", CL_COMMON },
1652 { NULL, 0 }
1654 unsigned int *pflags;
1655 const char *comma;
1656 unsigned int lang_flag, specific_flag;
1657 unsigned int len;
1658 unsigned int i;
1660 if (*a == '^')
1662 ++a;
1663 if (*a == '\0')
1665 error_at (loc, "missing argument to %qs", "--help=^");
1666 break;
1668 pflags = &exclude_flags;
1670 else
1671 pflags = &include_flags;
1673 comma = strchr (a, ',');
1674 if (comma == NULL)
1675 len = strlen (a);
1676 else
1677 len = comma - a;
1678 if (len == 0)
1680 a = comma + 1;
1681 continue;
1684 /* Check to see if the string matches an option class name. */
1685 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1686 if (strncasecmp (a, specifics[i].string, len) == 0)
1688 specific_flag = specifics[i].flag;
1689 break;
1692 /* Check to see if the string matches a language name.
1693 Note - we rely upon the alpha-sorted nature of the entries in
1694 the lang_names array, specifically that shorter names appear
1695 before their longer variants. (i.e. C before C++). That way
1696 when we are attempting to match --help=c for example we will
1697 match with C first and not C++. */
1698 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1699 if (strncasecmp (a, lang_names[i], len) == 0)
1701 lang_flag = 1U << i;
1702 break;
1705 if (specific_flag != 0)
1707 if (lang_flag == 0)
1708 *pflags |= specific_flag;
1709 else
1711 /* The option's argument matches both the start of a
1712 language name and the start of an option class name.
1713 We have a special case for when the user has
1714 specified "--help=c", but otherwise we have to issue
1715 a warning. */
1716 if (strncasecmp (a, "c", len) == 0)
1717 *pflags |= lang_flag;
1718 else
1719 warning_at (loc, 0,
1720 "--help argument %q.*s is ambiguous, "
1721 "please be more specific",
1722 len, a);
1725 else if (lang_flag != 0)
1726 *pflags |= lang_flag;
1727 else
1728 warning_at (loc, 0,
1729 "unrecognized argument to --help= option: %q.*s",
1730 len, a);
1732 if (comma == NULL)
1733 break;
1734 a = comma + 1;
1737 if (include_flags)
1738 print_specific_help (include_flags, exclude_flags, 0, opts,
1739 lang_mask);
1740 opts->x_exit_after_options = true;
1741 break;
1744 case OPT__version:
1745 if (lang_mask == CL_DRIVER)
1746 break;
1748 opts->x_exit_after_options = true;
1749 break;
1751 case OPT_fsanitize_:
1752 opts->x_flag_sanitize
1753 = parse_sanitizer_options (arg, loc, code,
1754 opts->x_flag_sanitize, value, true);
1756 /* Kernel ASan implies normal ASan but does not yet support
1757 all features. */
1758 if (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS)
1760 maybe_set_param_value (PARAM_ASAN_INSTRUMENTATION_WITH_CALL_THRESHOLD,
1761 0, opts->x_param_values,
1762 opts_set->x_param_values);
1763 maybe_set_param_value (PARAM_ASAN_GLOBALS, 0, opts->x_param_values,
1764 opts_set->x_param_values);
1765 maybe_set_param_value (PARAM_ASAN_STACK, 0, opts->x_param_values,
1766 opts_set->x_param_values);
1767 maybe_set_param_value (PARAM_ASAN_USE_AFTER_RETURN, 0,
1768 opts->x_param_values,
1769 opts_set->x_param_values);
1771 break;
1773 case OPT_fsanitize_recover_:
1774 opts->x_flag_sanitize_recover
1775 = parse_sanitizer_options (arg, loc, code,
1776 opts->x_flag_sanitize_recover, value, true);
1777 break;
1779 case OPT_fasan_shadow_offset_:
1780 /* Deferred. */
1781 break;
1783 case OPT_fsanitize_recover:
1784 if (value)
1785 opts->x_flag_sanitize_recover
1786 |= (SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT)
1787 & ~(SANITIZE_UNREACHABLE | SANITIZE_RETURN);
1788 else
1789 opts->x_flag_sanitize_recover
1790 &= ~(SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT);
1791 break;
1793 case OPT_O:
1794 case OPT_Os:
1795 case OPT_Ofast:
1796 case OPT_Og:
1797 /* Currently handled in a prescan. */
1798 break;
1800 case OPT_Werror:
1801 dc->warning_as_error_requested = value;
1802 break;
1804 case OPT_Werror_:
1805 if (lang_mask == CL_DRIVER)
1806 break;
1808 enable_warning_as_error (arg, value, lang_mask, handlers,
1809 opts, opts_set, loc, dc);
1810 break;
1812 case OPT_Wlarger_than_:
1813 opts->x_larger_than_size = value;
1814 opts->x_warn_larger_than = value != -1;
1815 break;
1817 case OPT_Wfatal_errors:
1818 dc->fatal_errors = value;
1819 break;
1821 case OPT_Wframe_larger_than_:
1822 opts->x_frame_larger_than_size = value;
1823 opts->x_warn_frame_larger_than = value != -1;
1824 break;
1826 case OPT_Wstack_usage_:
1827 opts->x_warn_stack_usage = value;
1828 opts->x_flag_stack_usage_info = value != -1;
1829 break;
1831 case OPT_Wstrict_aliasing:
1832 set_Wstrict_aliasing (opts, value);
1833 break;
1835 case OPT_Wstrict_overflow:
1836 opts->x_warn_strict_overflow = (value
1837 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1838 : 0);
1839 break;
1841 case OPT_Wsystem_headers:
1842 dc->dc_warn_system_headers = value;
1843 break;
1845 case OPT_aux_info:
1846 opts->x_flag_gen_aux_info = 1;
1847 break;
1849 case OPT_auxbase_strip:
1851 char *tmp = xstrdup (arg);
1852 strip_off_ending (tmp, strlen (tmp));
1853 if (tmp[0])
1854 opts->x_aux_base_name = tmp;
1855 else
1856 free (tmp);
1858 break;
1860 case OPT_d:
1861 decode_d_option (arg, opts, loc, dc);
1862 break;
1864 case OPT_fcall_used_:
1865 case OPT_fcall_saved_:
1866 /* Deferred. */
1867 break;
1869 case OPT_fdbg_cnt_:
1870 /* Deferred. */
1871 break;
1873 case OPT_fdbg_cnt_list:
1874 /* Deferred. */
1875 opts->x_exit_after_options = true;
1876 break;
1878 case OPT_fdebug_prefix_map_:
1879 /* Deferred. */
1880 break;
1882 case OPT_fdiagnostics_show_location_:
1883 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1884 break;
1886 case OPT_fdiagnostics_show_caret:
1887 dc->show_caret = value;
1888 break;
1890 case OPT_fdiagnostics_color_:
1891 diagnostic_color_init (dc, value);
1892 break;
1894 case OPT_fdiagnostics_parseable_fixits:
1895 dc->parseable_fixits_p = value;
1896 break;
1898 case OPT_fdiagnostics_show_option:
1899 dc->show_option_requested = value;
1900 break;
1902 case OPT_fdump_:
1903 /* Deferred. */
1904 break;
1906 case OPT_ffast_math:
1907 set_fast_math_flags (opts, value);
1908 break;
1910 case OPT_funsafe_math_optimizations:
1911 set_unsafe_math_optimizations_flags (opts, value);
1912 break;
1914 case OPT_ffixed_:
1915 /* Deferred. */
1916 break;
1918 case OPT_finline_limit_:
1919 set_param_value ("max-inline-insns-single", value / 2,
1920 opts->x_param_values, opts_set->x_param_values);
1921 set_param_value ("max-inline-insns-auto", value / 2,
1922 opts->x_param_values, opts_set->x_param_values);
1923 break;
1925 case OPT_finstrument_functions_exclude_function_list_:
1926 add_comma_separated_to_vector
1927 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1928 break;
1930 case OPT_finstrument_functions_exclude_file_list_:
1931 add_comma_separated_to_vector
1932 (&opts->x_flag_instrument_functions_exclude_files, arg);
1933 break;
1935 case OPT_fmessage_length_:
1936 pp_set_line_maximum_length (dc->printer, value);
1937 diagnostic_set_caret_max_width (dc, value);
1938 break;
1940 case OPT_fopt_info:
1941 case OPT_fopt_info_:
1942 /* Deferred. */
1943 break;
1945 case OPT_foffload_:
1947 const char *p = arg;
1948 opts->x_flag_disable_hsa = true;
1949 while (*p != 0)
1951 const char *comma = strchr (p, ',');
1953 if ((strncmp (p, "disable", 7) == 0)
1954 && (p[7] == ',' || p[7] == '\0'))
1956 opts->x_flag_disable_hsa = true;
1957 break;
1960 if ((strncmp (p, "hsa", 3) == 0)
1961 && (p[3] == ',' || p[3] == '\0'))
1963 #ifdef ENABLE_HSA
1964 opts->x_flag_disable_hsa = false;
1965 #else
1966 sorry ("HSA has not been enabled during configuration");
1967 #endif
1969 if (!comma)
1970 break;
1971 p = comma + 1;
1973 break;
1976 #ifndef ACCEL_COMPILER
1977 case OPT_foffload_abi_:
1978 error_at (loc, "-foffload-abi option can be specified only for "
1979 "offload compiler");
1980 break;
1981 #endif
1983 case OPT_fpack_struct_:
1984 if (value <= 0 || (value & (value - 1)) || value > 16)
1985 error_at (loc,
1986 "structure alignment must be a small power of two, not %d",
1987 value);
1988 else
1989 opts->x_initial_max_fld_align = value;
1990 break;
1992 case OPT_fplugin_:
1993 case OPT_fplugin_arg_:
1994 /* Deferred. */
1995 break;
1997 case OPT_fprofile_use_:
1998 opts->x_profile_data_prefix = xstrdup (arg);
1999 opts->x_flag_profile_use = true;
2000 value = true;
2001 /* No break here - do -fprofile-use processing. */
2002 /* FALLTHRU */
2003 case OPT_fprofile_use:
2004 enable_fdo_optimizations (opts, opts_set, value);
2005 if (!opts_set->x_flag_profile_reorder_functions)
2006 opts->x_flag_profile_reorder_functions = value;
2007 /* Indirect call profiling should do all useful transformations
2008 speculative devirtualization does. */
2009 if (!opts_set->x_flag_devirtualize_speculatively
2010 && opts->x_flag_value_profile_transformations)
2011 opts->x_flag_devirtualize_speculatively = false;
2012 break;
2014 case OPT_fauto_profile_:
2015 opts->x_auto_profile_file = xstrdup (arg);
2016 opts->x_flag_auto_profile = true;
2017 value = true;
2018 /* No break here - do -fauto-profile processing. */
2019 /* FALLTHRU */
2020 case OPT_fauto_profile:
2021 enable_fdo_optimizations (opts, opts_set, value);
2022 if (!opts_set->x_flag_profile_correction)
2023 opts->x_flag_profile_correction = value;
2024 maybe_set_param_value (
2025 PARAM_EARLY_INLINER_MAX_ITERATIONS, 10,
2026 opts->x_param_values, opts_set->x_param_values);
2027 break;
2029 case OPT_fprofile_generate_:
2030 opts->x_profile_data_prefix = xstrdup (arg);
2031 value = true;
2032 /* No break here - do -fprofile-generate processing. */
2033 /* FALLTHRU */
2034 case OPT_fprofile_generate:
2035 if (!opts_set->x_profile_arc_flag)
2036 opts->x_profile_arc_flag = value;
2037 if (!opts_set->x_flag_profile_values)
2038 opts->x_flag_profile_values = value;
2039 if (!opts_set->x_flag_inline_functions)
2040 opts->x_flag_inline_functions = value;
2041 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
2042 quadratic. Disable the pass until better memory representation
2043 is done. */
2044 if (!opts_set->x_flag_ipa_reference)
2045 opts->x_flag_ipa_reference = false;
2046 break;
2048 case OPT_ftree_vectorize:
2049 if (!opts_set->x_flag_tree_loop_vectorize)
2050 opts->x_flag_tree_loop_vectorize = value;
2051 if (!opts_set->x_flag_tree_slp_vectorize)
2052 opts->x_flag_tree_slp_vectorize = value;
2053 break;
2054 case OPT_fshow_column:
2055 dc->show_column = value;
2056 break;
2058 case OPT_frandom_seed:
2059 /* The real switch is -fno-random-seed. */
2060 if (value)
2061 return false;
2062 /* Deferred. */
2063 break;
2065 case OPT_frandom_seed_:
2066 /* Deferred. */
2067 break;
2069 case OPT_fsched_verbose_:
2070 #ifdef INSN_SCHEDULING
2071 /* Handled with Var in common.opt. */
2072 break;
2073 #else
2074 return false;
2075 #endif
2077 case OPT_fsched_stalled_insns_:
2078 opts->x_flag_sched_stalled_insns = value;
2079 if (opts->x_flag_sched_stalled_insns == 0)
2080 opts->x_flag_sched_stalled_insns = -1;
2081 break;
2083 case OPT_fsched_stalled_insns_dep_:
2084 opts->x_flag_sched_stalled_insns_dep = value;
2085 break;
2087 case OPT_fstack_check_:
2088 if (!strcmp (arg, "no"))
2089 opts->x_flag_stack_check = NO_STACK_CHECK;
2090 else if (!strcmp (arg, "generic"))
2091 /* This is the old stack checking method. */
2092 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2093 ? FULL_BUILTIN_STACK_CHECK
2094 : GENERIC_STACK_CHECK;
2095 else if (!strcmp (arg, "specific"))
2096 /* This is the new stack checking method. */
2097 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2098 ? FULL_BUILTIN_STACK_CHECK
2099 : STACK_CHECK_STATIC_BUILTIN
2100 ? STATIC_BUILTIN_STACK_CHECK
2101 : GENERIC_STACK_CHECK;
2102 else
2103 warning_at (loc, 0, "unknown stack check parameter %qs", arg);
2104 break;
2106 case OPT_fstack_limit:
2107 /* The real switch is -fno-stack-limit. */
2108 if (value)
2109 return false;
2110 /* Deferred. */
2111 break;
2113 case OPT_fstack_limit_register_:
2114 case OPT_fstack_limit_symbol_:
2115 /* Deferred. */
2116 break;
2118 case OPT_fstack_usage:
2119 opts->x_flag_stack_usage = value;
2120 opts->x_flag_stack_usage_info = value != 0;
2121 break;
2123 case OPT_g:
2124 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
2125 loc);
2126 break;
2128 case OPT_gcoff:
2129 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
2130 break;
2132 case OPT_gdwarf:
2133 if (arg && strlen (arg) != 0)
2135 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
2136 "use %<-gdwarf-%s%> for DWARF version "
2137 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
2138 break;
2140 else
2141 value = opts->x_dwarf_version;
2143 /* FALLTHRU */
2144 case OPT_gdwarf_:
2145 if (value < 2 || value > 5)
2146 error_at (loc, "dwarf version %d is not supported", value);
2147 else
2148 opts->x_dwarf_version = value;
2149 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
2150 break;
2152 case OPT_gsplit_dwarf:
2153 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
2154 loc);
2155 break;
2157 case OPT_ggdb:
2158 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
2159 break;
2161 case OPT_gstabs:
2162 case OPT_gstabs_:
2163 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
2164 loc);
2165 break;
2167 case OPT_gvms:
2168 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
2169 break;
2171 case OPT_gxcoff:
2172 case OPT_gxcoff_:
2173 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
2174 loc);
2175 break;
2177 case OPT_gz:
2178 case OPT_gz_:
2179 /* Handled completely via specs. */
2180 break;
2182 case OPT_pedantic_errors:
2183 dc->pedantic_errors = 1;
2184 control_warning_option (OPT_Wpedantic, DK_ERROR, NULL, value,
2185 loc, lang_mask,
2186 handlers, opts, opts_set,
2187 dc);
2188 break;
2190 case OPT_flto:
2191 opts->x_flag_lto = value ? "" : NULL;
2192 break;
2194 case OPT_w:
2195 dc->dc_inhibit_warnings = true;
2196 break;
2198 case OPT_fmax_errors_:
2199 dc->max_errors = value;
2200 break;
2202 case OPT_fuse_ld_bfd:
2203 case OPT_fuse_ld_gold:
2204 case OPT_fuse_linker_plugin:
2205 /* No-op. Used by the driver and passed to us because it starts with f.*/
2206 break;
2208 case OPT_fwrapv:
2209 if (value)
2210 opts->x_flag_trapv = 0;
2211 break;
2213 case OPT_ftrapv:
2214 if (value)
2215 opts->x_flag_wrapv = 0;
2216 break;
2218 case OPT_fipa_icf:
2219 opts->x_flag_ipa_icf_functions = value;
2220 opts->x_flag_ipa_icf_variables = value;
2221 break;
2223 default:
2224 /* If the flag was handled in a standard way, assume the lack of
2225 processing here is intentional. */
2226 gcc_assert (option_flag_var (scode, opts));
2227 break;
2230 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
2231 loc, handlers, dc);
2232 return true;
2235 /* Handle --param NAME=VALUE. */
2236 static void
2237 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
2238 location_t loc, const char *carg)
2240 char *equal, *arg;
2241 int value;
2243 arg = xstrdup (carg);
2244 equal = strchr (arg, '=');
2245 if (!equal)
2246 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
2247 arg);
2248 else
2250 *equal = '\0';
2252 enum compiler_param index;
2253 if (!find_param (arg, &index))
2255 const char *suggestion = find_param_fuzzy (arg);
2256 if (suggestion)
2257 error_at (loc, "invalid --param name %qs; did you mean %qs?",
2258 arg, suggestion);
2259 else
2260 error_at (loc, "invalid --param name %qs", arg);
2262 else
2264 if (!param_string_value_p (index, equal + 1, &value))
2265 value = integral_argument (equal + 1);
2267 if (value == -1)
2268 error_at (loc, "invalid --param value %qs", equal + 1);
2269 else
2270 set_param_value (arg, value,
2271 opts->x_param_values, opts_set->x_param_values);
2275 free (arg);
2278 /* Used to set the level of strict aliasing warnings in OPTS,
2279 when no level is specified (i.e., when -Wstrict-aliasing, and not
2280 -Wstrict-aliasing=level was given).
2281 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
2282 and 0 otherwise. After calling this function, wstrict_aliasing will be
2283 set to the default value of -Wstrict_aliasing=level, currently 3. */
2284 static void
2285 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
2287 gcc_assert (onoff == 0 || onoff == 1);
2288 if (onoff != 0)
2289 opts->x_warn_strict_aliasing = 3;
2290 else
2291 opts->x_warn_strict_aliasing = 0;
2294 /* The following routines are useful in setting all the flags that
2295 -ffast-math and -fno-fast-math imply. */
2296 static void
2297 set_fast_math_flags (struct gcc_options *opts, int set)
2299 if (!opts->frontend_set_flag_unsafe_math_optimizations)
2301 opts->x_flag_unsafe_math_optimizations = set;
2302 set_unsafe_math_optimizations_flags (opts, set);
2304 if (!opts->frontend_set_flag_finite_math_only)
2305 opts->x_flag_finite_math_only = set;
2306 if (!opts->frontend_set_flag_errno_math)
2307 opts->x_flag_errno_math = !set;
2308 if (set)
2310 if (!opts->frontend_set_flag_signaling_nans)
2311 opts->x_flag_signaling_nans = 0;
2312 if (!opts->frontend_set_flag_rounding_math)
2313 opts->x_flag_rounding_math = 0;
2314 if (!opts->frontend_set_flag_cx_limited_range)
2315 opts->x_flag_cx_limited_range = 1;
2319 /* When -funsafe-math-optimizations is set the following
2320 flags are set as well. */
2321 static void
2322 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
2324 if (!opts->frontend_set_flag_trapping_math)
2325 opts->x_flag_trapping_math = !set;
2326 if (!opts->frontend_set_flag_signed_zeros)
2327 opts->x_flag_signed_zeros = !set;
2328 if (!opts->frontend_set_flag_associative_math)
2329 opts->x_flag_associative_math = set;
2330 if (!opts->frontend_set_flag_reciprocal_math)
2331 opts->x_flag_reciprocal_math = set;
2334 /* Return true iff flags in OPTS are set as if -ffast-math. */
2335 bool
2336 fast_math_flags_set_p (const struct gcc_options *opts)
2338 return (!opts->x_flag_trapping_math
2339 && opts->x_flag_unsafe_math_optimizations
2340 && opts->x_flag_finite_math_only
2341 && !opts->x_flag_signed_zeros
2342 && !opts->x_flag_errno_math);
2345 /* Return true iff flags are set as if -ffast-math but using the flags stored
2346 in the struct cl_optimization structure. */
2347 bool
2348 fast_math_flags_struct_set_p (struct cl_optimization *opt)
2350 return (!opt->x_flag_trapping_math
2351 && opt->x_flag_unsafe_math_optimizations
2352 && opt->x_flag_finite_math_only
2353 && !opt->x_flag_signed_zeros
2354 && !opt->x_flag_errno_math);
2357 /* Handle a debug output -g switch for options OPTS
2358 (OPTS_SET->x_write_symbols storing whether a debug type was passed
2359 explicitly), location LOC. EXTENDED is true or false to support
2360 extended output (2 is special and means "-ggdb" was given). */
2361 static void
2362 set_debug_level (enum debug_info_type type, int extended, const char *arg,
2363 struct gcc_options *opts, struct gcc_options *opts_set,
2364 location_t loc)
2366 opts->x_use_gnu_debug_info_extensions = extended;
2368 if (type == NO_DEBUG)
2370 if (opts->x_write_symbols == NO_DEBUG)
2372 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
2374 if (extended == 2)
2376 #if defined DWARF2_DEBUGGING_INFO || defined DWARF2_LINENO_DEBUGGING_INFO
2377 opts->x_write_symbols = DWARF2_DEBUG;
2378 #elif defined DBX_DEBUGGING_INFO
2379 opts->x_write_symbols = DBX_DEBUG;
2380 #endif
2383 if (opts->x_write_symbols == NO_DEBUG)
2384 warning_at (loc, 0, "target system does not support debug output");
2387 else
2389 /* Does it conflict with an already selected type? */
2390 if (opts_set->x_write_symbols != NO_DEBUG
2391 && opts->x_write_symbols != NO_DEBUG
2392 && type != opts->x_write_symbols)
2393 error_at (loc, "debug format %qs conflicts with prior selection",
2394 debug_type_names[type]);
2395 opts->x_write_symbols = type;
2396 opts_set->x_write_symbols = type;
2399 /* A debug flag without a level defaults to level 2.
2400 If off or at level 1, set it to level 2, but if already
2401 at level 3, don't lower it. */
2402 if (*arg == '\0')
2404 if (opts->x_debug_info_level < DINFO_LEVEL_NORMAL)
2405 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2407 else
2409 int argval = integral_argument (arg);
2410 if (argval == -1)
2411 error_at (loc, "unrecognised debug output level %qs", arg);
2412 else if (argval > 3)
2413 error_at (loc, "debug output level %qs is too high", arg);
2414 else
2415 opts->x_debug_info_level = (enum debug_info_levels) argval;
2419 /* Arrange to dump core on error for diagnostic context DC. (The
2420 regular error message is still printed first, except in the case of
2421 abort ().) */
2423 static void
2424 setup_core_dumping (diagnostic_context *dc)
2426 #ifdef SIGABRT
2427 signal (SIGABRT, SIG_DFL);
2428 #endif
2429 #if defined(HAVE_SETRLIMIT)
2431 struct rlimit rlim;
2432 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2433 fatal_error (input_location, "getting core file size maximum limit: %m");
2434 rlim.rlim_cur = rlim.rlim_max;
2435 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2436 fatal_error (input_location,
2437 "setting core file size limit to maximum: %m");
2439 #endif
2440 diagnostic_abort_on_error (dc);
2443 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2444 diagnostic context DC. */
2446 static void
2447 decode_d_option (const char *arg, struct gcc_options *opts,
2448 location_t loc, diagnostic_context *dc)
2450 int c;
2452 while (*arg)
2453 switch (c = *arg++)
2455 case 'A':
2456 opts->x_flag_debug_asm = 1;
2457 break;
2458 case 'p':
2459 opts->x_flag_print_asm_name = 1;
2460 break;
2461 case 'P':
2462 opts->x_flag_dump_rtl_in_asm = 1;
2463 opts->x_flag_print_asm_name = 1;
2464 break;
2465 case 'x':
2466 opts->x_rtl_dump_and_exit = 1;
2467 break;
2468 case 'D': /* These are handled by the preprocessor. */
2469 case 'I':
2470 case 'M':
2471 case 'N':
2472 case 'U':
2473 break;
2474 case 'H':
2475 setup_core_dumping (dc);
2476 break;
2477 case 'a':
2478 opts->x_flag_dump_all_passed = true;
2479 break;
2481 default:
2482 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2483 break;
2487 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2488 mask LANG_MASK, option handlers HANDLERS) as an error for option
2489 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2490 NULL), location LOC. This is used by -Werror=. */
2492 static void
2493 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2494 const struct cl_option_handlers *handlers,
2495 struct gcc_options *opts,
2496 struct gcc_options *opts_set,
2497 location_t loc, diagnostic_context *dc)
2499 char *new_option;
2500 int option_index;
2502 new_option = XNEWVEC (char, strlen (arg) + 2);
2503 new_option[0] = 'W';
2504 strcpy (new_option + 1, arg);
2505 option_index = find_opt (new_option, lang_mask);
2506 if (option_index == OPT_SPECIAL_unknown)
2507 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2508 else if (!(cl_options[option_index].flags & CL_WARNING))
2509 error_at (loc, "-Werror=%s: -%s is not an option that controls warnings",
2510 arg, new_option);
2511 else
2513 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2514 const char *arg = NULL;
2516 if (cl_options[option_index].flags & CL_JOINED)
2517 arg = new_option + cl_options[option_index].opt_len;
2518 control_warning_option (option_index, (int) kind, arg, value,
2519 loc, lang_mask,
2520 handlers, opts, opts_set, dc);
2522 free (new_option);
2525 /* Return malloced memory for the name of the option OPTION_INDEX
2526 which enabled a diagnostic (context CONTEXT), originally of type
2527 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2528 as -Werror. */
2530 char *
2531 option_name (diagnostic_context *context, int option_index,
2532 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2534 if (option_index)
2536 /* A warning classified as an error. */
2537 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2538 && diag_kind == DK_ERROR)
2539 return concat (cl_options[OPT_Werror_].opt_text,
2540 /* Skip over "-W". */
2541 cl_options[option_index].opt_text + 2,
2542 NULL);
2543 /* A warning with option. */
2544 else
2545 return xstrdup (cl_options[option_index].opt_text);
2547 /* A warning without option classified as an error. */
2548 else if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2549 || diag_kind == DK_WARNING)
2550 && context->warning_as_error_requested)
2551 return xstrdup (cl_options[OPT_Werror].opt_text);
2552 else
2553 return NULL;