PR rtl-optimization/71673
[official-gcc.git] / gcc / opts.c
blob74062106895d2b994c83cecaf419e0cbbaa70517
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_ftree_pre, NULL, 1 },
504 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
505 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
506 { OPT_LEVELS_2_PLUS, OPT_fipa_cp_alignment, NULL, 1 },
507 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
508 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
509 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
510 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
511 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
512 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
513 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
514 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
515 { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
516 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
517 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
518 { OPT_LEVELS_2_PLUS, OPT_fipa_icf, NULL, 1 },
519 { OPT_LEVELS_2_PLUS, OPT_fisolate_erroneous_paths_dereference, NULL, 1 },
520 { OPT_LEVELS_2_PLUS, OPT_fipa_ra, NULL, 1 },
521 { OPT_LEVELS_2_PLUS, OPT_flra_remat, NULL, 1 },
523 /* -O3 optimizations. */
524 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
525 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
526 { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
527 /* Inlining of functions reducing size is a good idea with -Os
528 regardless of them being declared inline. */
529 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
530 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
531 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
532 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
533 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
534 { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
535 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
536 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
537 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
538 { OPT_LEVELS_3_PLUS, OPT_fpeel_loops, NULL, 1 },
540 /* -Ofast adds optimizations to -O3. */
541 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
543 { OPT_LEVELS_NONE, 0, NULL, 0 }
546 /* Default the options in OPTS and OPTS_SET based on the optimization
547 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
548 void
549 default_options_optimization (struct gcc_options *opts,
550 struct gcc_options *opts_set,
551 struct cl_decoded_option *decoded_options,
552 unsigned int decoded_options_count,
553 location_t loc,
554 unsigned int lang_mask,
555 const struct cl_option_handlers *handlers,
556 diagnostic_context *dc)
558 unsigned int i;
559 int opt2;
560 bool openacc_mode = false;
562 /* Scan to see what optimization level has been specified. That will
563 determine the default value of many flags. */
564 for (i = 1; i < decoded_options_count; i++)
566 struct cl_decoded_option *opt = &decoded_options[i];
567 switch (opt->opt_index)
569 case OPT_O:
570 if (*opt->arg == '\0')
572 opts->x_optimize = 1;
573 opts->x_optimize_size = 0;
574 opts->x_optimize_fast = 0;
575 opts->x_optimize_debug = 0;
577 else
579 const int optimize_val = integral_argument (opt->arg);
580 if (optimize_val == -1)
581 error_at (loc, "argument to %<-O%> should be a non-negative "
582 "integer, %<g%>, %<s%> or %<fast%>");
583 else
585 opts->x_optimize = optimize_val;
586 if ((unsigned int) opts->x_optimize > 255)
587 opts->x_optimize = 255;
588 opts->x_optimize_size = 0;
589 opts->x_optimize_fast = 0;
590 opts->x_optimize_debug = 0;
593 break;
595 case OPT_Os:
596 opts->x_optimize_size = 1;
598 /* Optimizing for size forces optimize to be 2. */
599 opts->x_optimize = 2;
600 opts->x_optimize_fast = 0;
601 opts->x_optimize_debug = 0;
602 break;
604 case OPT_Ofast:
605 /* -Ofast only adds flags to -O3. */
606 opts->x_optimize_size = 0;
607 opts->x_optimize = 3;
608 opts->x_optimize_fast = 1;
609 opts->x_optimize_debug = 0;
610 break;
612 case OPT_Og:
613 /* -Og selects optimization level 1. */
614 opts->x_optimize_size = 0;
615 opts->x_optimize = 1;
616 opts->x_optimize_fast = 0;
617 opts->x_optimize_debug = 1;
618 break;
620 case OPT_fopenacc:
621 if (opt->value)
622 openacc_mode = true;
623 break;
625 default:
626 /* Ignore other options in this prescan. */
627 break;
631 maybe_default_options (opts, opts_set, default_options_table,
632 opts->x_optimize, opts->x_optimize_size,
633 opts->x_optimize_fast, opts->x_optimize_debug,
634 lang_mask, handlers, loc, dc);
636 /* -O2 param settings. */
637 opt2 = (opts->x_optimize >= 2);
639 if (openacc_mode
640 && !opts_set->x_flag_ipa_pta)
641 opts->x_flag_ipa_pta = true;
643 /* Track fields in field-sensitive alias analysis. */
644 maybe_set_param_value
645 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
646 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
647 opts->x_param_values, opts_set->x_param_values);
649 /* For -O1 only do loop invariant motion for very small loops. */
650 maybe_set_param_value
651 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
652 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
653 opts->x_param_values, opts_set->x_param_values);
655 /* At -Ofast, allow store motion to introduce potential race conditions. */
656 maybe_set_param_value
657 (PARAM_ALLOW_STORE_DATA_RACES,
658 opts->x_optimize_fast ? 1
659 : default_param_value (PARAM_ALLOW_STORE_DATA_RACES),
660 opts->x_param_values, opts_set->x_param_values);
662 if (opts->x_optimize_size)
663 /* We want to crossjump as much as possible. */
664 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
665 opts->x_param_values, opts_set->x_param_values);
666 else
667 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
668 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
669 opts->x_param_values, opts_set->x_param_values);
671 /* Restrict the amount of work combine does at -Og while retaining
672 most of its useful transforms. */
673 if (opts->x_optimize_debug)
674 maybe_set_param_value (PARAM_MAX_COMBINE_INSNS, 2,
675 opts->x_param_values, opts_set->x_param_values);
677 /* Allow default optimizations to be specified on a per-machine basis. */
678 maybe_default_options (opts, opts_set,
679 targetm_common.option_optimization_table,
680 opts->x_optimize, opts->x_optimize_size,
681 opts->x_optimize_fast, opts->x_optimize_debug,
682 lang_mask, handlers, loc, dc);
685 /* After all options at LOC have been read into OPTS and OPTS_SET,
686 finalize settings of those options and diagnose incompatible
687 combinations. */
688 void
689 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
690 location_t loc)
692 enum unwind_info_type ui_except;
694 if (opts->x_dump_base_name
695 && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name)
696 && ! opts->x_dump_base_name_prefixed)
698 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
699 OPTS->X_DUMP_DIR_NAME directory. Then try to make
700 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
701 directory, typically the directory to contain the object
702 file. */
703 if (opts->x_dump_dir_name)
704 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
705 opts->x_dump_base_name, NULL);
706 else if (opts->x_aux_base_name
707 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
709 const char *aux_base;
711 base_of_path (opts->x_aux_base_name, &aux_base);
712 if (opts->x_aux_base_name != aux_base)
714 int dir_len = aux_base - opts->x_aux_base_name;
715 char *new_dump_base_name
716 = XOBNEWVEC (&opts_obstack, char,
717 strlen (opts->x_dump_base_name) + dir_len + 1);
719 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
720 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
721 /* Append existing OPTS->X_DUMP_BASE_NAME. */
722 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
723 opts->x_dump_base_name = new_dump_base_name;
726 opts->x_dump_base_name_prefixed = true;
729 /* Handle related options for unit-at-a-time, toplevel-reorder, and
730 section-anchors. */
731 if (!opts->x_flag_unit_at_a_time)
733 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
734 error_at (loc, "section anchors must be disabled when unit-at-a-time "
735 "is disabled");
736 opts->x_flag_section_anchors = 0;
737 if (opts->x_flag_toplevel_reorder == 1)
738 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
739 "is disabled");
740 opts->x_flag_toplevel_reorder = 0;
743 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
744 sorry ("transactional memory is not supported with non-call exceptions");
746 /* Unless the user has asked for section anchors, we disable toplevel
747 reordering at -O0 to disable transformations that might be surprising
748 to end users and to get -fno-toplevel-reorder tested. */
749 if (!opts->x_optimize
750 && opts->x_flag_toplevel_reorder == 2
751 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
753 opts->x_flag_toplevel_reorder = 0;
754 opts->x_flag_section_anchors = 0;
756 if (!opts->x_flag_toplevel_reorder)
758 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
759 error_at (loc, "section anchors must be disabled when toplevel reorder"
760 " is disabled");
761 opts->x_flag_section_anchors = 0;
764 if (!opts->x_flag_opts_finished)
766 /* We initialize opts->x_flag_pie to -1 so that targets can set a
767 default value. */
768 if (opts->x_flag_pie == -1)
770 /* We initialize opts->x_flag_pic to -1 so that we can tell if
771 -fpic, -fPIC, -fno-pic or -fno-PIC is used. */
772 if (opts->x_flag_pic == -1)
773 opts->x_flag_pie = DEFAULT_FLAG_PIE;
774 else
775 opts->x_flag_pie = 0;
777 /* If -fPIE or -fpie is used, turn on PIC. */
778 if (opts->x_flag_pie)
779 opts->x_flag_pic = opts->x_flag_pie;
780 else if (opts->x_flag_pic == -1)
781 opts->x_flag_pic = 0;
782 if (opts->x_flag_pic && !opts->x_flag_pie)
783 opts->x_flag_shlib = 1;
784 opts->x_flag_opts_finished = true;
787 /* We initialize opts->x_flag_stack_protect to -1 so that targets
788 can set a default value. */
789 if (opts->x_flag_stack_protect == -1)
790 opts->x_flag_stack_protect = DEFAULT_FLAG_SSP;
792 if (opts->x_optimize == 0)
794 /* Inlining does not work if not optimizing,
795 so force it not to be done. */
796 opts->x_warn_inline = 0;
797 opts->x_flag_no_inline = 1;
800 /* The optimization to partition hot and cold basic blocks into separate
801 sections of the .o and executable files does not work (currently)
802 with exception handling. This is because there is no support for
803 generating unwind info. If opts->x_flag_exceptions is turned on
804 we need to turn off the partitioning optimization. */
806 ui_except = targetm_common.except_unwind_info (opts);
808 if (opts->x_flag_exceptions
809 && opts->x_flag_reorder_blocks_and_partition
810 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
812 if (opts_set->x_flag_reorder_blocks_and_partition)
813 inform (loc,
814 "-freorder-blocks-and-partition does not work "
815 "with exceptions on this architecture");
816 opts->x_flag_reorder_blocks_and_partition = 0;
817 opts->x_flag_reorder_blocks = 1;
820 /* If user requested unwind info, then turn off the partitioning
821 optimization. */
823 if (opts->x_flag_unwind_tables
824 && !targetm_common.unwind_tables_default
825 && opts->x_flag_reorder_blocks_and_partition
826 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
828 if (opts_set->x_flag_reorder_blocks_and_partition)
829 inform (loc,
830 "-freorder-blocks-and-partition does not support "
831 "unwind info on this architecture");
832 opts->x_flag_reorder_blocks_and_partition = 0;
833 opts->x_flag_reorder_blocks = 1;
836 /* If the target requested unwind info, then turn off the partitioning
837 optimization with a different message. Likewise, if the target does not
838 support named sections. */
840 if (opts->x_flag_reorder_blocks_and_partition
841 && (!targetm_common.have_named_sections
842 || (opts->x_flag_unwind_tables
843 && targetm_common.unwind_tables_default
844 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
846 if (opts_set->x_flag_reorder_blocks_and_partition)
847 inform (loc,
848 "-freorder-blocks-and-partition does not work "
849 "on this architecture");
850 opts->x_flag_reorder_blocks_and_partition = 0;
851 opts->x_flag_reorder_blocks = 1;
854 /* Disable -freorder-blocks-and-partition when -fprofile-use is not in
855 effect. Function splitting was not actually being performed in that case,
856 as probably_never_executed_bb_p does not distinguish any basic blocks as
857 being cold vs hot when there is no profile data. Leaving it enabled,
858 however, causes the assembly code generator to create (empty) cold
859 sections and labels, leading to unnecessary size overhead. */
860 if (opts->x_flag_reorder_blocks_and_partition
861 && !opts_set->x_flag_profile_use)
862 opts->x_flag_reorder_blocks_and_partition = 0;
864 if (opts->x_flag_reorder_blocks_and_partition
865 && !opts_set->x_flag_reorder_functions)
866 opts->x_flag_reorder_functions = 1;
868 /* Pipelining of outer loops is only possible when general pipelining
869 capabilities are requested. */
870 if (!opts->x_flag_sel_sched_pipelining)
871 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
873 if (opts->x_flag_conserve_stack)
875 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
876 opts->x_param_values, opts_set->x_param_values);
877 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
878 opts->x_param_values, opts_set->x_param_values);
881 if (opts->x_flag_lto)
883 #ifdef ENABLE_LTO
884 opts->x_flag_generate_lto = 1;
886 /* When generating IL, do not operate in whole-program mode.
887 Otherwise, symbols will be privatized too early, causing link
888 errors later. */
889 opts->x_flag_whole_program = 0;
890 #else
891 error_at (loc, "LTO support has not been enabled in this configuration");
892 #endif
893 if (!opts->x_flag_fat_lto_objects
894 && (!HAVE_LTO_PLUGIN
895 || (opts_set->x_flag_use_linker_plugin
896 && !opts->x_flag_use_linker_plugin)))
898 if (opts_set->x_flag_fat_lto_objects)
899 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin");
900 opts->x_flag_fat_lto_objects = 1;
904 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
905 default value if they choose based on other options. */
906 if (opts->x_flag_split_stack == -1)
907 opts->x_flag_split_stack = 0;
908 else if (opts->x_flag_split_stack)
910 if (!targetm_common.supports_split_stack (true, opts))
912 error_at (loc, "%<-fsplit-stack%> is not supported by "
913 "this compiler configuration");
914 opts->x_flag_split_stack = 0;
918 /* Tune vectorization related parametees according to cost model. */
919 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
921 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
922 6, opts->x_param_values, opts_set->x_param_values);
923 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
924 0, opts->x_param_values, opts_set->x_param_values);
925 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
926 0, opts->x_param_values, opts_set->x_param_values);
929 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
930 is disabled. */
931 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
932 || !opts->x_flag_tree_loop_if_convert)
933 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
934 opts->x_param_values, opts_set->x_param_values);
936 /* The -gsplit-dwarf option requires -ggnu-pubnames. */
937 if (opts->x_dwarf_split_debug_info)
938 opts->x_debug_generate_pub_sections = 2;
940 /* Userspace and kernel ASan conflict with each other. */
942 if ((opts->x_flag_sanitize & SANITIZE_USER_ADDRESS)
943 && (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS))
944 error_at (loc,
945 "-fsanitize=address is incompatible with "
946 "-fsanitize=kernel-address");
948 /* 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 /* Error recovery is not allowed for LSan and TSan. */
958 if (opts->x_flag_sanitize_recover & SANITIZE_THREAD)
959 error_at (loc, "-fsanitize-recover=thread is not supported");
961 if (opts->x_flag_sanitize_recover & SANITIZE_LEAK)
962 error_at (loc, "-fsanitize-recover=leak is not supported");
964 /* When instrumenting the pointers, we don't want to remove
965 the null pointer checks. */
966 if (opts->x_flag_sanitize & (SANITIZE_NULL | SANITIZE_NONNULL_ATTRIBUTE
967 | SANITIZE_RETURNS_NONNULL_ATTRIBUTE))
968 opts->x_flag_delete_null_pointer_checks = 0;
970 /* Aggressive compiler optimizations may cause false negatives. */
971 if (opts->x_flag_sanitize)
973 opts->x_flag_aggressive_loop_optimizations = 0;
974 opts->x_flag_strict_overflow = 0;
978 #define LEFT_COLUMN 27
980 /* Output ITEM, of length ITEM_WIDTH, in the left column,
981 followed by word-wrapped HELP in a second column. */
982 static void
983 wrap_help (const char *help,
984 const char *item,
985 unsigned int item_width,
986 unsigned int columns)
988 unsigned int col_width = LEFT_COLUMN;
989 unsigned int remaining, room, len;
991 remaining = strlen (help);
995 room = columns - 3 - MAX (col_width, item_width);
996 if (room > columns)
997 room = 0;
998 len = remaining;
1000 if (room < len)
1002 unsigned int i;
1004 for (i = 0; help[i]; i++)
1006 if (i >= room && len != remaining)
1007 break;
1008 if (help[i] == ' ')
1009 len = i;
1010 else if ((help[i] == '-' || help[i] == '/')
1011 && help[i + 1] != ' '
1012 && i > 0 && ISALPHA (help[i - 1]))
1013 len = i + 1;
1017 printf (" %-*.*s %.*s\n", col_width, item_width, item, len, help);
1018 item_width = 0;
1019 while (help[len] == ' ')
1020 len++;
1021 help += len;
1022 remaining -= len;
1024 while (remaining);
1027 /* Print help for a specific front-end, etc. */
1028 static void
1029 print_filtered_help (unsigned int include_flags,
1030 unsigned int exclude_flags,
1031 unsigned int any_flags,
1032 unsigned int columns,
1033 struct gcc_options *opts,
1034 unsigned int lang_mask)
1036 unsigned int i;
1037 const char *help;
1038 bool found = false;
1039 bool displayed = false;
1040 char new_help[256];
1042 if (include_flags == CL_PARAMS)
1044 for (i = 0; i < LAST_PARAM; i++)
1046 const char *param = compiler_params[i].option;
1048 help = compiler_params[i].help;
1049 if (help == NULL || *help == '\0')
1051 if (exclude_flags & CL_UNDOCUMENTED)
1052 continue;
1053 help = undocumented_msg;
1056 /* Get the translation. */
1057 help = _(help);
1059 if (!opts->x_quiet_flag)
1061 snprintf (new_help, sizeof (new_help),
1062 _("default %d minimum %d maximum %d"),
1063 compiler_params[i].default_value,
1064 compiler_params[i].min_value,
1065 compiler_params[i].max_value);
1066 help = new_help;
1068 wrap_help (help, param, strlen (param), columns);
1070 putchar ('\n');
1071 return;
1074 if (!opts->x_help_printed)
1075 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
1077 if (!opts->x_help_enum_printed)
1078 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
1080 for (i = 0; i < cl_options_count; i++)
1082 const struct cl_option *option = cl_options + i;
1083 unsigned int len;
1084 const char *opt;
1085 const char *tab;
1087 if (include_flags == 0
1088 || ((option->flags & include_flags) != include_flags))
1090 if ((option->flags & any_flags) == 0)
1091 continue;
1094 /* Skip unwanted switches. */
1095 if ((option->flags & exclude_flags) != 0)
1096 continue;
1098 /* The driver currently prints its own help text. */
1099 if ((option->flags & CL_DRIVER) != 0
1100 && (option->flags & (((1U << cl_lang_count) - 1)
1101 | CL_COMMON | CL_TARGET)) == 0)
1102 continue;
1104 found = true;
1105 /* Skip switches that have already been printed. */
1106 if (opts->x_help_printed[i])
1107 continue;
1109 opts->x_help_printed[i] = true;
1111 help = option->help;
1112 if (help == NULL)
1114 if (exclude_flags & CL_UNDOCUMENTED)
1115 continue;
1117 help = undocumented_msg;
1120 if (option->alias_target < N_OPTS
1121 && cl_options [option->alias_target].help)
1123 if (help == undocumented_msg)
1125 /* For undocumented options that are aliases for other options
1126 that are documented, point the reader to the other option in
1127 preference of the former. */
1128 snprintf (new_help, sizeof new_help,
1129 _("Same as %s. Use the latter option instead."),
1130 cl_options [option->alias_target].opt_text);
1132 else
1134 /* For documented options with aliases, mention the aliased
1135 option's name for reference. */
1136 snprintf (new_help, sizeof new_help,
1137 _("%s Same as %s."),
1138 help, cl_options [option->alias_target].opt_text);
1141 help = new_help;
1144 if (option->warn_message)
1146 /* Mention that the use of the option will trigger a warning. */
1147 if (help == new_help)
1148 snprintf (new_help + strlen (new_help),
1149 sizeof new_help - strlen (new_help),
1150 " %s", _(use_diagnosed_msg));
1151 else
1152 snprintf (new_help, sizeof new_help,
1153 "%s %s", help, _(use_diagnosed_msg));
1155 help = new_help;
1158 /* Get the translation. */
1159 help = _(help);
1161 /* Find the gap between the name of the
1162 option and its descriptive text. */
1163 tab = strchr (help, '\t');
1164 if (tab)
1166 len = tab - help;
1167 opt = help;
1168 help = tab + 1;
1170 else
1172 opt = option->opt_text;
1173 len = strlen (opt);
1176 /* With the -Q option enabled we change the descriptive text associated
1177 with an option to be an indication of its current setting. */
1178 if (!opts->x_quiet_flag)
1180 void *flag_var = option_flag_var (i, opts);
1182 if (len < (LEFT_COLUMN + 2))
1183 strcpy (new_help, "\t\t");
1184 else
1185 strcpy (new_help, "\t");
1187 if (flag_var != NULL
1188 && option->var_type != CLVC_DEFER)
1190 if (option->flags & CL_JOINED)
1192 if (option->var_type == CLVC_STRING)
1194 if (* (const char **) flag_var != NULL)
1195 snprintf (new_help + strlen (new_help),
1196 sizeof (new_help) - strlen (new_help),
1197 "%s", * (const char **) flag_var);
1199 else if (option->var_type == CLVC_ENUM)
1201 const struct cl_enum *e = &cl_enums[option->var_enum];
1202 int value;
1203 const char *arg = NULL;
1205 value = e->get (flag_var);
1206 enum_value_to_arg (e->values, &arg, value, lang_mask);
1207 if (arg == NULL)
1208 arg = _("[default]");
1209 snprintf (new_help + strlen (new_help),
1210 sizeof (new_help) - strlen (new_help),
1211 "%s", arg);
1213 else
1214 sprintf (new_help + strlen (new_help),
1215 "%#x", * (int *) flag_var);
1217 else
1218 strcat (new_help, option_enabled (i, opts)
1219 ? _("[enabled]") : _("[disabled]"));
1222 help = new_help;
1225 wrap_help (help, opt, len, columns);
1226 displayed = true;
1228 if (option->var_type == CLVC_ENUM
1229 && opts->x_help_enum_printed[option->var_enum] != 2)
1230 opts->x_help_enum_printed[option->var_enum] = 1;
1233 if (! found)
1235 unsigned int langs = include_flags & CL_LANG_ALL;
1237 if (langs == 0)
1238 printf (_(" No options with the desired characteristics were found\n"));
1239 else
1241 unsigned int i;
1243 /* PR 31349: Tell the user how to see all of the
1244 options supported by a specific front end. */
1245 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1246 if ((1U << i) & langs)
1247 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end.\n"),
1248 lang_names[i], lang_names[i]);
1252 else if (! displayed)
1253 printf (_(" All options with the desired characteristics have already been displayed\n"));
1255 putchar ('\n');
1257 /* Print details of enumerated option arguments, if those
1258 enumerations have help text headings provided. If no help text
1259 is provided, presume that the possible values are listed in the
1260 help text for the relevant options. */
1261 for (i = 0; i < cl_enums_count; i++)
1263 unsigned int j, pos;
1265 if (opts->x_help_enum_printed[i] != 1)
1266 continue;
1267 if (cl_enums[i].help == NULL)
1268 continue;
1269 printf (" %s\n ", _(cl_enums[i].help));
1270 pos = 4;
1271 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1273 unsigned int len = strlen (cl_enums[i].values[j].arg);
1275 if (pos > 4 && pos + 1 + len <= columns)
1277 printf (" %s", cl_enums[i].values[j].arg);
1278 pos += 1 + len;
1280 else
1282 if (pos > 4)
1284 printf ("\n ");
1285 pos = 4;
1287 printf ("%s", cl_enums[i].values[j].arg);
1288 pos += len;
1291 printf ("\n\n");
1292 opts->x_help_enum_printed[i] = 2;
1296 /* Display help for a specified type of option.
1297 The options must have ALL of the INCLUDE_FLAGS set
1298 ANY of the flags in the ANY_FLAGS set
1299 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1300 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1301 static void
1302 print_specific_help (unsigned int include_flags,
1303 unsigned int exclude_flags,
1304 unsigned int any_flags,
1305 struct gcc_options *opts,
1306 unsigned int lang_mask)
1308 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1309 const char * description = NULL;
1310 const char * descrip_extra = "";
1311 size_t i;
1312 unsigned int flag;
1314 /* Sanity check: Make sure that we do not have more
1315 languages than we have bits available to enumerate them. */
1316 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1318 /* If we have not done so already, obtain
1319 the desired maximum width of the output. */
1320 if (opts->x_help_columns == 0)
1322 opts->x_help_columns = get_terminal_width ();
1323 if (opts->x_help_columns == INT_MAX)
1324 /* Use a reasonable default. */
1325 opts->x_help_columns = 80;
1328 /* Decide upon the title for the options that we are going to display. */
1329 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1331 switch (flag & include_flags)
1333 case 0:
1334 case CL_DRIVER:
1335 break;
1337 case CL_TARGET:
1338 description = _("The following options are target specific");
1339 break;
1340 case CL_WARNING:
1341 description = _("The following options control compiler warning messages");
1342 break;
1343 case CL_OPTIMIZATION:
1344 description = _("The following options control optimizations");
1345 break;
1346 case CL_COMMON:
1347 description = _("The following options are language-independent");
1348 break;
1349 case CL_PARAMS:
1350 description = _("The --param option recognizes the following as parameters");
1351 break;
1352 default:
1353 if (i >= cl_lang_count)
1354 break;
1355 if (exclude_flags & all_langs_mask)
1356 description = _("The following options are specific to just the language ");
1357 else
1358 description = _("The following options are supported by the language ");
1359 descrip_extra = lang_names [i];
1360 break;
1364 if (description == NULL)
1366 if (any_flags == 0)
1368 if (include_flags & CL_UNDOCUMENTED)
1369 description = _("The following options are not documented");
1370 else if (include_flags & CL_SEPARATE)
1371 description = _("The following options take separate arguments");
1372 else if (include_flags & CL_JOINED)
1373 description = _("The following options take joined arguments");
1374 else
1376 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1377 include_flags);
1378 return;
1381 else
1383 if (any_flags & all_langs_mask)
1384 description = _("The following options are language-related");
1385 else
1386 description = _("The following options are language-independent");
1390 printf ("%s%s:\n", description, descrip_extra);
1391 print_filtered_help (include_flags, exclude_flags, any_flags,
1392 opts->x_help_columns, opts, lang_mask);
1395 /* Enable FDO-related flags. */
1397 static void
1398 enable_fdo_optimizations (struct gcc_options *opts,
1399 struct gcc_options *opts_set,
1400 int value)
1402 if (!opts_set->x_flag_branch_probabilities)
1403 opts->x_flag_branch_probabilities = value;
1404 if (!opts_set->x_flag_profile_values)
1405 opts->x_flag_profile_values = value;
1406 if (!opts_set->x_flag_unroll_loops)
1407 opts->x_flag_unroll_loops = value;
1408 if (!opts_set->x_flag_peel_loops)
1409 opts->x_flag_peel_loops = value;
1410 if (!opts_set->x_flag_tracer)
1411 opts->x_flag_tracer = value;
1412 if (!opts_set->x_flag_value_profile_transformations)
1413 opts->x_flag_value_profile_transformations = value;
1414 if (!opts_set->x_flag_inline_functions)
1415 opts->x_flag_inline_functions = value;
1416 if (!opts_set->x_flag_ipa_cp)
1417 opts->x_flag_ipa_cp = value;
1418 if (!opts_set->x_flag_ipa_cp_clone
1419 && value && opts->x_flag_ipa_cp)
1420 opts->x_flag_ipa_cp_clone = value;
1421 if (!opts_set->x_flag_ipa_cp_alignment
1422 && value && opts->x_flag_ipa_cp)
1423 opts->x_flag_ipa_cp_alignment = value;
1424 if (!opts_set->x_flag_predictive_commoning)
1425 opts->x_flag_predictive_commoning = value;
1426 if (!opts_set->x_flag_unswitch_loops)
1427 opts->x_flag_unswitch_loops = value;
1428 if (!opts_set->x_flag_gcse_after_reload)
1429 opts->x_flag_gcse_after_reload = value;
1430 if (!opts_set->x_flag_tree_loop_vectorize
1431 && !opts_set->x_flag_tree_vectorize)
1432 opts->x_flag_tree_loop_vectorize = value;
1433 if (!opts_set->x_flag_tree_slp_vectorize
1434 && !opts_set->x_flag_tree_vectorize)
1435 opts->x_flag_tree_slp_vectorize = value;
1436 if (!opts_set->x_flag_vect_cost_model)
1437 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1438 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1439 opts->x_flag_tree_loop_distribute_patterns = value;
1442 /* -f{,no-}sanitize{,-recover}= suboptions. */
1443 const struct sanitizer_opts_s sanitizer_opts[] =
1445 #define SANITIZER_OPT(name, flags) { #name, flags, sizeof #name - 1 }
1446 SANITIZER_OPT (address, SANITIZE_ADDRESS | SANITIZE_USER_ADDRESS),
1447 SANITIZER_OPT (kernel-address, SANITIZE_ADDRESS | SANITIZE_KERNEL_ADDRESS),
1448 SANITIZER_OPT (thread, SANITIZE_THREAD),
1449 SANITIZER_OPT (leak, SANITIZE_LEAK),
1450 SANITIZER_OPT (shift, SANITIZE_SHIFT),
1451 SANITIZER_OPT (integer-divide-by-zero, SANITIZE_DIVIDE),
1452 SANITIZER_OPT (undefined, SANITIZE_UNDEFINED),
1453 SANITIZER_OPT (unreachable, SANITIZE_UNREACHABLE),
1454 SANITIZER_OPT (vla-bound, SANITIZE_VLA),
1455 SANITIZER_OPT (return, SANITIZE_RETURN),
1456 SANITIZER_OPT (null, SANITIZE_NULL),
1457 SANITIZER_OPT (signed-integer-overflow, SANITIZE_SI_OVERFLOW),
1458 SANITIZER_OPT (bool, SANITIZE_BOOL),
1459 SANITIZER_OPT (enum, SANITIZE_ENUM),
1460 SANITIZER_OPT (float-divide-by-zero, SANITIZE_FLOAT_DIVIDE),
1461 SANITIZER_OPT (float-cast-overflow, SANITIZE_FLOAT_CAST),
1462 SANITIZER_OPT (bounds, SANITIZE_BOUNDS),
1463 SANITIZER_OPT (bounds-strict, SANITIZE_BOUNDS | SANITIZE_BOUNDS_STRICT),
1464 SANITIZER_OPT (alignment, SANITIZE_ALIGNMENT),
1465 SANITIZER_OPT (nonnull-attribute, SANITIZE_NONNULL_ATTRIBUTE),
1466 SANITIZER_OPT (returns-nonnull-attribute, SANITIZE_RETURNS_NONNULL_ATTRIBUTE),
1467 SANITIZER_OPT (object-size, SANITIZE_OBJECT_SIZE),
1468 SANITIZER_OPT (vptr, SANITIZE_VPTR),
1469 SANITIZER_OPT (all, ~0),
1470 #undef SANITIZER_OPT
1471 { NULL, 0, 0 }
1474 /* Parse comma separated sanitizer suboptions from P for option SCODE,
1475 adjust previous FLAGS and return new ones. If COMPLAIN is false,
1476 don't issue diagnostics. */
1478 unsigned int
1479 parse_sanitizer_options (const char *p, location_t loc, int scode,
1480 unsigned int flags, int value, bool complain)
1482 enum opt_code code = (enum opt_code) scode;
1483 while (*p != 0)
1485 size_t len, i;
1486 bool found = false;
1487 const char *comma = strchr (p, ',');
1489 if (comma == NULL)
1490 len = strlen (p);
1491 else
1492 len = comma - p;
1493 if (len == 0)
1495 p = comma + 1;
1496 continue;
1499 /* Check to see if the string matches an option class name. */
1500 for (i = 0; sanitizer_opts[i].name != NULL; ++i)
1501 if (len == sanitizer_opts[i].len
1502 && memcmp (p, sanitizer_opts[i].name, len) == 0)
1504 /* Handle both -fsanitize and -fno-sanitize cases. */
1505 if (value && sanitizer_opts[i].flag == ~0U)
1507 if (code == OPT_fsanitize_)
1509 if (complain)
1510 error_at (loc, "-fsanitize=all option is not valid");
1512 else
1513 flags |= ~(SANITIZE_USER_ADDRESS | SANITIZE_THREAD
1514 | SANITIZE_LEAK);
1516 else if (value)
1517 flags |= sanitizer_opts[i].flag;
1518 else
1519 flags &= ~sanitizer_opts[i].flag;
1520 found = true;
1521 break;
1524 if (! found && complain)
1525 error_at (loc, "unrecognized argument to -fsanitize%s= option: %q.*s",
1526 code == OPT_fsanitize_ ? "" : "-recover", (int) len, p);
1528 if (comma == NULL)
1529 break;
1530 p = comma + 1;
1532 return flags;
1535 /* Handle target- and language-independent options. Return zero to
1536 generate an "unknown option" message. Only options that need
1537 extra handling need to be listed here; if you simply want
1538 DECODED->value assigned to a variable, it happens automatically. */
1540 bool
1541 common_handle_option (struct gcc_options *opts,
1542 struct gcc_options *opts_set,
1543 const struct cl_decoded_option *decoded,
1544 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1545 location_t loc,
1546 const struct cl_option_handlers *handlers,
1547 diagnostic_context *dc)
1549 size_t scode = decoded->opt_index;
1550 const char *arg = decoded->arg;
1551 int value = decoded->value;
1552 enum opt_code code = (enum opt_code) scode;
1554 gcc_assert (decoded->canonical_option_num_elements <= 2);
1556 switch (code)
1558 case OPT__param:
1559 handle_param (opts, opts_set, loc, arg);
1560 break;
1562 case OPT__help:
1564 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1565 unsigned int undoc_mask;
1566 unsigned int i;
1568 if (lang_mask == CL_DRIVER)
1569 break;
1571 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1573 : CL_UNDOCUMENTED);
1574 /* First display any single language specific options. */
1575 for (i = 0; i < cl_lang_count; i++)
1576 print_specific_help
1577 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1578 lang_mask);
1579 /* Next display any multi language specific options. */
1580 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1581 /* Then display any remaining, non-language options. */
1582 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1583 if (i != CL_DRIVER)
1584 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1585 opts->x_exit_after_options = true;
1586 break;
1589 case OPT__target_help:
1590 if (lang_mask == CL_DRIVER)
1591 break;
1593 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1594 opts->x_exit_after_options = true;
1595 break;
1597 case OPT__help_:
1599 const char *a = arg;
1600 unsigned int include_flags = 0;
1601 /* Note - by default we include undocumented options when listing
1602 specific classes. If you only want to see documented options
1603 then add ",^undocumented" to the --help= option. E.g.:
1605 --help=target,^undocumented */
1606 unsigned int exclude_flags = 0;
1608 if (lang_mask == CL_DRIVER)
1609 break;
1611 /* Walk along the argument string, parsing each word in turn.
1612 The format is:
1613 arg = [^]{word}[,{arg}]
1614 word = {optimizers|target|warnings|undocumented|
1615 params|common|<language>} */
1616 while (*a != 0)
1618 static const struct
1620 const char *string;
1621 unsigned int flag;
1623 specifics[] =
1625 { "optimizers", CL_OPTIMIZATION },
1626 { "target", CL_TARGET },
1627 { "warnings", CL_WARNING },
1628 { "undocumented", CL_UNDOCUMENTED },
1629 { "params", CL_PARAMS },
1630 { "joined", CL_JOINED },
1631 { "separate", CL_SEPARATE },
1632 { "common", CL_COMMON },
1633 { NULL, 0 }
1635 unsigned int *pflags;
1636 const char *comma;
1637 unsigned int lang_flag, specific_flag;
1638 unsigned int len;
1639 unsigned int i;
1641 if (*a == '^')
1643 ++a;
1644 if (*a == '\0')
1646 error_at (loc, "missing argument to %qs", "--help=^");
1647 break;
1649 pflags = &exclude_flags;
1651 else
1652 pflags = &include_flags;
1654 comma = strchr (a, ',');
1655 if (comma == NULL)
1656 len = strlen (a);
1657 else
1658 len = comma - a;
1659 if (len == 0)
1661 a = comma + 1;
1662 continue;
1665 /* Check to see if the string matches an option class name. */
1666 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1667 if (strncasecmp (a, specifics[i].string, len) == 0)
1669 specific_flag = specifics[i].flag;
1670 break;
1673 /* Check to see if the string matches a language name.
1674 Note - we rely upon the alpha-sorted nature of the entries in
1675 the lang_names array, specifically that shorter names appear
1676 before their longer variants. (i.e. C before C++). That way
1677 when we are attempting to match --help=c for example we will
1678 match with C first and not C++. */
1679 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1680 if (strncasecmp (a, lang_names[i], len) == 0)
1682 lang_flag = 1U << i;
1683 break;
1686 if (specific_flag != 0)
1688 if (lang_flag == 0)
1689 *pflags |= specific_flag;
1690 else
1692 /* The option's argument matches both the start of a
1693 language name and the start of an option class name.
1694 We have a special case for when the user has
1695 specified "--help=c", but otherwise we have to issue
1696 a warning. */
1697 if (strncasecmp (a, "c", len) == 0)
1698 *pflags |= lang_flag;
1699 else
1700 warning_at (loc, 0,
1701 "--help argument %q.*s is ambiguous, "
1702 "please be more specific",
1703 len, a);
1706 else if (lang_flag != 0)
1707 *pflags |= lang_flag;
1708 else
1709 warning_at (loc, 0,
1710 "unrecognized argument to --help= option: %q.*s",
1711 len, a);
1713 if (comma == NULL)
1714 break;
1715 a = comma + 1;
1718 if (include_flags)
1719 print_specific_help (include_flags, exclude_flags, 0, opts,
1720 lang_mask);
1721 opts->x_exit_after_options = true;
1722 break;
1725 case OPT__version:
1726 if (lang_mask == CL_DRIVER)
1727 break;
1729 opts->x_exit_after_options = true;
1730 break;
1732 case OPT_fsanitize_:
1733 opts->x_flag_sanitize
1734 = parse_sanitizer_options (arg, loc, code,
1735 opts->x_flag_sanitize, value, true);
1737 /* Kernel ASan implies normal ASan but does not yet support
1738 all features. */
1739 if (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS)
1741 maybe_set_param_value (PARAM_ASAN_INSTRUMENTATION_WITH_CALL_THRESHOLD,
1742 0, opts->x_param_values,
1743 opts_set->x_param_values);
1744 maybe_set_param_value (PARAM_ASAN_GLOBALS, 0, opts->x_param_values,
1745 opts_set->x_param_values);
1746 maybe_set_param_value (PARAM_ASAN_STACK, 0, opts->x_param_values,
1747 opts_set->x_param_values);
1748 maybe_set_param_value (PARAM_ASAN_USE_AFTER_RETURN, 0,
1749 opts->x_param_values,
1750 opts_set->x_param_values);
1752 break;
1754 case OPT_fsanitize_recover_:
1755 opts->x_flag_sanitize_recover
1756 = parse_sanitizer_options (arg, loc, code,
1757 opts->x_flag_sanitize_recover, value, true);
1758 break;
1760 case OPT_fasan_shadow_offset_:
1761 /* Deferred. */
1762 break;
1764 case OPT_fsanitize_recover:
1765 if (value)
1766 opts->x_flag_sanitize_recover
1767 |= SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT;
1768 else
1769 opts->x_flag_sanitize_recover
1770 &= ~(SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT);
1771 break;
1773 case OPT_O:
1774 case OPT_Os:
1775 case OPT_Ofast:
1776 case OPT_Og:
1777 /* Currently handled in a prescan. */
1778 break;
1780 case OPT_Werror:
1781 dc->warning_as_error_requested = value;
1782 break;
1784 case OPT_Werror_:
1785 if (lang_mask == CL_DRIVER)
1786 break;
1788 enable_warning_as_error (arg, value, lang_mask, handlers,
1789 opts, opts_set, loc, dc);
1790 break;
1792 case OPT_Wlarger_than_:
1793 opts->x_larger_than_size = value;
1794 opts->x_warn_larger_than = value != -1;
1795 break;
1797 case OPT_Wfatal_errors:
1798 dc->fatal_errors = value;
1799 break;
1801 case OPT_Wframe_larger_than_:
1802 opts->x_frame_larger_than_size = value;
1803 opts->x_warn_frame_larger_than = value != -1;
1804 break;
1806 case OPT_Wstack_usage_:
1807 opts->x_warn_stack_usage = value;
1808 opts->x_flag_stack_usage_info = value != -1;
1809 break;
1811 case OPT_Wstrict_aliasing:
1812 set_Wstrict_aliasing (opts, value);
1813 break;
1815 case OPT_Wstrict_overflow:
1816 opts->x_warn_strict_overflow = (value
1817 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1818 : 0);
1819 break;
1821 case OPT_Wsystem_headers:
1822 dc->dc_warn_system_headers = value;
1823 break;
1825 case OPT_aux_info:
1826 opts->x_flag_gen_aux_info = 1;
1827 break;
1829 case OPT_auxbase_strip:
1831 char *tmp = xstrdup (arg);
1832 strip_off_ending (tmp, strlen (tmp));
1833 if (tmp[0])
1834 opts->x_aux_base_name = tmp;
1835 else
1836 free (tmp);
1838 break;
1840 case OPT_d:
1841 decode_d_option (arg, opts, loc, dc);
1842 break;
1844 case OPT_fcall_used_:
1845 case OPT_fcall_saved_:
1846 /* Deferred. */
1847 break;
1849 case OPT_fdbg_cnt_:
1850 /* Deferred. */
1851 break;
1853 case OPT_fdbg_cnt_list:
1854 /* Deferred. */
1855 opts->x_exit_after_options = true;
1856 break;
1858 case OPT_fdebug_prefix_map_:
1859 /* Deferred. */
1860 break;
1862 case OPT_fdiagnostics_show_location_:
1863 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1864 break;
1866 case OPT_fdiagnostics_show_caret:
1867 dc->show_caret = value;
1868 break;
1870 case OPT_fdiagnostics_color_:
1871 diagnostic_color_init (dc, value);
1872 break;
1874 case OPT_fdiagnostics_parseable_fixits:
1875 dc->parseable_fixits_p = value;
1876 break;
1878 case OPT_fdiagnostics_show_option:
1879 dc->show_option_requested = value;
1880 break;
1882 case OPT_fdump_:
1883 /* Deferred. */
1884 break;
1886 case OPT_ffast_math:
1887 set_fast_math_flags (opts, value);
1888 break;
1890 case OPT_funsafe_math_optimizations:
1891 set_unsafe_math_optimizations_flags (opts, value);
1892 break;
1894 case OPT_ffixed_:
1895 /* Deferred. */
1896 break;
1898 case OPT_finline_limit_:
1899 set_param_value ("max-inline-insns-single", value / 2,
1900 opts->x_param_values, opts_set->x_param_values);
1901 set_param_value ("max-inline-insns-auto", value / 2,
1902 opts->x_param_values, opts_set->x_param_values);
1903 break;
1905 case OPT_finstrument_functions_exclude_function_list_:
1906 add_comma_separated_to_vector
1907 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1908 break;
1910 case OPT_finstrument_functions_exclude_file_list_:
1911 add_comma_separated_to_vector
1912 (&opts->x_flag_instrument_functions_exclude_files, arg);
1913 break;
1915 case OPT_fmessage_length_:
1916 pp_set_line_maximum_length (dc->printer, value);
1917 diagnostic_set_caret_max_width (dc, value);
1918 break;
1920 case OPT_fopt_info:
1921 case OPT_fopt_info_:
1922 /* Deferred. */
1923 break;
1925 case OPT_foffload_:
1927 const char *p = arg;
1928 opts->x_flag_disable_hsa = true;
1929 while (*p != 0)
1931 const char *comma = strchr (p, ',');
1933 if ((strncmp (p, "disable", 7) == 0)
1934 && (p[7] == ',' || p[7] == '\0'))
1936 opts->x_flag_disable_hsa = true;
1937 break;
1940 if ((strncmp (p, "hsa", 3) == 0)
1941 && (p[3] == ',' || p[3] == '\0'))
1943 #ifdef ENABLE_HSA
1944 opts->x_flag_disable_hsa = false;
1945 #else
1946 sorry ("HSA has not been enabled during configuration");
1947 #endif
1949 if (!comma)
1950 break;
1951 p = comma + 1;
1953 break;
1956 #ifndef ACCEL_COMPILER
1957 case OPT_foffload_abi_:
1958 error_at (loc, "-foffload-abi option can be specified only for "
1959 "offload compiler");
1960 break;
1961 #endif
1963 case OPT_fpack_struct_:
1964 if (value <= 0 || (value & (value - 1)) || value > 16)
1965 error_at (loc,
1966 "structure alignment must be a small power of two, not %d",
1967 value);
1968 else
1969 opts->x_initial_max_fld_align = value;
1970 break;
1972 case OPT_fplugin_:
1973 case OPT_fplugin_arg_:
1974 /* Deferred. */
1975 break;
1977 case OPT_fprofile_use_:
1978 opts->x_profile_data_prefix = xstrdup (arg);
1979 opts->x_flag_profile_use = true;
1980 value = true;
1981 /* No break here - do -fprofile-use processing. */
1982 case OPT_fprofile_use:
1983 enable_fdo_optimizations (opts, opts_set, value);
1984 if (!opts_set->x_flag_profile_reorder_functions)
1985 opts->x_flag_profile_reorder_functions = value;
1986 /* Indirect call profiling should do all useful transformations
1987 speculative devirtualization does. */
1988 if (!opts_set->x_flag_devirtualize_speculatively
1989 && opts->x_flag_value_profile_transformations)
1990 opts->x_flag_devirtualize_speculatively = false;
1991 break;
1993 case OPT_fauto_profile_:
1994 opts->x_auto_profile_file = xstrdup (arg);
1995 opts->x_flag_auto_profile = true;
1996 value = true;
1997 /* No break here - do -fauto-profile processing. */
1998 case OPT_fauto_profile:
1999 enable_fdo_optimizations (opts, opts_set, value);
2000 if (!opts_set->x_flag_profile_correction)
2001 opts->x_flag_profile_correction = value;
2002 maybe_set_param_value (
2003 PARAM_EARLY_INLINER_MAX_ITERATIONS, 10,
2004 opts->x_param_values, opts_set->x_param_values);
2005 break;
2007 case OPT_fprofile_generate_:
2008 opts->x_profile_data_prefix = xstrdup (arg);
2009 value = true;
2010 /* No break here - do -fprofile-generate processing. */
2011 case OPT_fprofile_generate:
2012 if (!opts_set->x_profile_arc_flag)
2013 opts->x_profile_arc_flag = value;
2014 if (!opts_set->x_flag_profile_values)
2015 opts->x_flag_profile_values = value;
2016 if (!opts_set->x_flag_inline_functions)
2017 opts->x_flag_inline_functions = value;
2018 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
2019 quadratic. Disable the pass until better memory representation
2020 is done. */
2021 if (!opts_set->x_flag_ipa_reference)
2022 opts->x_flag_ipa_reference = false;
2023 break;
2025 case OPT_ftree_vectorize:
2026 if (!opts_set->x_flag_tree_loop_vectorize)
2027 opts->x_flag_tree_loop_vectorize = value;
2028 if (!opts_set->x_flag_tree_slp_vectorize)
2029 opts->x_flag_tree_slp_vectorize = value;
2030 break;
2031 case OPT_fshow_column:
2032 dc->show_column = value;
2033 break;
2035 case OPT_frandom_seed:
2036 /* The real switch is -fno-random-seed. */
2037 if (value)
2038 return false;
2039 /* Deferred. */
2040 break;
2042 case OPT_frandom_seed_:
2043 /* Deferred. */
2044 break;
2046 case OPT_fsched_verbose_:
2047 #ifdef INSN_SCHEDULING
2048 /* Handled with Var in common.opt. */
2049 break;
2050 #else
2051 return false;
2052 #endif
2054 case OPT_fsched_stalled_insns_:
2055 opts->x_flag_sched_stalled_insns = value;
2056 if (opts->x_flag_sched_stalled_insns == 0)
2057 opts->x_flag_sched_stalled_insns = -1;
2058 break;
2060 case OPT_fsched_stalled_insns_dep_:
2061 opts->x_flag_sched_stalled_insns_dep = value;
2062 break;
2064 case OPT_fstack_check_:
2065 if (!strcmp (arg, "no"))
2066 opts->x_flag_stack_check = NO_STACK_CHECK;
2067 else if (!strcmp (arg, "generic"))
2068 /* This is the old stack checking method. */
2069 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2070 ? FULL_BUILTIN_STACK_CHECK
2071 : GENERIC_STACK_CHECK;
2072 else if (!strcmp (arg, "specific"))
2073 /* This is the new stack checking method. */
2074 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2075 ? FULL_BUILTIN_STACK_CHECK
2076 : STACK_CHECK_STATIC_BUILTIN
2077 ? STATIC_BUILTIN_STACK_CHECK
2078 : GENERIC_STACK_CHECK;
2079 else
2080 warning_at (loc, 0, "unknown stack check parameter %qs", arg);
2081 break;
2083 case OPT_fstack_limit:
2084 /* The real switch is -fno-stack-limit. */
2085 if (value)
2086 return false;
2087 /* Deferred. */
2088 break;
2090 case OPT_fstack_limit_register_:
2091 case OPT_fstack_limit_symbol_:
2092 /* Deferred. */
2093 break;
2095 case OPT_fstack_usage:
2096 opts->x_flag_stack_usage = value;
2097 opts->x_flag_stack_usage_info = value != 0;
2098 break;
2100 case OPT_g:
2101 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
2102 loc);
2103 break;
2105 case OPT_gcoff:
2106 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
2107 break;
2109 case OPT_gdwarf:
2110 if (arg && strlen (arg) != 0)
2112 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
2113 "use %<-gdwarf-%s%> for DWARF version "
2114 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
2115 break;
2117 else
2118 value = opts->x_dwarf_version;
2120 /* FALLTHRU */
2121 case OPT_gdwarf_:
2122 if (value < 2 || value > 5)
2123 error_at (loc, "dwarf version %d is not supported", value);
2124 else
2125 opts->x_dwarf_version = value;
2126 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
2127 break;
2129 case OPT_gsplit_dwarf:
2130 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
2131 loc);
2132 break;
2134 case OPT_ggdb:
2135 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
2136 break;
2138 case OPT_gstabs:
2139 case OPT_gstabs_:
2140 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
2141 loc);
2142 break;
2144 case OPT_gvms:
2145 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
2146 break;
2148 case OPT_gxcoff:
2149 case OPT_gxcoff_:
2150 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
2151 loc);
2152 break;
2154 case OPT_gz:
2155 case OPT_gz_:
2156 /* Handled completely via specs. */
2157 break;
2159 case OPT_pedantic_errors:
2160 dc->pedantic_errors = 1;
2161 control_warning_option (OPT_Wpedantic, DK_ERROR, NULL, value,
2162 loc, lang_mask,
2163 handlers, opts, opts_set,
2164 dc);
2165 break;
2167 case OPT_flto:
2168 opts->x_flag_lto = value ? "" : NULL;
2169 break;
2171 case OPT_w:
2172 dc->dc_inhibit_warnings = true;
2173 break;
2175 case OPT_fmax_errors_:
2176 dc->max_errors = value;
2177 break;
2179 case OPT_fuse_ld_bfd:
2180 case OPT_fuse_ld_gold:
2181 case OPT_fuse_linker_plugin:
2182 /* No-op. Used by the driver and passed to us because it starts with f.*/
2183 break;
2185 case OPT_fwrapv:
2186 if (value)
2187 opts->x_flag_trapv = 0;
2188 break;
2190 case OPT_ftrapv:
2191 if (value)
2192 opts->x_flag_wrapv = 0;
2193 break;
2195 case OPT_fipa_icf:
2196 opts->x_flag_ipa_icf_functions = value;
2197 opts->x_flag_ipa_icf_variables = value;
2198 break;
2200 default:
2201 /* If the flag was handled in a standard way, assume the lack of
2202 processing here is intentional. */
2203 gcc_assert (option_flag_var (scode, opts));
2204 break;
2207 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
2208 loc, handlers, dc);
2209 return true;
2212 /* Handle --param NAME=VALUE. */
2213 static void
2214 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
2215 location_t loc, const char *carg)
2217 char *equal, *arg;
2218 int value;
2220 arg = xstrdup (carg);
2221 equal = strchr (arg, '=');
2222 if (!equal)
2223 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
2224 arg);
2225 else
2227 *equal = '\0';
2229 enum compiler_param index;
2230 if (!find_param (arg, &index))
2231 error_at (loc, "invalid --param name %qs", arg);
2232 else
2234 if (!param_string_value_p (index, equal + 1, &value))
2235 value = integral_argument (equal + 1);
2237 if (value == -1)
2238 error_at (loc, "invalid --param value %qs", equal + 1);
2239 else
2240 set_param_value (arg, value,
2241 opts->x_param_values, opts_set->x_param_values);
2245 free (arg);
2248 /* Used to set the level of strict aliasing warnings in OPTS,
2249 when no level is specified (i.e., when -Wstrict-aliasing, and not
2250 -Wstrict-aliasing=level was given).
2251 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
2252 and 0 otherwise. After calling this function, wstrict_aliasing will be
2253 set to the default value of -Wstrict_aliasing=level, currently 3. */
2254 static void
2255 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
2257 gcc_assert (onoff == 0 || onoff == 1);
2258 if (onoff != 0)
2259 opts->x_warn_strict_aliasing = 3;
2260 else
2261 opts->x_warn_strict_aliasing = 0;
2264 /* The following routines are useful in setting all the flags that
2265 -ffast-math and -fno-fast-math imply. */
2266 static void
2267 set_fast_math_flags (struct gcc_options *opts, int set)
2269 if (!opts->frontend_set_flag_unsafe_math_optimizations)
2271 opts->x_flag_unsafe_math_optimizations = set;
2272 set_unsafe_math_optimizations_flags (opts, set);
2274 if (!opts->frontend_set_flag_finite_math_only)
2275 opts->x_flag_finite_math_only = set;
2276 if (!opts->frontend_set_flag_errno_math)
2277 opts->x_flag_errno_math = !set;
2278 if (set)
2280 if (!opts->frontend_set_flag_signaling_nans)
2281 opts->x_flag_signaling_nans = 0;
2282 if (!opts->frontend_set_flag_rounding_math)
2283 opts->x_flag_rounding_math = 0;
2284 if (!opts->frontend_set_flag_cx_limited_range)
2285 opts->x_flag_cx_limited_range = 1;
2289 /* When -funsafe-math-optimizations is set the following
2290 flags are set as well. */
2291 static void
2292 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
2294 if (!opts->frontend_set_flag_trapping_math)
2295 opts->x_flag_trapping_math = !set;
2296 if (!opts->frontend_set_flag_signed_zeros)
2297 opts->x_flag_signed_zeros = !set;
2298 if (!opts->frontend_set_flag_associative_math)
2299 opts->x_flag_associative_math = set;
2300 if (!opts->frontend_set_flag_reciprocal_math)
2301 opts->x_flag_reciprocal_math = set;
2304 /* Return true iff flags in OPTS are set as if -ffast-math. */
2305 bool
2306 fast_math_flags_set_p (const struct gcc_options *opts)
2308 return (!opts->x_flag_trapping_math
2309 && opts->x_flag_unsafe_math_optimizations
2310 && opts->x_flag_finite_math_only
2311 && !opts->x_flag_signed_zeros
2312 && !opts->x_flag_errno_math);
2315 /* Return true iff flags are set as if -ffast-math but using the flags stored
2316 in the struct cl_optimization structure. */
2317 bool
2318 fast_math_flags_struct_set_p (struct cl_optimization *opt)
2320 return (!opt->x_flag_trapping_math
2321 && opt->x_flag_unsafe_math_optimizations
2322 && opt->x_flag_finite_math_only
2323 && !opt->x_flag_signed_zeros
2324 && !opt->x_flag_errno_math);
2327 /* Handle a debug output -g switch for options OPTS
2328 (OPTS_SET->x_write_symbols storing whether a debug type was passed
2329 explicitly), location LOC. EXTENDED is true or false to support
2330 extended output (2 is special and means "-ggdb" was given). */
2331 static void
2332 set_debug_level (enum debug_info_type type, int extended, const char *arg,
2333 struct gcc_options *opts, struct gcc_options *opts_set,
2334 location_t loc)
2336 opts->x_use_gnu_debug_info_extensions = extended;
2338 if (type == NO_DEBUG)
2340 if (opts->x_write_symbols == NO_DEBUG)
2342 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
2344 if (extended == 2)
2346 #if defined DWARF2_DEBUGGING_INFO || defined DWARF2_LINENO_DEBUGGING_INFO
2347 opts->x_write_symbols = DWARF2_DEBUG;
2348 #elif defined DBX_DEBUGGING_INFO
2349 opts->x_write_symbols = DBX_DEBUG;
2350 #endif
2353 if (opts->x_write_symbols == NO_DEBUG)
2354 warning_at (loc, 0, "target system does not support debug output");
2357 else
2359 /* Does it conflict with an already selected type? */
2360 if (opts_set->x_write_symbols != NO_DEBUG
2361 && opts->x_write_symbols != NO_DEBUG
2362 && type != opts->x_write_symbols)
2363 error_at (loc, "debug format %qs conflicts with prior selection",
2364 debug_type_names[type]);
2365 opts->x_write_symbols = type;
2366 opts_set->x_write_symbols = type;
2369 /* A debug flag without a level defaults to level 2.
2370 If off or at level 1, set it to level 2, but if already
2371 at level 3, don't lower it. */
2372 if (*arg == '\0')
2374 if (opts->x_debug_info_level < DINFO_LEVEL_NORMAL)
2375 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2377 else
2379 int argval = integral_argument (arg);
2380 if (argval == -1)
2381 error_at (loc, "unrecognised debug output level %qs", arg);
2382 else if (argval > 3)
2383 error_at (loc, "debug output level %qs is too high", arg);
2384 else
2385 opts->x_debug_info_level = (enum debug_info_levels) argval;
2389 /* Arrange to dump core on error for diagnostic context DC. (The
2390 regular error message is still printed first, except in the case of
2391 abort ().) */
2393 static void
2394 setup_core_dumping (diagnostic_context *dc)
2396 #ifdef SIGABRT
2397 signal (SIGABRT, SIG_DFL);
2398 #endif
2399 #if defined(HAVE_SETRLIMIT)
2401 struct rlimit rlim;
2402 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2403 fatal_error (input_location, "getting core file size maximum limit: %m");
2404 rlim.rlim_cur = rlim.rlim_max;
2405 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2406 fatal_error (input_location,
2407 "setting core file size limit to maximum: %m");
2409 #endif
2410 diagnostic_abort_on_error (dc);
2413 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2414 diagnostic context DC. */
2416 static void
2417 decode_d_option (const char *arg, struct gcc_options *opts,
2418 location_t loc, diagnostic_context *dc)
2420 int c;
2422 while (*arg)
2423 switch (c = *arg++)
2425 case 'A':
2426 opts->x_flag_debug_asm = 1;
2427 break;
2428 case 'p':
2429 opts->x_flag_print_asm_name = 1;
2430 break;
2431 case 'P':
2432 opts->x_flag_dump_rtl_in_asm = 1;
2433 opts->x_flag_print_asm_name = 1;
2434 break;
2435 case 'x':
2436 opts->x_rtl_dump_and_exit = 1;
2437 break;
2438 case 'D': /* These are handled by the preprocessor. */
2439 case 'I':
2440 case 'M':
2441 case 'N':
2442 case 'U':
2443 break;
2444 case 'H':
2445 setup_core_dumping (dc);
2446 break;
2447 case 'a':
2448 opts->x_flag_dump_all_passed = true;
2449 break;
2451 default:
2452 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2453 break;
2457 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2458 mask LANG_MASK, option handlers HANDLERS) as an error for option
2459 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2460 NULL), location LOC. This is used by -Werror=. */
2462 static void
2463 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2464 const struct cl_option_handlers *handlers,
2465 struct gcc_options *opts,
2466 struct gcc_options *opts_set,
2467 location_t loc, diagnostic_context *dc)
2469 char *new_option;
2470 int option_index;
2472 new_option = XNEWVEC (char, strlen (arg) + 2);
2473 new_option[0] = 'W';
2474 strcpy (new_option + 1, arg);
2475 option_index = find_opt (new_option, lang_mask);
2476 if (option_index == OPT_SPECIAL_unknown)
2477 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2478 else if (!(cl_options[option_index].flags & CL_WARNING))
2479 error_at (loc, "-Werror=%s: -%s is not an option that controls warnings",
2480 arg, new_option);
2481 else
2483 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2484 const char *arg = NULL;
2486 if (cl_options[option_index].flags & CL_JOINED)
2487 arg = new_option + cl_options[option_index].opt_len;
2488 control_warning_option (option_index, (int) kind, arg, value,
2489 loc, lang_mask,
2490 handlers, opts, opts_set, dc);
2492 free (new_option);
2495 /* Return malloced memory for the name of the option OPTION_INDEX
2496 which enabled a diagnostic (context CONTEXT), originally of type
2497 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2498 as -Werror. */
2500 char *
2501 option_name (diagnostic_context *context, int option_index,
2502 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2504 if (option_index)
2506 /* A warning classified as an error. */
2507 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2508 && diag_kind == DK_ERROR)
2509 return concat (cl_options[OPT_Werror_].opt_text,
2510 /* Skip over "-W". */
2511 cl_options[option_index].opt_text + 2,
2512 NULL);
2513 /* A warning with option. */
2514 else
2515 return xstrdup (cl_options[option_index].opt_text);
2517 /* A warning without option classified as an error. */
2518 else if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2519 || diag_kind == DK_WARNING)
2520 && context->warning_as_error_requested)
2521 return xstrdup (cl_options[OPT_Werror].opt_text);
2522 else
2523 return NULL;