GIMPLE store merging pass
[official-gcc.git] / gcc / opts.c
blobd381cb5227c8b010871fbf67e096d60c4b60105e
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 },
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 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
748 sorry ("transactional memory is not supported with non-call exceptions");
750 /* Unless the user has asked for section anchors, we disable toplevel
751 reordering at -O0 to disable transformations that might be surprising
752 to end users and to get -fno-toplevel-reorder tested. */
753 if (!opts->x_optimize
754 && opts->x_flag_toplevel_reorder == 2
755 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
757 opts->x_flag_toplevel_reorder = 0;
758 opts->x_flag_section_anchors = 0;
760 if (!opts->x_flag_toplevel_reorder)
762 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
763 error_at (loc, "section anchors must be disabled when toplevel reorder"
764 " is disabled");
765 opts->x_flag_section_anchors = 0;
768 if (!opts->x_flag_opts_finished)
770 /* We initialize opts->x_flag_pie to -1 so that targets can set a
771 default value. */
772 if (opts->x_flag_pie == -1)
774 /* We initialize opts->x_flag_pic to -1 so that we can tell if
775 -fpic, -fPIC, -fno-pic or -fno-PIC is used. */
776 if (opts->x_flag_pic == -1)
777 opts->x_flag_pie = DEFAULT_FLAG_PIE;
778 else
779 opts->x_flag_pie = 0;
781 /* If -fPIE or -fpie is used, turn on PIC. */
782 if (opts->x_flag_pie)
783 opts->x_flag_pic = opts->x_flag_pie;
784 else if (opts->x_flag_pic == -1)
785 opts->x_flag_pic = 0;
786 if (opts->x_flag_pic && !opts->x_flag_pie)
787 opts->x_flag_shlib = 1;
788 opts->x_flag_opts_finished = true;
791 /* We initialize opts->x_flag_stack_protect to -1 so that targets
792 can set a default value. */
793 if (opts->x_flag_stack_protect == -1)
794 opts->x_flag_stack_protect = DEFAULT_FLAG_SSP;
796 if (opts->x_optimize == 0)
798 /* Inlining does not work if not optimizing,
799 so force it not to be done. */
800 opts->x_warn_inline = 0;
801 opts->x_flag_no_inline = 1;
804 /* The optimization to partition hot and cold basic blocks into separate
805 sections of the .o and executable files does not work (currently)
806 with exception handling. This is because there is no support for
807 generating unwind info. If opts->x_flag_exceptions is turned on
808 we need to turn off the partitioning optimization. */
810 ui_except = targetm_common.except_unwind_info (opts);
812 if (opts->x_flag_exceptions
813 && opts->x_flag_reorder_blocks_and_partition
814 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
816 if (opts_set->x_flag_reorder_blocks_and_partition)
817 inform (loc,
818 "-freorder-blocks-and-partition does not work "
819 "with exceptions on this architecture");
820 opts->x_flag_reorder_blocks_and_partition = 0;
821 opts->x_flag_reorder_blocks = 1;
824 /* If user requested unwind info, then turn off the partitioning
825 optimization. */
827 if (opts->x_flag_unwind_tables
828 && !targetm_common.unwind_tables_default
829 && opts->x_flag_reorder_blocks_and_partition
830 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
832 if (opts_set->x_flag_reorder_blocks_and_partition)
833 inform (loc,
834 "-freorder-blocks-and-partition does not support "
835 "unwind info on this architecture");
836 opts->x_flag_reorder_blocks_and_partition = 0;
837 opts->x_flag_reorder_blocks = 1;
840 /* If the target requested unwind info, then turn off the partitioning
841 optimization with a different message. Likewise, if the target does not
842 support named sections. */
844 if (opts->x_flag_reorder_blocks_and_partition
845 && (!targetm_common.have_named_sections
846 || (opts->x_flag_unwind_tables
847 && targetm_common.unwind_tables_default
848 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
850 if (opts_set->x_flag_reorder_blocks_and_partition)
851 inform (loc,
852 "-freorder-blocks-and-partition does not work "
853 "on this architecture");
854 opts->x_flag_reorder_blocks_and_partition = 0;
855 opts->x_flag_reorder_blocks = 1;
858 /* Disable -freorder-blocks-and-partition when -fprofile-use is not in
859 effect. Function splitting was not actually being performed in that case,
860 as probably_never_executed_bb_p does not distinguish any basic blocks as
861 being cold vs hot when there is no profile data. Leaving it enabled,
862 however, causes the assembly code generator to create (empty) cold
863 sections and labels, leading to unnecessary size overhead. */
864 if (opts->x_flag_reorder_blocks_and_partition
865 && !opts_set->x_flag_profile_use)
866 opts->x_flag_reorder_blocks_and_partition = 0;
868 if (opts->x_flag_reorder_blocks_and_partition
869 && !opts_set->x_flag_reorder_functions)
870 opts->x_flag_reorder_functions = 1;
872 /* Pipelining of outer loops is only possible when general pipelining
873 capabilities are requested. */
874 if (!opts->x_flag_sel_sched_pipelining)
875 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
877 if (opts->x_flag_conserve_stack)
879 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
880 opts->x_param_values, opts_set->x_param_values);
881 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
882 opts->x_param_values, opts_set->x_param_values);
885 if (opts->x_flag_lto)
887 #ifdef ENABLE_LTO
888 opts->x_flag_generate_lto = 1;
890 /* When generating IL, do not operate in whole-program mode.
891 Otherwise, symbols will be privatized too early, causing link
892 errors later. */
893 opts->x_flag_whole_program = 0;
894 #else
895 error_at (loc, "LTO support has not been enabled in this configuration");
896 #endif
897 if (!opts->x_flag_fat_lto_objects
898 && (!HAVE_LTO_PLUGIN
899 || (opts_set->x_flag_use_linker_plugin
900 && !opts->x_flag_use_linker_plugin)))
902 if (opts_set->x_flag_fat_lto_objects)
903 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin");
904 opts->x_flag_fat_lto_objects = 1;
908 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
909 default value if they choose based on other options. */
910 if (opts->x_flag_split_stack == -1)
911 opts->x_flag_split_stack = 0;
912 else if (opts->x_flag_split_stack)
914 if (!targetm_common.supports_split_stack (true, opts))
916 error_at (loc, "%<-fsplit-stack%> is not supported by "
917 "this compiler configuration");
918 opts->x_flag_split_stack = 0;
922 /* Tune vectorization related parametees according to cost model. */
923 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
925 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
926 6, opts->x_param_values, opts_set->x_param_values);
927 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
928 0, opts->x_param_values, opts_set->x_param_values);
929 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
930 0, opts->x_param_values, opts_set->x_param_values);
933 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
934 is disabled. */
935 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
936 || !opts->x_flag_tree_loop_if_convert)
937 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
938 opts->x_param_values, opts_set->x_param_values);
940 /* The -gsplit-dwarf option requires -ggnu-pubnames. */
941 if (opts->x_dwarf_split_debug_info)
942 opts->x_debug_generate_pub_sections = 2;
944 /* Userspace and kernel ASan conflict with each other. */
945 if ((opts->x_flag_sanitize & SANITIZE_USER_ADDRESS)
946 && (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS))
947 error_at (loc,
948 "-fsanitize=address is incompatible with "
949 "-fsanitize=kernel-address");
951 /* And with TSan. */
952 if ((opts->x_flag_sanitize & SANITIZE_ADDRESS)
953 && (opts->x_flag_sanitize & SANITIZE_THREAD))
954 error_at (loc,
955 "-fsanitize=address and -fsanitize=kernel-address "
956 "are incompatible with -fsanitize=thread");
958 if ((opts->x_flag_sanitize & SANITIZE_LEAK)
959 && (opts->x_flag_sanitize & SANITIZE_THREAD))
960 error_at (loc,
961 "-fsanitize=leak is incompatible with -fsanitize=thread");
963 /* Check error recovery for -fsanitize-recover option. */
964 for (int i = 0; sanitizer_opts[i].name != NULL; ++i)
965 if ((opts->x_flag_sanitize_recover & sanitizer_opts[i].flag)
966 && !sanitizer_opts[i].can_recover)
967 error_at (loc, "-fsanitize-recover=%s is not supported",
968 sanitizer_opts[i].name);
970 /* When instrumenting the pointers, we don't want to remove
971 the null pointer checks. */
972 if (opts->x_flag_sanitize & (SANITIZE_NULL | SANITIZE_NONNULL_ATTRIBUTE
973 | SANITIZE_RETURNS_NONNULL_ATTRIBUTE))
974 opts->x_flag_delete_null_pointer_checks = 0;
976 /* Aggressive compiler optimizations may cause false negatives. */
977 if (opts->x_flag_sanitize & ~(SANITIZE_LEAK | SANITIZE_UNREACHABLE))
979 opts->x_flag_aggressive_loop_optimizations = 0;
980 opts->x_flag_strict_overflow = 0;
984 #define LEFT_COLUMN 27
986 /* Output ITEM, of length ITEM_WIDTH, in the left column,
987 followed by word-wrapped HELP in a second column. */
988 static void
989 wrap_help (const char *help,
990 const char *item,
991 unsigned int item_width,
992 unsigned int columns)
994 unsigned int col_width = LEFT_COLUMN;
995 unsigned int remaining, room, len;
997 remaining = strlen (help);
1001 room = columns - 3 - MAX (col_width, item_width);
1002 if (room > columns)
1003 room = 0;
1004 len = remaining;
1006 if (room < len)
1008 unsigned int i;
1010 for (i = 0; help[i]; i++)
1012 if (i >= room && len != remaining)
1013 break;
1014 if (help[i] == ' ')
1015 len = i;
1016 else if ((help[i] == '-' || help[i] == '/')
1017 && help[i + 1] != ' '
1018 && i > 0 && ISALPHA (help[i - 1]))
1019 len = i + 1;
1023 printf (" %-*.*s %.*s\n", col_width, item_width, item, len, help);
1024 item_width = 0;
1025 while (help[len] == ' ')
1026 len++;
1027 help += len;
1028 remaining -= len;
1030 while (remaining);
1033 /* Print help for a specific front-end, etc. */
1034 static void
1035 print_filtered_help (unsigned int include_flags,
1036 unsigned int exclude_flags,
1037 unsigned int any_flags,
1038 unsigned int columns,
1039 struct gcc_options *opts,
1040 unsigned int lang_mask)
1042 unsigned int i;
1043 const char *help;
1044 bool found = false;
1045 bool displayed = false;
1046 char new_help[256];
1048 if (include_flags == CL_PARAMS)
1050 for (i = 0; i < LAST_PARAM; i++)
1052 const char *param = compiler_params[i].option;
1054 help = compiler_params[i].help;
1055 if (help == NULL || *help == '\0')
1057 if (exclude_flags & CL_UNDOCUMENTED)
1058 continue;
1059 help = undocumented_msg;
1062 /* Get the translation. */
1063 help = _(help);
1065 if (!opts->x_quiet_flag)
1067 snprintf (new_help, sizeof (new_help),
1068 _("default %d minimum %d maximum %d"),
1069 compiler_params[i].default_value,
1070 compiler_params[i].min_value,
1071 compiler_params[i].max_value);
1072 help = new_help;
1074 wrap_help (help, param, strlen (param), columns);
1076 putchar ('\n');
1077 return;
1080 if (!opts->x_help_printed)
1081 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
1083 if (!opts->x_help_enum_printed)
1084 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
1086 for (i = 0; i < cl_options_count; i++)
1088 const struct cl_option *option = cl_options + i;
1089 unsigned int len;
1090 const char *opt;
1091 const char *tab;
1093 if (include_flags == 0
1094 || ((option->flags & include_flags) != include_flags))
1096 if ((option->flags & any_flags) == 0)
1097 continue;
1100 /* Skip unwanted switches. */
1101 if ((option->flags & exclude_flags) != 0)
1102 continue;
1104 /* The driver currently prints its own help text. */
1105 if ((option->flags & CL_DRIVER) != 0
1106 && (option->flags & (((1U << cl_lang_count) - 1)
1107 | CL_COMMON | CL_TARGET)) == 0)
1108 continue;
1110 found = true;
1111 /* Skip switches that have already been printed. */
1112 if (opts->x_help_printed[i])
1113 continue;
1115 opts->x_help_printed[i] = true;
1117 help = option->help;
1118 if (help == NULL)
1120 if (exclude_flags & CL_UNDOCUMENTED)
1121 continue;
1123 help = undocumented_msg;
1126 if (option->alias_target < N_OPTS
1127 && cl_options [option->alias_target].help)
1129 if (help == undocumented_msg)
1131 /* For undocumented options that are aliases for other options
1132 that are documented, point the reader to the other option in
1133 preference of the former. */
1134 snprintf (new_help, sizeof new_help,
1135 _("Same as %s. Use the latter option instead."),
1136 cl_options [option->alias_target].opt_text);
1138 else
1140 /* For documented options with aliases, mention the aliased
1141 option's name for reference. */
1142 snprintf (new_help, sizeof new_help,
1143 _("%s Same as %s."),
1144 help, cl_options [option->alias_target].opt_text);
1147 help = new_help;
1150 if (option->warn_message)
1152 /* Mention that the use of the option will trigger a warning. */
1153 if (help == new_help)
1154 snprintf (new_help + strlen (new_help),
1155 sizeof new_help - strlen (new_help),
1156 " %s", _(use_diagnosed_msg));
1157 else
1158 snprintf (new_help, sizeof new_help,
1159 "%s %s", help, _(use_diagnosed_msg));
1161 help = new_help;
1164 /* Get the translation. */
1165 help = _(help);
1167 /* Find the gap between the name of the
1168 option and its descriptive text. */
1169 tab = strchr (help, '\t');
1170 if (tab)
1172 len = tab - help;
1173 opt = help;
1174 help = tab + 1;
1176 else
1178 opt = option->opt_text;
1179 len = strlen (opt);
1182 /* With the -Q option enabled we change the descriptive text associated
1183 with an option to be an indication of its current setting. */
1184 if (!opts->x_quiet_flag)
1186 void *flag_var = option_flag_var (i, opts);
1188 if (len < (LEFT_COLUMN + 2))
1189 strcpy (new_help, "\t\t");
1190 else
1191 strcpy (new_help, "\t");
1193 if (flag_var != NULL
1194 && option->var_type != CLVC_DEFER)
1196 if (option->flags & CL_JOINED)
1198 if (option->var_type == CLVC_STRING)
1200 if (* (const char **) flag_var != NULL)
1201 snprintf (new_help + strlen (new_help),
1202 sizeof (new_help) - strlen (new_help),
1203 "%s", * (const char **) flag_var);
1205 else if (option->var_type == CLVC_ENUM)
1207 const struct cl_enum *e = &cl_enums[option->var_enum];
1208 int value;
1209 const char *arg = NULL;
1211 value = e->get (flag_var);
1212 enum_value_to_arg (e->values, &arg, value, lang_mask);
1213 if (arg == NULL)
1214 arg = _("[default]");
1215 snprintf (new_help + strlen (new_help),
1216 sizeof (new_help) - strlen (new_help),
1217 "%s", arg);
1219 else
1220 sprintf (new_help + strlen (new_help),
1221 "%#x", * (int *) flag_var);
1223 else
1224 strcat (new_help, option_enabled (i, opts)
1225 ? _("[enabled]") : _("[disabled]"));
1228 help = new_help;
1231 wrap_help (help, opt, len, columns);
1232 displayed = true;
1234 if (option->var_type == CLVC_ENUM
1235 && opts->x_help_enum_printed[option->var_enum] != 2)
1236 opts->x_help_enum_printed[option->var_enum] = 1;
1239 if (! found)
1241 unsigned int langs = include_flags & CL_LANG_ALL;
1243 if (langs == 0)
1244 printf (_(" No options with the desired characteristics were found\n"));
1245 else
1247 unsigned int i;
1249 /* PR 31349: Tell the user how to see all of the
1250 options supported by a specific front end. */
1251 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1252 if ((1U << i) & langs)
1253 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end.\n"),
1254 lang_names[i], lang_names[i]);
1258 else if (! displayed)
1259 printf (_(" All options with the desired characteristics have already been displayed\n"));
1261 putchar ('\n');
1263 /* Print details of enumerated option arguments, if those
1264 enumerations have help text headings provided. If no help text
1265 is provided, presume that the possible values are listed in the
1266 help text for the relevant options. */
1267 for (i = 0; i < cl_enums_count; i++)
1269 unsigned int j, pos;
1271 if (opts->x_help_enum_printed[i] != 1)
1272 continue;
1273 if (cl_enums[i].help == NULL)
1274 continue;
1275 printf (" %s\n ", _(cl_enums[i].help));
1276 pos = 4;
1277 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1279 unsigned int len = strlen (cl_enums[i].values[j].arg);
1281 if (pos > 4 && pos + 1 + len <= columns)
1283 printf (" %s", cl_enums[i].values[j].arg);
1284 pos += 1 + len;
1286 else
1288 if (pos > 4)
1290 printf ("\n ");
1291 pos = 4;
1293 printf ("%s", cl_enums[i].values[j].arg);
1294 pos += len;
1297 printf ("\n\n");
1298 opts->x_help_enum_printed[i] = 2;
1302 /* Display help for a specified type of option.
1303 The options must have ALL of the INCLUDE_FLAGS set
1304 ANY of the flags in the ANY_FLAGS set
1305 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1306 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1307 static void
1308 print_specific_help (unsigned int include_flags,
1309 unsigned int exclude_flags,
1310 unsigned int any_flags,
1311 struct gcc_options *opts,
1312 unsigned int lang_mask)
1314 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1315 const char * description = NULL;
1316 const char * descrip_extra = "";
1317 size_t i;
1318 unsigned int flag;
1320 /* Sanity check: Make sure that we do not have more
1321 languages than we have bits available to enumerate them. */
1322 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1324 /* If we have not done so already, obtain
1325 the desired maximum width of the output. */
1326 if (opts->x_help_columns == 0)
1328 opts->x_help_columns = get_terminal_width ();
1329 if (opts->x_help_columns == INT_MAX)
1330 /* Use a reasonable default. */
1331 opts->x_help_columns = 80;
1334 /* Decide upon the title for the options that we are going to display. */
1335 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1337 switch (flag & include_flags)
1339 case 0:
1340 case CL_DRIVER:
1341 break;
1343 case CL_TARGET:
1344 description = _("The following options are target specific");
1345 break;
1346 case CL_WARNING:
1347 description = _("The following options control compiler warning messages");
1348 break;
1349 case CL_OPTIMIZATION:
1350 description = _("The following options control optimizations");
1351 break;
1352 case CL_COMMON:
1353 description = _("The following options are language-independent");
1354 break;
1355 case CL_PARAMS:
1356 description = _("The --param option recognizes the following as parameters");
1357 break;
1358 default:
1359 if (i >= cl_lang_count)
1360 break;
1361 if (exclude_flags & all_langs_mask)
1362 description = _("The following options are specific to just the language ");
1363 else
1364 description = _("The following options are supported by the language ");
1365 descrip_extra = lang_names [i];
1366 break;
1370 if (description == NULL)
1372 if (any_flags == 0)
1374 if (include_flags & CL_UNDOCUMENTED)
1375 description = _("The following options are not documented");
1376 else if (include_flags & CL_SEPARATE)
1377 description = _("The following options take separate arguments");
1378 else if (include_flags & CL_JOINED)
1379 description = _("The following options take joined arguments");
1380 else
1382 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1383 include_flags);
1384 return;
1387 else
1389 if (any_flags & all_langs_mask)
1390 description = _("The following options are language-related");
1391 else
1392 description = _("The following options are language-independent");
1396 printf ("%s%s:\n", description, descrip_extra);
1397 print_filtered_help (include_flags, exclude_flags, any_flags,
1398 opts->x_help_columns, opts, lang_mask);
1401 /* Enable FDO-related flags. */
1403 static void
1404 enable_fdo_optimizations (struct gcc_options *opts,
1405 struct gcc_options *opts_set,
1406 int value)
1408 if (!opts_set->x_flag_branch_probabilities)
1409 opts->x_flag_branch_probabilities = value;
1410 if (!opts_set->x_flag_profile_values)
1411 opts->x_flag_profile_values = value;
1412 if (!opts_set->x_flag_unroll_loops)
1413 opts->x_flag_unroll_loops = value;
1414 if (!opts_set->x_flag_peel_loops)
1415 opts->x_flag_peel_loops = value;
1416 if (!opts_set->x_flag_tracer)
1417 opts->x_flag_tracer = value;
1418 if (!opts_set->x_flag_value_profile_transformations)
1419 opts->x_flag_value_profile_transformations = value;
1420 if (!opts_set->x_flag_inline_functions)
1421 opts->x_flag_inline_functions = value;
1422 if (!opts_set->x_flag_ipa_cp)
1423 opts->x_flag_ipa_cp = value;
1424 if (!opts_set->x_flag_ipa_cp_clone
1425 && value && opts->x_flag_ipa_cp)
1426 opts->x_flag_ipa_cp_clone = value;
1427 if (!opts_set->x_flag_ipa_bit_cp
1428 && value && opts->x_flag_ipa_cp)
1429 opts->x_flag_ipa_bit_cp = value;
1430 if (!opts_set->x_flag_predictive_commoning)
1431 opts->x_flag_predictive_commoning = value;
1432 if (!opts_set->x_flag_split_loops)
1433 opts->x_flag_split_loops = value;
1434 if (!opts_set->x_flag_unswitch_loops)
1435 opts->x_flag_unswitch_loops = value;
1436 if (!opts_set->x_flag_gcse_after_reload)
1437 opts->x_flag_gcse_after_reload = value;
1438 if (!opts_set->x_flag_tree_loop_vectorize
1439 && !opts_set->x_flag_tree_vectorize)
1440 opts->x_flag_tree_loop_vectorize = value;
1441 if (!opts_set->x_flag_tree_slp_vectorize
1442 && !opts_set->x_flag_tree_vectorize)
1443 opts->x_flag_tree_slp_vectorize = value;
1444 if (!opts_set->x_flag_vect_cost_model)
1445 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1446 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1447 opts->x_flag_tree_loop_distribute_patterns = value;
1450 /* -f{,no-}sanitize{,-recover}= suboptions. */
1451 const struct sanitizer_opts_s sanitizer_opts[] =
1453 #define SANITIZER_OPT(name, flags, recover) \
1454 { #name, flags, sizeof #name - 1, recover }
1455 SANITIZER_OPT (address, SANITIZE_ADDRESS | SANITIZE_USER_ADDRESS, true),
1456 SANITIZER_OPT (kernel-address, SANITIZE_ADDRESS | SANITIZE_KERNEL_ADDRESS,
1457 true),
1458 SANITIZER_OPT (thread, SANITIZE_THREAD, false),
1459 SANITIZER_OPT (leak, SANITIZE_LEAK, false),
1460 SANITIZER_OPT (shift, SANITIZE_SHIFT, true),
1461 SANITIZER_OPT (integer-divide-by-zero, SANITIZE_DIVIDE, true),
1462 SANITIZER_OPT (undefined, SANITIZE_UNDEFINED, true),
1463 SANITIZER_OPT (unreachable, SANITIZE_UNREACHABLE, false),
1464 SANITIZER_OPT (vla-bound, SANITIZE_VLA, true),
1465 SANITIZER_OPT (return, SANITIZE_RETURN, false),
1466 SANITIZER_OPT (null, SANITIZE_NULL, true),
1467 SANITIZER_OPT (signed-integer-overflow, SANITIZE_SI_OVERFLOW, true),
1468 SANITIZER_OPT (bool, SANITIZE_BOOL, true),
1469 SANITIZER_OPT (enum, SANITIZE_ENUM, true),
1470 SANITIZER_OPT (float-divide-by-zero, SANITIZE_FLOAT_DIVIDE, true),
1471 SANITIZER_OPT (float-cast-overflow, SANITIZE_FLOAT_CAST, true),
1472 SANITIZER_OPT (bounds, SANITIZE_BOUNDS, true),
1473 SANITIZER_OPT (bounds-strict, SANITIZE_BOUNDS | SANITIZE_BOUNDS_STRICT, true),
1474 SANITIZER_OPT (alignment, SANITIZE_ALIGNMENT, true),
1475 SANITIZER_OPT (nonnull-attribute, SANITIZE_NONNULL_ATTRIBUTE, true),
1476 SANITIZER_OPT (returns-nonnull-attribute, SANITIZE_RETURNS_NONNULL_ATTRIBUTE,
1477 true),
1478 SANITIZER_OPT (object-size, SANITIZE_OBJECT_SIZE, true),
1479 SANITIZER_OPT (vptr, SANITIZE_VPTR, true),
1480 SANITIZER_OPT (all, ~0U, true),
1481 #undef SANITIZER_OPT
1482 { NULL, 0U, 0UL, false }
1485 /* Parse comma separated sanitizer suboptions from P for option SCODE,
1486 adjust previous FLAGS and return new ones. If COMPLAIN is false,
1487 don't issue diagnostics. */
1489 unsigned int
1490 parse_sanitizer_options (const char *p, location_t loc, int scode,
1491 unsigned int flags, int value, bool complain)
1493 enum opt_code code = (enum opt_code) scode;
1494 while (*p != 0)
1496 size_t len, i;
1497 bool found = false;
1498 const char *comma = strchr (p, ',');
1500 if (comma == NULL)
1501 len = strlen (p);
1502 else
1503 len = comma - p;
1504 if (len == 0)
1506 p = comma + 1;
1507 continue;
1510 /* Check to see if the string matches an option class name. */
1511 for (i = 0; sanitizer_opts[i].name != NULL; ++i)
1512 if (len == sanitizer_opts[i].len
1513 && memcmp (p, sanitizer_opts[i].name, len) == 0)
1515 /* Handle both -fsanitize and -fno-sanitize cases. */
1516 if (value && sanitizer_opts[i].flag == ~0U)
1518 if (code == OPT_fsanitize_)
1520 if (complain)
1521 error_at (loc, "-fsanitize=all option is not valid");
1523 else
1524 flags |= ~(SANITIZE_THREAD | SANITIZE_LEAK
1525 | SANITIZE_UNREACHABLE | SANITIZE_RETURN);
1527 else if (value)
1529 /* Do not enable -fsanitize-recover=unreachable and
1530 -fsanitize-recover=return if -fsanitize-recover=undefined
1531 is selected. */
1532 if (sanitizer_opts[i].flag == SANITIZE_UNDEFINED)
1533 flags |= (SANITIZE_UNDEFINED
1534 & ~(SANITIZE_UNREACHABLE | SANITIZE_RETURN));
1535 else
1536 flags |= sanitizer_opts[i].flag;
1538 else
1539 flags &= ~sanitizer_opts[i].flag;
1540 found = true;
1541 break;
1544 if (! found && complain)
1545 error_at (loc, "unrecognized argument to -fsanitize%s= option: %q.*s",
1546 code == OPT_fsanitize_ ? "" : "-recover", (int) len, p);
1548 if (comma == NULL)
1549 break;
1550 p = comma + 1;
1552 return flags;
1555 /* Handle target- and language-independent options. Return zero to
1556 generate an "unknown option" message. Only options that need
1557 extra handling need to be listed here; if you simply want
1558 DECODED->value assigned to a variable, it happens automatically. */
1560 bool
1561 common_handle_option (struct gcc_options *opts,
1562 struct gcc_options *opts_set,
1563 const struct cl_decoded_option *decoded,
1564 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1565 location_t loc,
1566 const struct cl_option_handlers *handlers,
1567 diagnostic_context *dc)
1569 size_t scode = decoded->opt_index;
1570 const char *arg = decoded->arg;
1571 int value = decoded->value;
1572 enum opt_code code = (enum opt_code) scode;
1574 gcc_assert (decoded->canonical_option_num_elements <= 2);
1576 switch (code)
1578 case OPT__param:
1579 handle_param (opts, opts_set, loc, arg);
1580 break;
1582 case OPT__help:
1584 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1585 unsigned int undoc_mask;
1586 unsigned int i;
1588 if (lang_mask == CL_DRIVER)
1589 break;
1591 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1593 : CL_UNDOCUMENTED);
1594 /* First display any single language specific options. */
1595 for (i = 0; i < cl_lang_count; i++)
1596 print_specific_help
1597 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1598 lang_mask);
1599 /* Next display any multi language specific options. */
1600 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1601 /* Then display any remaining, non-language options. */
1602 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1603 if (i != CL_DRIVER)
1604 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1605 opts->x_exit_after_options = true;
1606 break;
1609 case OPT__target_help:
1610 if (lang_mask == CL_DRIVER)
1611 break;
1613 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1614 opts->x_exit_after_options = true;
1615 break;
1617 case OPT__help_:
1619 const char *a = arg;
1620 unsigned int include_flags = 0;
1621 /* Note - by default we include undocumented options when listing
1622 specific classes. If you only want to see documented options
1623 then add ",^undocumented" to the --help= option. E.g.:
1625 --help=target,^undocumented */
1626 unsigned int exclude_flags = 0;
1628 if (lang_mask == CL_DRIVER)
1629 break;
1631 /* Walk along the argument string, parsing each word in turn.
1632 The format is:
1633 arg = [^]{word}[,{arg}]
1634 word = {optimizers|target|warnings|undocumented|
1635 params|common|<language>} */
1636 while (*a != 0)
1638 static const struct
1640 const char *string;
1641 unsigned int flag;
1643 specifics[] =
1645 { "optimizers", CL_OPTIMIZATION },
1646 { "target", CL_TARGET },
1647 { "warnings", CL_WARNING },
1648 { "undocumented", CL_UNDOCUMENTED },
1649 { "params", CL_PARAMS },
1650 { "joined", CL_JOINED },
1651 { "separate", CL_SEPARATE },
1652 { "common", CL_COMMON },
1653 { NULL, 0 }
1655 unsigned int *pflags;
1656 const char *comma;
1657 unsigned int lang_flag, specific_flag;
1658 unsigned int len;
1659 unsigned int i;
1661 if (*a == '^')
1663 ++a;
1664 if (*a == '\0')
1666 error_at (loc, "missing argument to %qs", "--help=^");
1667 break;
1669 pflags = &exclude_flags;
1671 else
1672 pflags = &include_flags;
1674 comma = strchr (a, ',');
1675 if (comma == NULL)
1676 len = strlen (a);
1677 else
1678 len = comma - a;
1679 if (len == 0)
1681 a = comma + 1;
1682 continue;
1685 /* Check to see if the string matches an option class name. */
1686 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1687 if (strncasecmp (a, specifics[i].string, len) == 0)
1689 specific_flag = specifics[i].flag;
1690 break;
1693 /* Check to see if the string matches a language name.
1694 Note - we rely upon the alpha-sorted nature of the entries in
1695 the lang_names array, specifically that shorter names appear
1696 before their longer variants. (i.e. C before C++). That way
1697 when we are attempting to match --help=c for example we will
1698 match with C first and not C++. */
1699 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1700 if (strncasecmp (a, lang_names[i], len) == 0)
1702 lang_flag = 1U << i;
1703 break;
1706 if (specific_flag != 0)
1708 if (lang_flag == 0)
1709 *pflags |= specific_flag;
1710 else
1712 /* The option's argument matches both the start of a
1713 language name and the start of an option class name.
1714 We have a special case for when the user has
1715 specified "--help=c", but otherwise we have to issue
1716 a warning. */
1717 if (strncasecmp (a, "c", len) == 0)
1718 *pflags |= lang_flag;
1719 else
1720 warning_at (loc, 0,
1721 "--help argument %q.*s is ambiguous, "
1722 "please be more specific",
1723 len, a);
1726 else if (lang_flag != 0)
1727 *pflags |= lang_flag;
1728 else
1729 warning_at (loc, 0,
1730 "unrecognized argument to --help= option: %q.*s",
1731 len, a);
1733 if (comma == NULL)
1734 break;
1735 a = comma + 1;
1738 if (include_flags)
1739 print_specific_help (include_flags, exclude_flags, 0, opts,
1740 lang_mask);
1741 opts->x_exit_after_options = true;
1742 break;
1745 case OPT__version:
1746 if (lang_mask == CL_DRIVER)
1747 break;
1749 opts->x_exit_after_options = true;
1750 break;
1752 case OPT_fsanitize_:
1753 opts->x_flag_sanitize
1754 = parse_sanitizer_options (arg, loc, code,
1755 opts->x_flag_sanitize, value, true);
1757 /* Kernel ASan implies normal ASan but does not yet support
1758 all features. */
1759 if (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS)
1761 maybe_set_param_value (PARAM_ASAN_INSTRUMENTATION_WITH_CALL_THRESHOLD,
1762 0, opts->x_param_values,
1763 opts_set->x_param_values);
1764 maybe_set_param_value (PARAM_ASAN_GLOBALS, 0, opts->x_param_values,
1765 opts_set->x_param_values);
1766 maybe_set_param_value (PARAM_ASAN_STACK, 0, opts->x_param_values,
1767 opts_set->x_param_values);
1768 maybe_set_param_value (PARAM_ASAN_USE_AFTER_RETURN, 0,
1769 opts->x_param_values,
1770 opts_set->x_param_values);
1772 break;
1774 case OPT_fsanitize_recover_:
1775 opts->x_flag_sanitize_recover
1776 = parse_sanitizer_options (arg, loc, code,
1777 opts->x_flag_sanitize_recover, value, true);
1778 break;
1780 case OPT_fasan_shadow_offset_:
1781 /* Deferred. */
1782 break;
1784 case OPT_fsanitize_recover:
1785 if (value)
1786 opts->x_flag_sanitize_recover
1787 |= (SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT)
1788 & ~(SANITIZE_UNREACHABLE | SANITIZE_RETURN);
1789 else
1790 opts->x_flag_sanitize_recover
1791 &= ~(SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT);
1792 break;
1794 case OPT_O:
1795 case OPT_Os:
1796 case OPT_Ofast:
1797 case OPT_Og:
1798 /* Currently handled in a prescan. */
1799 break;
1801 case OPT_Werror:
1802 dc->warning_as_error_requested = value;
1803 break;
1805 case OPT_Werror_:
1806 if (lang_mask == CL_DRIVER)
1807 break;
1809 enable_warning_as_error (arg, value, lang_mask, handlers,
1810 opts, opts_set, loc, dc);
1811 break;
1813 case OPT_Wlarger_than_:
1814 opts->x_larger_than_size = value;
1815 opts->x_warn_larger_than = value != -1;
1816 break;
1818 case OPT_Wfatal_errors:
1819 dc->fatal_errors = value;
1820 break;
1822 case OPT_Wframe_larger_than_:
1823 opts->x_frame_larger_than_size = value;
1824 opts->x_warn_frame_larger_than = value != -1;
1825 break;
1827 case OPT_Wstack_usage_:
1828 opts->x_warn_stack_usage = value;
1829 opts->x_flag_stack_usage_info = value != -1;
1830 break;
1832 case OPT_Wstrict_aliasing:
1833 set_Wstrict_aliasing (opts, value);
1834 break;
1836 case OPT_Wstrict_overflow:
1837 opts->x_warn_strict_overflow = (value
1838 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1839 : 0);
1840 break;
1842 case OPT_Wsystem_headers:
1843 dc->dc_warn_system_headers = value;
1844 break;
1846 case OPT_aux_info:
1847 opts->x_flag_gen_aux_info = 1;
1848 break;
1850 case OPT_auxbase_strip:
1852 char *tmp = xstrdup (arg);
1853 strip_off_ending (tmp, strlen (tmp));
1854 if (tmp[0])
1855 opts->x_aux_base_name = tmp;
1856 else
1857 free (tmp);
1859 break;
1861 case OPT_d:
1862 decode_d_option (arg, opts, loc, dc);
1863 break;
1865 case OPT_fcall_used_:
1866 case OPT_fcall_saved_:
1867 /* Deferred. */
1868 break;
1870 case OPT_fdbg_cnt_:
1871 /* Deferred. */
1872 break;
1874 case OPT_fdbg_cnt_list:
1875 /* Deferred. */
1876 opts->x_exit_after_options = true;
1877 break;
1879 case OPT_fdebug_prefix_map_:
1880 /* Deferred. */
1881 break;
1883 case OPT_fdiagnostics_show_location_:
1884 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1885 break;
1887 case OPT_fdiagnostics_show_caret:
1888 dc->show_caret = value;
1889 break;
1891 case OPT_fdiagnostics_color_:
1892 diagnostic_color_init (dc, value);
1893 break;
1895 case OPT_fdiagnostics_parseable_fixits:
1896 dc->parseable_fixits_p = value;
1897 break;
1899 case OPT_fdiagnostics_show_option:
1900 dc->show_option_requested = value;
1901 break;
1903 case OPT_fdump_:
1904 /* Deferred. */
1905 break;
1907 case OPT_ffast_math:
1908 set_fast_math_flags (opts, value);
1909 break;
1911 case OPT_funsafe_math_optimizations:
1912 set_unsafe_math_optimizations_flags (opts, value);
1913 break;
1915 case OPT_ffixed_:
1916 /* Deferred. */
1917 break;
1919 case OPT_finline_limit_:
1920 set_param_value ("max-inline-insns-single", value / 2,
1921 opts->x_param_values, opts_set->x_param_values);
1922 set_param_value ("max-inline-insns-auto", value / 2,
1923 opts->x_param_values, opts_set->x_param_values);
1924 break;
1926 case OPT_finstrument_functions_exclude_function_list_:
1927 add_comma_separated_to_vector
1928 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1929 break;
1931 case OPT_finstrument_functions_exclude_file_list_:
1932 add_comma_separated_to_vector
1933 (&opts->x_flag_instrument_functions_exclude_files, arg);
1934 break;
1936 case OPT_fmessage_length_:
1937 pp_set_line_maximum_length (dc->printer, value);
1938 diagnostic_set_caret_max_width (dc, value);
1939 break;
1941 case OPT_fopt_info:
1942 case OPT_fopt_info_:
1943 /* Deferred. */
1944 break;
1946 case OPT_foffload_:
1948 const char *p = arg;
1949 opts->x_flag_disable_hsa = true;
1950 while (*p != 0)
1952 const char *comma = strchr (p, ',');
1954 if ((strncmp (p, "disable", 7) == 0)
1955 && (p[7] == ',' || p[7] == '\0'))
1957 opts->x_flag_disable_hsa = true;
1958 break;
1961 if ((strncmp (p, "hsa", 3) == 0)
1962 && (p[3] == ',' || p[3] == '\0'))
1964 #ifdef ENABLE_HSA
1965 opts->x_flag_disable_hsa = false;
1966 #else
1967 sorry ("HSA has not been enabled during configuration");
1968 #endif
1970 if (!comma)
1971 break;
1972 p = comma + 1;
1974 break;
1977 #ifndef ACCEL_COMPILER
1978 case OPT_foffload_abi_:
1979 error_at (loc, "-foffload-abi option can be specified only for "
1980 "offload compiler");
1981 break;
1982 #endif
1984 case OPT_fpack_struct_:
1985 if (value <= 0 || (value & (value - 1)) || value > 16)
1986 error_at (loc,
1987 "structure alignment must be a small power of two, not %d",
1988 value);
1989 else
1990 opts->x_initial_max_fld_align = value;
1991 break;
1993 case OPT_fplugin_:
1994 case OPT_fplugin_arg_:
1995 /* Deferred. */
1996 break;
1998 case OPT_fprofile_use_:
1999 opts->x_profile_data_prefix = xstrdup (arg);
2000 opts->x_flag_profile_use = true;
2001 value = true;
2002 /* No break here - do -fprofile-use processing. */
2003 /* FALLTHRU */
2004 case OPT_fprofile_use:
2005 enable_fdo_optimizations (opts, opts_set, value);
2006 if (!opts_set->x_flag_profile_reorder_functions)
2007 opts->x_flag_profile_reorder_functions = value;
2008 /* Indirect call profiling should do all useful transformations
2009 speculative devirtualization does. */
2010 if (!opts_set->x_flag_devirtualize_speculatively
2011 && opts->x_flag_value_profile_transformations)
2012 opts->x_flag_devirtualize_speculatively = false;
2013 break;
2015 case OPT_fauto_profile_:
2016 opts->x_auto_profile_file = xstrdup (arg);
2017 opts->x_flag_auto_profile = true;
2018 value = true;
2019 /* No break here - do -fauto-profile processing. */
2020 /* FALLTHRU */
2021 case OPT_fauto_profile:
2022 enable_fdo_optimizations (opts, opts_set, value);
2023 if (!opts_set->x_flag_profile_correction)
2024 opts->x_flag_profile_correction = value;
2025 maybe_set_param_value (
2026 PARAM_EARLY_INLINER_MAX_ITERATIONS, 10,
2027 opts->x_param_values, opts_set->x_param_values);
2028 break;
2030 case OPT_fprofile_generate_:
2031 opts->x_profile_data_prefix = xstrdup (arg);
2032 value = true;
2033 /* No break here - do -fprofile-generate processing. */
2034 /* FALLTHRU */
2035 case OPT_fprofile_generate:
2036 if (!opts_set->x_profile_arc_flag)
2037 opts->x_profile_arc_flag = value;
2038 if (!opts_set->x_flag_profile_values)
2039 opts->x_flag_profile_values = value;
2040 if (!opts_set->x_flag_inline_functions)
2041 opts->x_flag_inline_functions = value;
2042 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
2043 quadratic. Disable the pass until better memory representation
2044 is done. */
2045 if (!opts_set->x_flag_ipa_reference)
2046 opts->x_flag_ipa_reference = false;
2047 break;
2049 case OPT_ftree_vectorize:
2050 if (!opts_set->x_flag_tree_loop_vectorize)
2051 opts->x_flag_tree_loop_vectorize = value;
2052 if (!opts_set->x_flag_tree_slp_vectorize)
2053 opts->x_flag_tree_slp_vectorize = value;
2054 break;
2055 case OPT_fshow_column:
2056 dc->show_column = value;
2057 break;
2059 case OPT_frandom_seed:
2060 /* The real switch is -fno-random-seed. */
2061 if (value)
2062 return false;
2063 /* Deferred. */
2064 break;
2066 case OPT_frandom_seed_:
2067 /* Deferred. */
2068 break;
2070 case OPT_fsched_verbose_:
2071 #ifdef INSN_SCHEDULING
2072 /* Handled with Var in common.opt. */
2073 break;
2074 #else
2075 return false;
2076 #endif
2078 case OPT_fsched_stalled_insns_:
2079 opts->x_flag_sched_stalled_insns = value;
2080 if (opts->x_flag_sched_stalled_insns == 0)
2081 opts->x_flag_sched_stalled_insns = -1;
2082 break;
2084 case OPT_fsched_stalled_insns_dep_:
2085 opts->x_flag_sched_stalled_insns_dep = value;
2086 break;
2088 case OPT_fstack_check_:
2089 if (!strcmp (arg, "no"))
2090 opts->x_flag_stack_check = NO_STACK_CHECK;
2091 else if (!strcmp (arg, "generic"))
2092 /* This is the old stack checking method. */
2093 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2094 ? FULL_BUILTIN_STACK_CHECK
2095 : GENERIC_STACK_CHECK;
2096 else if (!strcmp (arg, "specific"))
2097 /* This is the new stack checking method. */
2098 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2099 ? FULL_BUILTIN_STACK_CHECK
2100 : STACK_CHECK_STATIC_BUILTIN
2101 ? STATIC_BUILTIN_STACK_CHECK
2102 : GENERIC_STACK_CHECK;
2103 else
2104 warning_at (loc, 0, "unknown stack check parameter %qs", arg);
2105 break;
2107 case OPT_fstack_limit:
2108 /* The real switch is -fno-stack-limit. */
2109 if (value)
2110 return false;
2111 /* Deferred. */
2112 break;
2114 case OPT_fstack_limit_register_:
2115 case OPT_fstack_limit_symbol_:
2116 /* Deferred. */
2117 break;
2119 case OPT_fstack_usage:
2120 opts->x_flag_stack_usage = value;
2121 opts->x_flag_stack_usage_info = value != 0;
2122 break;
2124 case OPT_g:
2125 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
2126 loc);
2127 break;
2129 case OPT_gcoff:
2130 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
2131 break;
2133 case OPT_gdwarf:
2134 if (arg && strlen (arg) != 0)
2136 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
2137 "use %<-gdwarf-%s%> for DWARF version "
2138 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
2139 break;
2141 else
2142 value = opts->x_dwarf_version;
2144 /* FALLTHRU */
2145 case OPT_gdwarf_:
2146 if (value < 2 || value > 5)
2147 error_at (loc, "dwarf version %d is not supported", value);
2148 else
2149 opts->x_dwarf_version = value;
2150 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
2151 break;
2153 case OPT_gsplit_dwarf:
2154 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
2155 loc);
2156 break;
2158 case OPT_ggdb:
2159 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
2160 break;
2162 case OPT_gstabs:
2163 case OPT_gstabs_:
2164 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
2165 loc);
2166 break;
2168 case OPT_gvms:
2169 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
2170 break;
2172 case OPT_gxcoff:
2173 case OPT_gxcoff_:
2174 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
2175 loc);
2176 break;
2178 case OPT_gz:
2179 case OPT_gz_:
2180 /* Handled completely via specs. */
2181 break;
2183 case OPT_pedantic_errors:
2184 dc->pedantic_errors = 1;
2185 control_warning_option (OPT_Wpedantic, DK_ERROR, NULL, value,
2186 loc, lang_mask,
2187 handlers, opts, opts_set,
2188 dc);
2189 break;
2191 case OPT_flto:
2192 opts->x_flag_lto = value ? "" : NULL;
2193 break;
2195 case OPT_w:
2196 dc->dc_inhibit_warnings = true;
2197 break;
2199 case OPT_fmax_errors_:
2200 dc->max_errors = value;
2201 break;
2203 case OPT_fuse_ld_bfd:
2204 case OPT_fuse_ld_gold:
2205 case OPT_fuse_linker_plugin:
2206 /* No-op. Used by the driver and passed to us because it starts with f.*/
2207 break;
2209 case OPT_fwrapv:
2210 if (value)
2211 opts->x_flag_trapv = 0;
2212 break;
2214 case OPT_ftrapv:
2215 if (value)
2216 opts->x_flag_wrapv = 0;
2217 break;
2219 case OPT_fipa_icf:
2220 opts->x_flag_ipa_icf_functions = value;
2221 opts->x_flag_ipa_icf_variables = value;
2222 break;
2224 default:
2225 /* If the flag was handled in a standard way, assume the lack of
2226 processing here is intentional. */
2227 gcc_assert (option_flag_var (scode, opts));
2228 break;
2231 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
2232 loc, handlers, dc);
2233 return true;
2236 /* Handle --param NAME=VALUE. */
2237 static void
2238 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
2239 location_t loc, const char *carg)
2241 char *equal, *arg;
2242 int value;
2244 arg = xstrdup (carg);
2245 equal = strchr (arg, '=');
2246 if (!equal)
2247 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
2248 arg);
2249 else
2251 *equal = '\0';
2253 enum compiler_param index;
2254 if (!find_param (arg, &index))
2256 const char *suggestion = find_param_fuzzy (arg);
2257 if (suggestion)
2258 error_at (loc, "invalid --param name %qs; did you mean %qs?",
2259 arg, suggestion);
2260 else
2261 error_at (loc, "invalid --param name %qs", arg);
2263 else
2265 if (!param_string_value_p (index, equal + 1, &value))
2266 value = integral_argument (equal + 1);
2268 if (value == -1)
2269 error_at (loc, "invalid --param value %qs", equal + 1);
2270 else
2271 set_param_value (arg, value,
2272 opts->x_param_values, opts_set->x_param_values);
2276 free (arg);
2279 /* Used to set the level of strict aliasing warnings in OPTS,
2280 when no level is specified (i.e., when -Wstrict-aliasing, and not
2281 -Wstrict-aliasing=level was given).
2282 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
2283 and 0 otherwise. After calling this function, wstrict_aliasing will be
2284 set to the default value of -Wstrict_aliasing=level, currently 3. */
2285 static void
2286 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
2288 gcc_assert (onoff == 0 || onoff == 1);
2289 if (onoff != 0)
2290 opts->x_warn_strict_aliasing = 3;
2291 else
2292 opts->x_warn_strict_aliasing = 0;
2295 /* The following routines are useful in setting all the flags that
2296 -ffast-math and -fno-fast-math imply. */
2297 static void
2298 set_fast_math_flags (struct gcc_options *opts, int set)
2300 if (!opts->frontend_set_flag_unsafe_math_optimizations)
2302 opts->x_flag_unsafe_math_optimizations = set;
2303 set_unsafe_math_optimizations_flags (opts, set);
2305 if (!opts->frontend_set_flag_finite_math_only)
2306 opts->x_flag_finite_math_only = set;
2307 if (!opts->frontend_set_flag_errno_math)
2308 opts->x_flag_errno_math = !set;
2309 if (set)
2311 if (!opts->frontend_set_flag_signaling_nans)
2312 opts->x_flag_signaling_nans = 0;
2313 if (!opts->frontend_set_flag_rounding_math)
2314 opts->x_flag_rounding_math = 0;
2315 if (!opts->frontend_set_flag_cx_limited_range)
2316 opts->x_flag_cx_limited_range = 1;
2320 /* When -funsafe-math-optimizations is set the following
2321 flags are set as well. */
2322 static void
2323 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
2325 if (!opts->frontend_set_flag_trapping_math)
2326 opts->x_flag_trapping_math = !set;
2327 if (!opts->frontend_set_flag_signed_zeros)
2328 opts->x_flag_signed_zeros = !set;
2329 if (!opts->frontend_set_flag_associative_math)
2330 opts->x_flag_associative_math = set;
2331 if (!opts->frontend_set_flag_reciprocal_math)
2332 opts->x_flag_reciprocal_math = set;
2335 /* Return true iff flags in OPTS are set as if -ffast-math. */
2336 bool
2337 fast_math_flags_set_p (const struct gcc_options *opts)
2339 return (!opts->x_flag_trapping_math
2340 && opts->x_flag_unsafe_math_optimizations
2341 && opts->x_flag_finite_math_only
2342 && !opts->x_flag_signed_zeros
2343 && !opts->x_flag_errno_math);
2346 /* Return true iff flags are set as if -ffast-math but using the flags stored
2347 in the struct cl_optimization structure. */
2348 bool
2349 fast_math_flags_struct_set_p (struct cl_optimization *opt)
2351 return (!opt->x_flag_trapping_math
2352 && opt->x_flag_unsafe_math_optimizations
2353 && opt->x_flag_finite_math_only
2354 && !opt->x_flag_signed_zeros
2355 && !opt->x_flag_errno_math);
2358 /* Handle a debug output -g switch for options OPTS
2359 (OPTS_SET->x_write_symbols storing whether a debug type was passed
2360 explicitly), location LOC. EXTENDED is true or false to support
2361 extended output (2 is special and means "-ggdb" was given). */
2362 static void
2363 set_debug_level (enum debug_info_type type, int extended, const char *arg,
2364 struct gcc_options *opts, struct gcc_options *opts_set,
2365 location_t loc)
2367 opts->x_use_gnu_debug_info_extensions = extended;
2369 if (type == NO_DEBUG)
2371 if (opts->x_write_symbols == NO_DEBUG)
2373 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
2375 if (extended == 2)
2377 #if defined DWARF2_DEBUGGING_INFO || defined DWARF2_LINENO_DEBUGGING_INFO
2378 opts->x_write_symbols = DWARF2_DEBUG;
2379 #elif defined DBX_DEBUGGING_INFO
2380 opts->x_write_symbols = DBX_DEBUG;
2381 #endif
2384 if (opts->x_write_symbols == NO_DEBUG)
2385 warning_at (loc, 0, "target system does not support debug output");
2388 else
2390 /* Does it conflict with an already selected type? */
2391 if (opts_set->x_write_symbols != NO_DEBUG
2392 && opts->x_write_symbols != NO_DEBUG
2393 && type != opts->x_write_symbols)
2394 error_at (loc, "debug format %qs conflicts with prior selection",
2395 debug_type_names[type]);
2396 opts->x_write_symbols = type;
2397 opts_set->x_write_symbols = type;
2400 /* A debug flag without a level defaults to level 2.
2401 If off or at level 1, set it to level 2, but if already
2402 at level 3, don't lower it. */
2403 if (*arg == '\0')
2405 if (opts->x_debug_info_level < DINFO_LEVEL_NORMAL)
2406 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2408 else
2410 int argval = integral_argument (arg);
2411 if (argval == -1)
2412 error_at (loc, "unrecognised debug output level %qs", arg);
2413 else if (argval > 3)
2414 error_at (loc, "debug output level %qs is too high", arg);
2415 else
2416 opts->x_debug_info_level = (enum debug_info_levels) argval;
2420 /* Arrange to dump core on error for diagnostic context DC. (The
2421 regular error message is still printed first, except in the case of
2422 abort ().) */
2424 static void
2425 setup_core_dumping (diagnostic_context *dc)
2427 #ifdef SIGABRT
2428 signal (SIGABRT, SIG_DFL);
2429 #endif
2430 #if defined(HAVE_SETRLIMIT)
2432 struct rlimit rlim;
2433 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2434 fatal_error (input_location, "getting core file size maximum limit: %m");
2435 rlim.rlim_cur = rlim.rlim_max;
2436 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2437 fatal_error (input_location,
2438 "setting core file size limit to maximum: %m");
2440 #endif
2441 diagnostic_abort_on_error (dc);
2444 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2445 diagnostic context DC. */
2447 static void
2448 decode_d_option (const char *arg, struct gcc_options *opts,
2449 location_t loc, diagnostic_context *dc)
2451 int c;
2453 while (*arg)
2454 switch (c = *arg++)
2456 case 'A':
2457 opts->x_flag_debug_asm = 1;
2458 break;
2459 case 'p':
2460 opts->x_flag_print_asm_name = 1;
2461 break;
2462 case 'P':
2463 opts->x_flag_dump_rtl_in_asm = 1;
2464 opts->x_flag_print_asm_name = 1;
2465 break;
2466 case 'x':
2467 opts->x_rtl_dump_and_exit = 1;
2468 break;
2469 case 'D': /* These are handled by the preprocessor. */
2470 case 'I':
2471 case 'M':
2472 case 'N':
2473 case 'U':
2474 break;
2475 case 'H':
2476 setup_core_dumping (dc);
2477 break;
2478 case 'a':
2479 opts->x_flag_dump_all_passed = true;
2480 break;
2482 default:
2483 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2484 break;
2488 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2489 mask LANG_MASK, option handlers HANDLERS) as an error for option
2490 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2491 NULL), location LOC. This is used by -Werror=. */
2493 static void
2494 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2495 const struct cl_option_handlers *handlers,
2496 struct gcc_options *opts,
2497 struct gcc_options *opts_set,
2498 location_t loc, diagnostic_context *dc)
2500 char *new_option;
2501 int option_index;
2503 new_option = XNEWVEC (char, strlen (arg) + 2);
2504 new_option[0] = 'W';
2505 strcpy (new_option + 1, arg);
2506 option_index = find_opt (new_option, lang_mask);
2507 if (option_index == OPT_SPECIAL_unknown)
2508 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2509 else if (!(cl_options[option_index].flags & CL_WARNING))
2510 error_at (loc, "-Werror=%s: -%s is not an option that controls warnings",
2511 arg, new_option);
2512 else
2514 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2515 const char *arg = NULL;
2517 if (cl_options[option_index].flags & CL_JOINED)
2518 arg = new_option + cl_options[option_index].opt_len;
2519 control_warning_option (option_index, (int) kind, arg, value,
2520 loc, lang_mask,
2521 handlers, opts, opts_set, dc);
2523 free (new_option);
2526 /* Return malloced memory for the name of the option OPTION_INDEX
2527 which enabled a diagnostic (context CONTEXT), originally of type
2528 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2529 as -Werror. */
2531 char *
2532 option_name (diagnostic_context *context, int option_index,
2533 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2535 if (option_index)
2537 /* A warning classified as an error. */
2538 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2539 && diag_kind == DK_ERROR)
2540 return concat (cl_options[OPT_Werror_].opt_text,
2541 /* Skip over "-W". */
2542 cl_options[option_index].opt_text + 2,
2543 NULL);
2544 /* A warning with option. */
2545 else
2546 return xstrdup (cl_options[option_index].opt_text);
2548 /* A warning without option classified as an error. */
2549 else if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2550 || diag_kind == DK_WARNING)
2551 && context->warning_as_error_requested)
2552 return xstrdup (cl_options[OPT_Werror].opt_text);
2553 else
2554 return NULL;