2016-10-17 Paul Thomas <pault@gcc.gnu.org>
[official-gcc.git] / gcc / opts.c
blob90e6186e71101d01a9ef8bad72e50b6aad0f4d19
1 /* Command line option handling.
2 Copyright (C) 2002-2016 Free Software Foundation, Inc.
3 Contributed by Neil Booth.
5 This file is part of GCC.
7 GCC is free software; you can redistribute it and/or modify it under
8 the terms of the GNU General Public License as published by the Free
9 Software Foundation; either version 3, or (at your option) any later
10 version.
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
15 for more details.
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING3. If not see
19 <http://www.gnu.org/licenses/>. */
21 #include "config.h"
22 #include "system.h"
23 #include "intl.h"
24 #include "coretypes.h"
25 #include "opts.h"
26 #include "tm.h"
27 #include "flags.h"
28 #include "params.h"
29 #include "diagnostic.h"
30 #include "opts-diagnostic.h"
31 #include "insn-attr-common.h"
32 #include "common/common-target.h"
34 static void set_Wstrict_aliasing (struct gcc_options *opts, int onoff);
36 /* Indexed by enum debug_info_type. */
37 const char *const debug_type_names[] =
39 "none", "stabs", "coff", "dwarf-2", "xcoff", "vms"
42 /* Parse the -femit-struct-debug-detailed option value
43 and set the flag variables. */
45 #define MATCH( prefix, string ) \
46 ((strncmp (prefix, string, sizeof prefix - 1) == 0) \
47 ? ((string += sizeof prefix - 1), 1) : 0)
49 void
50 set_struct_debug_option (struct gcc_options *opts, location_t loc,
51 const char *spec)
53 /* various labels for comparison */
54 static const char dfn_lbl[] = "dfn:", dir_lbl[] = "dir:", ind_lbl[] = "ind:";
55 static const char ord_lbl[] = "ord:", gen_lbl[] = "gen:";
56 static const char none_lbl[] = "none", any_lbl[] = "any";
57 static const char base_lbl[] = "base", sys_lbl[] = "sys";
59 enum debug_struct_file files = DINFO_STRUCT_FILE_ANY;
60 /* Default is to apply to as much as possible. */
61 enum debug_info_usage usage = DINFO_USAGE_NUM_ENUMS;
62 int ord = 1, gen = 1;
64 /* What usage? */
65 if (MATCH (dfn_lbl, spec))
66 usage = DINFO_USAGE_DFN;
67 else if (MATCH (dir_lbl, spec))
68 usage = DINFO_USAGE_DIR_USE;
69 else if (MATCH (ind_lbl, spec))
70 usage = DINFO_USAGE_IND_USE;
72 /* Generics or not? */
73 if (MATCH (ord_lbl, spec))
74 gen = 0;
75 else if (MATCH (gen_lbl, spec))
76 ord = 0;
78 /* What allowable environment? */
79 if (MATCH (none_lbl, spec))
80 files = DINFO_STRUCT_FILE_NONE;
81 else if (MATCH (any_lbl, spec))
82 files = DINFO_STRUCT_FILE_ANY;
83 else if (MATCH (sys_lbl, spec))
84 files = DINFO_STRUCT_FILE_SYS;
85 else if (MATCH (base_lbl, spec))
86 files = DINFO_STRUCT_FILE_BASE;
87 else
88 error_at (loc,
89 "argument %qs to %<-femit-struct-debug-detailed%> "
90 "not recognized",
91 spec);
93 /* Effect the specification. */
94 if (usage == DINFO_USAGE_NUM_ENUMS)
96 if (ord)
98 opts->x_debug_struct_ordinary[DINFO_USAGE_DFN] = files;
99 opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE] = files;
100 opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE] = files;
102 if (gen)
104 opts->x_debug_struct_generic[DINFO_USAGE_DFN] = files;
105 opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE] = files;
106 opts->x_debug_struct_generic[DINFO_USAGE_IND_USE] = files;
109 else
111 if (ord)
112 opts->x_debug_struct_ordinary[usage] = files;
113 if (gen)
114 opts->x_debug_struct_generic[usage] = files;
117 if (*spec == ',')
118 set_struct_debug_option (opts, loc, spec+1);
119 else
121 /* No more -femit-struct-debug-detailed specifications.
122 Do final checks. */
123 if (*spec != '\0')
124 error_at (loc,
125 "argument %qs to %<-femit-struct-debug-detailed%> unknown",
126 spec);
127 if (opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE]
128 < opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE]
129 || opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE]
130 < opts->x_debug_struct_generic[DINFO_USAGE_IND_USE])
131 error_at (loc,
132 "%<-femit-struct-debug-detailed=dir:...%> must allow "
133 "at least as much as "
134 "%<-femit-struct-debug-detailed=ind:...%>");
138 /* Strip off a legitimate source ending from the input string NAME of
139 length LEN. Rather than having to know the names used by all of
140 our front ends, we strip off an ending of a period followed by
141 up to five characters. (Java uses ".class".) */
143 void
144 strip_off_ending (char *name, int len)
146 int i;
147 for (i = 2; i < 6 && len > i; i++)
149 if (name[len - i] == '.')
151 name[len - i] = '\0';
152 break;
157 /* Find the base name of a path, stripping off both directories and
158 a single final extension. */
160 base_of_path (const char *path, const char **base_out)
162 const char *base = path;
163 const char *dot = 0;
164 const char *p = path;
165 char c = *p;
166 while (c)
168 if (IS_DIR_SEPARATOR (c))
170 base = p + 1;
171 dot = 0;
173 else if (c == '.')
174 dot = p;
175 c = *++p;
177 if (!dot)
178 dot = p;
179 *base_out = base;
180 return dot - base;
183 /* What to print when a switch has no documentation. */
184 static const char undocumented_msg[] = N_("This option lacks documentation.");
185 static const char use_diagnosed_msg[] = N_("Uses of this option are diagnosed.");
187 typedef char *char_p; /* For DEF_VEC_P. */
189 static void handle_param (struct gcc_options *opts,
190 struct gcc_options *opts_set, location_t loc,
191 const char *carg);
192 static void set_debug_level (enum debug_info_type type, int extended,
193 const char *arg, struct gcc_options *opts,
194 struct gcc_options *opts_set,
195 location_t loc);
196 static void set_fast_math_flags (struct gcc_options *opts, int set);
197 static void decode_d_option (const char *arg, struct gcc_options *opts,
198 location_t loc, diagnostic_context *dc);
199 static void set_unsafe_math_optimizations_flags (struct gcc_options *opts,
200 int set);
201 static void enable_warning_as_error (const char *arg, int value,
202 unsigned int lang_mask,
203 const struct cl_option_handlers *handlers,
204 struct gcc_options *opts,
205 struct gcc_options *opts_set,
206 location_t loc,
207 diagnostic_context *dc);
209 /* Handle a back-end option; arguments and return value as for
210 handle_option. */
212 bool
213 target_handle_option (struct gcc_options *opts,
214 struct gcc_options *opts_set,
215 const struct cl_decoded_option *decoded,
216 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
217 location_t loc,
218 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
219 diagnostic_context *dc)
221 gcc_assert (dc == global_dc);
222 gcc_assert (kind == DK_UNSPECIFIED);
223 return targetm_common.handle_option (opts, opts_set, decoded, loc);
226 /* Add comma-separated strings to a char_p vector. */
228 static void
229 add_comma_separated_to_vector (void **pvec, const char *arg)
231 char *tmp;
232 char *r;
233 char *w;
234 char *token_start;
235 vec<char_p> *v = (vec<char_p> *) *pvec;
237 vec_check_alloc (v, 1);
239 /* We never free this string. */
240 tmp = xstrdup (arg);
242 r = tmp;
243 w = tmp;
244 token_start = tmp;
246 while (*r != '\0')
248 if (*r == ',')
250 *w++ = '\0';
251 ++r;
252 v->safe_push (token_start);
253 token_start = w;
255 if (*r == '\\' && r[1] == ',')
257 *w++ = ',';
258 r += 2;
260 else
261 *w++ = *r++;
263 if (*token_start != '\0')
264 v->safe_push (token_start);
266 *pvec = v;
269 /* Initialize opts_obstack. */
271 void
272 init_opts_obstack (void)
274 gcc_obstack_init (&opts_obstack);
277 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
279 void
280 init_options_struct (struct gcc_options *opts, struct gcc_options *opts_set)
282 size_t num_params = get_num_compiler_params ();
284 /* Ensure that opts_obstack has already been initialized by the time
285 that we initialize any gcc_options instances (PR jit/68446). */
286 gcc_assert (opts_obstack.chunk_size > 0);
288 *opts = global_options_init;
290 if (opts_set)
291 memset (opts_set, 0, sizeof (*opts_set));
293 opts->x_param_values = XNEWVEC (int, num_params);
295 if (opts_set)
296 opts_set->x_param_values = XCNEWVEC (int, num_params);
298 init_param_values (opts->x_param_values);
300 /* Initialize whether `char' is signed. */
301 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
302 /* Set this to a special "uninitialized" value. The actual default
303 is set after target options have been processed. */
304 opts->x_flag_short_enums = 2;
306 /* Initialize target_flags before default_options_optimization
307 so the latter can modify it. */
308 opts->x_target_flags = targetm_common.default_target_flags;
310 /* Some targets have ABI-specified unwind tables. */
311 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
313 /* Some targets have other target-specific initialization. */
314 targetm_common.option_init_struct (opts);
317 /* Release any allocations owned by OPTS. */
319 void
320 finalize_options_struct (struct gcc_options *opts)
322 XDELETEVEC (opts->x_param_values);
325 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
326 -Ofast if FAST is set, -Og if DEBUG is set), apply the option DEFAULT_OPT
327 to OPTS and OPTS_SET, diagnostic context DC, location LOC, with language
328 mask LANG_MASK and option handlers HANDLERS. */
330 static void
331 maybe_default_option (struct gcc_options *opts,
332 struct gcc_options *opts_set,
333 const struct default_options *default_opt,
334 int level, bool size, bool fast, bool debug,
335 unsigned int lang_mask,
336 const struct cl_option_handlers *handlers,
337 location_t loc,
338 diagnostic_context *dc)
340 const struct cl_option *option = &cl_options[default_opt->opt_index];
341 bool enabled;
343 if (size)
344 gcc_assert (level == 2);
345 if (fast)
346 gcc_assert (level == 3);
347 if (debug)
348 gcc_assert (level == 1);
350 switch (default_opt->levels)
352 case OPT_LEVELS_ALL:
353 enabled = true;
354 break;
356 case OPT_LEVELS_0_ONLY:
357 enabled = (level == 0);
358 break;
360 case OPT_LEVELS_1_PLUS:
361 enabled = (level >= 1);
362 break;
364 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
365 enabled = (level >= 1 && !size && !debug);
366 break;
368 case OPT_LEVELS_1_PLUS_NOT_DEBUG:
369 enabled = (level >= 1 && !debug);
370 break;
372 case OPT_LEVELS_2_PLUS:
373 enabled = (level >= 2);
374 break;
376 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
377 enabled = (level >= 2 && !size && !debug);
378 break;
380 case OPT_LEVELS_3_PLUS:
381 enabled = (level >= 3);
382 break;
384 case OPT_LEVELS_3_PLUS_AND_SIZE:
385 enabled = (level >= 3 || size);
386 break;
388 case OPT_LEVELS_SIZE:
389 enabled = size;
390 break;
392 case OPT_LEVELS_FAST:
393 enabled = fast;
394 break;
396 case OPT_LEVELS_NONE:
397 default:
398 gcc_unreachable ();
401 if (enabled)
402 handle_generated_option (opts, opts_set, default_opt->opt_index,
403 default_opt->arg, default_opt->value,
404 lang_mask, DK_UNSPECIFIED, loc,
405 handlers, dc);
406 else if (default_opt->arg == NULL
407 && !option->cl_reject_negative)
408 handle_generated_option (opts, opts_set, default_opt->opt_index,
409 default_opt->arg, !default_opt->value,
410 lang_mask, DK_UNSPECIFIED, loc,
411 handlers, dc);
414 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
415 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
416 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
417 language mask LANG_MASK and option handlers HANDLERS. */
419 static void
420 maybe_default_options (struct gcc_options *opts,
421 struct gcc_options *opts_set,
422 const struct default_options *default_opts,
423 int level, bool size, bool fast, bool debug,
424 unsigned int lang_mask,
425 const struct cl_option_handlers *handlers,
426 location_t loc,
427 diagnostic_context *dc)
429 size_t i;
431 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
432 maybe_default_option (opts, opts_set, &default_opts[i],
433 level, size, fast, debug,
434 lang_mask, handlers, loc, dc);
437 /* Table of options enabled by default at different levels. */
439 static const struct default_options default_options_table[] =
441 /* -O1 optimizations. */
442 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
443 #if DELAY_SLOTS
444 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
445 #endif
446 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
447 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
448 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
449 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion, NULL, 1 },
450 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion2, NULL, 1 },
451 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
452 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
453 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
454 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
455 { OPT_LEVELS_1_PLUS, OPT_freorder_blocks, NULL, 1 },
456 { OPT_LEVELS_1_PLUS, OPT_fshrink_wrap, NULL, 1 },
457 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
458 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
459 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_bit_ccp, NULL, 1 },
460 { OPT_LEVELS_1_PLUS, OPT_ftree_coalesce_vars, NULL, 1 },
461 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
462 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
463 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
464 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
465 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_sra, NULL, 1 },
466 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
467 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
468 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
469 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
470 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
471 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
472 { OPT_LEVELS_1_PLUS, OPT_ftree_slsr, NULL, 1 },
473 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fbranch_count_reg, NULL, 1 },
474 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fmove_loop_invariants, NULL, 1 },
475 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_pta, NULL, 1 },
476 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fssa_phiopt, NULL, 1 },
477 { OPT_LEVELS_1_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
479 /* -O2 optimizations. */
480 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
481 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
482 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
483 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
484 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
488 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
489 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
490 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
491 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
492 #ifdef INSN_SCHEDULING
493 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
494 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
495 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
496 #endif
497 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
498 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
499 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
500 REORDER_BLOCKS_ALGORITHM_STC },
501 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
502 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
503 { OPT_LEVELS_2_PLUS, OPT_fcode_hoisting, NULL, 1 },
504 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
505 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
506 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
507 { OPT_LEVELS_2_PLUS, OPT_fipa_bit_cp, NULL, 1 },
508 { OPT_LEVELS_2_PLUS, OPT_fipa_vrp, NULL, 1 },
509 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
510 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
511 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
512 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
513 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
514 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
515 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
516 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
517 { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
518 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
519 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
520 { OPT_LEVELS_2_PLUS, OPT_fipa_icf, NULL, 1 },
521 { OPT_LEVELS_2_PLUS, OPT_fisolate_erroneous_paths_dereference, NULL, 1 },
522 { OPT_LEVELS_2_PLUS, OPT_fipa_ra, NULL, 1 },
523 { OPT_LEVELS_2_PLUS, OPT_flra_remat, NULL, 1 },
525 /* -O3 optimizations. */
526 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
527 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
528 { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
529 /* Inlining of functions reducing size is a good idea with -Os
530 regardless of them being declared inline. */
531 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
532 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
533 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
534 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
535 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
536 { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
537 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
538 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
539 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
540 { OPT_LEVELS_3_PLUS, OPT_fpeel_loops, NULL, 1 },
542 /* -Ofast adds optimizations to -O3. */
543 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
545 { OPT_LEVELS_NONE, 0, NULL, 0 }
548 /* Default the options in OPTS and OPTS_SET based on the optimization
549 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
550 void
551 default_options_optimization (struct gcc_options *opts,
552 struct gcc_options *opts_set,
553 struct cl_decoded_option *decoded_options,
554 unsigned int decoded_options_count,
555 location_t loc,
556 unsigned int lang_mask,
557 const struct cl_option_handlers *handlers,
558 diagnostic_context *dc)
560 unsigned int i;
561 int opt2;
562 bool openacc_mode = false;
564 /* Scan to see what optimization level has been specified. That will
565 determine the default value of many flags. */
566 for (i = 1; i < decoded_options_count; i++)
568 struct cl_decoded_option *opt = &decoded_options[i];
569 switch (opt->opt_index)
571 case OPT_O:
572 if (*opt->arg == '\0')
574 opts->x_optimize = 1;
575 opts->x_optimize_size = 0;
576 opts->x_optimize_fast = 0;
577 opts->x_optimize_debug = 0;
579 else
581 const int optimize_val = integral_argument (opt->arg);
582 if (optimize_val == -1)
583 error_at (loc, "argument to %<-O%> should be a non-negative "
584 "integer, %<g%>, %<s%> or %<fast%>");
585 else
587 opts->x_optimize = optimize_val;
588 if ((unsigned int) opts->x_optimize > 255)
589 opts->x_optimize = 255;
590 opts->x_optimize_size = 0;
591 opts->x_optimize_fast = 0;
592 opts->x_optimize_debug = 0;
595 break;
597 case OPT_Os:
598 opts->x_optimize_size = 1;
600 /* Optimizing for size forces optimize to be 2. */
601 opts->x_optimize = 2;
602 opts->x_optimize_fast = 0;
603 opts->x_optimize_debug = 0;
604 break;
606 case OPT_Ofast:
607 /* -Ofast only adds flags to -O3. */
608 opts->x_optimize_size = 0;
609 opts->x_optimize = 3;
610 opts->x_optimize_fast = 1;
611 opts->x_optimize_debug = 0;
612 break;
614 case OPT_Og:
615 /* -Og selects optimization level 1. */
616 opts->x_optimize_size = 0;
617 opts->x_optimize = 1;
618 opts->x_optimize_fast = 0;
619 opts->x_optimize_debug = 1;
620 break;
622 case OPT_fopenacc:
623 if (opt->value)
624 openacc_mode = true;
625 break;
627 default:
628 /* Ignore other options in this prescan. */
629 break;
633 maybe_default_options (opts, opts_set, default_options_table,
634 opts->x_optimize, opts->x_optimize_size,
635 opts->x_optimize_fast, opts->x_optimize_debug,
636 lang_mask, handlers, loc, dc);
638 /* -O2 param settings. */
639 opt2 = (opts->x_optimize >= 2);
641 if (openacc_mode
642 && !opts_set->x_flag_ipa_pta)
643 opts->x_flag_ipa_pta = true;
645 /* Track fields in field-sensitive alias analysis. */
646 maybe_set_param_value
647 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
648 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
649 opts->x_param_values, opts_set->x_param_values);
651 /* For -O1 only do loop invariant motion for very small loops. */
652 maybe_set_param_value
653 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
654 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
655 opts->x_param_values, opts_set->x_param_values);
657 /* At -Ofast, allow store motion to introduce potential race conditions. */
658 maybe_set_param_value
659 (PARAM_ALLOW_STORE_DATA_RACES,
660 opts->x_optimize_fast ? 1
661 : default_param_value (PARAM_ALLOW_STORE_DATA_RACES),
662 opts->x_param_values, opts_set->x_param_values);
664 if (opts->x_optimize_size)
665 /* We want to crossjump as much as possible. */
666 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
667 opts->x_param_values, opts_set->x_param_values);
668 else
669 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
670 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
671 opts->x_param_values, opts_set->x_param_values);
673 /* Restrict the amount of work combine does at -Og while retaining
674 most of its useful transforms. */
675 if (opts->x_optimize_debug)
676 maybe_set_param_value (PARAM_MAX_COMBINE_INSNS, 2,
677 opts->x_param_values, opts_set->x_param_values);
679 /* Allow default optimizations to be specified on a per-machine basis. */
680 maybe_default_options (opts, opts_set,
681 targetm_common.option_optimization_table,
682 opts->x_optimize, opts->x_optimize_size,
683 opts->x_optimize_fast, opts->x_optimize_debug,
684 lang_mask, handlers, loc, dc);
687 /* After all options at LOC have been read into OPTS and OPTS_SET,
688 finalize settings of those options and diagnose incompatible
689 combinations. */
690 void
691 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
692 location_t loc)
694 enum unwind_info_type ui_except;
696 if (opts->x_dump_base_name
697 && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name)
698 && ! opts->x_dump_base_name_prefixed)
700 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
701 OPTS->X_DUMP_DIR_NAME directory. Then try to make
702 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
703 directory, typically the directory to contain the object
704 file. */
705 if (opts->x_dump_dir_name)
706 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
707 opts->x_dump_base_name, NULL);
708 else if (opts->x_aux_base_name
709 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
711 const char *aux_base;
713 base_of_path (opts->x_aux_base_name, &aux_base);
714 if (opts->x_aux_base_name != aux_base)
716 int dir_len = aux_base - opts->x_aux_base_name;
717 char *new_dump_base_name
718 = XOBNEWVEC (&opts_obstack, char,
719 strlen (opts->x_dump_base_name) + dir_len + 1);
721 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
722 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
723 /* Append existing OPTS->X_DUMP_BASE_NAME. */
724 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
725 opts->x_dump_base_name = new_dump_base_name;
728 opts->x_dump_base_name_prefixed = true;
731 /* Handle related options for unit-at-a-time, toplevel-reorder, and
732 section-anchors. */
733 if (!opts->x_flag_unit_at_a_time)
735 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
736 error_at (loc, "section anchors must be disabled when unit-at-a-time "
737 "is disabled");
738 opts->x_flag_section_anchors = 0;
739 if (opts->x_flag_toplevel_reorder == 1)
740 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
741 "is disabled");
742 opts->x_flag_toplevel_reorder = 0;
745 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
746 sorry ("transactional memory is not supported with non-call exceptions");
748 /* Unless the user has asked for section anchors, we disable toplevel
749 reordering at -O0 to disable transformations that might be surprising
750 to end users and to get -fno-toplevel-reorder tested. */
751 if (!opts->x_optimize
752 && opts->x_flag_toplevel_reorder == 2
753 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
755 opts->x_flag_toplevel_reorder = 0;
756 opts->x_flag_section_anchors = 0;
758 if (!opts->x_flag_toplevel_reorder)
760 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
761 error_at (loc, "section anchors must be disabled when toplevel reorder"
762 " is disabled");
763 opts->x_flag_section_anchors = 0;
766 if (!opts->x_flag_opts_finished)
768 /* We initialize opts->x_flag_pie to -1 so that targets can set a
769 default value. */
770 if (opts->x_flag_pie == -1)
772 /* We initialize opts->x_flag_pic to -1 so that we can tell if
773 -fpic, -fPIC, -fno-pic or -fno-PIC is used. */
774 if (opts->x_flag_pic == -1)
775 opts->x_flag_pie = DEFAULT_FLAG_PIE;
776 else
777 opts->x_flag_pie = 0;
779 /* If -fPIE or -fpie is used, turn on PIC. */
780 if (opts->x_flag_pie)
781 opts->x_flag_pic = opts->x_flag_pie;
782 else if (opts->x_flag_pic == -1)
783 opts->x_flag_pic = 0;
784 if (opts->x_flag_pic && !opts->x_flag_pie)
785 opts->x_flag_shlib = 1;
786 opts->x_flag_opts_finished = true;
789 /* We initialize opts->x_flag_stack_protect to -1 so that targets
790 can set a default value. */
791 if (opts->x_flag_stack_protect == -1)
792 opts->x_flag_stack_protect = DEFAULT_FLAG_SSP;
794 if (opts->x_optimize == 0)
796 /* Inlining does not work if not optimizing,
797 so force it not to be done. */
798 opts->x_warn_inline = 0;
799 opts->x_flag_no_inline = 1;
802 /* The optimization to partition hot and cold basic blocks into separate
803 sections of the .o and executable files does not work (currently)
804 with exception handling. This is because there is no support for
805 generating unwind info. If opts->x_flag_exceptions is turned on
806 we need to turn off the partitioning optimization. */
808 ui_except = targetm_common.except_unwind_info (opts);
810 if (opts->x_flag_exceptions
811 && opts->x_flag_reorder_blocks_and_partition
812 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
814 if (opts_set->x_flag_reorder_blocks_and_partition)
815 inform (loc,
816 "-freorder-blocks-and-partition does not work "
817 "with exceptions on this architecture");
818 opts->x_flag_reorder_blocks_and_partition = 0;
819 opts->x_flag_reorder_blocks = 1;
822 /* If user requested unwind info, then turn off the partitioning
823 optimization. */
825 if (opts->x_flag_unwind_tables
826 && !targetm_common.unwind_tables_default
827 && opts->x_flag_reorder_blocks_and_partition
828 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
830 if (opts_set->x_flag_reorder_blocks_and_partition)
831 inform (loc,
832 "-freorder-blocks-and-partition does not support "
833 "unwind info on this architecture");
834 opts->x_flag_reorder_blocks_and_partition = 0;
835 opts->x_flag_reorder_blocks = 1;
838 /* If the target requested unwind info, then turn off the partitioning
839 optimization with a different message. Likewise, if the target does not
840 support named sections. */
842 if (opts->x_flag_reorder_blocks_and_partition
843 && (!targetm_common.have_named_sections
844 || (opts->x_flag_unwind_tables
845 && targetm_common.unwind_tables_default
846 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
848 if (opts_set->x_flag_reorder_blocks_and_partition)
849 inform (loc,
850 "-freorder-blocks-and-partition does not work "
851 "on this architecture");
852 opts->x_flag_reorder_blocks_and_partition = 0;
853 opts->x_flag_reorder_blocks = 1;
856 /* Disable -freorder-blocks-and-partition when -fprofile-use is not in
857 effect. Function splitting was not actually being performed in that case,
858 as probably_never_executed_bb_p does not distinguish any basic blocks as
859 being cold vs hot when there is no profile data. Leaving it enabled,
860 however, causes the assembly code generator to create (empty) cold
861 sections and labels, leading to unnecessary size overhead. */
862 if (opts->x_flag_reorder_blocks_and_partition
863 && !opts_set->x_flag_profile_use)
864 opts->x_flag_reorder_blocks_and_partition = 0;
866 if (opts->x_flag_reorder_blocks_and_partition
867 && !opts_set->x_flag_reorder_functions)
868 opts->x_flag_reorder_functions = 1;
870 /* Pipelining of outer loops is only possible when general pipelining
871 capabilities are requested. */
872 if (!opts->x_flag_sel_sched_pipelining)
873 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
875 if (opts->x_flag_conserve_stack)
877 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
878 opts->x_param_values, opts_set->x_param_values);
879 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
880 opts->x_param_values, opts_set->x_param_values);
883 if (opts->x_flag_lto)
885 #ifdef ENABLE_LTO
886 opts->x_flag_generate_lto = 1;
888 /* When generating IL, do not operate in whole-program mode.
889 Otherwise, symbols will be privatized too early, causing link
890 errors later. */
891 opts->x_flag_whole_program = 0;
892 #else
893 error_at (loc, "LTO support has not been enabled in this configuration");
894 #endif
895 if (!opts->x_flag_fat_lto_objects
896 && (!HAVE_LTO_PLUGIN
897 || (opts_set->x_flag_use_linker_plugin
898 && !opts->x_flag_use_linker_plugin)))
900 if (opts_set->x_flag_fat_lto_objects)
901 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin");
902 opts->x_flag_fat_lto_objects = 1;
906 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
907 default value if they choose based on other options. */
908 if (opts->x_flag_split_stack == -1)
909 opts->x_flag_split_stack = 0;
910 else if (opts->x_flag_split_stack)
912 if (!targetm_common.supports_split_stack (true, opts))
914 error_at (loc, "%<-fsplit-stack%> is not supported by "
915 "this compiler configuration");
916 opts->x_flag_split_stack = 0;
920 /* Tune vectorization related parametees according to cost model. */
921 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
923 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
924 6, opts->x_param_values, opts_set->x_param_values);
925 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
926 0, opts->x_param_values, opts_set->x_param_values);
927 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
928 0, opts->x_param_values, opts_set->x_param_values);
931 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
932 is disabled. */
933 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
934 || !opts->x_flag_tree_loop_if_convert)
935 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
936 opts->x_param_values, opts_set->x_param_values);
938 /* The -gsplit-dwarf option requires -ggnu-pubnames. */
939 if (opts->x_dwarf_split_debug_info)
940 opts->x_debug_generate_pub_sections = 2;
942 /* Userspace and kernel ASan conflict with each other. */
943 if ((opts->x_flag_sanitize & SANITIZE_USER_ADDRESS)
944 && (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS))
945 error_at (loc,
946 "-fsanitize=address is incompatible with "
947 "-fsanitize=kernel-address");
949 /* And with TSan. */
950 if ((opts->x_flag_sanitize & SANITIZE_ADDRESS)
951 && (opts->x_flag_sanitize & SANITIZE_THREAD))
952 error_at (loc,
953 "-fsanitize=address and -fsanitize=kernel-address "
954 "are incompatible with -fsanitize=thread");
956 if ((opts->x_flag_sanitize & SANITIZE_LEAK)
957 && (opts->x_flag_sanitize & SANITIZE_THREAD))
958 error_at (loc,
959 "-fsanitize=leak is incompatible with -fsanitize=thread");
961 /* Check error recovery for -fsanitize-recover option. */
962 for (int i = 0; sanitizer_opts[i].name != NULL; ++i)
963 if ((opts->x_flag_sanitize_recover & sanitizer_opts[i].flag)
964 && !sanitizer_opts[i].can_recover)
965 error_at (loc, "-fsanitize-recover=%s is not supported",
966 sanitizer_opts[i].name);
968 /* When instrumenting the pointers, we don't want to remove
969 the null pointer checks. */
970 if (opts->x_flag_sanitize & (SANITIZE_NULL | SANITIZE_NONNULL_ATTRIBUTE
971 | SANITIZE_RETURNS_NONNULL_ATTRIBUTE))
972 opts->x_flag_delete_null_pointer_checks = 0;
974 /* Aggressive compiler optimizations may cause false negatives. */
975 if (opts->x_flag_sanitize)
977 opts->x_flag_aggressive_loop_optimizations = 0;
978 opts->x_flag_strict_overflow = 0;
982 #define LEFT_COLUMN 27
984 /* Output ITEM, of length ITEM_WIDTH, in the left column,
985 followed by word-wrapped HELP in a second column. */
986 static void
987 wrap_help (const char *help,
988 const char *item,
989 unsigned int item_width,
990 unsigned int columns)
992 unsigned int col_width = LEFT_COLUMN;
993 unsigned int remaining, room, len;
995 remaining = strlen (help);
999 room = columns - 3 - MAX (col_width, item_width);
1000 if (room > columns)
1001 room = 0;
1002 len = remaining;
1004 if (room < len)
1006 unsigned int i;
1008 for (i = 0; help[i]; i++)
1010 if (i >= room && len != remaining)
1011 break;
1012 if (help[i] == ' ')
1013 len = i;
1014 else if ((help[i] == '-' || help[i] == '/')
1015 && help[i + 1] != ' '
1016 && i > 0 && ISALPHA (help[i - 1]))
1017 len = i + 1;
1021 printf (" %-*.*s %.*s\n", col_width, item_width, item, len, help);
1022 item_width = 0;
1023 while (help[len] == ' ')
1024 len++;
1025 help += len;
1026 remaining -= len;
1028 while (remaining);
1031 /* Print help for a specific front-end, etc. */
1032 static void
1033 print_filtered_help (unsigned int include_flags,
1034 unsigned int exclude_flags,
1035 unsigned int any_flags,
1036 unsigned int columns,
1037 struct gcc_options *opts,
1038 unsigned int lang_mask)
1040 unsigned int i;
1041 const char *help;
1042 bool found = false;
1043 bool displayed = false;
1044 char new_help[256];
1046 if (include_flags == CL_PARAMS)
1048 for (i = 0; i < LAST_PARAM; i++)
1050 const char *param = compiler_params[i].option;
1052 help = compiler_params[i].help;
1053 if (help == NULL || *help == '\0')
1055 if (exclude_flags & CL_UNDOCUMENTED)
1056 continue;
1057 help = undocumented_msg;
1060 /* Get the translation. */
1061 help = _(help);
1063 if (!opts->x_quiet_flag)
1065 snprintf (new_help, sizeof (new_help),
1066 _("default %d minimum %d maximum %d"),
1067 compiler_params[i].default_value,
1068 compiler_params[i].min_value,
1069 compiler_params[i].max_value);
1070 help = new_help;
1072 wrap_help (help, param, strlen (param), columns);
1074 putchar ('\n');
1075 return;
1078 if (!opts->x_help_printed)
1079 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
1081 if (!opts->x_help_enum_printed)
1082 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
1084 for (i = 0; i < cl_options_count; i++)
1086 const struct cl_option *option = cl_options + i;
1087 unsigned int len;
1088 const char *opt;
1089 const char *tab;
1091 if (include_flags == 0
1092 || ((option->flags & include_flags) != include_flags))
1094 if ((option->flags & any_flags) == 0)
1095 continue;
1098 /* Skip unwanted switches. */
1099 if ((option->flags & exclude_flags) != 0)
1100 continue;
1102 /* The driver currently prints its own help text. */
1103 if ((option->flags & CL_DRIVER) != 0
1104 && (option->flags & (((1U << cl_lang_count) - 1)
1105 | CL_COMMON | CL_TARGET)) == 0)
1106 continue;
1108 found = true;
1109 /* Skip switches that have already been printed. */
1110 if (opts->x_help_printed[i])
1111 continue;
1113 opts->x_help_printed[i] = true;
1115 help = option->help;
1116 if (help == NULL)
1118 if (exclude_flags & CL_UNDOCUMENTED)
1119 continue;
1121 help = undocumented_msg;
1124 if (option->alias_target < N_OPTS
1125 && cl_options [option->alias_target].help)
1127 if (help == undocumented_msg)
1129 /* For undocumented options that are aliases for other options
1130 that are documented, point the reader to the other option in
1131 preference of the former. */
1132 snprintf (new_help, sizeof new_help,
1133 _("Same as %s. Use the latter option instead."),
1134 cl_options [option->alias_target].opt_text);
1136 else
1138 /* For documented options with aliases, mention the aliased
1139 option's name for reference. */
1140 snprintf (new_help, sizeof new_help,
1141 _("%s Same as %s."),
1142 help, cl_options [option->alias_target].opt_text);
1145 help = new_help;
1148 if (option->warn_message)
1150 /* Mention that the use of the option will trigger a warning. */
1151 if (help == new_help)
1152 snprintf (new_help + strlen (new_help),
1153 sizeof new_help - strlen (new_help),
1154 " %s", _(use_diagnosed_msg));
1155 else
1156 snprintf (new_help, sizeof new_help,
1157 "%s %s", help, _(use_diagnosed_msg));
1159 help = new_help;
1162 /* Get the translation. */
1163 help = _(help);
1165 /* Find the gap between the name of the
1166 option and its descriptive text. */
1167 tab = strchr (help, '\t');
1168 if (tab)
1170 len = tab - help;
1171 opt = help;
1172 help = tab + 1;
1174 else
1176 opt = option->opt_text;
1177 len = strlen (opt);
1180 /* With the -Q option enabled we change the descriptive text associated
1181 with an option to be an indication of its current setting. */
1182 if (!opts->x_quiet_flag)
1184 void *flag_var = option_flag_var (i, opts);
1186 if (len < (LEFT_COLUMN + 2))
1187 strcpy (new_help, "\t\t");
1188 else
1189 strcpy (new_help, "\t");
1191 if (flag_var != NULL
1192 && option->var_type != CLVC_DEFER)
1194 if (option->flags & CL_JOINED)
1196 if (option->var_type == CLVC_STRING)
1198 if (* (const char **) flag_var != NULL)
1199 snprintf (new_help + strlen (new_help),
1200 sizeof (new_help) - strlen (new_help),
1201 "%s", * (const char **) flag_var);
1203 else if (option->var_type == CLVC_ENUM)
1205 const struct cl_enum *e = &cl_enums[option->var_enum];
1206 int value;
1207 const char *arg = NULL;
1209 value = e->get (flag_var);
1210 enum_value_to_arg (e->values, &arg, value, lang_mask);
1211 if (arg == NULL)
1212 arg = _("[default]");
1213 snprintf (new_help + strlen (new_help),
1214 sizeof (new_help) - strlen (new_help),
1215 "%s", arg);
1217 else
1218 sprintf (new_help + strlen (new_help),
1219 "%#x", * (int *) flag_var);
1221 else
1222 strcat (new_help, option_enabled (i, opts)
1223 ? _("[enabled]") : _("[disabled]"));
1226 help = new_help;
1229 wrap_help (help, opt, len, columns);
1230 displayed = true;
1232 if (option->var_type == CLVC_ENUM
1233 && opts->x_help_enum_printed[option->var_enum] != 2)
1234 opts->x_help_enum_printed[option->var_enum] = 1;
1237 if (! found)
1239 unsigned int langs = include_flags & CL_LANG_ALL;
1241 if (langs == 0)
1242 printf (_(" No options with the desired characteristics were found\n"));
1243 else
1245 unsigned int i;
1247 /* PR 31349: Tell the user how to see all of the
1248 options supported by a specific front end. */
1249 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1250 if ((1U << i) & langs)
1251 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end.\n"),
1252 lang_names[i], lang_names[i]);
1256 else if (! displayed)
1257 printf (_(" All options with the desired characteristics have already been displayed\n"));
1259 putchar ('\n');
1261 /* Print details of enumerated option arguments, if those
1262 enumerations have help text headings provided. If no help text
1263 is provided, presume that the possible values are listed in the
1264 help text for the relevant options. */
1265 for (i = 0; i < cl_enums_count; i++)
1267 unsigned int j, pos;
1269 if (opts->x_help_enum_printed[i] != 1)
1270 continue;
1271 if (cl_enums[i].help == NULL)
1272 continue;
1273 printf (" %s\n ", _(cl_enums[i].help));
1274 pos = 4;
1275 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1277 unsigned int len = strlen (cl_enums[i].values[j].arg);
1279 if (pos > 4 && pos + 1 + len <= columns)
1281 printf (" %s", cl_enums[i].values[j].arg);
1282 pos += 1 + len;
1284 else
1286 if (pos > 4)
1288 printf ("\n ");
1289 pos = 4;
1291 printf ("%s", cl_enums[i].values[j].arg);
1292 pos += len;
1295 printf ("\n\n");
1296 opts->x_help_enum_printed[i] = 2;
1300 /* Display help for a specified type of option.
1301 The options must have ALL of the INCLUDE_FLAGS set
1302 ANY of the flags in the ANY_FLAGS set
1303 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1304 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1305 static void
1306 print_specific_help (unsigned int include_flags,
1307 unsigned int exclude_flags,
1308 unsigned int any_flags,
1309 struct gcc_options *opts,
1310 unsigned int lang_mask)
1312 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1313 const char * description = NULL;
1314 const char * descrip_extra = "";
1315 size_t i;
1316 unsigned int flag;
1318 /* Sanity check: Make sure that we do not have more
1319 languages than we have bits available to enumerate them. */
1320 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1322 /* If we have not done so already, obtain
1323 the desired maximum width of the output. */
1324 if (opts->x_help_columns == 0)
1326 opts->x_help_columns = get_terminal_width ();
1327 if (opts->x_help_columns == INT_MAX)
1328 /* Use a reasonable default. */
1329 opts->x_help_columns = 80;
1332 /* Decide upon the title for the options that we are going to display. */
1333 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1335 switch (flag & include_flags)
1337 case 0:
1338 case CL_DRIVER:
1339 break;
1341 case CL_TARGET:
1342 description = _("The following options are target specific");
1343 break;
1344 case CL_WARNING:
1345 description = _("The following options control compiler warning messages");
1346 break;
1347 case CL_OPTIMIZATION:
1348 description = _("The following options control optimizations");
1349 break;
1350 case CL_COMMON:
1351 description = _("The following options are language-independent");
1352 break;
1353 case CL_PARAMS:
1354 description = _("The --param option recognizes the following as parameters");
1355 break;
1356 default:
1357 if (i >= cl_lang_count)
1358 break;
1359 if (exclude_flags & all_langs_mask)
1360 description = _("The following options are specific to just the language ");
1361 else
1362 description = _("The following options are supported by the language ");
1363 descrip_extra = lang_names [i];
1364 break;
1368 if (description == NULL)
1370 if (any_flags == 0)
1372 if (include_flags & CL_UNDOCUMENTED)
1373 description = _("The following options are not documented");
1374 else if (include_flags & CL_SEPARATE)
1375 description = _("The following options take separate arguments");
1376 else if (include_flags & CL_JOINED)
1377 description = _("The following options take joined arguments");
1378 else
1380 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1381 include_flags);
1382 return;
1385 else
1387 if (any_flags & all_langs_mask)
1388 description = _("The following options are language-related");
1389 else
1390 description = _("The following options are language-independent");
1394 printf ("%s%s:\n", description, descrip_extra);
1395 print_filtered_help (include_flags, exclude_flags, any_flags,
1396 opts->x_help_columns, opts, lang_mask);
1399 /* Enable FDO-related flags. */
1401 static void
1402 enable_fdo_optimizations (struct gcc_options *opts,
1403 struct gcc_options *opts_set,
1404 int value)
1406 if (!opts_set->x_flag_branch_probabilities)
1407 opts->x_flag_branch_probabilities = value;
1408 if (!opts_set->x_flag_profile_values)
1409 opts->x_flag_profile_values = value;
1410 if (!opts_set->x_flag_unroll_loops)
1411 opts->x_flag_unroll_loops = value;
1412 if (!opts_set->x_flag_peel_loops)
1413 opts->x_flag_peel_loops = value;
1414 if (!opts_set->x_flag_tracer)
1415 opts->x_flag_tracer = value;
1416 if (!opts_set->x_flag_value_profile_transformations)
1417 opts->x_flag_value_profile_transformations = value;
1418 if (!opts_set->x_flag_inline_functions)
1419 opts->x_flag_inline_functions = value;
1420 if (!opts_set->x_flag_ipa_cp)
1421 opts->x_flag_ipa_cp = value;
1422 if (!opts_set->x_flag_ipa_cp_clone
1423 && value && opts->x_flag_ipa_cp)
1424 opts->x_flag_ipa_cp_clone = value;
1425 if (!opts_set->x_flag_ipa_bit_cp
1426 && value && opts->x_flag_ipa_cp)
1427 opts->x_flag_ipa_bit_cp = value;
1428 if (!opts_set->x_flag_predictive_commoning)
1429 opts->x_flag_predictive_commoning = value;
1430 if (!opts_set->x_flag_unswitch_loops)
1431 opts->x_flag_unswitch_loops = value;
1432 if (!opts_set->x_flag_gcse_after_reload)
1433 opts->x_flag_gcse_after_reload = value;
1434 if (!opts_set->x_flag_tree_loop_vectorize
1435 && !opts_set->x_flag_tree_vectorize)
1436 opts->x_flag_tree_loop_vectorize = value;
1437 if (!opts_set->x_flag_tree_slp_vectorize
1438 && !opts_set->x_flag_tree_vectorize)
1439 opts->x_flag_tree_slp_vectorize = value;
1440 if (!opts_set->x_flag_vect_cost_model)
1441 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1442 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1443 opts->x_flag_tree_loop_distribute_patterns = value;
1446 /* -f{,no-}sanitize{,-recover}= suboptions. */
1447 const struct sanitizer_opts_s sanitizer_opts[] =
1449 #define SANITIZER_OPT(name, flags, recover) \
1450 { #name, flags, sizeof #name - 1, recover }
1451 SANITIZER_OPT (address, SANITIZE_ADDRESS | SANITIZE_USER_ADDRESS, true),
1452 SANITIZER_OPT (kernel-address, SANITIZE_ADDRESS | SANITIZE_KERNEL_ADDRESS,
1453 true),
1454 SANITIZER_OPT (thread, SANITIZE_THREAD, false),
1455 SANITIZER_OPT (leak, SANITIZE_LEAK, false),
1456 SANITIZER_OPT (shift, SANITIZE_SHIFT, true),
1457 SANITIZER_OPT (integer-divide-by-zero, SANITIZE_DIVIDE, true),
1458 SANITIZER_OPT (undefined, SANITIZE_UNDEFINED, true),
1459 SANITIZER_OPT (unreachable, SANITIZE_UNREACHABLE, false),
1460 SANITIZER_OPT (vla-bound, SANITIZE_VLA, true),
1461 SANITIZER_OPT (return, SANITIZE_RETURN, false),
1462 SANITIZER_OPT (null, SANITIZE_NULL, true),
1463 SANITIZER_OPT (signed-integer-overflow, SANITIZE_SI_OVERFLOW, true),
1464 SANITIZER_OPT (bool, SANITIZE_BOOL, true),
1465 SANITIZER_OPT (enum, SANITIZE_ENUM, true),
1466 SANITIZER_OPT (float-divide-by-zero, SANITIZE_FLOAT_DIVIDE, true),
1467 SANITIZER_OPT (float-cast-overflow, SANITIZE_FLOAT_CAST, true),
1468 SANITIZER_OPT (bounds, SANITIZE_BOUNDS, true),
1469 SANITIZER_OPT (bounds-strict, SANITIZE_BOUNDS | SANITIZE_BOUNDS_STRICT, true),
1470 SANITIZER_OPT (alignment, SANITIZE_ALIGNMENT, true),
1471 SANITIZER_OPT (nonnull-attribute, SANITIZE_NONNULL_ATTRIBUTE, true),
1472 SANITIZER_OPT (returns-nonnull-attribute, SANITIZE_RETURNS_NONNULL_ATTRIBUTE,
1473 true),
1474 SANITIZER_OPT (object-size, SANITIZE_OBJECT_SIZE, true),
1475 SANITIZER_OPT (vptr, SANITIZE_VPTR, true),
1476 SANITIZER_OPT (all, ~0U, true),
1477 #undef SANITIZER_OPT
1478 { NULL, 0U, 0UL, false }
1481 /* Parse comma separated sanitizer suboptions from P for option SCODE,
1482 adjust previous FLAGS and return new ones. If COMPLAIN is false,
1483 don't issue diagnostics. */
1485 unsigned int
1486 parse_sanitizer_options (const char *p, location_t loc, int scode,
1487 unsigned int flags, int value, bool complain)
1489 enum opt_code code = (enum opt_code) scode;
1490 while (*p != 0)
1492 size_t len, i;
1493 bool found = false;
1494 const char *comma = strchr (p, ',');
1496 if (comma == NULL)
1497 len = strlen (p);
1498 else
1499 len = comma - p;
1500 if (len == 0)
1502 p = comma + 1;
1503 continue;
1506 /* Check to see if the string matches an option class name. */
1507 for (i = 0; sanitizer_opts[i].name != NULL; ++i)
1508 if (len == sanitizer_opts[i].len
1509 && memcmp (p, sanitizer_opts[i].name, len) == 0)
1511 /* Handle both -fsanitize and -fno-sanitize cases. */
1512 if (value && sanitizer_opts[i].flag == ~0U)
1514 if (code == OPT_fsanitize_)
1516 if (complain)
1517 error_at (loc, "-fsanitize=all option is not valid");
1519 else
1520 flags |= ~(SANITIZE_THREAD | SANITIZE_LEAK
1521 | SANITIZE_UNREACHABLE | SANITIZE_RETURN);
1523 else if (value)
1525 /* Do not enable -fsanitize-recover=unreachable and
1526 -fsanitize-recover=return if -fsanitize-recover=undefined
1527 is selected. */
1528 if (sanitizer_opts[i].flag == SANITIZE_UNDEFINED)
1529 flags |= (SANITIZE_UNDEFINED
1530 & ~(SANITIZE_UNREACHABLE | SANITIZE_RETURN));
1531 else
1532 flags |= sanitizer_opts[i].flag;
1534 else
1535 flags &= ~sanitizer_opts[i].flag;
1536 found = true;
1537 break;
1540 if (! found && complain)
1541 error_at (loc, "unrecognized argument to -fsanitize%s= option: %q.*s",
1542 code == OPT_fsanitize_ ? "" : "-recover", (int) len, p);
1544 if (comma == NULL)
1545 break;
1546 p = comma + 1;
1548 return flags;
1551 /* Handle target- and language-independent options. Return zero to
1552 generate an "unknown option" message. Only options that need
1553 extra handling need to be listed here; if you simply want
1554 DECODED->value assigned to a variable, it happens automatically. */
1556 bool
1557 common_handle_option (struct gcc_options *opts,
1558 struct gcc_options *opts_set,
1559 const struct cl_decoded_option *decoded,
1560 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1561 location_t loc,
1562 const struct cl_option_handlers *handlers,
1563 diagnostic_context *dc)
1565 size_t scode = decoded->opt_index;
1566 const char *arg = decoded->arg;
1567 int value = decoded->value;
1568 enum opt_code code = (enum opt_code) scode;
1570 gcc_assert (decoded->canonical_option_num_elements <= 2);
1572 switch (code)
1574 case OPT__param:
1575 handle_param (opts, opts_set, loc, arg);
1576 break;
1578 case OPT__help:
1580 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1581 unsigned int undoc_mask;
1582 unsigned int i;
1584 if (lang_mask == CL_DRIVER)
1585 break;
1587 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1589 : CL_UNDOCUMENTED);
1590 /* First display any single language specific options. */
1591 for (i = 0; i < cl_lang_count; i++)
1592 print_specific_help
1593 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1594 lang_mask);
1595 /* Next display any multi language specific options. */
1596 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1597 /* Then display any remaining, non-language options. */
1598 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1599 if (i != CL_DRIVER)
1600 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1601 opts->x_exit_after_options = true;
1602 break;
1605 case OPT__target_help:
1606 if (lang_mask == CL_DRIVER)
1607 break;
1609 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1610 opts->x_exit_after_options = true;
1611 break;
1613 case OPT__help_:
1615 const char *a = arg;
1616 unsigned int include_flags = 0;
1617 /* Note - by default we include undocumented options when listing
1618 specific classes. If you only want to see documented options
1619 then add ",^undocumented" to the --help= option. E.g.:
1621 --help=target,^undocumented */
1622 unsigned int exclude_flags = 0;
1624 if (lang_mask == CL_DRIVER)
1625 break;
1627 /* Walk along the argument string, parsing each word in turn.
1628 The format is:
1629 arg = [^]{word}[,{arg}]
1630 word = {optimizers|target|warnings|undocumented|
1631 params|common|<language>} */
1632 while (*a != 0)
1634 static const struct
1636 const char *string;
1637 unsigned int flag;
1639 specifics[] =
1641 { "optimizers", CL_OPTIMIZATION },
1642 { "target", CL_TARGET },
1643 { "warnings", CL_WARNING },
1644 { "undocumented", CL_UNDOCUMENTED },
1645 { "params", CL_PARAMS },
1646 { "joined", CL_JOINED },
1647 { "separate", CL_SEPARATE },
1648 { "common", CL_COMMON },
1649 { NULL, 0 }
1651 unsigned int *pflags;
1652 const char *comma;
1653 unsigned int lang_flag, specific_flag;
1654 unsigned int len;
1655 unsigned int i;
1657 if (*a == '^')
1659 ++a;
1660 if (*a == '\0')
1662 error_at (loc, "missing argument to %qs", "--help=^");
1663 break;
1665 pflags = &exclude_flags;
1667 else
1668 pflags = &include_flags;
1670 comma = strchr (a, ',');
1671 if (comma == NULL)
1672 len = strlen (a);
1673 else
1674 len = comma - a;
1675 if (len == 0)
1677 a = comma + 1;
1678 continue;
1681 /* Check to see if the string matches an option class name. */
1682 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1683 if (strncasecmp (a, specifics[i].string, len) == 0)
1685 specific_flag = specifics[i].flag;
1686 break;
1689 /* Check to see if the string matches a language name.
1690 Note - we rely upon the alpha-sorted nature of the entries in
1691 the lang_names array, specifically that shorter names appear
1692 before their longer variants. (i.e. C before C++). That way
1693 when we are attempting to match --help=c for example we will
1694 match with C first and not C++. */
1695 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1696 if (strncasecmp (a, lang_names[i], len) == 0)
1698 lang_flag = 1U << i;
1699 break;
1702 if (specific_flag != 0)
1704 if (lang_flag == 0)
1705 *pflags |= specific_flag;
1706 else
1708 /* The option's argument matches both the start of a
1709 language name and the start of an option class name.
1710 We have a special case for when the user has
1711 specified "--help=c", but otherwise we have to issue
1712 a warning. */
1713 if (strncasecmp (a, "c", len) == 0)
1714 *pflags |= lang_flag;
1715 else
1716 warning_at (loc, 0,
1717 "--help argument %q.*s is ambiguous, "
1718 "please be more specific",
1719 len, a);
1722 else if (lang_flag != 0)
1723 *pflags |= lang_flag;
1724 else
1725 warning_at (loc, 0,
1726 "unrecognized argument to --help= option: %q.*s",
1727 len, a);
1729 if (comma == NULL)
1730 break;
1731 a = comma + 1;
1734 if (include_flags)
1735 print_specific_help (include_flags, exclude_flags, 0, opts,
1736 lang_mask);
1737 opts->x_exit_after_options = true;
1738 break;
1741 case OPT__version:
1742 if (lang_mask == CL_DRIVER)
1743 break;
1745 opts->x_exit_after_options = true;
1746 break;
1748 case OPT_fsanitize_:
1749 opts->x_flag_sanitize
1750 = parse_sanitizer_options (arg, loc, code,
1751 opts->x_flag_sanitize, value, true);
1753 /* Kernel ASan implies normal ASan but does not yet support
1754 all features. */
1755 if (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS)
1757 maybe_set_param_value (PARAM_ASAN_INSTRUMENTATION_WITH_CALL_THRESHOLD,
1758 0, opts->x_param_values,
1759 opts_set->x_param_values);
1760 maybe_set_param_value (PARAM_ASAN_GLOBALS, 0, opts->x_param_values,
1761 opts_set->x_param_values);
1762 maybe_set_param_value (PARAM_ASAN_STACK, 0, opts->x_param_values,
1763 opts_set->x_param_values);
1764 maybe_set_param_value (PARAM_ASAN_USE_AFTER_RETURN, 0,
1765 opts->x_param_values,
1766 opts_set->x_param_values);
1768 break;
1770 case OPT_fsanitize_recover_:
1771 opts->x_flag_sanitize_recover
1772 = parse_sanitizer_options (arg, loc, code,
1773 opts->x_flag_sanitize_recover, value, true);
1774 break;
1776 case OPT_fasan_shadow_offset_:
1777 /* Deferred. */
1778 break;
1780 case OPT_fsanitize_recover:
1781 if (value)
1782 opts->x_flag_sanitize_recover
1783 |= (SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT)
1784 & ~(SANITIZE_UNREACHABLE | SANITIZE_RETURN);
1785 else
1786 opts->x_flag_sanitize_recover
1787 &= ~(SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT);
1788 break;
1790 case OPT_O:
1791 case OPT_Os:
1792 case OPT_Ofast:
1793 case OPT_Og:
1794 /* Currently handled in a prescan. */
1795 break;
1797 case OPT_Werror:
1798 dc->warning_as_error_requested = value;
1799 break;
1801 case OPT_Werror_:
1802 if (lang_mask == CL_DRIVER)
1803 break;
1805 enable_warning_as_error (arg, value, lang_mask, handlers,
1806 opts, opts_set, loc, dc);
1807 break;
1809 case OPT_Wlarger_than_:
1810 opts->x_larger_than_size = value;
1811 opts->x_warn_larger_than = value != -1;
1812 break;
1814 case OPT_Wfatal_errors:
1815 dc->fatal_errors = value;
1816 break;
1818 case OPT_Wframe_larger_than_:
1819 opts->x_frame_larger_than_size = value;
1820 opts->x_warn_frame_larger_than = value != -1;
1821 break;
1823 case OPT_Wstack_usage_:
1824 opts->x_warn_stack_usage = value;
1825 opts->x_flag_stack_usage_info = value != -1;
1826 break;
1828 case OPT_Wstrict_aliasing:
1829 set_Wstrict_aliasing (opts, value);
1830 break;
1832 case OPT_Wstrict_overflow:
1833 opts->x_warn_strict_overflow = (value
1834 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1835 : 0);
1836 break;
1838 case OPT_Wsystem_headers:
1839 dc->dc_warn_system_headers = value;
1840 break;
1842 case OPT_aux_info:
1843 opts->x_flag_gen_aux_info = 1;
1844 break;
1846 case OPT_auxbase_strip:
1848 char *tmp = xstrdup (arg);
1849 strip_off_ending (tmp, strlen (tmp));
1850 if (tmp[0])
1851 opts->x_aux_base_name = tmp;
1852 else
1853 free (tmp);
1855 break;
1857 case OPT_d:
1858 decode_d_option (arg, opts, loc, dc);
1859 break;
1861 case OPT_fcall_used_:
1862 case OPT_fcall_saved_:
1863 /* Deferred. */
1864 break;
1866 case OPT_fdbg_cnt_:
1867 /* Deferred. */
1868 break;
1870 case OPT_fdbg_cnt_list:
1871 /* Deferred. */
1872 opts->x_exit_after_options = true;
1873 break;
1875 case OPT_fdebug_prefix_map_:
1876 /* Deferred. */
1877 break;
1879 case OPT_fdiagnostics_show_location_:
1880 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1881 break;
1883 case OPT_fdiagnostics_show_caret:
1884 dc->show_caret = value;
1885 break;
1887 case OPT_fdiagnostics_color_:
1888 diagnostic_color_init (dc, value);
1889 break;
1891 case OPT_fdiagnostics_parseable_fixits:
1892 dc->parseable_fixits_p = value;
1893 break;
1895 case OPT_fdiagnostics_show_option:
1896 dc->show_option_requested = value;
1897 break;
1899 case OPT_fdump_:
1900 /* Deferred. */
1901 break;
1903 case OPT_ffast_math:
1904 set_fast_math_flags (opts, value);
1905 break;
1907 case OPT_funsafe_math_optimizations:
1908 set_unsafe_math_optimizations_flags (opts, value);
1909 break;
1911 case OPT_ffixed_:
1912 /* Deferred. */
1913 break;
1915 case OPT_finline_limit_:
1916 set_param_value ("max-inline-insns-single", value / 2,
1917 opts->x_param_values, opts_set->x_param_values);
1918 set_param_value ("max-inline-insns-auto", value / 2,
1919 opts->x_param_values, opts_set->x_param_values);
1920 break;
1922 case OPT_finstrument_functions_exclude_function_list_:
1923 add_comma_separated_to_vector
1924 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1925 break;
1927 case OPT_finstrument_functions_exclude_file_list_:
1928 add_comma_separated_to_vector
1929 (&opts->x_flag_instrument_functions_exclude_files, arg);
1930 break;
1932 case OPT_fmessage_length_:
1933 pp_set_line_maximum_length (dc->printer, value);
1934 diagnostic_set_caret_max_width (dc, value);
1935 break;
1937 case OPT_fopt_info:
1938 case OPT_fopt_info_:
1939 /* Deferred. */
1940 break;
1942 case OPT_foffload_:
1944 const char *p = arg;
1945 opts->x_flag_disable_hsa = true;
1946 while (*p != 0)
1948 const char *comma = strchr (p, ',');
1950 if ((strncmp (p, "disable", 7) == 0)
1951 && (p[7] == ',' || p[7] == '\0'))
1953 opts->x_flag_disable_hsa = true;
1954 break;
1957 if ((strncmp (p, "hsa", 3) == 0)
1958 && (p[3] == ',' || p[3] == '\0'))
1960 #ifdef ENABLE_HSA
1961 opts->x_flag_disable_hsa = false;
1962 #else
1963 sorry ("HSA has not been enabled during configuration");
1964 #endif
1966 if (!comma)
1967 break;
1968 p = comma + 1;
1970 break;
1973 #ifndef ACCEL_COMPILER
1974 case OPT_foffload_abi_:
1975 error_at (loc, "-foffload-abi option can be specified only for "
1976 "offload compiler");
1977 break;
1978 #endif
1980 case OPT_fpack_struct_:
1981 if (value <= 0 || (value & (value - 1)) || value > 16)
1982 error_at (loc,
1983 "structure alignment must be a small power of two, not %d",
1984 value);
1985 else
1986 opts->x_initial_max_fld_align = value;
1987 break;
1989 case OPT_fplugin_:
1990 case OPT_fplugin_arg_:
1991 /* Deferred. */
1992 break;
1994 case OPT_fprofile_use_:
1995 opts->x_profile_data_prefix = xstrdup (arg);
1996 opts->x_flag_profile_use = true;
1997 value = true;
1998 /* No break here - do -fprofile-use processing. */
1999 /* FALLTHRU */
2000 case OPT_fprofile_use:
2001 enable_fdo_optimizations (opts, opts_set, value);
2002 if (!opts_set->x_flag_profile_reorder_functions)
2003 opts->x_flag_profile_reorder_functions = value;
2004 /* Indirect call profiling should do all useful transformations
2005 speculative devirtualization does. */
2006 if (!opts_set->x_flag_devirtualize_speculatively
2007 && opts->x_flag_value_profile_transformations)
2008 opts->x_flag_devirtualize_speculatively = false;
2009 break;
2011 case OPT_fauto_profile_:
2012 opts->x_auto_profile_file = xstrdup (arg);
2013 opts->x_flag_auto_profile = true;
2014 value = true;
2015 /* No break here - do -fauto-profile processing. */
2016 /* FALLTHRU */
2017 case OPT_fauto_profile:
2018 enable_fdo_optimizations (opts, opts_set, value);
2019 if (!opts_set->x_flag_profile_correction)
2020 opts->x_flag_profile_correction = value;
2021 maybe_set_param_value (
2022 PARAM_EARLY_INLINER_MAX_ITERATIONS, 10,
2023 opts->x_param_values, opts_set->x_param_values);
2024 break;
2026 case OPT_fprofile_generate_:
2027 opts->x_profile_data_prefix = xstrdup (arg);
2028 value = true;
2029 /* No break here - do -fprofile-generate processing. */
2030 /* FALLTHRU */
2031 case OPT_fprofile_generate:
2032 if (!opts_set->x_profile_arc_flag)
2033 opts->x_profile_arc_flag = value;
2034 if (!opts_set->x_flag_profile_values)
2035 opts->x_flag_profile_values = value;
2036 if (!opts_set->x_flag_inline_functions)
2037 opts->x_flag_inline_functions = value;
2038 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
2039 quadratic. Disable the pass until better memory representation
2040 is done. */
2041 if (!opts_set->x_flag_ipa_reference)
2042 opts->x_flag_ipa_reference = false;
2043 break;
2045 case OPT_ftree_vectorize:
2046 if (!opts_set->x_flag_tree_loop_vectorize)
2047 opts->x_flag_tree_loop_vectorize = value;
2048 if (!opts_set->x_flag_tree_slp_vectorize)
2049 opts->x_flag_tree_slp_vectorize = value;
2050 break;
2051 case OPT_fshow_column:
2052 dc->show_column = value;
2053 break;
2055 case OPT_frandom_seed:
2056 /* The real switch is -fno-random-seed. */
2057 if (value)
2058 return false;
2059 /* Deferred. */
2060 break;
2062 case OPT_frandom_seed_:
2063 /* Deferred. */
2064 break;
2066 case OPT_fsched_verbose_:
2067 #ifdef INSN_SCHEDULING
2068 /* Handled with Var in common.opt. */
2069 break;
2070 #else
2071 return false;
2072 #endif
2074 case OPT_fsched_stalled_insns_:
2075 opts->x_flag_sched_stalled_insns = value;
2076 if (opts->x_flag_sched_stalled_insns == 0)
2077 opts->x_flag_sched_stalled_insns = -1;
2078 break;
2080 case OPT_fsched_stalled_insns_dep_:
2081 opts->x_flag_sched_stalled_insns_dep = value;
2082 break;
2084 case OPT_fstack_check_:
2085 if (!strcmp (arg, "no"))
2086 opts->x_flag_stack_check = NO_STACK_CHECK;
2087 else if (!strcmp (arg, "generic"))
2088 /* This is the old stack checking method. */
2089 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2090 ? FULL_BUILTIN_STACK_CHECK
2091 : GENERIC_STACK_CHECK;
2092 else if (!strcmp (arg, "specific"))
2093 /* This is the new stack checking method. */
2094 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2095 ? FULL_BUILTIN_STACK_CHECK
2096 : STACK_CHECK_STATIC_BUILTIN
2097 ? STATIC_BUILTIN_STACK_CHECK
2098 : GENERIC_STACK_CHECK;
2099 else
2100 warning_at (loc, 0, "unknown stack check parameter %qs", arg);
2101 break;
2103 case OPT_fstack_limit:
2104 /* The real switch is -fno-stack-limit. */
2105 if (value)
2106 return false;
2107 /* Deferred. */
2108 break;
2110 case OPT_fstack_limit_register_:
2111 case OPT_fstack_limit_symbol_:
2112 /* Deferred. */
2113 break;
2115 case OPT_fstack_usage:
2116 opts->x_flag_stack_usage = value;
2117 opts->x_flag_stack_usage_info = value != 0;
2118 break;
2120 case OPT_g:
2121 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
2122 loc);
2123 break;
2125 case OPT_gcoff:
2126 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
2127 break;
2129 case OPT_gdwarf:
2130 if (arg && strlen (arg) != 0)
2132 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
2133 "use %<-gdwarf-%s%> for DWARF version "
2134 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
2135 break;
2137 else
2138 value = opts->x_dwarf_version;
2140 /* FALLTHRU */
2141 case OPT_gdwarf_:
2142 if (value < 2 || value > 5)
2143 error_at (loc, "dwarf version %d is not supported", value);
2144 else
2145 opts->x_dwarf_version = value;
2146 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
2147 break;
2149 case OPT_gsplit_dwarf:
2150 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
2151 loc);
2152 break;
2154 case OPT_ggdb:
2155 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
2156 break;
2158 case OPT_gstabs:
2159 case OPT_gstabs_:
2160 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
2161 loc);
2162 break;
2164 case OPT_gvms:
2165 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
2166 break;
2168 case OPT_gxcoff:
2169 case OPT_gxcoff_:
2170 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
2171 loc);
2172 break;
2174 case OPT_gz:
2175 case OPT_gz_:
2176 /* Handled completely via specs. */
2177 break;
2179 case OPT_pedantic_errors:
2180 dc->pedantic_errors = 1;
2181 control_warning_option (OPT_Wpedantic, DK_ERROR, NULL, value,
2182 loc, lang_mask,
2183 handlers, opts, opts_set,
2184 dc);
2185 break;
2187 case OPT_flto:
2188 opts->x_flag_lto = value ? "" : NULL;
2189 break;
2191 case OPT_w:
2192 dc->dc_inhibit_warnings = true;
2193 break;
2195 case OPT_fmax_errors_:
2196 dc->max_errors = value;
2197 break;
2199 case OPT_fuse_ld_bfd:
2200 case OPT_fuse_ld_gold:
2201 case OPT_fuse_linker_plugin:
2202 /* No-op. Used by the driver and passed to us because it starts with f.*/
2203 break;
2205 case OPT_fwrapv:
2206 if (value)
2207 opts->x_flag_trapv = 0;
2208 break;
2210 case OPT_ftrapv:
2211 if (value)
2212 opts->x_flag_wrapv = 0;
2213 break;
2215 case OPT_fipa_icf:
2216 opts->x_flag_ipa_icf_functions = value;
2217 opts->x_flag_ipa_icf_variables = value;
2218 break;
2220 default:
2221 /* If the flag was handled in a standard way, assume the lack of
2222 processing here is intentional. */
2223 gcc_assert (option_flag_var (scode, opts));
2224 break;
2227 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
2228 loc, handlers, dc);
2229 return true;
2232 /* Handle --param NAME=VALUE. */
2233 static void
2234 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
2235 location_t loc, const char *carg)
2237 char *equal, *arg;
2238 int value;
2240 arg = xstrdup (carg);
2241 equal = strchr (arg, '=');
2242 if (!equal)
2243 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
2244 arg);
2245 else
2247 *equal = '\0';
2249 enum compiler_param index;
2250 if (!find_param (arg, &index))
2252 const char *suggestion = find_param_fuzzy (arg);
2253 if (suggestion)
2254 error_at (loc, "invalid --param name %qs; did you mean %qs?",
2255 arg, suggestion);
2256 else
2257 error_at (loc, "invalid --param name %qs", arg);
2259 else
2261 if (!param_string_value_p (index, equal + 1, &value))
2262 value = integral_argument (equal + 1);
2264 if (value == -1)
2265 error_at (loc, "invalid --param value %qs", equal + 1);
2266 else
2267 set_param_value (arg, value,
2268 opts->x_param_values, opts_set->x_param_values);
2272 free (arg);
2275 /* Used to set the level of strict aliasing warnings in OPTS,
2276 when no level is specified (i.e., when -Wstrict-aliasing, and not
2277 -Wstrict-aliasing=level was given).
2278 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
2279 and 0 otherwise. After calling this function, wstrict_aliasing will be
2280 set to the default value of -Wstrict_aliasing=level, currently 3. */
2281 static void
2282 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
2284 gcc_assert (onoff == 0 || onoff == 1);
2285 if (onoff != 0)
2286 opts->x_warn_strict_aliasing = 3;
2287 else
2288 opts->x_warn_strict_aliasing = 0;
2291 /* The following routines are useful in setting all the flags that
2292 -ffast-math and -fno-fast-math imply. */
2293 static void
2294 set_fast_math_flags (struct gcc_options *opts, int set)
2296 if (!opts->frontend_set_flag_unsafe_math_optimizations)
2298 opts->x_flag_unsafe_math_optimizations = set;
2299 set_unsafe_math_optimizations_flags (opts, set);
2301 if (!opts->frontend_set_flag_finite_math_only)
2302 opts->x_flag_finite_math_only = set;
2303 if (!opts->frontend_set_flag_errno_math)
2304 opts->x_flag_errno_math = !set;
2305 if (set)
2307 if (!opts->frontend_set_flag_signaling_nans)
2308 opts->x_flag_signaling_nans = 0;
2309 if (!opts->frontend_set_flag_rounding_math)
2310 opts->x_flag_rounding_math = 0;
2311 if (!opts->frontend_set_flag_cx_limited_range)
2312 opts->x_flag_cx_limited_range = 1;
2316 /* When -funsafe-math-optimizations is set the following
2317 flags are set as well. */
2318 static void
2319 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
2321 if (!opts->frontend_set_flag_trapping_math)
2322 opts->x_flag_trapping_math = !set;
2323 if (!opts->frontend_set_flag_signed_zeros)
2324 opts->x_flag_signed_zeros = !set;
2325 if (!opts->frontend_set_flag_associative_math)
2326 opts->x_flag_associative_math = set;
2327 if (!opts->frontend_set_flag_reciprocal_math)
2328 opts->x_flag_reciprocal_math = set;
2331 /* Return true iff flags in OPTS are set as if -ffast-math. */
2332 bool
2333 fast_math_flags_set_p (const struct gcc_options *opts)
2335 return (!opts->x_flag_trapping_math
2336 && opts->x_flag_unsafe_math_optimizations
2337 && opts->x_flag_finite_math_only
2338 && !opts->x_flag_signed_zeros
2339 && !opts->x_flag_errno_math);
2342 /* Return true iff flags are set as if -ffast-math but using the flags stored
2343 in the struct cl_optimization structure. */
2344 bool
2345 fast_math_flags_struct_set_p (struct cl_optimization *opt)
2347 return (!opt->x_flag_trapping_math
2348 && opt->x_flag_unsafe_math_optimizations
2349 && opt->x_flag_finite_math_only
2350 && !opt->x_flag_signed_zeros
2351 && !opt->x_flag_errno_math);
2354 /* Handle a debug output -g switch for options OPTS
2355 (OPTS_SET->x_write_symbols storing whether a debug type was passed
2356 explicitly), location LOC. EXTENDED is true or false to support
2357 extended output (2 is special and means "-ggdb" was given). */
2358 static void
2359 set_debug_level (enum debug_info_type type, int extended, const char *arg,
2360 struct gcc_options *opts, struct gcc_options *opts_set,
2361 location_t loc)
2363 opts->x_use_gnu_debug_info_extensions = extended;
2365 if (type == NO_DEBUG)
2367 if (opts->x_write_symbols == NO_DEBUG)
2369 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
2371 if (extended == 2)
2373 #if defined DWARF2_DEBUGGING_INFO || defined DWARF2_LINENO_DEBUGGING_INFO
2374 opts->x_write_symbols = DWARF2_DEBUG;
2375 #elif defined DBX_DEBUGGING_INFO
2376 opts->x_write_symbols = DBX_DEBUG;
2377 #endif
2380 if (opts->x_write_symbols == NO_DEBUG)
2381 warning_at (loc, 0, "target system does not support debug output");
2384 else
2386 /* Does it conflict with an already selected type? */
2387 if (opts_set->x_write_symbols != NO_DEBUG
2388 && opts->x_write_symbols != NO_DEBUG
2389 && type != opts->x_write_symbols)
2390 error_at (loc, "debug format %qs conflicts with prior selection",
2391 debug_type_names[type]);
2392 opts->x_write_symbols = type;
2393 opts_set->x_write_symbols = type;
2396 /* A debug flag without a level defaults to level 2.
2397 If off or at level 1, set it to level 2, but if already
2398 at level 3, don't lower it. */
2399 if (*arg == '\0')
2401 if (opts->x_debug_info_level < DINFO_LEVEL_NORMAL)
2402 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2404 else
2406 int argval = integral_argument (arg);
2407 if (argval == -1)
2408 error_at (loc, "unrecognised debug output level %qs", arg);
2409 else if (argval > 3)
2410 error_at (loc, "debug output level %qs is too high", arg);
2411 else
2412 opts->x_debug_info_level = (enum debug_info_levels) argval;
2416 /* Arrange to dump core on error for diagnostic context DC. (The
2417 regular error message is still printed first, except in the case of
2418 abort ().) */
2420 static void
2421 setup_core_dumping (diagnostic_context *dc)
2423 #ifdef SIGABRT
2424 signal (SIGABRT, SIG_DFL);
2425 #endif
2426 #if defined(HAVE_SETRLIMIT)
2428 struct rlimit rlim;
2429 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2430 fatal_error (input_location, "getting core file size maximum limit: %m");
2431 rlim.rlim_cur = rlim.rlim_max;
2432 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2433 fatal_error (input_location,
2434 "setting core file size limit to maximum: %m");
2436 #endif
2437 diagnostic_abort_on_error (dc);
2440 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2441 diagnostic context DC. */
2443 static void
2444 decode_d_option (const char *arg, struct gcc_options *opts,
2445 location_t loc, diagnostic_context *dc)
2447 int c;
2449 while (*arg)
2450 switch (c = *arg++)
2452 case 'A':
2453 opts->x_flag_debug_asm = 1;
2454 break;
2455 case 'p':
2456 opts->x_flag_print_asm_name = 1;
2457 break;
2458 case 'P':
2459 opts->x_flag_dump_rtl_in_asm = 1;
2460 opts->x_flag_print_asm_name = 1;
2461 break;
2462 case 'x':
2463 opts->x_rtl_dump_and_exit = 1;
2464 break;
2465 case 'D': /* These are handled by the preprocessor. */
2466 case 'I':
2467 case 'M':
2468 case 'N':
2469 case 'U':
2470 break;
2471 case 'H':
2472 setup_core_dumping (dc);
2473 break;
2474 case 'a':
2475 opts->x_flag_dump_all_passed = true;
2476 break;
2478 default:
2479 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2480 break;
2484 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2485 mask LANG_MASK, option handlers HANDLERS) as an error for option
2486 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2487 NULL), location LOC. This is used by -Werror=. */
2489 static void
2490 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2491 const struct cl_option_handlers *handlers,
2492 struct gcc_options *opts,
2493 struct gcc_options *opts_set,
2494 location_t loc, diagnostic_context *dc)
2496 char *new_option;
2497 int option_index;
2499 new_option = XNEWVEC (char, strlen (arg) + 2);
2500 new_option[0] = 'W';
2501 strcpy (new_option + 1, arg);
2502 option_index = find_opt (new_option, lang_mask);
2503 if (option_index == OPT_SPECIAL_unknown)
2504 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2505 else if (!(cl_options[option_index].flags & CL_WARNING))
2506 error_at (loc, "-Werror=%s: -%s is not an option that controls warnings",
2507 arg, new_option);
2508 else
2510 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2511 const char *arg = NULL;
2513 if (cl_options[option_index].flags & CL_JOINED)
2514 arg = new_option + cl_options[option_index].opt_len;
2515 control_warning_option (option_index, (int) kind, arg, value,
2516 loc, lang_mask,
2517 handlers, opts, opts_set, dc);
2519 free (new_option);
2522 /* Return malloced memory for the name of the option OPTION_INDEX
2523 which enabled a diagnostic (context CONTEXT), originally of type
2524 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2525 as -Werror. */
2527 char *
2528 option_name (diagnostic_context *context, int option_index,
2529 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2531 if (option_index)
2533 /* A warning classified as an error. */
2534 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2535 && diag_kind == DK_ERROR)
2536 return concat (cl_options[OPT_Werror_].opt_text,
2537 /* Skip over "-W". */
2538 cl_options[option_index].opt_text + 2,
2539 NULL);
2540 /* A warning with option. */
2541 else
2542 return xstrdup (cl_options[option_index].opt_text);
2544 /* A warning without option classified as an error. */
2545 else if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2546 || diag_kind == DK_WARNING)
2547 && context->warning_as_error_requested)
2548 return xstrdup (cl_options[OPT_Werror].opt_text);
2549 else
2550 return NULL;