2016-01-19 Richard Biener <rguenther@suse.de>
[official-gcc.git] / gcc / opts.c
blob8e8410cd370025e969be179cdddbb418791056c0
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 if not initialized. */
271 void
272 init_opts_obstack (void)
274 static bool opts_obstack_initialized = false;
276 if (!opts_obstack_initialized)
278 opts_obstack_initialized = true;
279 gcc_obstack_init (&opts_obstack);
283 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
285 void
286 init_options_struct (struct gcc_options *opts, struct gcc_options *opts_set)
288 size_t num_params = get_num_compiler_params ();
290 init_opts_obstack ();
292 *opts = global_options_init;
294 if (opts_set)
295 memset (opts_set, 0, sizeof (*opts_set));
297 opts->x_param_values = XNEWVEC (int, num_params);
299 if (opts_set)
300 opts_set->x_param_values = XCNEWVEC (int, num_params);
302 init_param_values (opts->x_param_values);
304 /* Initialize whether `char' is signed. */
305 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
306 /* Set this to a special "uninitialized" value. The actual default
307 is set after target options have been processed. */
308 opts->x_flag_short_enums = 2;
310 /* Initialize target_flags before default_options_optimization
311 so the latter can modify it. */
312 opts->x_target_flags = targetm_common.default_target_flags;
314 /* Some targets have ABI-specified unwind tables. */
315 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
317 /* Some targets have other target-specific initialization. */
318 targetm_common.option_init_struct (opts);
321 /* Release any allocations owned by OPTS. */
323 void
324 finalize_options_struct (struct gcc_options *opts)
326 XDELETEVEC (opts->x_param_values);
329 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
330 -Ofast if FAST is set, -Og if DEBUG is set), apply the option DEFAULT_OPT
331 to OPTS and OPTS_SET, diagnostic context DC, location LOC, with language
332 mask LANG_MASK and option handlers HANDLERS. */
334 static void
335 maybe_default_option (struct gcc_options *opts,
336 struct gcc_options *opts_set,
337 const struct default_options *default_opt,
338 int level, bool size, bool fast, bool debug,
339 unsigned int lang_mask,
340 const struct cl_option_handlers *handlers,
341 location_t loc,
342 diagnostic_context *dc)
344 const struct cl_option *option = &cl_options[default_opt->opt_index];
345 bool enabled;
347 if (size)
348 gcc_assert (level == 2);
349 if (fast)
350 gcc_assert (level == 3);
351 if (debug)
352 gcc_assert (level == 1);
354 switch (default_opt->levels)
356 case OPT_LEVELS_ALL:
357 enabled = true;
358 break;
360 case OPT_LEVELS_0_ONLY:
361 enabled = (level == 0);
362 break;
364 case OPT_LEVELS_1_PLUS:
365 enabled = (level >= 1);
366 break;
368 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
369 enabled = (level >= 1 && !size && !debug);
370 break;
372 case OPT_LEVELS_1_PLUS_NOT_DEBUG:
373 enabled = (level >= 1 && !debug);
374 break;
376 case OPT_LEVELS_2_PLUS:
377 enabled = (level >= 2);
378 break;
380 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
381 enabled = (level >= 2 && !size && !debug);
382 break;
384 case OPT_LEVELS_3_PLUS:
385 enabled = (level >= 3);
386 break;
388 case OPT_LEVELS_3_PLUS_AND_SIZE:
389 enabled = (level >= 3 || size);
390 break;
392 case OPT_LEVELS_SIZE:
393 enabled = size;
394 break;
396 case OPT_LEVELS_FAST:
397 enabled = fast;
398 break;
400 case OPT_LEVELS_NONE:
401 default:
402 gcc_unreachable ();
405 if (enabled)
406 handle_generated_option (opts, opts_set, default_opt->opt_index,
407 default_opt->arg, default_opt->value,
408 lang_mask, DK_UNSPECIFIED, loc,
409 handlers, dc);
410 else if (default_opt->arg == NULL
411 && !option->cl_reject_negative)
412 handle_generated_option (opts, opts_set, default_opt->opt_index,
413 default_opt->arg, !default_opt->value,
414 lang_mask, DK_UNSPECIFIED, loc,
415 handlers, dc);
418 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
419 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
420 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
421 language mask LANG_MASK and option handlers HANDLERS. */
423 static void
424 maybe_default_options (struct gcc_options *opts,
425 struct gcc_options *opts_set,
426 const struct default_options *default_opts,
427 int level, bool size, bool fast, bool debug,
428 unsigned int lang_mask,
429 const struct cl_option_handlers *handlers,
430 location_t loc,
431 diagnostic_context *dc)
433 size_t i;
435 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
436 maybe_default_option (opts, opts_set, &default_opts[i],
437 level, size, fast, debug,
438 lang_mask, handlers, loc, dc);
441 /* Table of options enabled by default at different levels. */
443 static const struct default_options default_options_table[] =
445 /* -O1 optimizations. */
446 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
447 #if DELAY_SLOTS
448 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
449 #endif
450 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
451 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
452 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
453 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion, NULL, 1 },
454 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion2, NULL, 1 },
455 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
456 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
457 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
458 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
459 { OPT_LEVELS_1_PLUS, OPT_freorder_blocks, NULL, 1 },
460 { OPT_LEVELS_1_PLUS, OPT_fshrink_wrap, NULL, 1 },
461 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
462 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
463 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_bit_ccp, NULL, 1 },
464 { OPT_LEVELS_1_PLUS, OPT_ftree_coalesce_vars, NULL, 1 },
465 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
466 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
467 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
468 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
469 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_sra, NULL, 1 },
470 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
471 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
472 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
473 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
474 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
475 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
476 { OPT_LEVELS_1_PLUS, OPT_ftree_slsr, NULL, 1 },
477 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fbranch_count_reg, NULL, 1 },
478 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fmove_loop_invariants, NULL, 1 },
479 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_pta, NULL, 1 },
480 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fssa_phiopt, NULL, 1 },
481 { OPT_LEVELS_1_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
483 /* -O2 optimizations. */
484 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
488 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
489 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
490 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
491 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
492 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
493 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
494 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
495 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
496 #ifdef INSN_SCHEDULING
497 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
498 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
499 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
500 #endif
501 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
502 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
503 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
504 REORDER_BLOCKS_ALGORITHM_STC },
505 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
506 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
507 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
508 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
509 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
510 { OPT_LEVELS_2_PLUS, OPT_fipa_cp_alignment, NULL, 1 },
511 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
512 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
513 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
514 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
515 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
516 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
517 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
518 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
519 { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
520 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
521 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
522 { OPT_LEVELS_2_PLUS, OPT_fipa_icf, NULL, 1 },
523 { OPT_LEVELS_2_PLUS, OPT_fisolate_erroneous_paths_dereference, NULL, 1 },
524 { OPT_LEVELS_2_PLUS, OPT_fipa_ra, NULL, 1 },
525 { OPT_LEVELS_2_PLUS, OPT_flra_remat, NULL, 1 },
527 /* -O3 optimizations. */
528 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
529 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
530 { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
531 /* Inlining of functions reducing size is a good idea with -Os
532 regardless of them being declared inline. */
533 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
534 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
535 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
536 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
537 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
538 { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
539 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
540 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
541 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
543 /* -Ofast adds optimizations to -O3. */
544 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
546 { OPT_LEVELS_NONE, 0, NULL, 0 }
549 /* Default the options in OPTS and OPTS_SET based on the optimization
550 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
551 void
552 default_options_optimization (struct gcc_options *opts,
553 struct gcc_options *opts_set,
554 struct cl_decoded_option *decoded_options,
555 unsigned int decoded_options_count,
556 location_t loc,
557 unsigned int lang_mask,
558 const struct cl_option_handlers *handlers,
559 diagnostic_context *dc)
561 unsigned int i;
562 int opt2;
563 bool openacc_mode = false;
565 /* Scan to see what optimization level has been specified. That will
566 determine the default value of many flags. */
567 for (i = 1; i < decoded_options_count; i++)
569 struct cl_decoded_option *opt = &decoded_options[i];
570 switch (opt->opt_index)
572 case OPT_O:
573 if (*opt->arg == '\0')
575 opts->x_optimize = 1;
576 opts->x_optimize_size = 0;
577 opts->x_optimize_fast = 0;
578 opts->x_optimize_debug = 0;
580 else
582 const int optimize_val = integral_argument (opt->arg);
583 if (optimize_val == -1)
584 error_at (loc, "argument to %<-O%> should be a non-negative "
585 "integer, %<g%>, %<s%> or %<fast%>");
586 else
588 opts->x_optimize = optimize_val;
589 if ((unsigned int) opts->x_optimize > 255)
590 opts->x_optimize = 255;
591 opts->x_optimize_size = 0;
592 opts->x_optimize_fast = 0;
593 opts->x_optimize_debug = 0;
596 break;
598 case OPT_Os:
599 opts->x_optimize_size = 1;
601 /* Optimizing for size forces optimize to be 2. */
602 opts->x_optimize = 2;
603 opts->x_optimize_fast = 0;
604 opts->x_optimize_debug = 0;
605 break;
607 case OPT_Ofast:
608 /* -Ofast only adds flags to -O3. */
609 opts->x_optimize_size = 0;
610 opts->x_optimize = 3;
611 opts->x_optimize_fast = 1;
612 opts->x_optimize_debug = 0;
613 break;
615 case OPT_Og:
616 /* -Og selects optimization level 1. */
617 opts->x_optimize_size = 0;
618 opts->x_optimize = 1;
619 opts->x_optimize_fast = 0;
620 opts->x_optimize_debug = 1;
621 break;
623 case OPT_fopenacc:
624 if (opt->value)
625 openacc_mode = true;
626 break;
628 default:
629 /* Ignore other options in this prescan. */
630 break;
634 maybe_default_options (opts, opts_set, default_options_table,
635 opts->x_optimize, opts->x_optimize_size,
636 opts->x_optimize_fast, opts->x_optimize_debug,
637 lang_mask, handlers, loc, dc);
639 /* -O2 param settings. */
640 opt2 = (opts->x_optimize >= 2);
642 if (openacc_mode
643 && !opts_set->x_flag_ipa_pta)
644 opts->x_flag_ipa_pta = true;
646 /* Track fields in field-sensitive alias analysis. */
647 maybe_set_param_value
648 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
649 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
650 opts->x_param_values, opts_set->x_param_values);
652 /* For -O1 only do loop invariant motion for very small loops. */
653 maybe_set_param_value
654 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
655 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
656 opts->x_param_values, opts_set->x_param_values);
658 /* At -Ofast, allow store motion to introduce potential race conditions. */
659 maybe_set_param_value
660 (PARAM_ALLOW_STORE_DATA_RACES,
661 opts->x_optimize_fast ? 1
662 : default_param_value (PARAM_ALLOW_STORE_DATA_RACES),
663 opts->x_param_values, opts_set->x_param_values);
665 if (opts->x_optimize_size)
666 /* We want to crossjump as much as possible. */
667 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
668 opts->x_param_values, opts_set->x_param_values);
669 else
670 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
671 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
672 opts->x_param_values, opts_set->x_param_values);
674 /* Restrict the amount of work combine does at -Og while retaining
675 most of its useful transforms. */
676 if (opts->x_optimize_debug)
677 maybe_set_param_value (PARAM_MAX_COMBINE_INSNS, 2,
678 opts->x_param_values, opts_set->x_param_values);
680 /* Allow default optimizations to be specified on a per-machine basis. */
681 maybe_default_options (opts, opts_set,
682 targetm_common.option_optimization_table,
683 opts->x_optimize, opts->x_optimize_size,
684 opts->x_optimize_fast, opts->x_optimize_debug,
685 lang_mask, handlers, loc, dc);
688 /* After all options at LOC have been read into OPTS and OPTS_SET,
689 finalize settings of those options and diagnose incompatible
690 combinations. */
691 void
692 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
693 location_t loc)
695 enum unwind_info_type ui_except;
697 if (opts->x_dump_base_name
698 && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name)
699 && ! opts->x_dump_base_name_prefixed)
701 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
702 OPTS->X_DUMP_DIR_NAME directory. Then try to make
703 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
704 directory, typically the directory to contain the object
705 file. */
706 if (opts->x_dump_dir_name)
707 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
708 opts->x_dump_base_name, NULL);
709 else if (opts->x_aux_base_name
710 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
712 const char *aux_base;
714 base_of_path (opts->x_aux_base_name, &aux_base);
715 if (opts->x_aux_base_name != aux_base)
717 int dir_len = aux_base - opts->x_aux_base_name;
718 char *new_dump_base_name
719 = XOBNEWVEC (&opts_obstack, char,
720 strlen (opts->x_dump_base_name) + dir_len + 1);
722 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
723 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
724 /* Append existing OPTS->X_DUMP_BASE_NAME. */
725 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
726 opts->x_dump_base_name = new_dump_base_name;
729 opts->x_dump_base_name_prefixed = true;
732 /* Handle related options for unit-at-a-time, toplevel-reorder, and
733 section-anchors. */
734 if (!opts->x_flag_unit_at_a_time)
736 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
737 error_at (loc, "section anchors must be disabled when unit-at-a-time "
738 "is disabled");
739 opts->x_flag_section_anchors = 0;
740 if (opts->x_flag_toplevel_reorder == 1)
741 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
742 "is disabled");
743 opts->x_flag_toplevel_reorder = 0;
746 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
747 sorry ("transactional memory is not supported with non-call exceptions");
749 /* Unless the user has asked for section anchors, we disable toplevel
750 reordering at -O0 to disable transformations that might be surprising
751 to end users and to get -fno-toplevel-reorder tested. */
752 if (!opts->x_optimize
753 && opts->x_flag_toplevel_reorder == 2
754 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
756 opts->x_flag_toplevel_reorder = 0;
757 opts->x_flag_section_anchors = 0;
759 if (!opts->x_flag_toplevel_reorder)
761 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
762 error_at (loc, "section anchors must be disabled when toplevel reorder"
763 " is disabled");
764 opts->x_flag_section_anchors = 0;
767 if (!opts->x_flag_opts_finished)
769 /* We initialize opts->x_flag_pie to -1 so that targets can set a
770 default value. */
771 if (opts->x_flag_pie == -1)
773 if (opts->x_flag_pic == 0)
774 opts->x_flag_pie = DEFAULT_FLAG_PIE;
775 else
776 opts->x_flag_pie = 0;
778 if (opts->x_flag_pie)
779 opts->x_flag_pic = opts->x_flag_pie;
780 if (opts->x_flag_pic && !opts->x_flag_pie)
781 opts->x_flag_shlib = 1;
782 opts->x_flag_opts_finished = true;
785 /* We initialize opts->x_flag_stack_protect to -1 so that targets
786 can set a default value. */
787 if (opts->x_flag_stack_protect == -1)
788 opts->x_flag_stack_protect = DEFAULT_FLAG_SSP;
790 if (opts->x_optimize == 0)
792 /* Inlining does not work if not optimizing,
793 so force it not to be done. */
794 opts->x_warn_inline = 0;
795 opts->x_flag_no_inline = 1;
798 /* The optimization to partition hot and cold basic blocks into separate
799 sections of the .o and executable files does not work (currently)
800 with exception handling. This is because there is no support for
801 generating unwind info. If opts->x_flag_exceptions is turned on
802 we need to turn off the partitioning optimization. */
804 ui_except = targetm_common.except_unwind_info (opts);
806 if (opts->x_flag_exceptions
807 && opts->x_flag_reorder_blocks_and_partition
808 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
810 if (opts_set->x_flag_reorder_blocks_and_partition)
811 inform (loc,
812 "-freorder-blocks-and-partition does not work "
813 "with exceptions on this architecture");
814 opts->x_flag_reorder_blocks_and_partition = 0;
815 opts->x_flag_reorder_blocks = 1;
818 /* If user requested unwind info, then turn off the partitioning
819 optimization. */
821 if (opts->x_flag_unwind_tables
822 && !targetm_common.unwind_tables_default
823 && opts->x_flag_reorder_blocks_and_partition
824 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
826 if (opts_set->x_flag_reorder_blocks_and_partition)
827 inform (loc,
828 "-freorder-blocks-and-partition does not support "
829 "unwind info on this architecture");
830 opts->x_flag_reorder_blocks_and_partition = 0;
831 opts->x_flag_reorder_blocks = 1;
834 /* If the target requested unwind info, then turn off the partitioning
835 optimization with a different message. Likewise, if the target does not
836 support named sections. */
838 if (opts->x_flag_reorder_blocks_and_partition
839 && (!targetm_common.have_named_sections
840 || (opts->x_flag_unwind_tables
841 && targetm_common.unwind_tables_default
842 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
844 if (opts_set->x_flag_reorder_blocks_and_partition)
845 inform (loc,
846 "-freorder-blocks-and-partition does not work "
847 "on this architecture");
848 opts->x_flag_reorder_blocks_and_partition = 0;
849 opts->x_flag_reorder_blocks = 1;
852 /* Disable -freorder-blocks-and-partition when -fprofile-use is not in
853 effect. Function splitting was not actually being performed in that case,
854 as probably_never_executed_bb_p does not distinguish any basic blocks as
855 being cold vs hot when there is no profile data. Leaving it enabled,
856 however, causes the assembly code generator to create (empty) cold
857 sections and labels, leading to unnecessary size overhead. */
858 if (opts->x_flag_reorder_blocks_and_partition
859 && !opts_set->x_flag_profile_use)
860 opts->x_flag_reorder_blocks_and_partition = 0;
862 if (opts->x_flag_reorder_blocks_and_partition
863 && !opts_set->x_flag_reorder_functions)
864 opts->x_flag_reorder_functions = 1;
866 /* Pipelining of outer loops is only possible when general pipelining
867 capabilities are requested. */
868 if (!opts->x_flag_sel_sched_pipelining)
869 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
871 if (opts->x_flag_conserve_stack)
873 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
874 opts->x_param_values, opts_set->x_param_values);
875 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
876 opts->x_param_values, opts_set->x_param_values);
879 if (opts->x_flag_lto)
881 #ifdef ENABLE_LTO
882 opts->x_flag_generate_lto = 1;
884 /* When generating IL, do not operate in whole-program mode.
885 Otherwise, symbols will be privatized too early, causing link
886 errors later. */
887 opts->x_flag_whole_program = 0;
888 #else
889 error_at (loc, "LTO support has not been enabled in this configuration");
890 #endif
891 if (!opts->x_flag_fat_lto_objects
892 && (!HAVE_LTO_PLUGIN
893 || (opts_set->x_flag_use_linker_plugin
894 && !opts->x_flag_use_linker_plugin)))
896 if (opts_set->x_flag_fat_lto_objects)
897 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin");
898 opts->x_flag_fat_lto_objects = 1;
902 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
903 default value if they choose based on other options. */
904 if (opts->x_flag_split_stack == -1)
905 opts->x_flag_split_stack = 0;
906 else if (opts->x_flag_split_stack)
908 if (!targetm_common.supports_split_stack (true, opts))
910 error_at (loc, "%<-fsplit-stack%> is not supported by "
911 "this compiler configuration");
912 opts->x_flag_split_stack = 0;
916 /* Tune vectorization related parametees according to cost model. */
917 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
919 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
920 6, opts->x_param_values, opts_set->x_param_values);
921 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
922 0, opts->x_param_values, opts_set->x_param_values);
923 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
924 0, opts->x_param_values, opts_set->x_param_values);
927 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
928 is disabled. */
929 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
930 || !opts->x_flag_tree_loop_if_convert)
931 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
932 opts->x_param_values, opts_set->x_param_values);
934 /* The -gsplit-dwarf option requires -ggnu-pubnames. */
935 if (opts->x_dwarf_split_debug_info)
936 opts->x_debug_generate_pub_sections = 2;
938 /* Userspace and kernel ASan conflict with each other. */
940 if ((opts->x_flag_sanitize & SANITIZE_USER_ADDRESS)
941 && (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS))
942 error_at (loc,
943 "-fsanitize=address is incompatible with "
944 "-fsanitize=kernel-address");
946 /* And with TSan. */
948 if ((opts->x_flag_sanitize & SANITIZE_ADDRESS)
949 && (opts->x_flag_sanitize & SANITIZE_THREAD))
950 error_at (loc,
951 "-fsanitize=address and -fsanitize=kernel-address "
952 "are incompatible with -fsanitize=thread");
954 /* Error recovery is not allowed for LSan and TSan. */
956 if (opts->x_flag_sanitize_recover & SANITIZE_THREAD)
957 error_at (loc, "-fsanitize-recover=thread is not supported");
959 if (opts->x_flag_sanitize_recover & SANITIZE_LEAK)
960 error_at (loc, "-fsanitize-recover=leak is not supported");
962 /* When instrumenting the pointers, we don't want to remove
963 the null pointer checks. */
964 if (opts->x_flag_sanitize & (SANITIZE_NULL | SANITIZE_NONNULL_ATTRIBUTE
965 | SANITIZE_RETURNS_NONNULL_ATTRIBUTE))
966 opts->x_flag_delete_null_pointer_checks = 0;
968 /* Aggressive compiler optimizations may cause false negatives. */
969 if (opts->x_flag_sanitize)
971 opts->x_flag_aggressive_loop_optimizations = 0;
972 opts->x_flag_strict_overflow = 0;
976 #define LEFT_COLUMN 27
978 /* Output ITEM, of length ITEM_WIDTH, in the left column,
979 followed by word-wrapped HELP in a second column. */
980 static void
981 wrap_help (const char *help,
982 const char *item,
983 unsigned int item_width,
984 unsigned int columns)
986 unsigned int col_width = LEFT_COLUMN;
987 unsigned int remaining, room, len;
989 remaining = strlen (help);
993 room = columns - 3 - MAX (col_width, item_width);
994 if (room > columns)
995 room = 0;
996 len = remaining;
998 if (room < len)
1000 unsigned int i;
1002 for (i = 0; help[i]; i++)
1004 if (i >= room && len != remaining)
1005 break;
1006 if (help[i] == ' ')
1007 len = i;
1008 else if ((help[i] == '-' || help[i] == '/')
1009 && help[i + 1] != ' '
1010 && i > 0 && ISALPHA (help[i - 1]))
1011 len = i + 1;
1015 printf (" %-*.*s %.*s\n", col_width, item_width, item, len, help);
1016 item_width = 0;
1017 while (help[len] == ' ')
1018 len++;
1019 help += len;
1020 remaining -= len;
1022 while (remaining);
1025 /* Print help for a specific front-end, etc. */
1026 static void
1027 print_filtered_help (unsigned int include_flags,
1028 unsigned int exclude_flags,
1029 unsigned int any_flags,
1030 unsigned int columns,
1031 struct gcc_options *opts,
1032 unsigned int lang_mask)
1034 unsigned int i;
1035 const char *help;
1036 bool found = false;
1037 bool displayed = false;
1038 char new_help[256];
1040 if (include_flags == CL_PARAMS)
1042 for (i = 0; i < LAST_PARAM; i++)
1044 const char *param = compiler_params[i].option;
1046 help = compiler_params[i].help;
1047 if (help == NULL || *help == '\0')
1049 if (exclude_flags & CL_UNDOCUMENTED)
1050 continue;
1051 help = undocumented_msg;
1054 /* Get the translation. */
1055 help = _(help);
1057 if (!opts->x_quiet_flag)
1059 snprintf (new_help, sizeof (new_help),
1060 _("default %d minimum %d maximum %d"),
1061 compiler_params[i].default_value,
1062 compiler_params[i].min_value,
1063 compiler_params[i].max_value);
1064 help = new_help;
1066 wrap_help (help, param, strlen (param), columns);
1068 putchar ('\n');
1069 return;
1072 if (!opts->x_help_printed)
1073 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
1075 if (!opts->x_help_enum_printed)
1076 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
1078 for (i = 0; i < cl_options_count; i++)
1080 const struct cl_option *option = cl_options + i;
1081 unsigned int len;
1082 const char *opt;
1083 const char *tab;
1085 if (include_flags == 0
1086 || ((option->flags & include_flags) != include_flags))
1088 if ((option->flags & any_flags) == 0)
1089 continue;
1092 /* Skip unwanted switches. */
1093 if ((option->flags & exclude_flags) != 0)
1094 continue;
1096 /* The driver currently prints its own help text. */
1097 if ((option->flags & CL_DRIVER) != 0
1098 && (option->flags & (((1U << cl_lang_count) - 1)
1099 | CL_COMMON | CL_TARGET)) == 0)
1100 continue;
1102 found = true;
1103 /* Skip switches that have already been printed. */
1104 if (opts->x_help_printed[i])
1105 continue;
1107 opts->x_help_printed[i] = true;
1109 help = option->help;
1110 if (help == NULL)
1112 if (exclude_flags & CL_UNDOCUMENTED)
1113 continue;
1115 help = undocumented_msg;
1118 if (option->alias_target < N_OPTS
1119 && cl_options [option->alias_target].help)
1121 if (help == undocumented_msg)
1123 /* For undocumented options that are aliases for other options
1124 that are documented, point the reader to the other option in
1125 preference of the former. */
1126 snprintf (new_help, sizeof new_help,
1127 _("Same as %s. Use the latter option instead."),
1128 cl_options [option->alias_target].opt_text);
1130 else
1132 /* For documented options with aliases, mention the aliased
1133 option's name for reference. */
1134 snprintf (new_help, sizeof new_help,
1135 _("%s Same as %s."),
1136 help, cl_options [option->alias_target].opt_text);
1139 help = new_help;
1142 if (option->warn_message)
1144 /* Mention that the use of the option will trigger a warning. */
1145 if (help == new_help)
1146 snprintf (new_help + strlen (new_help),
1147 sizeof new_help - strlen (new_help),
1148 " %s", _(use_diagnosed_msg));
1149 else
1150 snprintf (new_help, sizeof new_help,
1151 "%s %s", help, _(use_diagnosed_msg));
1153 help = new_help;
1156 /* Get the translation. */
1157 help = _(help);
1159 /* Find the gap between the name of the
1160 option and its descriptive text. */
1161 tab = strchr (help, '\t');
1162 if (tab)
1164 len = tab - help;
1165 opt = help;
1166 help = tab + 1;
1168 else
1170 opt = option->opt_text;
1171 len = strlen (opt);
1174 /* With the -Q option enabled we change the descriptive text associated
1175 with an option to be an indication of its current setting. */
1176 if (!opts->x_quiet_flag)
1178 void *flag_var = option_flag_var (i, opts);
1180 if (len < (LEFT_COLUMN + 2))
1181 strcpy (new_help, "\t\t");
1182 else
1183 strcpy (new_help, "\t");
1185 if (flag_var != NULL
1186 && option->var_type != CLVC_DEFER)
1188 if (option->flags & CL_JOINED)
1190 if (option->var_type == CLVC_STRING)
1192 if (* (const char **) flag_var != NULL)
1193 snprintf (new_help + strlen (new_help),
1194 sizeof (new_help) - strlen (new_help),
1195 "%s", * (const char **) flag_var);
1197 else if (option->var_type == CLVC_ENUM)
1199 const struct cl_enum *e = &cl_enums[option->var_enum];
1200 int value;
1201 const char *arg = NULL;
1203 value = e->get (flag_var);
1204 enum_value_to_arg (e->values, &arg, value, lang_mask);
1205 if (arg == NULL)
1206 arg = _("[default]");
1207 snprintf (new_help + strlen (new_help),
1208 sizeof (new_help) - strlen (new_help),
1209 "%s", arg);
1211 else
1212 sprintf (new_help + strlen (new_help),
1213 "%#x", * (int *) flag_var);
1215 else
1216 strcat (new_help, option_enabled (i, opts)
1217 ? _("[enabled]") : _("[disabled]"));
1220 help = new_help;
1223 wrap_help (help, opt, len, columns);
1224 displayed = true;
1226 if (option->var_type == CLVC_ENUM
1227 && opts->x_help_enum_printed[option->var_enum] != 2)
1228 opts->x_help_enum_printed[option->var_enum] = 1;
1231 if (! found)
1233 unsigned int langs = include_flags & CL_LANG_ALL;
1235 if (langs == 0)
1236 printf (_(" No options with the desired characteristics were found\n"));
1237 else
1239 unsigned int i;
1241 /* PR 31349: Tell the user how to see all of the
1242 options supported by a specific front end. */
1243 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1244 if ((1U << i) & langs)
1245 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end.\n"),
1246 lang_names[i], lang_names[i]);
1250 else if (! displayed)
1251 printf (_(" All options with the desired characteristics have already been displayed\n"));
1253 putchar ('\n');
1255 /* Print details of enumerated option arguments, if those
1256 enumerations have help text headings provided. If no help text
1257 is provided, presume that the possible values are listed in the
1258 help text for the relevant options. */
1259 for (i = 0; i < cl_enums_count; i++)
1261 unsigned int j, pos;
1263 if (opts->x_help_enum_printed[i] != 1)
1264 continue;
1265 if (cl_enums[i].help == NULL)
1266 continue;
1267 printf (" %s\n ", _(cl_enums[i].help));
1268 pos = 4;
1269 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1271 unsigned int len = strlen (cl_enums[i].values[j].arg);
1273 if (pos > 4 && pos + 1 + len <= columns)
1275 printf (" %s", cl_enums[i].values[j].arg);
1276 pos += 1 + len;
1278 else
1280 if (pos > 4)
1282 printf ("\n ");
1283 pos = 4;
1285 printf ("%s", cl_enums[i].values[j].arg);
1286 pos += len;
1289 printf ("\n\n");
1290 opts->x_help_enum_printed[i] = 2;
1294 /* Display help for a specified type of option.
1295 The options must have ALL of the INCLUDE_FLAGS set
1296 ANY of the flags in the ANY_FLAGS set
1297 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1298 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1299 static void
1300 print_specific_help (unsigned int include_flags,
1301 unsigned int exclude_flags,
1302 unsigned int any_flags,
1303 struct gcc_options *opts,
1304 unsigned int lang_mask)
1306 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1307 const char * description = NULL;
1308 const char * descrip_extra = "";
1309 size_t i;
1310 unsigned int flag;
1312 /* Sanity check: Make sure that we do not have more
1313 languages than we have bits available to enumerate them. */
1314 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1316 /* If we have not done so already, obtain
1317 the desired maximum width of the output. */
1318 if (opts->x_help_columns == 0)
1320 opts->x_help_columns = get_terminal_width ();
1321 if (opts->x_help_columns == INT_MAX)
1322 /* Use a reasonable default. */
1323 opts->x_help_columns = 80;
1326 /* Decide upon the title for the options that we are going to display. */
1327 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1329 switch (flag & include_flags)
1331 case 0:
1332 case CL_DRIVER:
1333 break;
1335 case CL_TARGET:
1336 description = _("The following options are target specific");
1337 break;
1338 case CL_WARNING:
1339 description = _("The following options control compiler warning messages");
1340 break;
1341 case CL_OPTIMIZATION:
1342 description = _("The following options control optimizations");
1343 break;
1344 case CL_COMMON:
1345 description = _("The following options are language-independent");
1346 break;
1347 case CL_PARAMS:
1348 description = _("The --param option recognizes the following as parameters");
1349 break;
1350 default:
1351 if (i >= cl_lang_count)
1352 break;
1353 if (exclude_flags & all_langs_mask)
1354 description = _("The following options are specific to just the language ");
1355 else
1356 description = _("The following options are supported by the language ");
1357 descrip_extra = lang_names [i];
1358 break;
1362 if (description == NULL)
1364 if (any_flags == 0)
1366 if (include_flags & CL_UNDOCUMENTED)
1367 description = _("The following options are not documented");
1368 else if (include_flags & CL_SEPARATE)
1369 description = _("The following options take separate arguments");
1370 else if (include_flags & CL_JOINED)
1371 description = _("The following options take joined arguments");
1372 else
1374 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1375 include_flags);
1376 return;
1379 else
1381 if (any_flags & all_langs_mask)
1382 description = _("The following options are language-related");
1383 else
1384 description = _("The following options are language-independent");
1388 printf ("%s%s:\n", description, descrip_extra);
1389 print_filtered_help (include_flags, exclude_flags, any_flags,
1390 opts->x_help_columns, opts, lang_mask);
1393 /* Enable FDO-related flags. */
1395 static void
1396 enable_fdo_optimizations (struct gcc_options *opts,
1397 struct gcc_options *opts_set,
1398 int value)
1400 if (!opts_set->x_flag_branch_probabilities)
1401 opts->x_flag_branch_probabilities = value;
1402 if (!opts_set->x_flag_profile_values)
1403 opts->x_flag_profile_values = value;
1404 if (!opts_set->x_flag_unroll_loops)
1405 opts->x_flag_unroll_loops = value;
1406 if (!opts_set->x_flag_peel_loops)
1407 opts->x_flag_peel_loops = value;
1408 if (!opts_set->x_flag_tracer)
1409 opts->x_flag_tracer = value;
1410 if (!opts_set->x_flag_value_profile_transformations)
1411 opts->x_flag_value_profile_transformations = value;
1412 if (!opts_set->x_flag_inline_functions)
1413 opts->x_flag_inline_functions = value;
1414 if (!opts_set->x_flag_ipa_cp)
1415 opts->x_flag_ipa_cp = value;
1416 if (!opts_set->x_flag_ipa_cp_clone
1417 && value && opts->x_flag_ipa_cp)
1418 opts->x_flag_ipa_cp_clone = value;
1419 if (!opts_set->x_flag_ipa_cp_alignment
1420 && value && opts->x_flag_ipa_cp)
1421 opts->x_flag_ipa_cp_alignment = value;
1422 if (!opts_set->x_flag_predictive_commoning)
1423 opts->x_flag_predictive_commoning = value;
1424 if (!opts_set->x_flag_unswitch_loops)
1425 opts->x_flag_unswitch_loops = value;
1426 if (!opts_set->x_flag_gcse_after_reload)
1427 opts->x_flag_gcse_after_reload = value;
1428 if (!opts_set->x_flag_tree_loop_vectorize
1429 && !opts_set->x_flag_tree_vectorize)
1430 opts->x_flag_tree_loop_vectorize = value;
1431 if (!opts_set->x_flag_tree_slp_vectorize
1432 && !opts_set->x_flag_tree_vectorize)
1433 opts->x_flag_tree_slp_vectorize = value;
1434 if (!opts_set->x_flag_vect_cost_model)
1435 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1436 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1437 opts->x_flag_tree_loop_distribute_patterns = value;
1440 /* Handle target- and language-independent options. Return zero to
1441 generate an "unknown option" message. Only options that need
1442 extra handling need to be listed here; if you simply want
1443 DECODED->value assigned to a variable, it happens automatically. */
1445 bool
1446 common_handle_option (struct gcc_options *opts,
1447 struct gcc_options *opts_set,
1448 const struct cl_decoded_option *decoded,
1449 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1450 location_t loc,
1451 const struct cl_option_handlers *handlers,
1452 diagnostic_context *dc)
1454 size_t scode = decoded->opt_index;
1455 const char *arg = decoded->arg;
1456 int value = decoded->value;
1457 enum opt_code code = (enum opt_code) scode;
1459 gcc_assert (decoded->canonical_option_num_elements <= 2);
1461 switch (code)
1463 case OPT__param:
1464 handle_param (opts, opts_set, loc, arg);
1465 break;
1467 case OPT__help:
1469 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1470 unsigned int undoc_mask;
1471 unsigned int i;
1473 if (lang_mask == CL_DRIVER)
1474 break;
1476 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1478 : CL_UNDOCUMENTED);
1479 /* First display any single language specific options. */
1480 for (i = 0; i < cl_lang_count; i++)
1481 print_specific_help
1482 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1483 lang_mask);
1484 /* Next display any multi language specific options. */
1485 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1486 /* Then display any remaining, non-language options. */
1487 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1488 if (i != CL_DRIVER)
1489 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1490 opts->x_exit_after_options = true;
1491 break;
1494 case OPT__target_help:
1495 if (lang_mask == CL_DRIVER)
1496 break;
1498 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1499 opts->x_exit_after_options = true;
1500 break;
1502 case OPT__help_:
1504 const char * a = arg;
1505 unsigned int include_flags = 0;
1506 /* Note - by default we include undocumented options when listing
1507 specific classes. If you only want to see documented options
1508 then add ",^undocumented" to the --help= option. E.g.:
1510 --help=target,^undocumented */
1511 unsigned int exclude_flags = 0;
1513 if (lang_mask == CL_DRIVER)
1514 break;
1516 /* Walk along the argument string, parsing each word in turn.
1517 The format is:
1518 arg = [^]{word}[,{arg}]
1519 word = {optimizers|target|warnings|undocumented|
1520 params|common|<language>} */
1521 while (* a != 0)
1523 static const struct
1525 const char * string;
1526 unsigned int flag;
1528 specifics[] =
1530 { "optimizers", CL_OPTIMIZATION },
1531 { "target", CL_TARGET },
1532 { "warnings", CL_WARNING },
1533 { "undocumented", CL_UNDOCUMENTED },
1534 { "params", CL_PARAMS },
1535 { "joined", CL_JOINED },
1536 { "separate", CL_SEPARATE },
1537 { "common", CL_COMMON },
1538 { NULL, 0 }
1540 unsigned int * pflags;
1541 const char * comma;
1542 unsigned int lang_flag, specific_flag;
1543 unsigned int len;
1544 unsigned int i;
1546 if (* a == '^')
1548 ++ a;
1549 pflags = & exclude_flags;
1551 else
1552 pflags = & include_flags;
1554 comma = strchr (a, ',');
1555 if (comma == NULL)
1556 len = strlen (a);
1557 else
1558 len = comma - a;
1559 if (len == 0)
1561 a = comma + 1;
1562 continue;
1565 /* Check to see if the string matches an option class name. */
1566 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1567 if (strncasecmp (a, specifics[i].string, len) == 0)
1569 specific_flag = specifics[i].flag;
1570 break;
1573 /* Check to see if the string matches a language name.
1574 Note - we rely upon the alpha-sorted nature of the entries in
1575 the lang_names array, specifically that shorter names appear
1576 before their longer variants. (i.e. C before C++). That way
1577 when we are attempting to match --help=c for example we will
1578 match with C first and not C++. */
1579 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1580 if (strncasecmp (a, lang_names[i], len) == 0)
1582 lang_flag = 1U << i;
1583 break;
1586 if (specific_flag != 0)
1588 if (lang_flag == 0)
1589 * pflags |= specific_flag;
1590 else
1592 /* The option's argument matches both the start of a
1593 language name and the start of an option class name.
1594 We have a special case for when the user has
1595 specified "--help=c", but otherwise we have to issue
1596 a warning. */
1597 if (strncasecmp (a, "c", len) == 0)
1598 * pflags |= lang_flag;
1599 else
1600 warning_at (loc, 0,
1601 "--help argument %q.*s is ambiguous, "
1602 "please be more specific",
1603 len, a);
1606 else if (lang_flag != 0)
1607 * pflags |= lang_flag;
1608 else
1609 warning_at (loc, 0,
1610 "unrecognized argument to --help= option: %q.*s",
1611 len, a);
1613 if (comma == NULL)
1614 break;
1615 a = comma + 1;
1618 if (include_flags)
1619 print_specific_help (include_flags, exclude_flags, 0, opts,
1620 lang_mask);
1621 opts->x_exit_after_options = true;
1622 break;
1625 case OPT__version:
1626 if (lang_mask == CL_DRIVER)
1627 break;
1629 opts->x_exit_after_options = true;
1630 break;
1632 case OPT_fsanitize_:
1633 case OPT_fsanitize_recover_:
1635 const char *p = arg;
1636 unsigned int *flag
1637 = code == OPT_fsanitize_ ? &opts->x_flag_sanitize
1638 : &opts->x_flag_sanitize_recover;
1639 while (*p != 0)
1641 static const struct
1643 const char *const name;
1644 unsigned int flag;
1645 size_t len;
1646 } spec[] =
1648 { "address", SANITIZE_ADDRESS | SANITIZE_USER_ADDRESS,
1649 sizeof "address" - 1 },
1650 { "kernel-address", SANITIZE_ADDRESS | SANITIZE_KERNEL_ADDRESS,
1651 sizeof "kernel-address" - 1 },
1652 { "thread", SANITIZE_THREAD, sizeof "thread" - 1 },
1653 { "leak", SANITIZE_LEAK, sizeof "leak" - 1 },
1654 { "shift", SANITIZE_SHIFT, sizeof "shift" - 1 },
1655 { "integer-divide-by-zero", SANITIZE_DIVIDE,
1656 sizeof "integer-divide-by-zero" - 1 },
1657 { "undefined", SANITIZE_UNDEFINED, sizeof "undefined" - 1 },
1658 { "unreachable", SANITIZE_UNREACHABLE,
1659 sizeof "unreachable" - 1 },
1660 { "vla-bound", SANITIZE_VLA, sizeof "vla-bound" - 1 },
1661 { "return", SANITIZE_RETURN, sizeof "return" - 1 },
1662 { "null", SANITIZE_NULL, sizeof "null" - 1 },
1663 { "signed-integer-overflow", SANITIZE_SI_OVERFLOW,
1664 sizeof "signed-integer-overflow" -1 },
1665 { "bool", SANITIZE_BOOL, sizeof "bool" - 1 },
1666 { "enum", SANITIZE_ENUM, sizeof "enum" - 1 },
1667 { "float-divide-by-zero", SANITIZE_FLOAT_DIVIDE,
1668 sizeof "float-divide-by-zero" - 1 },
1669 { "float-cast-overflow", SANITIZE_FLOAT_CAST,
1670 sizeof "float-cast-overflow" - 1 },
1671 { "bounds", SANITIZE_BOUNDS, sizeof "bounds" - 1 },
1672 { "bounds-strict", SANITIZE_BOUNDS | SANITIZE_BOUNDS_STRICT,
1673 sizeof "bounds-strict" - 1 },
1674 { "alignment", SANITIZE_ALIGNMENT, sizeof "alignment" - 1 },
1675 { "nonnull-attribute", SANITIZE_NONNULL_ATTRIBUTE,
1676 sizeof "nonnull-attribute" - 1 },
1677 { "returns-nonnull-attribute",
1678 SANITIZE_RETURNS_NONNULL_ATTRIBUTE,
1679 sizeof "returns-nonnull-attribute" - 1 },
1680 { "object-size", SANITIZE_OBJECT_SIZE,
1681 sizeof "object-size" - 1 },
1682 { "vptr", SANITIZE_VPTR, sizeof "vptr" - 1 },
1683 { "all", ~0, sizeof "all" - 1 },
1684 { NULL, 0, 0 }
1686 const char *comma;
1687 size_t len, i;
1688 bool found = false;
1690 comma = strchr (p, ',');
1691 if (comma == NULL)
1692 len = strlen (p);
1693 else
1694 len = comma - p;
1695 if (len == 0)
1697 p = comma + 1;
1698 continue;
1701 /* Check to see if the string matches an option class name. */
1702 for (i = 0; spec[i].name != NULL; ++i)
1703 if (len == spec[i].len
1704 && memcmp (p, spec[i].name, len) == 0)
1706 /* Handle both -fsanitize and -fno-sanitize cases. */
1707 if (value && spec[i].flag == ~0U)
1709 if (code == OPT_fsanitize_)
1710 error_at (loc, "-fsanitize=all option is not valid");
1711 else
1712 *flag |= ~(SANITIZE_USER_ADDRESS | SANITIZE_THREAD
1713 | SANITIZE_LEAK);
1715 else if (value)
1716 *flag |= spec[i].flag;
1717 else
1718 *flag &= ~spec[i].flag;
1719 found = true;
1720 break;
1723 if (! found)
1724 error_at (loc,
1725 "unrecognized argument to -fsanitize%s= option: %q.*s",
1726 code == OPT_fsanitize_ ? "" : "-recover", (int) len, p);
1728 if (comma == NULL)
1729 break;
1730 p = comma + 1;
1733 if (code != OPT_fsanitize_)
1734 break;
1736 /* Kernel ASan implies normal ASan but does not yet support
1737 all features. */
1738 if (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS)
1740 maybe_set_param_value (PARAM_ASAN_INSTRUMENTATION_WITH_CALL_THRESHOLD, 0,
1741 opts->x_param_values,
1742 opts_set->x_param_values);
1743 maybe_set_param_value (PARAM_ASAN_GLOBALS, 0,
1744 opts->x_param_values,
1745 opts_set->x_param_values);
1746 maybe_set_param_value (PARAM_ASAN_STACK, 0,
1747 opts->x_param_values,
1748 opts_set->x_param_values);
1749 maybe_set_param_value (PARAM_ASAN_USE_AFTER_RETURN, 0,
1750 opts->x_param_values,
1751 opts_set->x_param_values);
1754 break;
1757 case OPT_fasan_shadow_offset_:
1758 /* Deferred. */
1759 break;
1761 case OPT_fsanitize_recover:
1762 if (value)
1763 opts->x_flag_sanitize_recover
1764 |= SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT;
1765 else
1766 opts->x_flag_sanitize_recover
1767 &= ~(SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT);
1768 break;
1770 case OPT_O:
1771 case OPT_Os:
1772 case OPT_Ofast:
1773 case OPT_Og:
1774 /* Currently handled in a prescan. */
1775 break;
1777 case OPT_Werror:
1778 dc->warning_as_error_requested = value;
1779 break;
1781 case OPT_Werror_:
1782 if (lang_mask == CL_DRIVER)
1783 break;
1785 enable_warning_as_error (arg, value, lang_mask, handlers,
1786 opts, opts_set, loc, dc);
1787 break;
1789 case OPT_Wlarger_than_:
1790 opts->x_larger_than_size = value;
1791 opts->x_warn_larger_than = value != -1;
1792 break;
1794 case OPT_Wfatal_errors:
1795 dc->fatal_errors = value;
1796 break;
1798 case OPT_Wframe_larger_than_:
1799 opts->x_frame_larger_than_size = value;
1800 opts->x_warn_frame_larger_than = value != -1;
1801 break;
1803 case OPT_Wstack_usage_:
1804 opts->x_warn_stack_usage = value;
1805 opts->x_flag_stack_usage_info = value != -1;
1806 break;
1808 case OPT_Wstrict_aliasing:
1809 set_Wstrict_aliasing (opts, value);
1810 break;
1812 case OPT_Wstrict_overflow:
1813 opts->x_warn_strict_overflow = (value
1814 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1815 : 0);
1816 break;
1818 case OPT_Wsystem_headers:
1819 dc->dc_warn_system_headers = value;
1820 break;
1822 case OPT_aux_info:
1823 opts->x_flag_gen_aux_info = 1;
1824 break;
1826 case OPT_auxbase_strip:
1828 char *tmp = xstrdup (arg);
1829 strip_off_ending (tmp, strlen (tmp));
1830 if (tmp[0])
1831 opts->x_aux_base_name = tmp;
1832 else
1833 free (tmp);
1835 break;
1837 case OPT_d:
1838 decode_d_option (arg, opts, loc, dc);
1839 break;
1841 case OPT_fcall_used_:
1842 case OPT_fcall_saved_:
1843 /* Deferred. */
1844 break;
1846 case OPT_fdbg_cnt_:
1847 /* Deferred. */
1848 break;
1850 case OPT_fdbg_cnt_list:
1851 /* Deferred. */
1852 opts->x_exit_after_options = true;
1853 break;
1855 case OPT_fdebug_prefix_map_:
1856 /* Deferred. */
1857 break;
1859 case OPT_fdiagnostics_show_location_:
1860 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1861 break;
1863 case OPT_fdiagnostics_show_caret:
1864 dc->show_caret = value;
1865 break;
1867 case OPT_fdiagnostics_color_:
1868 diagnostic_color_init (dc, value);
1869 break;
1871 case OPT_fdiagnostics_show_option:
1872 dc->show_option_requested = value;
1873 break;
1875 case OPT_fdump_:
1876 /* Deferred. */
1877 break;
1879 case OPT_ffast_math:
1880 set_fast_math_flags (opts, value);
1881 break;
1883 case OPT_funsafe_math_optimizations:
1884 set_unsafe_math_optimizations_flags (opts, value);
1885 break;
1887 case OPT_ffixed_:
1888 /* Deferred. */
1889 break;
1891 case OPT_finline_limit_:
1892 set_param_value ("max-inline-insns-single", value / 2,
1893 opts->x_param_values, opts_set->x_param_values);
1894 set_param_value ("max-inline-insns-auto", value / 2,
1895 opts->x_param_values, opts_set->x_param_values);
1896 break;
1898 case OPT_finstrument_functions_exclude_function_list_:
1899 add_comma_separated_to_vector
1900 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1901 break;
1903 case OPT_finstrument_functions_exclude_file_list_:
1904 add_comma_separated_to_vector
1905 (&opts->x_flag_instrument_functions_exclude_files, arg);
1906 break;
1908 case OPT_fmessage_length_:
1909 pp_set_line_maximum_length (dc->printer, value);
1910 diagnostic_set_caret_max_width (dc, value);
1911 break;
1913 case OPT_fopt_info:
1914 case OPT_fopt_info_:
1915 /* Deferred. */
1916 break;
1918 case OPT_foffload_:
1920 const char *p = arg;
1921 opts->x_flag_disable_hsa = true;
1922 while (*p != 0)
1924 const char *comma = strchr (p, ',');
1926 if ((strncmp (p, "disable", 7) == 0)
1927 && (p[7] == ',' || p[7] == '\0'))
1929 opts->x_flag_disable_hsa = true;
1930 break;
1933 if ((strncmp (p, "hsa", 3) == 0)
1934 && (p[3] == ',' || p[3] == '\0'))
1936 #ifdef ENABLE_HSA
1937 opts->x_flag_disable_hsa = false;
1938 #else
1939 sorry ("HSA has not been enabled during configuration");
1940 #endif
1942 if (!comma)
1943 break;
1944 p = comma + 1;
1946 break;
1949 #ifndef ACCEL_COMPILER
1950 case OPT_foffload_abi_:
1951 error_at (loc, "-foffload-abi option can be specified only for "
1952 "offload compiler");
1953 break;
1954 #endif
1956 case OPT_fpack_struct_:
1957 if (value <= 0 || (value & (value - 1)) || value > 16)
1958 error_at (loc,
1959 "structure alignment must be a small power of two, not %d",
1960 value);
1961 else
1962 opts->x_initial_max_fld_align = value;
1963 break;
1965 case OPT_fplugin_:
1966 case OPT_fplugin_arg_:
1967 /* Deferred. */
1968 break;
1970 case OPT_fprofile_use_:
1971 opts->x_profile_data_prefix = xstrdup (arg);
1972 opts->x_flag_profile_use = true;
1973 value = true;
1974 /* No break here - do -fprofile-use processing. */
1975 case OPT_fprofile_use:
1976 enable_fdo_optimizations (opts, opts_set, value);
1977 if (!opts_set->x_flag_profile_reorder_functions)
1978 opts->x_flag_profile_reorder_functions = value;
1979 /* Indirect call profiling should do all useful transformations
1980 speculative devirtualization does. */
1981 if (!opts_set->x_flag_devirtualize_speculatively
1982 && opts->x_flag_value_profile_transformations)
1983 opts->x_flag_devirtualize_speculatively = false;
1984 break;
1986 case OPT_fauto_profile_:
1987 opts->x_auto_profile_file = xstrdup (arg);
1988 opts->x_flag_auto_profile = true;
1989 value = true;
1990 /* No break here - do -fauto-profile processing. */
1991 case OPT_fauto_profile:
1992 enable_fdo_optimizations (opts, opts_set, value);
1993 if (!opts_set->x_flag_profile_correction)
1994 opts->x_flag_profile_correction = value;
1995 maybe_set_param_value (
1996 PARAM_EARLY_INLINER_MAX_ITERATIONS, 10,
1997 opts->x_param_values, opts_set->x_param_values);
1998 break;
2000 case OPT_fprofile_generate_:
2001 opts->x_profile_data_prefix = xstrdup (arg);
2002 value = true;
2003 /* No break here - do -fprofile-generate processing. */
2004 case OPT_fprofile_generate:
2005 if (!opts_set->x_profile_arc_flag)
2006 opts->x_profile_arc_flag = value;
2007 if (!opts_set->x_flag_profile_values)
2008 opts->x_flag_profile_values = value;
2009 if (!opts_set->x_flag_inline_functions)
2010 opts->x_flag_inline_functions = value;
2011 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
2012 quadratic. Disable the pass until better memory representation
2013 is done. */
2014 if (!opts_set->x_flag_ipa_reference)
2015 opts->x_flag_ipa_reference = false;
2016 break;
2018 case OPT_ftree_vectorize:
2019 if (!opts_set->x_flag_tree_loop_vectorize)
2020 opts->x_flag_tree_loop_vectorize = value;
2021 if (!opts_set->x_flag_tree_slp_vectorize)
2022 opts->x_flag_tree_slp_vectorize = value;
2023 break;
2024 case OPT_fshow_column:
2025 dc->show_column = value;
2026 break;
2028 case OPT_frandom_seed:
2029 /* The real switch is -fno-random-seed. */
2030 if (value)
2031 return false;
2032 /* Deferred. */
2033 break;
2035 case OPT_frandom_seed_:
2036 /* Deferred. */
2037 break;
2039 case OPT_fsched_verbose_:
2040 #ifdef INSN_SCHEDULING
2041 /* Handled with Var in common.opt. */
2042 break;
2043 #else
2044 return false;
2045 #endif
2047 case OPT_fsched_stalled_insns_:
2048 opts->x_flag_sched_stalled_insns = value;
2049 if (opts->x_flag_sched_stalled_insns == 0)
2050 opts->x_flag_sched_stalled_insns = -1;
2051 break;
2053 case OPT_fsched_stalled_insns_dep_:
2054 opts->x_flag_sched_stalled_insns_dep = value;
2055 break;
2057 case OPT_fstack_check_:
2058 if (!strcmp (arg, "no"))
2059 opts->x_flag_stack_check = NO_STACK_CHECK;
2060 else if (!strcmp (arg, "generic"))
2061 /* This is the old stack checking method. */
2062 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2063 ? FULL_BUILTIN_STACK_CHECK
2064 : GENERIC_STACK_CHECK;
2065 else if (!strcmp (arg, "specific"))
2066 /* This is the new stack checking method. */
2067 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2068 ? FULL_BUILTIN_STACK_CHECK
2069 : STACK_CHECK_STATIC_BUILTIN
2070 ? STATIC_BUILTIN_STACK_CHECK
2071 : GENERIC_STACK_CHECK;
2072 else
2073 warning_at (loc, 0, "unknown stack check parameter %qs", arg);
2074 break;
2076 case OPT_fstack_limit:
2077 /* The real switch is -fno-stack-limit. */
2078 if (value)
2079 return false;
2080 /* Deferred. */
2081 break;
2083 case OPT_fstack_limit_register_:
2084 case OPT_fstack_limit_symbol_:
2085 /* Deferred. */
2086 break;
2088 case OPT_fstack_usage:
2089 opts->x_flag_stack_usage = value;
2090 opts->x_flag_stack_usage_info = value != 0;
2091 break;
2093 case OPT_g:
2094 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
2095 loc);
2096 break;
2098 case OPT_gcoff:
2099 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
2100 break;
2102 case OPT_gdwarf:
2103 if (arg && strlen (arg) != 0)
2105 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
2106 "use %<-gdwarf-%s%> for DWARF version "
2107 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
2108 break;
2110 else
2111 value = opts->x_dwarf_version;
2113 /* FALLTHRU */
2114 case OPT_gdwarf_:
2115 if (value < 2 || value > 5)
2116 error_at (loc, "dwarf version %d is not supported", value);
2117 else
2118 opts->x_dwarf_version = value;
2119 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
2120 break;
2122 case OPT_gsplit_dwarf:
2123 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
2124 loc);
2125 break;
2127 case OPT_ggdb:
2128 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
2129 break;
2131 case OPT_gstabs:
2132 case OPT_gstabs_:
2133 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
2134 loc);
2135 break;
2137 case OPT_gvms:
2138 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
2139 break;
2141 case OPT_gxcoff:
2142 case OPT_gxcoff_:
2143 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
2144 loc);
2145 break;
2147 case OPT_gz:
2148 case OPT_gz_:
2149 /* Handled completely via specs. */
2150 break;
2152 case OPT_pedantic_errors:
2153 dc->pedantic_errors = 1;
2154 control_warning_option (OPT_Wpedantic, DK_ERROR, NULL, value,
2155 loc, lang_mask,
2156 handlers, opts, opts_set,
2157 dc);
2158 break;
2160 case OPT_flto:
2161 opts->x_flag_lto = value ? "" : NULL;
2162 break;
2164 case OPT_w:
2165 dc->dc_inhibit_warnings = true;
2166 break;
2168 case OPT_fmax_errors_:
2169 dc->max_errors = value;
2170 break;
2172 case OPT_fuse_ld_bfd:
2173 case OPT_fuse_ld_gold:
2174 case OPT_fuse_linker_plugin:
2175 /* No-op. Used by the driver and passed to us because it starts with f.*/
2176 break;
2178 case OPT_fwrapv:
2179 if (value)
2180 opts->x_flag_trapv = 0;
2181 break;
2183 case OPT_ftrapv:
2184 if (value)
2185 opts->x_flag_wrapv = 0;
2186 break;
2188 case OPT_fipa_icf:
2189 opts->x_flag_ipa_icf_functions = value;
2190 opts->x_flag_ipa_icf_variables = value;
2191 break;
2193 default:
2194 /* If the flag was handled in a standard way, assume the lack of
2195 processing here is intentional. */
2196 gcc_assert (option_flag_var (scode, opts));
2197 break;
2200 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
2201 loc, handlers, dc);
2202 return true;
2205 /* Handle --param NAME=VALUE. */
2206 static void
2207 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
2208 location_t loc, const char *carg)
2210 char *equal, *arg;
2211 int value;
2213 arg = xstrdup (carg);
2214 equal = strchr (arg, '=');
2215 if (!equal)
2216 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
2217 arg);
2218 else
2220 *equal = '\0';
2222 enum compiler_param index;
2223 if (!find_param (arg, &index))
2224 error_at (loc, "invalid --param name %qs", arg);
2225 else
2227 if (!param_string_value_p (index, equal + 1, &value))
2228 value = integral_argument (equal + 1);
2230 if (value == -1)
2231 error_at (loc, "invalid --param value %qs", equal + 1);
2232 else
2233 set_param_value (arg, value,
2234 opts->x_param_values, opts_set->x_param_values);
2238 free (arg);
2241 /* Used to set the level of strict aliasing warnings in OPTS,
2242 when no level is specified (i.e., when -Wstrict-aliasing, and not
2243 -Wstrict-aliasing=level was given).
2244 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
2245 and 0 otherwise. After calling this function, wstrict_aliasing will be
2246 set to the default value of -Wstrict_aliasing=level, currently 3. */
2247 static void
2248 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
2250 gcc_assert (onoff == 0 || onoff == 1);
2251 if (onoff != 0)
2252 opts->x_warn_strict_aliasing = 3;
2253 else
2254 opts->x_warn_strict_aliasing = 0;
2257 /* The following routines are useful in setting all the flags that
2258 -ffast-math and -fno-fast-math imply. */
2259 static void
2260 set_fast_math_flags (struct gcc_options *opts, int set)
2262 if (!opts->frontend_set_flag_unsafe_math_optimizations)
2264 opts->x_flag_unsafe_math_optimizations = set;
2265 set_unsafe_math_optimizations_flags (opts, set);
2267 if (!opts->frontend_set_flag_finite_math_only)
2268 opts->x_flag_finite_math_only = set;
2269 if (!opts->frontend_set_flag_errno_math)
2270 opts->x_flag_errno_math = !set;
2271 if (set)
2273 if (!opts->frontend_set_flag_signaling_nans)
2274 opts->x_flag_signaling_nans = 0;
2275 if (!opts->frontend_set_flag_rounding_math)
2276 opts->x_flag_rounding_math = 0;
2277 if (!opts->frontend_set_flag_cx_limited_range)
2278 opts->x_flag_cx_limited_range = 1;
2282 /* When -funsafe-math-optimizations is set the following
2283 flags are set as well. */
2284 static void
2285 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
2287 if (!opts->frontend_set_flag_trapping_math)
2288 opts->x_flag_trapping_math = !set;
2289 if (!opts->frontend_set_flag_signed_zeros)
2290 opts->x_flag_signed_zeros = !set;
2291 if (!opts->frontend_set_flag_associative_math)
2292 opts->x_flag_associative_math = set;
2293 if (!opts->frontend_set_flag_reciprocal_math)
2294 opts->x_flag_reciprocal_math = set;
2297 /* Return true iff flags in OPTS are set as if -ffast-math. */
2298 bool
2299 fast_math_flags_set_p (const struct gcc_options *opts)
2301 return (!opts->x_flag_trapping_math
2302 && opts->x_flag_unsafe_math_optimizations
2303 && opts->x_flag_finite_math_only
2304 && !opts->x_flag_signed_zeros
2305 && !opts->x_flag_errno_math);
2308 /* Return true iff flags are set as if -ffast-math but using the flags stored
2309 in the struct cl_optimization structure. */
2310 bool
2311 fast_math_flags_struct_set_p (struct cl_optimization *opt)
2313 return (!opt->x_flag_trapping_math
2314 && opt->x_flag_unsafe_math_optimizations
2315 && opt->x_flag_finite_math_only
2316 && !opt->x_flag_signed_zeros
2317 && !opt->x_flag_errno_math);
2320 /* Handle a debug output -g switch for options OPTS
2321 (OPTS_SET->x_write_symbols storing whether a debug type was passed
2322 explicitly), location LOC. EXTENDED is true or false to support
2323 extended output (2 is special and means "-ggdb" was given). */
2324 static void
2325 set_debug_level (enum debug_info_type type, int extended, const char *arg,
2326 struct gcc_options *opts, struct gcc_options *opts_set,
2327 location_t loc)
2329 opts->x_use_gnu_debug_info_extensions = extended;
2331 if (type == NO_DEBUG)
2333 if (opts->x_write_symbols == NO_DEBUG)
2335 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
2337 if (extended == 2)
2339 #if defined DWARF2_DEBUGGING_INFO || defined DWARF2_LINENO_DEBUGGING_INFO
2340 opts->x_write_symbols = DWARF2_DEBUG;
2341 #elif defined DBX_DEBUGGING_INFO
2342 opts->x_write_symbols = DBX_DEBUG;
2343 #endif
2346 if (opts->x_write_symbols == NO_DEBUG)
2347 warning_at (loc, 0, "target system does not support debug output");
2350 else
2352 /* Does it conflict with an already selected type? */
2353 if (opts_set->x_write_symbols != NO_DEBUG
2354 && opts->x_write_symbols != NO_DEBUG
2355 && type != opts->x_write_symbols)
2356 error_at (loc, "debug format %qs conflicts with prior selection",
2357 debug_type_names[type]);
2358 opts->x_write_symbols = type;
2359 opts_set->x_write_symbols = type;
2362 /* A debug flag without a level defaults to level 2.
2363 If off or at level 1, set it to level 2, but if already
2364 at level 3, don't lower it. */
2365 if (*arg == '\0')
2367 if (opts->x_debug_info_level < DINFO_LEVEL_NORMAL)
2368 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2370 else
2372 int argval = integral_argument (arg);
2373 if (argval == -1)
2374 error_at (loc, "unrecognised debug output level %qs", arg);
2375 else if (argval > 3)
2376 error_at (loc, "debug output level %qs is too high", arg);
2377 else
2378 opts->x_debug_info_level = (enum debug_info_levels) argval;
2382 /* Arrange to dump core on error for diagnostic context DC. (The
2383 regular error message is still printed first, except in the case of
2384 abort ().) */
2386 static void
2387 setup_core_dumping (diagnostic_context *dc)
2389 #ifdef SIGABRT
2390 signal (SIGABRT, SIG_DFL);
2391 #endif
2392 #if defined(HAVE_SETRLIMIT)
2394 struct rlimit rlim;
2395 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2396 fatal_error (input_location, "getting core file size maximum limit: %m");
2397 rlim.rlim_cur = rlim.rlim_max;
2398 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2399 fatal_error (input_location,
2400 "setting core file size limit to maximum: %m");
2402 #endif
2403 diagnostic_abort_on_error (dc);
2406 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2407 diagnostic context DC. */
2409 static void
2410 decode_d_option (const char *arg, struct gcc_options *opts,
2411 location_t loc, diagnostic_context *dc)
2413 int c;
2415 while (*arg)
2416 switch (c = *arg++)
2418 case 'A':
2419 opts->x_flag_debug_asm = 1;
2420 break;
2421 case 'p':
2422 opts->x_flag_print_asm_name = 1;
2423 break;
2424 case 'P':
2425 opts->x_flag_dump_rtl_in_asm = 1;
2426 opts->x_flag_print_asm_name = 1;
2427 break;
2428 case 'x':
2429 opts->x_rtl_dump_and_exit = 1;
2430 break;
2431 case 'D': /* These are handled by the preprocessor. */
2432 case 'I':
2433 case 'M':
2434 case 'N':
2435 case 'U':
2436 break;
2437 case 'H':
2438 setup_core_dumping (dc);
2439 break;
2440 case 'a':
2441 opts->x_flag_dump_all_passed = true;
2442 break;
2444 default:
2445 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2446 break;
2450 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2451 mask LANG_MASK, option handlers HANDLERS) as an error for option
2452 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2453 NULL), location LOC. This is used by -Werror=. */
2455 static void
2456 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2457 const struct cl_option_handlers *handlers,
2458 struct gcc_options *opts,
2459 struct gcc_options *opts_set,
2460 location_t loc, diagnostic_context *dc)
2462 char *new_option;
2463 int option_index;
2465 new_option = XNEWVEC (char, strlen (arg) + 2);
2466 new_option[0] = 'W';
2467 strcpy (new_option + 1, arg);
2468 option_index = find_opt (new_option, lang_mask);
2469 if (option_index == OPT_SPECIAL_unknown)
2470 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2471 else if (!(cl_options[option_index].flags & CL_WARNING))
2472 error_at (loc, "-Werror=%s: -%s is not an option that controls warnings",
2473 arg, new_option);
2474 else
2476 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2477 const char *arg = NULL;
2479 if (cl_options[option_index].flags & CL_JOINED)
2480 arg = new_option + cl_options[option_index].opt_len;
2481 control_warning_option (option_index, (int) kind, arg, value,
2482 loc, lang_mask,
2483 handlers, opts, opts_set, dc);
2485 free (new_option);
2488 /* Return malloced memory for the name of the option OPTION_INDEX
2489 which enabled a diagnostic (context CONTEXT), originally of type
2490 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2491 as -Werror. */
2493 char *
2494 option_name (diagnostic_context *context, int option_index,
2495 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2497 if (option_index)
2499 /* A warning classified as an error. */
2500 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2501 && diag_kind == DK_ERROR)
2502 return concat (cl_options[OPT_Werror_].opt_text,
2503 /* Skip over "-W". */
2504 cl_options[option_index].opt_text + 2,
2505 NULL);
2506 /* A warning with option. */
2507 else
2508 return xstrdup (cl_options[option_index].opt_text);
2510 /* A warning without option classified as an error. */
2511 else if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2512 || diag_kind == DK_WARNING)
2513 && context->warning_as_error_requested)
2514 return xstrdup (cl_options[OPT_Werror].opt_text);
2515 else
2516 return NULL;