PR tree-optimization/78496
[official-gcc.git] / gcc / opts.c
blobffedb10f18fee785a4af4267cc17ec4ad27ddfe7
1 /* Command line option handling.
2 Copyright (C) 2002-2017 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"
33 #include "spellcheck.h"
35 static void set_Wstrict_aliasing (struct gcc_options *opts, int onoff);
37 /* Indexed by enum debug_info_type. */
38 const char *const debug_type_names[] =
40 "none", "stabs", "coff", "dwarf-2", "xcoff", "vms"
43 /* Parse the -femit-struct-debug-detailed option value
44 and set the flag variables. */
46 #define MATCH( prefix, string ) \
47 ((strncmp (prefix, string, sizeof prefix - 1) == 0) \
48 ? ((string += sizeof prefix - 1), 1) : 0)
50 void
51 set_struct_debug_option (struct gcc_options *opts, location_t loc,
52 const char *spec)
54 /* various labels for comparison */
55 static const char dfn_lbl[] = "dfn:", dir_lbl[] = "dir:", ind_lbl[] = "ind:";
56 static const char ord_lbl[] = "ord:", gen_lbl[] = "gen:";
57 static const char none_lbl[] = "none", any_lbl[] = "any";
58 static const char base_lbl[] = "base", sys_lbl[] = "sys";
60 enum debug_struct_file files = DINFO_STRUCT_FILE_ANY;
61 /* Default is to apply to as much as possible. */
62 enum debug_info_usage usage = DINFO_USAGE_NUM_ENUMS;
63 int ord = 1, gen = 1;
65 /* What usage? */
66 if (MATCH (dfn_lbl, spec))
67 usage = DINFO_USAGE_DFN;
68 else if (MATCH (dir_lbl, spec))
69 usage = DINFO_USAGE_DIR_USE;
70 else if (MATCH (ind_lbl, spec))
71 usage = DINFO_USAGE_IND_USE;
73 /* Generics or not? */
74 if (MATCH (ord_lbl, spec))
75 gen = 0;
76 else if (MATCH (gen_lbl, spec))
77 ord = 0;
79 /* What allowable environment? */
80 if (MATCH (none_lbl, spec))
81 files = DINFO_STRUCT_FILE_NONE;
82 else if (MATCH (any_lbl, spec))
83 files = DINFO_STRUCT_FILE_ANY;
84 else if (MATCH (sys_lbl, spec))
85 files = DINFO_STRUCT_FILE_SYS;
86 else if (MATCH (base_lbl, spec))
87 files = DINFO_STRUCT_FILE_BASE;
88 else
89 error_at (loc,
90 "argument %qs to %<-femit-struct-debug-detailed%> "
91 "not recognized",
92 spec);
94 /* Effect the specification. */
95 if (usage == DINFO_USAGE_NUM_ENUMS)
97 if (ord)
99 opts->x_debug_struct_ordinary[DINFO_USAGE_DFN] = files;
100 opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE] = files;
101 opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE] = files;
103 if (gen)
105 opts->x_debug_struct_generic[DINFO_USAGE_DFN] = files;
106 opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE] = files;
107 opts->x_debug_struct_generic[DINFO_USAGE_IND_USE] = files;
110 else
112 if (ord)
113 opts->x_debug_struct_ordinary[usage] = files;
114 if (gen)
115 opts->x_debug_struct_generic[usage] = files;
118 if (*spec == ',')
119 set_struct_debug_option (opts, loc, spec+1);
120 else
122 /* No more -femit-struct-debug-detailed specifications.
123 Do final checks. */
124 if (*spec != '\0')
125 error_at (loc,
126 "argument %qs to %<-femit-struct-debug-detailed%> unknown",
127 spec);
128 if (opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE]
129 < opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE]
130 || opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE]
131 < opts->x_debug_struct_generic[DINFO_USAGE_IND_USE])
132 error_at (loc,
133 "%<-femit-struct-debug-detailed=dir:...%> must allow "
134 "at least as much as "
135 "%<-femit-struct-debug-detailed=ind:...%>");
139 /* Strip off a legitimate source ending from the input string NAME of
140 length LEN. Rather than having to know the names used by all of
141 our front ends, we strip off an ending of a period followed by
142 up to five characters. (Java uses ".class".) */
144 void
145 strip_off_ending (char *name, int len)
147 int i;
148 for (i = 2; i < 6 && len > i; i++)
150 if (name[len - i] == '.')
152 name[len - i] = '\0';
153 break;
158 /* Find the base name of a path, stripping off both directories and
159 a single final extension. */
161 base_of_path (const char *path, const char **base_out)
163 const char *base = path;
164 const char *dot = 0;
165 const char *p = path;
166 char c = *p;
167 while (c)
169 if (IS_DIR_SEPARATOR (c))
171 base = p + 1;
172 dot = 0;
174 else if (c == '.')
175 dot = p;
176 c = *++p;
178 if (!dot)
179 dot = p;
180 *base_out = base;
181 return dot - base;
184 /* What to print when a switch has no documentation. */
185 static const char undocumented_msg[] = N_("This option lacks documentation.");
186 static const char use_diagnosed_msg[] = N_("Uses of this option are diagnosed.");
188 typedef char *char_p; /* For DEF_VEC_P. */
190 static void handle_param (struct gcc_options *opts,
191 struct gcc_options *opts_set, location_t loc,
192 const char *carg);
193 static void set_debug_level (enum debug_info_type type, int extended,
194 const char *arg, struct gcc_options *opts,
195 struct gcc_options *opts_set,
196 location_t loc);
197 static void set_fast_math_flags (struct gcc_options *opts, int set);
198 static void decode_d_option (const char *arg, struct gcc_options *opts,
199 location_t loc, diagnostic_context *dc);
200 static void set_unsafe_math_optimizations_flags (struct gcc_options *opts,
201 int set);
202 static void enable_warning_as_error (const char *arg, int value,
203 unsigned int lang_mask,
204 const struct cl_option_handlers *handlers,
205 struct gcc_options *opts,
206 struct gcc_options *opts_set,
207 location_t loc,
208 diagnostic_context *dc);
210 /* Handle a back-end option; arguments and return value as for
211 handle_option. */
213 bool
214 target_handle_option (struct gcc_options *opts,
215 struct gcc_options *opts_set,
216 const struct cl_decoded_option *decoded,
217 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
218 location_t loc,
219 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
220 diagnostic_context *dc)
222 gcc_assert (dc == global_dc);
223 gcc_assert (kind == DK_UNSPECIFIED);
224 return targetm_common.handle_option (opts, opts_set, decoded, loc);
227 /* Add comma-separated strings to a char_p vector. */
229 static void
230 add_comma_separated_to_vector (void **pvec, const char *arg)
232 char *tmp;
233 char *r;
234 char *w;
235 char *token_start;
236 vec<char_p> *v = (vec<char_p> *) *pvec;
238 vec_check_alloc (v, 1);
240 /* We never free this string. */
241 tmp = xstrdup (arg);
243 r = tmp;
244 w = tmp;
245 token_start = tmp;
247 while (*r != '\0')
249 if (*r == ',')
251 *w++ = '\0';
252 ++r;
253 v->safe_push (token_start);
254 token_start = w;
256 if (*r == '\\' && r[1] == ',')
258 *w++ = ',';
259 r += 2;
261 else
262 *w++ = *r++;
264 if (*token_start != '\0')
265 v->safe_push (token_start);
267 *pvec = v;
270 /* Initialize opts_obstack. */
272 void
273 init_opts_obstack (void)
275 gcc_obstack_init (&opts_obstack);
278 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
280 void
281 init_options_struct (struct gcc_options *opts, struct gcc_options *opts_set)
283 size_t num_params = get_num_compiler_params ();
285 /* Ensure that opts_obstack has already been initialized by the time
286 that we initialize any gcc_options instances (PR jit/68446). */
287 gcc_assert (opts_obstack.chunk_size > 0);
289 *opts = global_options_init;
291 if (opts_set)
292 memset (opts_set, 0, sizeof (*opts_set));
294 opts->x_param_values = XNEWVEC (int, num_params);
296 if (opts_set)
297 opts_set->x_param_values = XCNEWVEC (int, num_params);
299 init_param_values (opts->x_param_values);
301 /* Initialize whether `char' is signed. */
302 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
303 /* Set this to a special "uninitialized" value. The actual default
304 is set after target options have been processed. */
305 opts->x_flag_short_enums = 2;
307 /* Initialize target_flags before default_options_optimization
308 so the latter can modify it. */
309 opts->x_target_flags = targetm_common.default_target_flags;
311 /* Some targets have ABI-specified unwind tables. */
312 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
314 /* Some targets have other target-specific initialization. */
315 targetm_common.option_init_struct (opts);
318 /* Release any allocations owned by OPTS. */
320 void
321 finalize_options_struct (struct gcc_options *opts)
323 XDELETEVEC (opts->x_param_values);
326 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
327 -Ofast if FAST is set, -Og if DEBUG is set), apply the option DEFAULT_OPT
328 to OPTS and OPTS_SET, diagnostic context DC, location LOC, with language
329 mask LANG_MASK and option handlers HANDLERS. */
331 static void
332 maybe_default_option (struct gcc_options *opts,
333 struct gcc_options *opts_set,
334 const struct default_options *default_opt,
335 int level, bool size, bool fast, bool debug,
336 unsigned int lang_mask,
337 const struct cl_option_handlers *handlers,
338 location_t loc,
339 diagnostic_context *dc)
341 const struct cl_option *option = &cl_options[default_opt->opt_index];
342 bool enabled;
344 if (size)
345 gcc_assert (level == 2);
346 if (fast)
347 gcc_assert (level == 3);
348 if (debug)
349 gcc_assert (level == 1);
351 switch (default_opt->levels)
353 case OPT_LEVELS_ALL:
354 enabled = true;
355 break;
357 case OPT_LEVELS_0_ONLY:
358 enabled = (level == 0);
359 break;
361 case OPT_LEVELS_1_PLUS:
362 enabled = (level >= 1);
363 break;
365 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
366 enabled = (level >= 1 && !size && !debug);
367 break;
369 case OPT_LEVELS_1_PLUS_NOT_DEBUG:
370 enabled = (level >= 1 && !debug);
371 break;
373 case OPT_LEVELS_2_PLUS:
374 enabled = (level >= 2);
375 break;
377 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
378 enabled = (level >= 2 && !size && !debug);
379 break;
381 case OPT_LEVELS_3_PLUS:
382 enabled = (level >= 3);
383 break;
385 case OPT_LEVELS_3_PLUS_AND_SIZE:
386 enabled = (level >= 3 || size);
387 break;
389 case OPT_LEVELS_SIZE:
390 enabled = size;
391 break;
393 case OPT_LEVELS_FAST:
394 enabled = fast;
395 break;
397 case OPT_LEVELS_NONE:
398 default:
399 gcc_unreachable ();
402 if (enabled)
403 handle_generated_option (opts, opts_set, default_opt->opt_index,
404 default_opt->arg, default_opt->value,
405 lang_mask, DK_UNSPECIFIED, loc,
406 handlers, true, dc);
407 else if (default_opt->arg == NULL
408 && !option->cl_reject_negative)
409 handle_generated_option (opts, opts_set, default_opt->opt_index,
410 default_opt->arg, !default_opt->value,
411 lang_mask, DK_UNSPECIFIED, loc,
412 handlers, true, dc);
415 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
416 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
417 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
418 language mask LANG_MASK and option handlers HANDLERS. */
420 static void
421 maybe_default_options (struct gcc_options *opts,
422 struct gcc_options *opts_set,
423 const struct default_options *default_opts,
424 int level, bool size, bool fast, bool debug,
425 unsigned int lang_mask,
426 const struct cl_option_handlers *handlers,
427 location_t loc,
428 diagnostic_context *dc)
430 size_t i;
432 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
433 maybe_default_option (opts, opts_set, &default_opts[i],
434 level, size, fast, debug,
435 lang_mask, handlers, loc, dc);
438 /* Table of options enabled by default at different levels. */
440 static const struct default_options default_options_table[] =
442 /* -O1 optimizations. */
443 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
444 #if DELAY_SLOTS
445 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
446 #endif
447 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
448 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
449 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
450 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion, NULL, 1 },
451 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion2, NULL, 1 },
452 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
453 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
454 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
455 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
456 { OPT_LEVELS_1_PLUS, OPT_freorder_blocks, NULL, 1 },
457 { OPT_LEVELS_1_PLUS, OPT_fshrink_wrap, NULL, 1 },
458 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
459 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
460 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_bit_ccp, NULL, 1 },
461 { OPT_LEVELS_1_PLUS, OPT_ftree_coalesce_vars, NULL, 1 },
462 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
463 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
464 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
465 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
466 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_sra, NULL, 1 },
467 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
468 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
469 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
470 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
471 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
472 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
473 { OPT_LEVELS_1_PLUS, OPT_ftree_slsr, NULL, 1 },
474 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fbranch_count_reg, NULL, 1 },
475 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fmove_loop_invariants, NULL, 1 },
476 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_pta, NULL, 1 },
477 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fssa_phiopt, NULL, 1 },
478 { OPT_LEVELS_1_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
480 /* -O2 optimizations. */
481 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
482 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
483 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
484 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
488 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
489 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
490 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
491 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
492 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
493 #ifdef INSN_SCHEDULING
494 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
495 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
496 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
497 #endif
498 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, 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 },
524 { OPT_LEVELS_2_PLUS, OPT_fstore_merging, NULL, 1 },
526 /* -O3 optimizations. */
527 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
528 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
529 { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
530 /* Inlining of functions reducing size is a good idea with -Os
531 regardless of them being declared inline. */
532 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
533 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
534 { OPT_LEVELS_3_PLUS, OPT_fsplit_loops, NULL, 1 },
535 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
536 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
537 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
538 { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
539 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
540 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
541 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
542 { OPT_LEVELS_3_PLUS, OPT_fpeel_loops, NULL, 1 },
544 /* -Ofast adds optimizations to -O3. */
545 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
547 { OPT_LEVELS_NONE, 0, NULL, 0 }
550 /* Default the options in OPTS and OPTS_SET based on the optimization
551 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
552 void
553 default_options_optimization (struct gcc_options *opts,
554 struct gcc_options *opts_set,
555 struct cl_decoded_option *decoded_options,
556 unsigned int decoded_options_count,
557 location_t loc,
558 unsigned int lang_mask,
559 const struct cl_option_handlers *handlers,
560 diagnostic_context *dc)
562 unsigned int i;
563 int opt2;
564 bool openacc_mode = false;
566 /* Scan to see what optimization level has been specified. That will
567 determine the default value of many flags. */
568 for (i = 1; i < decoded_options_count; i++)
570 struct cl_decoded_option *opt = &decoded_options[i];
571 switch (opt->opt_index)
573 case OPT_O:
574 if (*opt->arg == '\0')
576 opts->x_optimize = 1;
577 opts->x_optimize_size = 0;
578 opts->x_optimize_fast = 0;
579 opts->x_optimize_debug = 0;
581 else
583 const int optimize_val = integral_argument (opt->arg);
584 if (optimize_val == -1)
585 error_at (loc, "argument to %<-O%> should be a non-negative "
586 "integer, %<g%>, %<s%> or %<fast%>");
587 else
589 opts->x_optimize = optimize_val;
590 if ((unsigned int) opts->x_optimize > 255)
591 opts->x_optimize = 255;
592 opts->x_optimize_size = 0;
593 opts->x_optimize_fast = 0;
594 opts->x_optimize_debug = 0;
597 break;
599 case OPT_Os:
600 opts->x_optimize_size = 1;
602 /* Optimizing for size forces optimize to be 2. */
603 opts->x_optimize = 2;
604 opts->x_optimize_fast = 0;
605 opts->x_optimize_debug = 0;
606 break;
608 case OPT_Ofast:
609 /* -Ofast only adds flags to -O3. */
610 opts->x_optimize_size = 0;
611 opts->x_optimize = 3;
612 opts->x_optimize_fast = 1;
613 opts->x_optimize_debug = 0;
614 break;
616 case OPT_Og:
617 /* -Og selects optimization level 1. */
618 opts->x_optimize_size = 0;
619 opts->x_optimize = 1;
620 opts->x_optimize_fast = 0;
621 opts->x_optimize_debug = 1;
622 break;
624 case OPT_fopenacc:
625 if (opt->value)
626 openacc_mode = true;
627 break;
629 default:
630 /* Ignore other options in this prescan. */
631 break;
635 maybe_default_options (opts, opts_set, default_options_table,
636 opts->x_optimize, opts->x_optimize_size,
637 opts->x_optimize_fast, opts->x_optimize_debug,
638 lang_mask, handlers, loc, dc);
640 /* -O2 param settings. */
641 opt2 = (opts->x_optimize >= 2);
643 if (openacc_mode
644 && !opts_set->x_flag_ipa_pta)
645 opts->x_flag_ipa_pta = true;
647 /* Track fields in field-sensitive alias analysis. */
648 maybe_set_param_value
649 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
650 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
651 opts->x_param_values, opts_set->x_param_values);
653 /* For -O1 only do loop invariant motion for very small loops. */
654 maybe_set_param_value
655 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
656 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
657 opts->x_param_values, opts_set->x_param_values);
659 /* At -Ofast, allow store motion to introduce potential race conditions. */
660 maybe_set_param_value
661 (PARAM_ALLOW_STORE_DATA_RACES,
662 opts->x_optimize_fast ? 1
663 : default_param_value (PARAM_ALLOW_STORE_DATA_RACES),
664 opts->x_param_values, opts_set->x_param_values);
666 if (opts->x_optimize_size)
667 /* We want to crossjump as much as possible. */
668 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
669 opts->x_param_values, opts_set->x_param_values);
670 else
671 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
672 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
673 opts->x_param_values, opts_set->x_param_values);
675 /* Restrict the amount of work combine does at -Og while retaining
676 most of its useful transforms. */
677 if (opts->x_optimize_debug)
678 maybe_set_param_value (PARAM_MAX_COMBINE_INSNS, 2,
679 opts->x_param_values, opts_set->x_param_values);
681 /* Allow default optimizations to be specified on a per-machine basis. */
682 maybe_default_options (opts, opts_set,
683 targetm_common.option_optimization_table,
684 opts->x_optimize, opts->x_optimize_size,
685 opts->x_optimize_fast, opts->x_optimize_debug,
686 lang_mask, handlers, loc, dc);
689 /* After all options at LOC have been read into OPTS and OPTS_SET,
690 finalize settings of those options and diagnose incompatible
691 combinations. */
692 void
693 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
694 location_t loc)
696 enum unwind_info_type ui_except;
698 if (opts->x_dump_base_name
699 && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name)
700 && ! opts->x_dump_base_name_prefixed)
702 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
703 OPTS->X_DUMP_DIR_NAME directory. Then try to make
704 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
705 directory, typically the directory to contain the object
706 file. */
707 if (opts->x_dump_dir_name)
708 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
709 opts->x_dump_base_name, NULL);
710 else if (opts->x_aux_base_name
711 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
713 const char *aux_base;
715 base_of_path (opts->x_aux_base_name, &aux_base);
716 if (opts->x_aux_base_name != aux_base)
718 int dir_len = aux_base - opts->x_aux_base_name;
719 char *new_dump_base_name
720 = XOBNEWVEC (&opts_obstack, char,
721 strlen (opts->x_dump_base_name) + dir_len + 1);
723 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
724 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
725 /* Append existing OPTS->X_DUMP_BASE_NAME. */
726 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
727 opts->x_dump_base_name = new_dump_base_name;
730 opts->x_dump_base_name_prefixed = true;
733 /* Handle related options for unit-at-a-time, toplevel-reorder, and
734 section-anchors. */
735 if (!opts->x_flag_unit_at_a_time)
737 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
738 error_at (loc, "section anchors must be disabled when unit-at-a-time "
739 "is disabled");
740 opts->x_flag_section_anchors = 0;
741 if (opts->x_flag_toplevel_reorder == 1)
742 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
743 "is disabled");
744 opts->x_flag_toplevel_reorder = 0;
747 /* -fself-test depends on the state of the compiler prior to
748 compiling anything. Ideally it should be run on an empty source
749 file. However, in case we get run with actual source, assume
750 -fsyntax-only which will inhibit any compiler initialization
751 which may confuse the self tests. */
752 if (opts->x_flag_self_test)
753 opts->x_flag_syntax_only = 1;
755 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
756 sorry ("transactional memory is not supported with non-call exceptions");
758 /* Unless the user has asked for section anchors, we disable toplevel
759 reordering at -O0 to disable transformations that might be surprising
760 to end users and to get -fno-toplevel-reorder tested. */
761 if (!opts->x_optimize
762 && opts->x_flag_toplevel_reorder == 2
763 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
765 opts->x_flag_toplevel_reorder = 0;
766 opts->x_flag_section_anchors = 0;
768 if (!opts->x_flag_toplevel_reorder)
770 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
771 error_at (loc, "section anchors must be disabled when toplevel reorder"
772 " is disabled");
773 opts->x_flag_section_anchors = 0;
776 if (!opts->x_flag_opts_finished)
778 /* We initialize opts->x_flag_pie to -1 so that targets can set a
779 default value. */
780 if (opts->x_flag_pie == -1)
782 /* We initialize opts->x_flag_pic to -1 so that we can tell if
783 -fpic, -fPIC, -fno-pic or -fno-PIC is used. */
784 if (opts->x_flag_pic == -1)
785 opts->x_flag_pie = DEFAULT_FLAG_PIE;
786 else
787 opts->x_flag_pie = 0;
789 /* If -fPIE or -fpie is used, turn on PIC. */
790 if (opts->x_flag_pie)
791 opts->x_flag_pic = opts->x_flag_pie;
792 else if (opts->x_flag_pic == -1)
793 opts->x_flag_pic = 0;
794 if (opts->x_flag_pic && !opts->x_flag_pie)
795 opts->x_flag_shlib = 1;
796 opts->x_flag_opts_finished = true;
799 /* We initialize opts->x_flag_stack_protect to -1 so that targets
800 can set a default value. */
801 if (opts->x_flag_stack_protect == -1)
802 opts->x_flag_stack_protect = DEFAULT_FLAG_SSP;
804 if (opts->x_optimize == 0)
806 /* Inlining does not work if not optimizing,
807 so force it not to be done. */
808 opts->x_warn_inline = 0;
809 opts->x_flag_no_inline = 1;
812 /* The optimization to partition hot and cold basic blocks into separate
813 sections of the .o and executable files does not work (currently)
814 with exception handling. This is because there is no support for
815 generating unwind info. If opts->x_flag_exceptions is turned on
816 we need to turn off the partitioning optimization. */
818 ui_except = targetm_common.except_unwind_info (opts);
820 if (opts->x_flag_exceptions
821 && opts->x_flag_reorder_blocks_and_partition
822 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
824 if (opts_set->x_flag_reorder_blocks_and_partition)
825 inform (loc,
826 "-freorder-blocks-and-partition does not work "
827 "with exceptions on this architecture");
828 opts->x_flag_reorder_blocks_and_partition = 0;
829 opts->x_flag_reorder_blocks = 1;
832 /* If user requested unwind info, then turn off the partitioning
833 optimization. */
835 if (opts->x_flag_unwind_tables
836 && !targetm_common.unwind_tables_default
837 && opts->x_flag_reorder_blocks_and_partition
838 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
840 if (opts_set->x_flag_reorder_blocks_and_partition)
841 inform (loc,
842 "-freorder-blocks-and-partition does not support "
843 "unwind info on this architecture");
844 opts->x_flag_reorder_blocks_and_partition = 0;
845 opts->x_flag_reorder_blocks = 1;
848 /* If the target requested unwind info, then turn off the partitioning
849 optimization with a different message. Likewise, if the target does not
850 support named sections. */
852 if (opts->x_flag_reorder_blocks_and_partition
853 && (!targetm_common.have_named_sections
854 || (opts->x_flag_unwind_tables
855 && targetm_common.unwind_tables_default
856 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
858 if (opts_set->x_flag_reorder_blocks_and_partition)
859 inform (loc,
860 "-freorder-blocks-and-partition does not work "
861 "on this architecture");
862 opts->x_flag_reorder_blocks_and_partition = 0;
863 opts->x_flag_reorder_blocks = 1;
866 /* Disable -freorder-blocks-and-partition when -fprofile-use is not in
867 effect. Function splitting was not actually being performed in that case,
868 as probably_never_executed_bb_p does not distinguish any basic blocks as
869 being cold vs hot when there is no profile data. Leaving it enabled,
870 however, causes the assembly code generator to create (empty) cold
871 sections and labels, leading to unnecessary size overhead. */
872 if (opts->x_flag_reorder_blocks_and_partition
873 && !opts_set->x_flag_profile_use)
874 opts->x_flag_reorder_blocks_and_partition = 0;
876 if (opts->x_flag_reorder_blocks_and_partition
877 && !opts_set->x_flag_reorder_functions)
878 opts->x_flag_reorder_functions = 1;
880 /* Pipelining of outer loops is only possible when general pipelining
881 capabilities are requested. */
882 if (!opts->x_flag_sel_sched_pipelining)
883 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
885 if (opts->x_flag_conserve_stack)
887 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
888 opts->x_param_values, opts_set->x_param_values);
889 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
890 opts->x_param_values, opts_set->x_param_values);
893 if (opts->x_flag_lto)
895 #ifdef ENABLE_LTO
896 opts->x_flag_generate_lto = 1;
898 /* When generating IL, do not operate in whole-program mode.
899 Otherwise, symbols will be privatized too early, causing link
900 errors later. */
901 opts->x_flag_whole_program = 0;
902 #else
903 error_at (loc, "LTO support has not been enabled in this configuration");
904 #endif
905 if (!opts->x_flag_fat_lto_objects
906 && (!HAVE_LTO_PLUGIN
907 || (opts_set->x_flag_use_linker_plugin
908 && !opts->x_flag_use_linker_plugin)))
910 if (opts_set->x_flag_fat_lto_objects)
911 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin");
912 opts->x_flag_fat_lto_objects = 1;
916 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
917 default value if they choose based on other options. */
918 if (opts->x_flag_split_stack == -1)
919 opts->x_flag_split_stack = 0;
920 else if (opts->x_flag_split_stack)
922 if (!targetm_common.supports_split_stack (true, opts))
924 error_at (loc, "%<-fsplit-stack%> is not supported by "
925 "this compiler configuration");
926 opts->x_flag_split_stack = 0;
930 /* Tune vectorization related parametees according to cost model. */
931 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
933 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
934 6, opts->x_param_values, opts_set->x_param_values);
935 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
936 0, opts->x_param_values, opts_set->x_param_values);
937 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
938 0, opts->x_param_values, opts_set->x_param_values);
941 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
942 is disabled. */
943 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
944 || !opts->x_flag_tree_loop_if_convert)
945 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
946 opts->x_param_values, opts_set->x_param_values);
948 /* The -gsplit-dwarf option requires -ggnu-pubnames. */
949 if (opts->x_dwarf_split_debug_info)
950 opts->x_debug_generate_pub_sections = 2;
952 /* Userspace and kernel ASan conflict with each other. */
953 if ((opts->x_flag_sanitize & SANITIZE_USER_ADDRESS)
954 && (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS))
955 error_at (loc,
956 "-fsanitize=address is incompatible with "
957 "-fsanitize=kernel-address");
959 /* And with TSan. */
960 if ((opts->x_flag_sanitize & SANITIZE_ADDRESS)
961 && (opts->x_flag_sanitize & SANITIZE_THREAD))
962 error_at (loc,
963 "-fsanitize=address and -fsanitize=kernel-address "
964 "are incompatible with -fsanitize=thread");
966 if ((opts->x_flag_sanitize & SANITIZE_LEAK)
967 && (opts->x_flag_sanitize & SANITIZE_THREAD))
968 error_at (loc,
969 "-fsanitize=leak is incompatible with -fsanitize=thread");
971 /* Check error recovery for -fsanitize-recover option. */
972 for (int i = 0; sanitizer_opts[i].name != NULL; ++i)
973 if ((opts->x_flag_sanitize_recover & sanitizer_opts[i].flag)
974 && !sanitizer_opts[i].can_recover)
975 error_at (loc, "-fsanitize-recover=%s is not supported",
976 sanitizer_opts[i].name);
978 /* When instrumenting the pointers, we don't want to remove
979 the null pointer checks. */
980 if (opts->x_flag_sanitize & (SANITIZE_NULL | SANITIZE_NONNULL_ATTRIBUTE
981 | SANITIZE_RETURNS_NONNULL_ATTRIBUTE))
982 opts->x_flag_delete_null_pointer_checks = 0;
984 /* Aggressive compiler optimizations may cause false negatives. */
985 if (opts->x_flag_sanitize & ~(SANITIZE_LEAK | SANITIZE_UNREACHABLE))
986 opts->x_flag_aggressive_loop_optimizations = 0;
988 /* Enable -fsanitize-address-use-after-scope if address sanitizer is
989 enabled. */
990 if ((opts->x_flag_sanitize & SANITIZE_USER_ADDRESS)
991 && !opts_set->x_flag_sanitize_address_use_after_scope)
992 opts->x_flag_sanitize_address_use_after_scope = true;
994 /* Force -fstack-reuse=none in case -fsanitize-address-use-after-scope
995 is enabled. */
996 if (opts->x_flag_sanitize_address_use_after_scope)
998 if (opts->x_flag_stack_reuse != SR_NONE
999 && opts_set->x_flag_stack_reuse != SR_NONE)
1000 error_at (loc,
1001 "-fsanitize-address-use-after-scope requires "
1002 "-fstack-reuse=none option");
1004 opts->x_flag_stack_reuse = SR_NONE;
1008 #define LEFT_COLUMN 27
1010 /* Output ITEM, of length ITEM_WIDTH, in the left column,
1011 followed by word-wrapped HELP in a second column. */
1012 static void
1013 wrap_help (const char *help,
1014 const char *item,
1015 unsigned int item_width,
1016 unsigned int columns)
1018 unsigned int col_width = LEFT_COLUMN;
1019 unsigned int remaining, room, len;
1021 remaining = strlen (help);
1025 room = columns - 3 - MAX (col_width, item_width);
1026 if (room > columns)
1027 room = 0;
1028 len = remaining;
1030 if (room < len)
1032 unsigned int i;
1034 for (i = 0; help[i]; i++)
1036 if (i >= room && len != remaining)
1037 break;
1038 if (help[i] == ' ')
1039 len = i;
1040 else if ((help[i] == '-' || help[i] == '/')
1041 && help[i + 1] != ' '
1042 && i > 0 && ISALPHA (help[i - 1]))
1043 len = i + 1;
1047 printf (" %-*.*s %.*s\n", col_width, item_width, item, len, help);
1048 item_width = 0;
1049 while (help[len] == ' ')
1050 len++;
1051 help += len;
1052 remaining -= len;
1054 while (remaining);
1057 /* Print help for a specific front-end, etc. */
1058 static void
1059 print_filtered_help (unsigned int include_flags,
1060 unsigned int exclude_flags,
1061 unsigned int any_flags,
1062 unsigned int columns,
1063 struct gcc_options *opts,
1064 unsigned int lang_mask)
1066 unsigned int i;
1067 const char *help;
1068 bool found = false;
1069 bool displayed = false;
1070 char new_help[256];
1072 if (include_flags == CL_PARAMS)
1074 for (i = 0; i < LAST_PARAM; i++)
1076 const char *param = compiler_params[i].option;
1078 help = compiler_params[i].help;
1079 if (help == NULL || *help == '\0')
1081 if (exclude_flags & CL_UNDOCUMENTED)
1082 continue;
1083 help = undocumented_msg;
1086 /* Get the translation. */
1087 help = _(help);
1089 if (!opts->x_quiet_flag)
1091 snprintf (new_help, sizeof (new_help),
1092 _("default %d minimum %d maximum %d"),
1093 compiler_params[i].default_value,
1094 compiler_params[i].min_value,
1095 compiler_params[i].max_value);
1096 help = new_help;
1098 wrap_help (help, param, strlen (param), columns);
1100 putchar ('\n');
1101 return;
1104 if (!opts->x_help_printed)
1105 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
1107 if (!opts->x_help_enum_printed)
1108 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
1110 for (i = 0; i < cl_options_count; i++)
1112 const struct cl_option *option = cl_options + i;
1113 unsigned int len;
1114 const char *opt;
1115 const char *tab;
1117 if (include_flags == 0
1118 || ((option->flags & include_flags) != include_flags))
1120 if ((option->flags & any_flags) == 0)
1121 continue;
1124 /* Skip unwanted switches. */
1125 if ((option->flags & exclude_flags) != 0)
1126 continue;
1128 /* The driver currently prints its own help text. */
1129 if ((option->flags & CL_DRIVER) != 0
1130 && (option->flags & (((1U << cl_lang_count) - 1)
1131 | CL_COMMON | CL_TARGET)) == 0)
1132 continue;
1134 found = true;
1135 /* Skip switches that have already been printed. */
1136 if (opts->x_help_printed[i])
1137 continue;
1139 opts->x_help_printed[i] = true;
1141 help = option->help;
1142 if (help == NULL)
1144 if (exclude_flags & CL_UNDOCUMENTED)
1145 continue;
1147 help = undocumented_msg;
1150 if (option->alias_target < N_OPTS
1151 && cl_options [option->alias_target].help)
1153 if (help == undocumented_msg)
1155 /* For undocumented options that are aliases for other options
1156 that are documented, point the reader to the other option in
1157 preference of the former. */
1158 snprintf (new_help, sizeof new_help,
1159 _("Same as %s. Use the latter option instead."),
1160 cl_options [option->alias_target].opt_text);
1162 else
1164 /* For documented options with aliases, mention the aliased
1165 option's name for reference. */
1166 snprintf (new_help, sizeof new_help,
1167 _("%s Same as %s."),
1168 help, cl_options [option->alias_target].opt_text);
1171 help = new_help;
1174 if (option->warn_message)
1176 /* Mention that the use of the option will trigger a warning. */
1177 if (help == new_help)
1178 snprintf (new_help + strlen (new_help),
1179 sizeof new_help - strlen (new_help),
1180 " %s", _(use_diagnosed_msg));
1181 else
1182 snprintf (new_help, sizeof new_help,
1183 "%s %s", help, _(use_diagnosed_msg));
1185 help = new_help;
1188 /* Get the translation. */
1189 help = _(help);
1191 /* Find the gap between the name of the
1192 option and its descriptive text. */
1193 tab = strchr (help, '\t');
1194 if (tab)
1196 len = tab - help;
1197 opt = help;
1198 help = tab + 1;
1200 else
1202 opt = option->opt_text;
1203 len = strlen (opt);
1206 /* With the -Q option enabled we change the descriptive text associated
1207 with an option to be an indication of its current setting. */
1208 if (!opts->x_quiet_flag)
1210 void *flag_var = option_flag_var (i, opts);
1212 if (len < (LEFT_COLUMN + 2))
1213 strcpy (new_help, "\t\t");
1214 else
1215 strcpy (new_help, "\t");
1217 if (flag_var != NULL
1218 && option->var_type != CLVC_DEFER)
1220 if (option->flags & CL_JOINED)
1222 if (option->var_type == CLVC_STRING)
1224 if (* (const char **) flag_var != NULL)
1225 snprintf (new_help + strlen (new_help),
1226 sizeof (new_help) - strlen (new_help),
1227 "%s", * (const char **) flag_var);
1229 else if (option->var_type == CLVC_ENUM)
1231 const struct cl_enum *e = &cl_enums[option->var_enum];
1232 int value;
1233 const char *arg = NULL;
1235 value = e->get (flag_var);
1236 enum_value_to_arg (e->values, &arg, value, lang_mask);
1237 if (arg == NULL)
1238 arg = _("[default]");
1239 snprintf (new_help + strlen (new_help),
1240 sizeof (new_help) - strlen (new_help),
1241 "%s", arg);
1243 else
1244 sprintf (new_help + strlen (new_help),
1245 "%d", * (int *) flag_var);
1247 else
1248 strcat (new_help, option_enabled (i, opts)
1249 ? _("[enabled]") : _("[disabled]"));
1252 help = new_help;
1255 wrap_help (help, opt, len, columns);
1256 displayed = true;
1258 if (option->var_type == CLVC_ENUM
1259 && opts->x_help_enum_printed[option->var_enum] != 2)
1260 opts->x_help_enum_printed[option->var_enum] = 1;
1263 if (! found)
1265 unsigned int langs = include_flags & CL_LANG_ALL;
1267 if (langs == 0)
1268 printf (_(" No options with the desired characteristics were found\n"));
1269 else
1271 unsigned int i;
1273 /* PR 31349: Tell the user how to see all of the
1274 options supported by a specific front end. */
1275 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1276 if ((1U << i) & langs)
1277 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end.\n"),
1278 lang_names[i], lang_names[i]);
1282 else if (! displayed)
1283 printf (_(" All options with the desired characteristics have already been displayed\n"));
1285 putchar ('\n');
1287 /* Print details of enumerated option arguments, if those
1288 enumerations have help text headings provided. If no help text
1289 is provided, presume that the possible values are listed in the
1290 help text for the relevant options. */
1291 for (i = 0; i < cl_enums_count; i++)
1293 unsigned int j, pos;
1295 if (opts->x_help_enum_printed[i] != 1)
1296 continue;
1297 if (cl_enums[i].help == NULL)
1298 continue;
1299 printf (" %s\n ", _(cl_enums[i].help));
1300 pos = 4;
1301 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1303 unsigned int len = strlen (cl_enums[i].values[j].arg);
1305 if (pos > 4 && pos + 1 + len <= columns)
1307 printf (" %s", cl_enums[i].values[j].arg);
1308 pos += 1 + len;
1310 else
1312 if (pos > 4)
1314 printf ("\n ");
1315 pos = 4;
1317 printf ("%s", cl_enums[i].values[j].arg);
1318 pos += len;
1321 printf ("\n\n");
1322 opts->x_help_enum_printed[i] = 2;
1326 /* Display help for a specified type of option.
1327 The options must have ALL of the INCLUDE_FLAGS set
1328 ANY of the flags in the ANY_FLAGS set
1329 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1330 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1331 static void
1332 print_specific_help (unsigned int include_flags,
1333 unsigned int exclude_flags,
1334 unsigned int any_flags,
1335 struct gcc_options *opts,
1336 unsigned int lang_mask)
1338 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1339 const char * description = NULL;
1340 const char * descrip_extra = "";
1341 size_t i;
1342 unsigned int flag;
1344 /* Sanity check: Make sure that we do not have more
1345 languages than we have bits available to enumerate them. */
1346 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1348 /* If we have not done so already, obtain
1349 the desired maximum width of the output. */
1350 if (opts->x_help_columns == 0)
1352 opts->x_help_columns = get_terminal_width ();
1353 if (opts->x_help_columns == INT_MAX)
1354 /* Use a reasonable default. */
1355 opts->x_help_columns = 80;
1358 /* Decide upon the title for the options that we are going to display. */
1359 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1361 switch (flag & include_flags)
1363 case 0:
1364 case CL_DRIVER:
1365 break;
1367 case CL_TARGET:
1368 description = _("The following options are target specific");
1369 break;
1370 case CL_WARNING:
1371 description = _("The following options control compiler warning messages");
1372 break;
1373 case CL_OPTIMIZATION:
1374 description = _("The following options control optimizations");
1375 break;
1376 case CL_COMMON:
1377 description = _("The following options are language-independent");
1378 break;
1379 case CL_PARAMS:
1380 description = _("The --param option recognizes the following as parameters");
1381 break;
1382 default:
1383 if (i >= cl_lang_count)
1384 break;
1385 if (exclude_flags & all_langs_mask)
1386 description = _("The following options are specific to just the language ");
1387 else
1388 description = _("The following options are supported by the language ");
1389 descrip_extra = lang_names [i];
1390 break;
1394 if (description == NULL)
1396 if (any_flags == 0)
1398 if (include_flags & CL_UNDOCUMENTED)
1399 description = _("The following options are not documented");
1400 else if (include_flags & CL_SEPARATE)
1401 description = _("The following options take separate arguments");
1402 else if (include_flags & CL_JOINED)
1403 description = _("The following options take joined arguments");
1404 else
1406 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1407 include_flags);
1408 return;
1411 else
1413 if (any_flags & all_langs_mask)
1414 description = _("The following options are language-related");
1415 else
1416 description = _("The following options are language-independent");
1420 printf ("%s%s:\n", description, descrip_extra);
1421 print_filtered_help (include_flags, exclude_flags, any_flags,
1422 opts->x_help_columns, opts, lang_mask);
1425 /* Enable FDO-related flags. */
1427 static void
1428 enable_fdo_optimizations (struct gcc_options *opts,
1429 struct gcc_options *opts_set,
1430 int value)
1432 if (!opts_set->x_flag_branch_probabilities)
1433 opts->x_flag_branch_probabilities = value;
1434 if (!opts_set->x_flag_profile_values)
1435 opts->x_flag_profile_values = value;
1436 if (!opts_set->x_flag_unroll_loops)
1437 opts->x_flag_unroll_loops = value;
1438 if (!opts_set->x_flag_peel_loops)
1439 opts->x_flag_peel_loops = value;
1440 if (!opts_set->x_flag_tracer)
1441 opts->x_flag_tracer = value;
1442 if (!opts_set->x_flag_value_profile_transformations)
1443 opts->x_flag_value_profile_transformations = value;
1444 if (!opts_set->x_flag_inline_functions)
1445 opts->x_flag_inline_functions = value;
1446 if (!opts_set->x_flag_ipa_cp)
1447 opts->x_flag_ipa_cp = value;
1448 if (!opts_set->x_flag_ipa_cp_clone
1449 && value && opts->x_flag_ipa_cp)
1450 opts->x_flag_ipa_cp_clone = value;
1451 if (!opts_set->x_flag_ipa_bit_cp
1452 && value && opts->x_flag_ipa_cp)
1453 opts->x_flag_ipa_bit_cp = value;
1454 if (!opts_set->x_flag_predictive_commoning)
1455 opts->x_flag_predictive_commoning = value;
1456 if (!opts_set->x_flag_split_loops)
1457 opts->x_flag_split_loops = value;
1458 if (!opts_set->x_flag_unswitch_loops)
1459 opts->x_flag_unswitch_loops = value;
1460 if (!opts_set->x_flag_gcse_after_reload)
1461 opts->x_flag_gcse_after_reload = value;
1462 if (!opts_set->x_flag_tree_loop_vectorize
1463 && !opts_set->x_flag_tree_vectorize)
1464 opts->x_flag_tree_loop_vectorize = value;
1465 if (!opts_set->x_flag_tree_slp_vectorize
1466 && !opts_set->x_flag_tree_vectorize)
1467 opts->x_flag_tree_slp_vectorize = value;
1468 if (!opts_set->x_flag_vect_cost_model)
1469 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1470 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1471 opts->x_flag_tree_loop_distribute_patterns = value;
1474 /* -f{,no-}sanitize{,-recover}= suboptions. */
1475 const struct sanitizer_opts_s sanitizer_opts[] =
1477 #define SANITIZER_OPT(name, flags, recover) \
1478 { #name, flags, sizeof #name - 1, recover }
1479 SANITIZER_OPT (address, (SANITIZE_ADDRESS | SANITIZE_USER_ADDRESS), true),
1480 SANITIZER_OPT (kernel-address, (SANITIZE_ADDRESS | SANITIZE_KERNEL_ADDRESS),
1481 true),
1482 SANITIZER_OPT (thread, SANITIZE_THREAD, false),
1483 SANITIZER_OPT (leak, SANITIZE_LEAK, false),
1484 SANITIZER_OPT (shift, SANITIZE_SHIFT, true),
1485 SANITIZER_OPT (shift-base, SANITIZE_SHIFT_BASE, true),
1486 SANITIZER_OPT (shift-exponent, SANITIZE_SHIFT_EXPONENT, true),
1487 SANITIZER_OPT (integer-divide-by-zero, SANITIZE_DIVIDE, true),
1488 SANITIZER_OPT (undefined, SANITIZE_UNDEFINED, true),
1489 SANITIZER_OPT (unreachable, SANITIZE_UNREACHABLE, false),
1490 SANITIZER_OPT (vla-bound, SANITIZE_VLA, true),
1491 SANITIZER_OPT (return, SANITIZE_RETURN, false),
1492 SANITIZER_OPT (null, SANITIZE_NULL, true),
1493 SANITIZER_OPT (signed-integer-overflow, SANITIZE_SI_OVERFLOW, true),
1494 SANITIZER_OPT (bool, SANITIZE_BOOL, true),
1495 SANITIZER_OPT (enum, SANITIZE_ENUM, true),
1496 SANITIZER_OPT (float-divide-by-zero, SANITIZE_FLOAT_DIVIDE, true),
1497 SANITIZER_OPT (float-cast-overflow, SANITIZE_FLOAT_CAST, true),
1498 SANITIZER_OPT (bounds, SANITIZE_BOUNDS, true),
1499 SANITIZER_OPT (bounds-strict, SANITIZE_BOUNDS | SANITIZE_BOUNDS_STRICT, true),
1500 SANITIZER_OPT (alignment, SANITIZE_ALIGNMENT, true),
1501 SANITIZER_OPT (nonnull-attribute, SANITIZE_NONNULL_ATTRIBUTE, true),
1502 SANITIZER_OPT (returns-nonnull-attribute, SANITIZE_RETURNS_NONNULL_ATTRIBUTE,
1503 true),
1504 SANITIZER_OPT (object-size, SANITIZE_OBJECT_SIZE, true),
1505 SANITIZER_OPT (vptr, SANITIZE_VPTR, true),
1506 SANITIZER_OPT (all, ~0U, true),
1507 #undef SANITIZER_OPT
1508 { NULL, 0U, 0UL, false }
1511 /* A struct for describing a run of chars within a string. */
1513 struct string_fragment
1515 string_fragment (const char *start, size_t len)
1516 : m_start (start), m_len (len) {}
1518 const char *m_start;
1519 size_t m_len;
1522 /* Specialization of edit_distance_traits for string_fragment,
1523 for use by get_closest_sanitizer_option. */
1525 template <>
1526 struct edit_distance_traits<const string_fragment &>
1528 static size_t get_length (const string_fragment &fragment)
1530 return fragment.m_len;
1533 static const char *get_string (const string_fragment &fragment)
1535 return fragment.m_start;
1539 /* Given ARG, an unrecognized sanitizer option, return the best
1540 matching sanitizer option, or NULL if there isn't one.
1541 CODE is OPT_fsanitize_ or OPT_fsanitize_recover_.
1542 VALUE is non-zero for the regular form of the option, zero
1543 for the "no-" form (e.g. "-fno-sanitize-recover="). */
1545 static const char *
1546 get_closest_sanitizer_option (const string_fragment &arg,
1547 enum opt_code code, int value)
1549 best_match <const string_fragment &, const char*> bm (arg);
1550 for (int i = 0; sanitizer_opts[i].name != NULL; ++i)
1552 /* -fsanitize=all is not valid, so don't offer it. */
1553 if (sanitizer_opts[i].flag == ~0U
1554 && code == OPT_fsanitize_
1555 && value)
1556 continue;
1558 /* For -fsanitize-recover= (and not -fno-sanitize-recover=),
1559 don't offer the non-recoverable options. */
1560 if (!sanitizer_opts[i].can_recover
1561 && code == OPT_fsanitize_recover_
1562 && value)
1563 continue;
1565 bm.consider (sanitizer_opts[i].name);
1567 return bm.get_best_meaningful_candidate ();
1570 /* Parse comma separated sanitizer suboptions from P for option SCODE,
1571 adjust previous FLAGS and return new ones. If COMPLAIN is false,
1572 don't issue diagnostics. */
1574 unsigned int
1575 parse_sanitizer_options (const char *p, location_t loc, int scode,
1576 unsigned int flags, int value, bool complain)
1578 enum opt_code code = (enum opt_code) scode;
1579 while (*p != 0)
1581 size_t len, i;
1582 bool found = false;
1583 const char *comma = strchr (p, ',');
1585 if (comma == NULL)
1586 len = strlen (p);
1587 else
1588 len = comma - p;
1589 if (len == 0)
1591 p = comma + 1;
1592 continue;
1595 /* Check to see if the string matches an option class name. */
1596 for (i = 0; sanitizer_opts[i].name != NULL; ++i)
1597 if (len == sanitizer_opts[i].len
1598 && memcmp (p, sanitizer_opts[i].name, len) == 0)
1600 /* Handle both -fsanitize and -fno-sanitize cases. */
1601 if (value && sanitizer_opts[i].flag == ~0U)
1603 if (code == OPT_fsanitize_)
1605 if (complain)
1606 error_at (loc, "-fsanitize=all option is not valid");
1608 else
1609 flags |= ~(SANITIZE_THREAD | SANITIZE_LEAK
1610 | SANITIZE_UNREACHABLE | SANITIZE_RETURN);
1612 else if (value)
1614 /* Do not enable -fsanitize-recover=unreachable and
1615 -fsanitize-recover=return if -fsanitize-recover=undefined
1616 is selected. */
1617 if (code == OPT_fsanitize_recover_
1618 && sanitizer_opts[i].flag == SANITIZE_UNDEFINED)
1619 flags |= (SANITIZE_UNDEFINED
1620 & ~(SANITIZE_UNREACHABLE | SANITIZE_RETURN));
1621 else
1622 flags |= sanitizer_opts[i].flag;
1624 else
1625 flags &= ~sanitizer_opts[i].flag;
1626 found = true;
1627 break;
1630 if (! found && complain)
1632 const char *hint
1633 = get_closest_sanitizer_option (string_fragment (p, len),
1634 code, value);
1636 if (hint)
1637 error_at (loc,
1638 "unrecognized argument to -f%ssanitize%s= option: %q.*s;"
1639 " did you mean %qs?",
1640 value ? "" : "no-",
1641 code == OPT_fsanitize_ ? "" : "-recover",
1642 (int) len, p, hint);
1643 else
1644 error_at (loc,
1645 "unrecognized argument to -f%ssanitize%s= option: %q.*s",
1646 value ? "" : "no-",
1647 code == OPT_fsanitize_ ? "" : "-recover",
1648 (int) len, p);
1651 if (comma == NULL)
1652 break;
1653 p = comma + 1;
1655 return flags;
1658 /* Handle target- and language-independent options. Return zero to
1659 generate an "unknown option" message. Only options that need
1660 extra handling need to be listed here; if you simply want
1661 DECODED->value assigned to a variable, it happens automatically. */
1663 bool
1664 common_handle_option (struct gcc_options *opts,
1665 struct gcc_options *opts_set,
1666 const struct cl_decoded_option *decoded,
1667 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1668 location_t loc,
1669 const struct cl_option_handlers *handlers,
1670 diagnostic_context *dc)
1672 size_t scode = decoded->opt_index;
1673 const char *arg = decoded->arg;
1674 int value = decoded->value;
1675 enum opt_code code = (enum opt_code) scode;
1677 gcc_assert (decoded->canonical_option_num_elements <= 2);
1679 switch (code)
1681 case OPT__param:
1682 handle_param (opts, opts_set, loc, arg);
1683 break;
1685 case OPT__help:
1687 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1688 unsigned int undoc_mask;
1689 unsigned int i;
1691 if (lang_mask == CL_DRIVER)
1692 break;
1694 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1696 : CL_UNDOCUMENTED);
1697 /* First display any single language specific options. */
1698 for (i = 0; i < cl_lang_count; i++)
1699 print_specific_help
1700 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1701 lang_mask);
1702 /* Next display any multi language specific options. */
1703 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1704 /* Then display any remaining, non-language options. */
1705 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1706 if (i != CL_DRIVER)
1707 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1708 opts->x_exit_after_options = true;
1709 break;
1712 case OPT__target_help:
1713 if (lang_mask == CL_DRIVER)
1714 break;
1716 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1717 opts->x_exit_after_options = true;
1718 break;
1720 case OPT__help_:
1722 const char *a = arg;
1723 unsigned int include_flags = 0;
1724 /* Note - by default we include undocumented options when listing
1725 specific classes. If you only want to see documented options
1726 then add ",^undocumented" to the --help= option. E.g.:
1728 --help=target,^undocumented */
1729 unsigned int exclude_flags = 0;
1731 if (lang_mask == CL_DRIVER)
1732 break;
1734 /* Walk along the argument string, parsing each word in turn.
1735 The format is:
1736 arg = [^]{word}[,{arg}]
1737 word = {optimizers|target|warnings|undocumented|
1738 params|common|<language>} */
1739 while (*a != 0)
1741 static const struct
1743 const char *string;
1744 unsigned int flag;
1746 specifics[] =
1748 { "optimizers", CL_OPTIMIZATION },
1749 { "target", CL_TARGET },
1750 { "warnings", CL_WARNING },
1751 { "undocumented", CL_UNDOCUMENTED },
1752 { "params", CL_PARAMS },
1753 { "joined", CL_JOINED },
1754 { "separate", CL_SEPARATE },
1755 { "common", CL_COMMON },
1756 { NULL, 0 }
1758 unsigned int *pflags;
1759 const char *comma;
1760 unsigned int lang_flag, specific_flag;
1761 unsigned int len;
1762 unsigned int i;
1764 if (*a == '^')
1766 ++a;
1767 if (*a == '\0')
1769 error_at (loc, "missing argument to %qs", "--help=^");
1770 break;
1772 pflags = &exclude_flags;
1774 else
1775 pflags = &include_flags;
1777 comma = strchr (a, ',');
1778 if (comma == NULL)
1779 len = strlen (a);
1780 else
1781 len = comma - a;
1782 if (len == 0)
1784 a = comma + 1;
1785 continue;
1788 /* Check to see if the string matches an option class name. */
1789 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1790 if (strncasecmp (a, specifics[i].string, len) == 0)
1792 specific_flag = specifics[i].flag;
1793 break;
1796 /* Check to see if the string matches a language name.
1797 Note - we rely upon the alpha-sorted nature of the entries in
1798 the lang_names array, specifically that shorter names appear
1799 before their longer variants. (i.e. C before C++). That way
1800 when we are attempting to match --help=c for example we will
1801 match with C first and not C++. */
1802 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1803 if (strncasecmp (a, lang_names[i], len) == 0)
1805 lang_flag = 1U << i;
1806 break;
1809 if (specific_flag != 0)
1811 if (lang_flag == 0)
1812 *pflags |= specific_flag;
1813 else
1815 /* The option's argument matches both the start of a
1816 language name and the start of an option class name.
1817 We have a special case for when the user has
1818 specified "--help=c", but otherwise we have to issue
1819 a warning. */
1820 if (strncasecmp (a, "c", len) == 0)
1821 *pflags |= lang_flag;
1822 else
1823 warning_at (loc, 0,
1824 "--help argument %q.*s is ambiguous, "
1825 "please be more specific",
1826 len, a);
1829 else if (lang_flag != 0)
1830 *pflags |= lang_flag;
1831 else
1832 warning_at (loc, 0,
1833 "unrecognized argument to --help= option: %q.*s",
1834 len, a);
1836 if (comma == NULL)
1837 break;
1838 a = comma + 1;
1841 if (include_flags)
1842 print_specific_help (include_flags, exclude_flags, 0, opts,
1843 lang_mask);
1844 opts->x_exit_after_options = true;
1845 break;
1848 case OPT__version:
1849 if (lang_mask == CL_DRIVER)
1850 break;
1852 opts->x_exit_after_options = true;
1853 break;
1855 case OPT_fsanitize_:
1856 opts->x_flag_sanitize
1857 = parse_sanitizer_options (arg, loc, code,
1858 opts->x_flag_sanitize, value, true);
1860 /* Kernel ASan implies normal ASan but does not yet support
1861 all features. */
1862 if (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS)
1864 maybe_set_param_value (PARAM_ASAN_INSTRUMENTATION_WITH_CALL_THRESHOLD,
1865 0, opts->x_param_values,
1866 opts_set->x_param_values);
1867 maybe_set_param_value (PARAM_ASAN_GLOBALS, 0, opts->x_param_values,
1868 opts_set->x_param_values);
1869 maybe_set_param_value (PARAM_ASAN_STACK, 0, opts->x_param_values,
1870 opts_set->x_param_values);
1871 maybe_set_param_value (PARAM_ASAN_USE_AFTER_RETURN, 0,
1872 opts->x_param_values,
1873 opts_set->x_param_values);
1875 break;
1877 case OPT_fsanitize_recover_:
1878 opts->x_flag_sanitize_recover
1879 = parse_sanitizer_options (arg, loc, code,
1880 opts->x_flag_sanitize_recover, value, true);
1881 break;
1883 case OPT_fasan_shadow_offset_:
1884 /* Deferred. */
1885 break;
1887 case OPT_fsanitize_address_use_after_scope:
1888 opts->x_flag_sanitize_address_use_after_scope = value;
1889 break;
1891 case OPT_fsanitize_recover:
1892 if (value)
1893 opts->x_flag_sanitize_recover
1894 |= (SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT)
1895 & ~(SANITIZE_UNREACHABLE | SANITIZE_RETURN);
1896 else
1897 opts->x_flag_sanitize_recover
1898 &= ~(SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT);
1899 break;
1901 case OPT_O:
1902 case OPT_Os:
1903 case OPT_Ofast:
1904 case OPT_Og:
1905 /* Currently handled in a prescan. */
1906 break;
1908 case OPT_Werror:
1909 dc->warning_as_error_requested = value;
1910 break;
1912 case OPT_Werror_:
1913 if (lang_mask == CL_DRIVER)
1914 break;
1916 enable_warning_as_error (arg, value, lang_mask, handlers,
1917 opts, opts_set, loc, dc);
1918 break;
1920 case OPT_Wlarger_than_:
1921 opts->x_larger_than_size = value;
1922 opts->x_warn_larger_than = value != -1;
1923 break;
1925 case OPT_Wfatal_errors:
1926 dc->fatal_errors = value;
1927 break;
1929 case OPT_Wframe_larger_than_:
1930 opts->x_frame_larger_than_size = value;
1931 opts->x_warn_frame_larger_than = value != -1;
1932 break;
1934 case OPT_Wstack_usage_:
1935 opts->x_warn_stack_usage = value;
1936 opts->x_flag_stack_usage_info = value != -1;
1937 break;
1939 case OPT_Wstrict_aliasing:
1940 set_Wstrict_aliasing (opts, value);
1941 break;
1943 case OPT_Wstrict_overflow:
1944 opts->x_warn_strict_overflow = (value
1945 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1946 : 0);
1947 break;
1949 case OPT_Wsystem_headers:
1950 dc->dc_warn_system_headers = value;
1951 break;
1953 case OPT_aux_info:
1954 opts->x_flag_gen_aux_info = 1;
1955 break;
1957 case OPT_auxbase_strip:
1959 char *tmp = xstrdup (arg);
1960 strip_off_ending (tmp, strlen (tmp));
1961 if (tmp[0])
1962 opts->x_aux_base_name = tmp;
1963 else
1964 free (tmp);
1966 break;
1968 case OPT_d:
1969 decode_d_option (arg, opts, loc, dc);
1970 break;
1972 case OPT_fcall_used_:
1973 case OPT_fcall_saved_:
1974 /* Deferred. */
1975 break;
1977 case OPT_fdbg_cnt_:
1978 /* Deferred. */
1979 break;
1981 case OPT_fdbg_cnt_list:
1982 /* Deferred. */
1983 opts->x_exit_after_options = true;
1984 break;
1986 case OPT_fdebug_prefix_map_:
1987 /* Deferred. */
1988 break;
1990 case OPT_fdiagnostics_show_location_:
1991 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1992 break;
1994 case OPT_fdiagnostics_show_caret:
1995 dc->show_caret = value;
1996 break;
1998 case OPT_fdiagnostics_color_:
1999 diagnostic_color_init (dc, value);
2000 break;
2002 case OPT_fdiagnostics_parseable_fixits:
2003 dc->parseable_fixits_p = value;
2004 break;
2006 case OPT_fdiagnostics_show_option:
2007 dc->show_option_requested = value;
2008 break;
2010 case OPT_fdump_:
2011 /* Deferred. */
2012 break;
2014 case OPT_ffast_math:
2015 set_fast_math_flags (opts, value);
2016 break;
2018 case OPT_funsafe_math_optimizations:
2019 set_unsafe_math_optimizations_flags (opts, value);
2020 break;
2022 case OPT_ffixed_:
2023 /* Deferred. */
2024 break;
2026 case OPT_finline_limit_:
2027 set_param_value ("max-inline-insns-single", value / 2,
2028 opts->x_param_values, opts_set->x_param_values);
2029 set_param_value ("max-inline-insns-auto", value / 2,
2030 opts->x_param_values, opts_set->x_param_values);
2031 break;
2033 case OPT_finstrument_functions_exclude_function_list_:
2034 add_comma_separated_to_vector
2035 (&opts->x_flag_instrument_functions_exclude_functions, arg);
2036 break;
2038 case OPT_finstrument_functions_exclude_file_list_:
2039 add_comma_separated_to_vector
2040 (&opts->x_flag_instrument_functions_exclude_files, arg);
2041 break;
2043 case OPT_fmessage_length_:
2044 pp_set_line_maximum_length (dc->printer, value);
2045 diagnostic_set_caret_max_width (dc, value);
2046 break;
2048 case OPT_fopt_info:
2049 case OPT_fopt_info_:
2050 /* Deferred. */
2051 break;
2053 case OPT_foffload_:
2055 const char *p = arg;
2056 opts->x_flag_disable_hsa = true;
2057 while (*p != 0)
2059 const char *comma = strchr (p, ',');
2061 if ((strncmp (p, "disable", 7) == 0)
2062 && (p[7] == ',' || p[7] == '\0'))
2064 opts->x_flag_disable_hsa = true;
2065 break;
2068 if ((strncmp (p, "hsa", 3) == 0)
2069 && (p[3] == ',' || p[3] == '\0'))
2071 #ifdef ENABLE_HSA
2072 opts->x_flag_disable_hsa = false;
2073 #else
2074 sorry ("HSA has not been enabled during configuration");
2075 #endif
2077 if (!comma)
2078 break;
2079 p = comma + 1;
2081 break;
2084 #ifndef ACCEL_COMPILER
2085 case OPT_foffload_abi_:
2086 error_at (loc, "-foffload-abi option can be specified only for "
2087 "offload compiler");
2088 break;
2089 #endif
2091 case OPT_fpack_struct_:
2092 if (value <= 0 || (value & (value - 1)) || value > 16)
2093 error_at (loc,
2094 "structure alignment must be a small power of two, not %d",
2095 value);
2096 else
2097 opts->x_initial_max_fld_align = value;
2098 break;
2100 case OPT_fplugin_:
2101 case OPT_fplugin_arg_:
2102 /* Deferred. */
2103 break;
2105 case OPT_fprofile_use_:
2106 opts->x_profile_data_prefix = xstrdup (arg);
2107 opts->x_flag_profile_use = true;
2108 value = true;
2109 /* No break here - do -fprofile-use processing. */
2110 /* FALLTHRU */
2111 case OPT_fprofile_use:
2112 enable_fdo_optimizations (opts, opts_set, value);
2113 if (!opts_set->x_flag_profile_reorder_functions)
2114 opts->x_flag_profile_reorder_functions = value;
2115 /* Indirect call profiling should do all useful transformations
2116 speculative devirtualization does. */
2117 if (!opts_set->x_flag_devirtualize_speculatively
2118 && opts->x_flag_value_profile_transformations)
2119 opts->x_flag_devirtualize_speculatively = false;
2120 break;
2122 case OPT_fauto_profile_:
2123 opts->x_auto_profile_file = xstrdup (arg);
2124 opts->x_flag_auto_profile = true;
2125 value = true;
2126 /* No break here - do -fauto-profile processing. */
2127 /* FALLTHRU */
2128 case OPT_fauto_profile:
2129 enable_fdo_optimizations (opts, opts_set, value);
2130 if (!opts_set->x_flag_profile_correction)
2131 opts->x_flag_profile_correction = value;
2132 maybe_set_param_value (
2133 PARAM_EARLY_INLINER_MAX_ITERATIONS, 10,
2134 opts->x_param_values, opts_set->x_param_values);
2135 break;
2137 case OPT_fprofile_generate_:
2138 opts->x_profile_data_prefix = xstrdup (arg);
2139 value = true;
2140 /* No break here - do -fprofile-generate processing. */
2141 /* FALLTHRU */
2142 case OPT_fprofile_generate:
2143 if (!opts_set->x_profile_arc_flag)
2144 opts->x_profile_arc_flag = value;
2145 if (!opts_set->x_flag_profile_values)
2146 opts->x_flag_profile_values = value;
2147 if (!opts_set->x_flag_inline_functions)
2148 opts->x_flag_inline_functions = value;
2149 if (!opts_set->x_flag_ipa_bit_cp)
2150 opts->x_flag_ipa_bit_cp = value;
2151 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
2152 quadratic. Disable the pass until better memory representation
2153 is done. */
2154 if (!opts_set->x_flag_ipa_reference)
2155 opts->x_flag_ipa_reference = false;
2156 break;
2158 case OPT_ftree_vectorize:
2159 if (!opts_set->x_flag_tree_loop_vectorize)
2160 opts->x_flag_tree_loop_vectorize = value;
2161 if (!opts_set->x_flag_tree_slp_vectorize)
2162 opts->x_flag_tree_slp_vectorize = value;
2163 break;
2164 case OPT_fshow_column:
2165 dc->show_column = value;
2166 break;
2168 case OPT_frandom_seed:
2169 /* The real switch is -fno-random-seed. */
2170 if (value)
2171 return false;
2172 /* Deferred. */
2173 break;
2175 case OPT_frandom_seed_:
2176 /* Deferred. */
2177 break;
2179 case OPT_fsched_verbose_:
2180 #ifdef INSN_SCHEDULING
2181 /* Handled with Var in common.opt. */
2182 break;
2183 #else
2184 return false;
2185 #endif
2187 case OPT_fsched_stalled_insns_:
2188 opts->x_flag_sched_stalled_insns = value;
2189 if (opts->x_flag_sched_stalled_insns == 0)
2190 opts->x_flag_sched_stalled_insns = -1;
2191 break;
2193 case OPT_fsched_stalled_insns_dep_:
2194 opts->x_flag_sched_stalled_insns_dep = value;
2195 break;
2197 case OPT_fstack_check_:
2198 if (!strcmp (arg, "no"))
2199 opts->x_flag_stack_check = NO_STACK_CHECK;
2200 else if (!strcmp (arg, "generic"))
2201 /* This is the old stack checking method. */
2202 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2203 ? FULL_BUILTIN_STACK_CHECK
2204 : GENERIC_STACK_CHECK;
2205 else if (!strcmp (arg, "specific"))
2206 /* This is the new stack checking method. */
2207 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2208 ? FULL_BUILTIN_STACK_CHECK
2209 : STACK_CHECK_STATIC_BUILTIN
2210 ? STATIC_BUILTIN_STACK_CHECK
2211 : GENERIC_STACK_CHECK;
2212 else
2213 warning_at (loc, 0, "unknown stack check parameter %qs", arg);
2214 break;
2216 case OPT_fstack_limit:
2217 /* The real switch is -fno-stack-limit. */
2218 if (value)
2219 return false;
2220 /* Deferred. */
2221 break;
2223 case OPT_fstack_limit_register_:
2224 case OPT_fstack_limit_symbol_:
2225 /* Deferred. */
2226 break;
2228 case OPT_fstack_usage:
2229 opts->x_flag_stack_usage = value;
2230 opts->x_flag_stack_usage_info = value != 0;
2231 break;
2233 case OPT_g:
2234 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
2235 loc);
2236 break;
2238 case OPT_gcoff:
2239 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
2240 break;
2242 case OPT_gdwarf:
2243 if (arg && strlen (arg) != 0)
2245 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
2246 "use %<-gdwarf-%s%> for DWARF version "
2247 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
2248 break;
2250 else
2251 value = opts->x_dwarf_version;
2253 /* FALLTHRU */
2254 case OPT_gdwarf_:
2255 if (value < 2 || value > 5)
2256 error_at (loc, "dwarf version %d is not supported", value);
2257 else
2258 opts->x_dwarf_version = value;
2259 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
2260 break;
2262 case OPT_gsplit_dwarf:
2263 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
2264 loc);
2265 break;
2267 case OPT_ggdb:
2268 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
2269 break;
2271 case OPT_gstabs:
2272 case OPT_gstabs_:
2273 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
2274 loc);
2275 break;
2277 case OPT_gvms:
2278 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
2279 break;
2281 case OPT_gxcoff:
2282 case OPT_gxcoff_:
2283 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
2284 loc);
2285 break;
2287 case OPT_gz:
2288 case OPT_gz_:
2289 /* Handled completely via specs. */
2290 break;
2292 case OPT_pedantic_errors:
2293 dc->pedantic_errors = 1;
2294 control_warning_option (OPT_Wpedantic, DK_ERROR, NULL, value,
2295 loc, lang_mask,
2296 handlers, opts, opts_set,
2297 dc);
2298 break;
2300 case OPT_flto:
2301 opts->x_flag_lto = value ? "" : NULL;
2302 break;
2304 case OPT_w:
2305 dc->dc_inhibit_warnings = true;
2306 break;
2308 case OPT_fmax_errors_:
2309 dc->max_errors = value;
2310 break;
2312 case OPT_fuse_ld_bfd:
2313 case OPT_fuse_ld_gold:
2314 case OPT_fuse_linker_plugin:
2315 /* No-op. Used by the driver and passed to us because it starts with f.*/
2316 break;
2318 case OPT_fwrapv:
2319 if (value)
2320 opts->x_flag_trapv = 0;
2321 break;
2323 case OPT_ftrapv:
2324 if (value)
2325 opts->x_flag_wrapv = 0;
2326 break;
2328 case OPT_fipa_icf:
2329 opts->x_flag_ipa_icf_functions = value;
2330 opts->x_flag_ipa_icf_variables = value;
2331 break;
2333 default:
2334 /* If the flag was handled in a standard way, assume the lack of
2335 processing here is intentional. */
2336 gcc_assert (option_flag_var (scode, opts));
2337 break;
2340 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
2341 loc, handlers, dc);
2342 return true;
2345 /* Handle --param NAME=VALUE. */
2346 static void
2347 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
2348 location_t loc, const char *carg)
2350 char *equal, *arg;
2351 int value;
2353 arg = xstrdup (carg);
2354 equal = strchr (arg, '=');
2355 if (!equal)
2356 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
2357 arg);
2358 else
2360 *equal = '\0';
2362 enum compiler_param index;
2363 if (!find_param (arg, &index))
2365 const char *suggestion = find_param_fuzzy (arg);
2366 if (suggestion)
2367 error_at (loc, "invalid --param name %qs; did you mean %qs?",
2368 arg, suggestion);
2369 else
2370 error_at (loc, "invalid --param name %qs", arg);
2372 else
2374 if (!param_string_value_p (index, equal + 1, &value))
2375 value = integral_argument (equal + 1);
2377 if (value == -1)
2378 error_at (loc, "invalid --param value %qs", equal + 1);
2379 else
2380 set_param_value (arg, value,
2381 opts->x_param_values, opts_set->x_param_values);
2385 free (arg);
2388 /* Used to set the level of strict aliasing warnings in OPTS,
2389 when no level is specified (i.e., when -Wstrict-aliasing, and not
2390 -Wstrict-aliasing=level was given).
2391 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
2392 and 0 otherwise. After calling this function, wstrict_aliasing will be
2393 set to the default value of -Wstrict_aliasing=level, currently 3. */
2394 static void
2395 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
2397 gcc_assert (onoff == 0 || onoff == 1);
2398 if (onoff != 0)
2399 opts->x_warn_strict_aliasing = 3;
2400 else
2401 opts->x_warn_strict_aliasing = 0;
2404 /* The following routines are useful in setting all the flags that
2405 -ffast-math and -fno-fast-math imply. */
2406 static void
2407 set_fast_math_flags (struct gcc_options *opts, int set)
2409 if (!opts->frontend_set_flag_unsafe_math_optimizations)
2411 opts->x_flag_unsafe_math_optimizations = set;
2412 set_unsafe_math_optimizations_flags (opts, set);
2414 if (!opts->frontend_set_flag_finite_math_only)
2415 opts->x_flag_finite_math_only = set;
2416 if (!opts->frontend_set_flag_errno_math)
2417 opts->x_flag_errno_math = !set;
2418 if (set)
2420 if (opts->frontend_set_flag_excess_precision_cmdline
2421 == EXCESS_PRECISION_DEFAULT)
2422 opts->x_flag_excess_precision_cmdline
2423 = set ? EXCESS_PRECISION_FAST : EXCESS_PRECISION_DEFAULT;
2424 if (!opts->frontend_set_flag_signaling_nans)
2425 opts->x_flag_signaling_nans = 0;
2426 if (!opts->frontend_set_flag_rounding_math)
2427 opts->x_flag_rounding_math = 0;
2428 if (!opts->frontend_set_flag_cx_limited_range)
2429 opts->x_flag_cx_limited_range = 1;
2433 /* When -funsafe-math-optimizations is set the following
2434 flags are set as well. */
2435 static void
2436 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
2438 if (!opts->frontend_set_flag_trapping_math)
2439 opts->x_flag_trapping_math = !set;
2440 if (!opts->frontend_set_flag_signed_zeros)
2441 opts->x_flag_signed_zeros = !set;
2442 if (!opts->frontend_set_flag_associative_math)
2443 opts->x_flag_associative_math = set;
2444 if (!opts->frontend_set_flag_reciprocal_math)
2445 opts->x_flag_reciprocal_math = set;
2448 /* Return true iff flags in OPTS are set as if -ffast-math. */
2449 bool
2450 fast_math_flags_set_p (const struct gcc_options *opts)
2452 return (!opts->x_flag_trapping_math
2453 && opts->x_flag_unsafe_math_optimizations
2454 && opts->x_flag_finite_math_only
2455 && !opts->x_flag_signed_zeros
2456 && !opts->x_flag_errno_math
2457 && opts->x_flag_excess_precision_cmdline
2458 == EXCESS_PRECISION_FAST);
2461 /* Return true iff flags are set as if -ffast-math but using the flags stored
2462 in the struct cl_optimization structure. */
2463 bool
2464 fast_math_flags_struct_set_p (struct cl_optimization *opt)
2466 return (!opt->x_flag_trapping_math
2467 && opt->x_flag_unsafe_math_optimizations
2468 && opt->x_flag_finite_math_only
2469 && !opt->x_flag_signed_zeros
2470 && !opt->x_flag_errno_math);
2473 /* Handle a debug output -g switch for options OPTS
2474 (OPTS_SET->x_write_symbols storing whether a debug type was passed
2475 explicitly), location LOC. EXTENDED is true or false to support
2476 extended output (2 is special and means "-ggdb" was given). */
2477 static void
2478 set_debug_level (enum debug_info_type type, int extended, const char *arg,
2479 struct gcc_options *opts, struct gcc_options *opts_set,
2480 location_t loc)
2482 opts->x_use_gnu_debug_info_extensions = extended;
2484 if (type == NO_DEBUG)
2486 if (opts->x_write_symbols == NO_DEBUG)
2488 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
2490 if (extended == 2)
2492 #if defined DWARF2_DEBUGGING_INFO || defined DWARF2_LINENO_DEBUGGING_INFO
2493 opts->x_write_symbols = DWARF2_DEBUG;
2494 #elif defined DBX_DEBUGGING_INFO
2495 opts->x_write_symbols = DBX_DEBUG;
2496 #endif
2499 if (opts->x_write_symbols == NO_DEBUG)
2500 warning_at (loc, 0, "target system does not support debug output");
2503 else
2505 /* Does it conflict with an already selected type? */
2506 if (opts_set->x_write_symbols != NO_DEBUG
2507 && opts->x_write_symbols != NO_DEBUG
2508 && type != opts->x_write_symbols)
2509 error_at (loc, "debug format %qs conflicts with prior selection",
2510 debug_type_names[type]);
2511 opts->x_write_symbols = type;
2512 opts_set->x_write_symbols = type;
2515 /* A debug flag without a level defaults to level 2.
2516 If off or at level 1, set it to level 2, but if already
2517 at level 3, don't lower it. */
2518 if (*arg == '\0')
2520 if (opts->x_debug_info_level < DINFO_LEVEL_NORMAL)
2521 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2523 else
2525 int argval = integral_argument (arg);
2526 if (argval == -1)
2527 error_at (loc, "unrecognized debug output level %qs", arg);
2528 else if (argval > 3)
2529 error_at (loc, "debug output level %qs is too high", arg);
2530 else
2531 opts->x_debug_info_level = (enum debug_info_levels) argval;
2535 /* Arrange to dump core on error for diagnostic context DC. (The
2536 regular error message is still printed first, except in the case of
2537 abort ().) */
2539 static void
2540 setup_core_dumping (diagnostic_context *dc)
2542 #ifdef SIGABRT
2543 signal (SIGABRT, SIG_DFL);
2544 #endif
2545 #if defined(HAVE_SETRLIMIT)
2547 struct rlimit rlim;
2548 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2549 fatal_error (input_location, "getting core file size maximum limit: %m");
2550 rlim.rlim_cur = rlim.rlim_max;
2551 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2552 fatal_error (input_location,
2553 "setting core file size limit to maximum: %m");
2555 #endif
2556 diagnostic_abort_on_error (dc);
2559 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2560 diagnostic context DC. */
2562 static void
2563 decode_d_option (const char *arg, struct gcc_options *opts,
2564 location_t loc, diagnostic_context *dc)
2566 int c;
2568 while (*arg)
2569 switch (c = *arg++)
2571 case 'A':
2572 opts->x_flag_debug_asm = 1;
2573 break;
2574 case 'p':
2575 opts->x_flag_print_asm_name = 1;
2576 break;
2577 case 'P':
2578 opts->x_flag_dump_rtl_in_asm = 1;
2579 opts->x_flag_print_asm_name = 1;
2580 break;
2581 case 'x':
2582 opts->x_rtl_dump_and_exit = 1;
2583 break;
2584 case 'D': /* These are handled by the preprocessor. */
2585 case 'I':
2586 case 'M':
2587 case 'N':
2588 case 'U':
2589 break;
2590 case 'H':
2591 setup_core_dumping (dc);
2592 break;
2593 case 'a':
2594 opts->x_flag_dump_all_passed = true;
2595 break;
2597 default:
2598 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2599 break;
2603 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2604 mask LANG_MASK, option handlers HANDLERS) as an error for option
2605 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2606 NULL), location LOC. This is used by -Werror=. */
2608 static void
2609 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2610 const struct cl_option_handlers *handlers,
2611 struct gcc_options *opts,
2612 struct gcc_options *opts_set,
2613 location_t loc, diagnostic_context *dc)
2615 char *new_option;
2616 int option_index;
2618 new_option = XNEWVEC (char, strlen (arg) + 2);
2619 new_option[0] = 'W';
2620 strcpy (new_option + 1, arg);
2621 option_index = find_opt (new_option, lang_mask);
2622 if (option_index == OPT_SPECIAL_unknown)
2623 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2624 else if (!(cl_options[option_index].flags & CL_WARNING))
2625 error_at (loc, "-Werror=%s: -%s is not an option that controls warnings",
2626 arg, new_option);
2627 else
2629 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2630 const char *arg = NULL;
2632 if (cl_options[option_index].flags & CL_JOINED)
2633 arg = new_option + cl_options[option_index].opt_len;
2634 control_warning_option (option_index, (int) kind, arg, value,
2635 loc, lang_mask,
2636 handlers, opts, opts_set, dc);
2638 free (new_option);
2641 /* Return malloced memory for the name of the option OPTION_INDEX
2642 which enabled a diagnostic (context CONTEXT), originally of type
2643 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2644 as -Werror. */
2646 char *
2647 option_name (diagnostic_context *context, int option_index,
2648 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2650 if (option_index)
2652 /* A warning classified as an error. */
2653 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2654 && diag_kind == DK_ERROR)
2655 return concat (cl_options[OPT_Werror_].opt_text,
2656 /* Skip over "-W". */
2657 cl_options[option_index].opt_text + 2,
2658 NULL);
2659 /* A warning with option. */
2660 else
2661 return xstrdup (cl_options[option_index].opt_text);
2663 /* A warning without option classified as an error. */
2664 else if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2665 || diag_kind == DK_WARNING)
2666 && context->warning_as_error_requested)
2667 return xstrdup (cl_options[OPT_Werror].opt_text);
2668 else
2669 return NULL;