mn10300: Use the STC bb-reorder algorithm at -Os
[official-gcc.git] / gcc / opts.c
blob89b3e793de62cb3f372c1daf1c9560e6b96dd304
1 /* Command line option handling.
2 Copyright (C) 2002-2015 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 switch lacks documentation");
186 typedef char *char_p; /* For DEF_VEC_P. */
188 static void handle_param (struct gcc_options *opts,
189 struct gcc_options *opts_set, location_t loc,
190 const char *carg);
191 static void set_debug_level (enum debug_info_type type, int extended,
192 const char *arg, struct gcc_options *opts,
193 struct gcc_options *opts_set,
194 location_t loc);
195 static void set_fast_math_flags (struct gcc_options *opts, int set);
196 static void decode_d_option (const char *arg, struct gcc_options *opts,
197 location_t loc, diagnostic_context *dc);
198 static void set_unsafe_math_optimizations_flags (struct gcc_options *opts,
199 int set);
200 static void enable_warning_as_error (const char *arg, int value,
201 unsigned int lang_mask,
202 const struct cl_option_handlers *handlers,
203 struct gcc_options *opts,
204 struct gcc_options *opts_set,
205 location_t loc,
206 diagnostic_context *dc);
208 /* Handle a back-end option; arguments and return value as for
209 handle_option. */
211 bool
212 target_handle_option (struct gcc_options *opts,
213 struct gcc_options *opts_set,
214 const struct cl_decoded_option *decoded,
215 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
216 location_t loc,
217 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
218 diagnostic_context *dc)
220 gcc_assert (dc == global_dc);
221 gcc_assert (kind == DK_UNSPECIFIED);
222 return targetm_common.handle_option (opts, opts_set, decoded, loc);
225 /* Add comma-separated strings to a char_p vector. */
227 static void
228 add_comma_separated_to_vector (void **pvec, const char *arg)
230 char *tmp;
231 char *r;
232 char *w;
233 char *token_start;
234 vec<char_p> *v = (vec<char_p> *) *pvec;
236 vec_check_alloc (v, 1);
238 /* We never free this string. */
239 tmp = xstrdup (arg);
241 r = tmp;
242 w = tmp;
243 token_start = tmp;
245 while (*r != '\0')
247 if (*r == ',')
249 *w++ = '\0';
250 ++r;
251 v->safe_push (token_start);
252 token_start = w;
254 if (*r == '\\' && r[1] == ',')
256 *w++ = ',';
257 r += 2;
259 else
260 *w++ = *r++;
262 if (*token_start != '\0')
263 v->safe_push (token_start);
265 *pvec = v;
268 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
270 void
271 init_options_struct (struct gcc_options *opts, struct gcc_options *opts_set)
273 size_t num_params = get_num_compiler_params ();
275 gcc_obstack_init (&opts_obstack);
277 *opts = global_options_init;
279 if (opts_set)
280 memset (opts_set, 0, sizeof (*opts_set));
282 opts->x_param_values = XNEWVEC (int, num_params);
284 if (opts_set)
285 opts_set->x_param_values = XCNEWVEC (int, num_params);
287 init_param_values (opts->x_param_values);
289 /* Initialize whether `char' is signed. */
290 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
291 /* Set this to a special "uninitialized" value. The actual default
292 is set after target options have been processed. */
293 opts->x_flag_short_enums = 2;
295 /* Initialize target_flags before default_options_optimization
296 so the latter can modify it. */
297 opts->x_target_flags = targetm_common.default_target_flags;
299 /* Some targets have ABI-specified unwind tables. */
300 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
302 /* Some targets have other target-specific initialization. */
303 targetm_common.option_init_struct (opts);
306 /* Release any allocations owned by OPTS. */
308 void
309 finalize_options_struct (struct gcc_options *opts)
311 XDELETEVEC (opts->x_param_values);
314 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
315 -Ofast if FAST is set, -Og if DEBUG is set), apply the option DEFAULT_OPT
316 to OPTS and OPTS_SET, diagnostic context DC, location LOC, with language
317 mask LANG_MASK and option handlers HANDLERS. */
319 static void
320 maybe_default_option (struct gcc_options *opts,
321 struct gcc_options *opts_set,
322 const struct default_options *default_opt,
323 int level, bool size, bool fast, bool debug,
324 unsigned int lang_mask,
325 const struct cl_option_handlers *handlers,
326 location_t loc,
327 diagnostic_context *dc)
329 const struct cl_option *option = &cl_options[default_opt->opt_index];
330 bool enabled;
332 if (size)
333 gcc_assert (level == 2);
334 if (fast)
335 gcc_assert (level == 3);
336 if (debug)
337 gcc_assert (level == 1);
339 switch (default_opt->levels)
341 case OPT_LEVELS_ALL:
342 enabled = true;
343 break;
345 case OPT_LEVELS_0_ONLY:
346 enabled = (level == 0);
347 break;
349 case OPT_LEVELS_1_PLUS:
350 enabled = (level >= 1);
351 break;
353 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
354 enabled = (level >= 1 && !size && !debug);
355 break;
357 case OPT_LEVELS_1_PLUS_NOT_DEBUG:
358 enabled = (level >= 1 && !debug);
359 break;
361 case OPT_LEVELS_2_PLUS:
362 enabled = (level >= 2);
363 break;
365 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
366 enabled = (level >= 2 && !size && !debug);
367 break;
369 case OPT_LEVELS_3_PLUS:
370 enabled = (level >= 3);
371 break;
373 case OPT_LEVELS_3_PLUS_AND_SIZE:
374 enabled = (level >= 3 || size);
375 break;
377 case OPT_LEVELS_SIZE:
378 enabled = size;
379 break;
381 case OPT_LEVELS_FAST:
382 enabled = fast;
383 break;
385 case OPT_LEVELS_NONE:
386 default:
387 gcc_unreachable ();
390 if (enabled)
391 handle_generated_option (opts, opts_set, default_opt->opt_index,
392 default_opt->arg, default_opt->value,
393 lang_mask, DK_UNSPECIFIED, loc,
394 handlers, dc);
395 else if (default_opt->arg == NULL
396 && !option->cl_reject_negative)
397 handle_generated_option (opts, opts_set, default_opt->opt_index,
398 default_opt->arg, !default_opt->value,
399 lang_mask, DK_UNSPECIFIED, loc,
400 handlers, dc);
403 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
404 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
405 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
406 language mask LANG_MASK and option handlers HANDLERS. */
408 static void
409 maybe_default_options (struct gcc_options *opts,
410 struct gcc_options *opts_set,
411 const struct default_options *default_opts,
412 int level, bool size, bool fast, bool debug,
413 unsigned int lang_mask,
414 const struct cl_option_handlers *handlers,
415 location_t loc,
416 diagnostic_context *dc)
418 size_t i;
420 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
421 maybe_default_option (opts, opts_set, &default_opts[i],
422 level, size, fast, debug,
423 lang_mask, handlers, loc, dc);
426 /* Table of options enabled by default at different levels. */
428 static const struct default_options default_options_table[] =
430 /* -O1 optimizations. */
431 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
432 #ifdef DELAY_SLOTS
433 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
434 #endif
435 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
436 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
437 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
438 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion, NULL, 1 },
439 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion2, NULL, 1 },
440 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
441 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
442 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
443 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
444 { OPT_LEVELS_1_PLUS, OPT_freorder_blocks, NULL, 1 },
445 { OPT_LEVELS_1_PLUS, OPT_fshrink_wrap, NULL, 1 },
446 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
447 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
448 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_bit_ccp, NULL, 1 },
449 { OPT_LEVELS_1_PLUS, OPT_ftree_coalesce_vars, NULL, 1 },
450 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
451 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
452 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
453 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
454 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_sra, NULL, 1 },
455 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
456 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
457 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
458 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
459 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
460 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
461 { OPT_LEVELS_1_PLUS, OPT_ftree_slsr, NULL, 1 },
462 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fbranch_count_reg, NULL, 1 },
463 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fmove_loop_invariants, NULL, 1 },
464 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_pta, NULL, 1 },
465 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fssa_phiopt, NULL, 1 },
467 /* -O2 optimizations. */
468 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
469 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
470 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
471 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
472 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
473 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
474 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
475 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
476 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
477 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
478 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
479 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
480 #ifdef INSN_SCHEDULING
481 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
482 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
483 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
484 #endif
485 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
487 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
488 REORDER_BLOCKS_ALGORITHM_STC },
489 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
490 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
491 { OPT_LEVELS_2_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
492 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
493 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
494 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
495 { OPT_LEVELS_2_PLUS, OPT_fipa_cp_alignment, NULL, 1 },
496 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
497 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
498 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
499 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
500 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
501 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
502 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
503 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
504 { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
505 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
506 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
507 { OPT_LEVELS_2_PLUS, OPT_fipa_icf, NULL, 1 },
508 { OPT_LEVELS_2_PLUS, OPT_fisolate_erroneous_paths_dereference, NULL, 1 },
509 { OPT_LEVELS_2_PLUS, OPT_fipa_ra, NULL, 1 },
510 { OPT_LEVELS_2_PLUS, OPT_flra_remat, NULL, 1 },
512 /* -O3 optimizations. */
513 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
514 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
515 /* Inlining of functions reducing size is a good idea with -Os
516 regardless of them being declared inline. */
517 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
518 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
519 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
520 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
521 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
522 { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
523 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
524 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
525 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
527 /* -Ofast adds optimizations to -O3. */
528 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
530 { OPT_LEVELS_NONE, 0, NULL, 0 }
533 /* Default the options in OPTS and OPTS_SET based on the optimization
534 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
535 void
536 default_options_optimization (struct gcc_options *opts,
537 struct gcc_options *opts_set,
538 struct cl_decoded_option *decoded_options,
539 unsigned int decoded_options_count,
540 location_t loc,
541 unsigned int lang_mask,
542 const struct cl_option_handlers *handlers,
543 diagnostic_context *dc)
545 unsigned int i;
546 int opt2;
548 /* Scan to see what optimization level has been specified. That will
549 determine the default value of many flags. */
550 for (i = 1; i < decoded_options_count; i++)
552 struct cl_decoded_option *opt = &decoded_options[i];
553 switch (opt->opt_index)
555 case OPT_O:
556 if (*opt->arg == '\0')
558 opts->x_optimize = 1;
559 opts->x_optimize_size = 0;
560 opts->x_optimize_fast = 0;
561 opts->x_optimize_debug = 0;
563 else
565 const int optimize_val = integral_argument (opt->arg);
566 if (optimize_val == -1)
567 error_at (loc, "argument to %<-O%> should be a non-negative "
568 "integer, %<g%>, %<s%> or %<fast%>");
569 else
571 opts->x_optimize = optimize_val;
572 if ((unsigned int) opts->x_optimize > 255)
573 opts->x_optimize = 255;
574 opts->x_optimize_size = 0;
575 opts->x_optimize_fast = 0;
576 opts->x_optimize_debug = 0;
579 break;
581 case OPT_Os:
582 opts->x_optimize_size = 1;
584 /* Optimizing for size forces optimize to be 2. */
585 opts->x_optimize = 2;
586 opts->x_optimize_fast = 0;
587 opts->x_optimize_debug = 0;
588 break;
590 case OPT_Ofast:
591 /* -Ofast only adds flags to -O3. */
592 opts->x_optimize_size = 0;
593 opts->x_optimize = 3;
594 opts->x_optimize_fast = 1;
595 opts->x_optimize_debug = 0;
596 break;
598 case OPT_Og:
599 /* -Og selects optimization level 1. */
600 opts->x_optimize_size = 0;
601 opts->x_optimize = 1;
602 opts->x_optimize_fast = 0;
603 opts->x_optimize_debug = 1;
604 break;
606 default:
607 /* Ignore other options in this prescan. */
608 break;
612 maybe_default_options (opts, opts_set, default_options_table,
613 opts->x_optimize, opts->x_optimize_size,
614 opts->x_optimize_fast, opts->x_optimize_debug,
615 lang_mask, handlers, loc, dc);
617 /* -O2 param settings. */
618 opt2 = (opts->x_optimize >= 2);
620 /* Track fields in field-sensitive alias analysis. */
621 maybe_set_param_value
622 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
623 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
624 opts->x_param_values, opts_set->x_param_values);
626 /* For -O1 only do loop invariant motion for very small loops. */
627 maybe_set_param_value
628 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
629 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
630 opts->x_param_values, opts_set->x_param_values);
632 /* At -Ofast, allow store motion to introduce potential race conditions. */
633 maybe_set_param_value
634 (PARAM_ALLOW_STORE_DATA_RACES,
635 opts->x_optimize_fast ? 1
636 : default_param_value (PARAM_ALLOW_STORE_DATA_RACES),
637 opts->x_param_values, opts_set->x_param_values);
639 if (opts->x_optimize_size)
640 /* We want to crossjump as much as possible. */
641 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
642 opts->x_param_values, opts_set->x_param_values);
643 else
644 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
645 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
646 opts->x_param_values, opts_set->x_param_values);
648 /* Restrict the amount of work combine does at -Og while retaining
649 most of its useful transforms. */
650 if (opts->x_optimize_debug)
651 maybe_set_param_value (PARAM_MAX_COMBINE_INSNS, 2,
652 opts->x_param_values, opts_set->x_param_values);
654 /* Allow default optimizations to be specified on a per-machine basis. */
655 maybe_default_options (opts, opts_set,
656 targetm_common.option_optimization_table,
657 opts->x_optimize, opts->x_optimize_size,
658 opts->x_optimize_fast, opts->x_optimize_debug,
659 lang_mask, handlers, loc, dc);
662 /* After all options at LOC have been read into OPTS and OPTS_SET,
663 finalize settings of those options and diagnose incompatible
664 combinations. */
665 void
666 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
667 location_t loc)
669 enum unwind_info_type ui_except;
671 if (opts->x_dump_base_name
672 && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name)
673 && ! opts->x_dump_base_name_prefixed)
675 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
676 OPTS->X_DUMP_DIR_NAME directory. Then try to make
677 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
678 directory, typically the directory to contain the object
679 file. */
680 if (opts->x_dump_dir_name)
681 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
682 opts->x_dump_base_name, NULL);
683 else if (opts->x_aux_base_name
684 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
686 const char *aux_base;
688 base_of_path (opts->x_aux_base_name, &aux_base);
689 if (opts->x_aux_base_name != aux_base)
691 int dir_len = aux_base - opts->x_aux_base_name;
692 char *new_dump_base_name
693 = XOBNEWVEC (&opts_obstack, char,
694 strlen (opts->x_dump_base_name) + dir_len + 1);
696 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
697 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
698 /* Append existing OPTS->X_DUMP_BASE_NAME. */
699 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
700 opts->x_dump_base_name = new_dump_base_name;
703 opts->x_dump_base_name_prefixed = true;
706 /* Handle related options for unit-at-a-time, toplevel-reorder, and
707 section-anchors. */
708 if (!opts->x_flag_unit_at_a_time)
710 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
711 error_at (loc, "section anchors must be disabled when unit-at-a-time "
712 "is disabled");
713 opts->x_flag_section_anchors = 0;
714 if (opts->x_flag_toplevel_reorder == 1)
715 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
716 "is disabled");
717 opts->x_flag_toplevel_reorder = 0;
720 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
721 sorry ("transactional memory is not supported with non-call exceptions");
723 /* Unless the user has asked for section anchors, we disable toplevel
724 reordering at -O0 to disable transformations that might be surprising
725 to end users and to get -fno-toplevel-reorder tested. */
726 if (!opts->x_optimize
727 && opts->x_flag_toplevel_reorder == 2
728 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
730 opts->x_flag_toplevel_reorder = 0;
731 opts->x_flag_section_anchors = 0;
733 if (!opts->x_flag_toplevel_reorder)
735 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
736 error_at (loc, "section anchors must be disabled when toplevel reorder"
737 " is disabled");
738 opts->x_flag_section_anchors = 0;
741 if (!opts->x_flag_opts_finished)
743 /* We initialize opts->x_flag_pie to -1 so that targets can set a
744 default value. */
745 if (opts->x_flag_pie == -1)
747 if (opts->x_flag_pic == 0)
748 opts->x_flag_pie = DEFAULT_FLAG_PIE;
749 else
750 opts->x_flag_pie = 0;
752 if (opts->x_flag_pie)
753 opts->x_flag_pic = opts->x_flag_pie;
754 if (opts->x_flag_pic && !opts->x_flag_pie)
755 opts->x_flag_shlib = 1;
756 opts->x_flag_opts_finished = true;
759 /* We initialize opts->x_flag_stack_protect to -1 so that targets
760 can set a default value. */
761 if (opts->x_flag_stack_protect == -1)
762 opts->x_flag_stack_protect = DEFAULT_FLAG_SSP;
764 if (opts->x_optimize == 0)
766 /* Inlining does not work if not optimizing,
767 so force it not to be done. */
768 opts->x_warn_inline = 0;
769 opts->x_flag_no_inline = 1;
772 /* The optimization to partition hot and cold basic blocks into separate
773 sections of the .o and executable files does not work (currently)
774 with exception handling. This is because there is no support for
775 generating unwind info. If opts->x_flag_exceptions is turned on
776 we need to turn off the partitioning optimization. */
778 ui_except = targetm_common.except_unwind_info (opts);
780 if (opts->x_flag_exceptions
781 && opts->x_flag_reorder_blocks_and_partition
782 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
784 if (opts_set->x_flag_reorder_blocks_and_partition)
785 inform (loc,
786 "-freorder-blocks-and-partition does not work "
787 "with exceptions on this architecture");
788 opts->x_flag_reorder_blocks_and_partition = 0;
789 opts->x_flag_reorder_blocks = 1;
792 /* If user requested unwind info, then turn off the partitioning
793 optimization. */
795 if (opts->x_flag_unwind_tables
796 && !targetm_common.unwind_tables_default
797 && opts->x_flag_reorder_blocks_and_partition
798 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
800 if (opts_set->x_flag_reorder_blocks_and_partition)
801 inform (loc,
802 "-freorder-blocks-and-partition does not support "
803 "unwind info on this architecture");
804 opts->x_flag_reorder_blocks_and_partition = 0;
805 opts->x_flag_reorder_blocks = 1;
808 /* If the target requested unwind info, then turn off the partitioning
809 optimization with a different message. Likewise, if the target does not
810 support named sections. */
812 if (opts->x_flag_reorder_blocks_and_partition
813 && (!targetm_common.have_named_sections
814 || (opts->x_flag_unwind_tables
815 && targetm_common.unwind_tables_default
816 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
818 if (opts_set->x_flag_reorder_blocks_and_partition)
819 inform (loc,
820 "-freorder-blocks-and-partition does not work "
821 "on this architecture");
822 opts->x_flag_reorder_blocks_and_partition = 0;
823 opts->x_flag_reorder_blocks = 1;
826 /* Disable -freorder-blocks-and-partition when -fprofile-use is not in
827 effect. Function splitting was not actually being performed in that case,
828 as probably_never_executed_bb_p does not distinguish any basic blocks as
829 being cold vs hot when there is no profile data. Leaving it enabled,
830 however, causes the assembly code generator to create (empty) cold
831 sections and labels, leading to unnecessary size overhead. */
832 if (opts->x_flag_reorder_blocks_and_partition
833 && !opts_set->x_flag_profile_use)
834 opts->x_flag_reorder_blocks_and_partition = 0;
836 if (opts->x_flag_reorder_blocks_and_partition
837 && !opts_set->x_flag_reorder_functions)
838 opts->x_flag_reorder_functions = 1;
840 /* Pipelining of outer loops is only possible when general pipelining
841 capabilities are requested. */
842 if (!opts->x_flag_sel_sched_pipelining)
843 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
845 if (opts->x_flag_conserve_stack)
847 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
848 opts->x_param_values, opts_set->x_param_values);
849 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
850 opts->x_param_values, opts_set->x_param_values);
853 if (opts->x_flag_lto)
855 #ifdef ENABLE_LTO
856 opts->x_flag_generate_lto = 1;
858 /* When generating IL, do not operate in whole-program mode.
859 Otherwise, symbols will be privatized too early, causing link
860 errors later. */
861 opts->x_flag_whole_program = 0;
862 #else
863 error_at (loc, "LTO support has not been enabled in this configuration");
864 #endif
865 if (!opts->x_flag_fat_lto_objects
866 && (!HAVE_LTO_PLUGIN
867 || (opts_set->x_flag_use_linker_plugin
868 && !opts->x_flag_use_linker_plugin)))
870 if (opts_set->x_flag_fat_lto_objects)
871 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin");
872 opts->x_flag_fat_lto_objects = 1;
876 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
877 default value if they choose based on other options. */
878 if (opts->x_flag_split_stack == -1)
879 opts->x_flag_split_stack = 0;
880 else if (opts->x_flag_split_stack)
882 if (!targetm_common.supports_split_stack (true, opts))
884 error_at (loc, "%<-fsplit-stack%> is not supported by "
885 "this compiler configuration");
886 opts->x_flag_split_stack = 0;
890 /* Tune vectorization related parametees according to cost model. */
891 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
893 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
894 6, opts->x_param_values, opts_set->x_param_values);
895 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
896 0, opts->x_param_values, opts_set->x_param_values);
897 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
898 0, opts->x_param_values, opts_set->x_param_values);
901 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
902 is disabled. */
903 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
904 || !opts->x_flag_tree_loop_if_convert)
905 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
906 opts->x_param_values, opts_set->x_param_values);
908 /* The -gsplit-dwarf option requires -ggnu-pubnames. */
909 if (opts->x_dwarf_split_debug_info)
910 opts->x_debug_generate_pub_sections = 2;
912 /* Userspace and kernel ASan conflict with each other. */
914 if ((opts->x_flag_sanitize & SANITIZE_USER_ADDRESS)
915 && (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS))
916 error_at (loc,
917 "-fsanitize=address is incompatible with "
918 "-fsanitize=kernel-address");
920 /* And with TSan. */
922 if ((opts->x_flag_sanitize & SANITIZE_ADDRESS)
923 && (opts->x_flag_sanitize & SANITIZE_THREAD))
924 error_at (loc,
925 "-fsanitize=address and -fsanitize=kernel-address "
926 "are incompatible with -fsanitize=thread");
928 /* Error recovery is not allowed for ASan and TSan. */
930 if (opts->x_flag_sanitize_recover & SANITIZE_USER_ADDRESS)
931 error_at (loc, "-fsanitize-recover=address is not supported");
933 if (opts->x_flag_sanitize_recover & SANITIZE_THREAD)
934 error_at (loc, "-fsanitize-recover=thread is not supported");
936 if (opts->x_flag_sanitize_recover & SANITIZE_LEAK)
937 error_at (loc, "-fsanitize-recover=leak is not supported");
939 /* When instrumenting the pointers, we don't want to remove
940 the null pointer checks. */
941 if (opts->x_flag_sanitize & (SANITIZE_NULL | SANITIZE_NONNULL_ATTRIBUTE
942 | SANITIZE_RETURNS_NONNULL_ATTRIBUTE))
943 opts->x_flag_delete_null_pointer_checks = 0;
945 /* Aggressive compiler optimizations may cause false negatives. */
946 if (opts->x_flag_sanitize)
948 opts->x_flag_aggressive_loop_optimizations = 0;
949 opts->x_flag_strict_overflow = 0;
953 #define LEFT_COLUMN 27
955 /* Output ITEM, of length ITEM_WIDTH, in the left column,
956 followed by word-wrapped HELP in a second column. */
957 static void
958 wrap_help (const char *help,
959 const char *item,
960 unsigned int item_width,
961 unsigned int columns)
963 unsigned int col_width = LEFT_COLUMN;
964 unsigned int remaining, room, len;
966 remaining = strlen (help);
970 room = columns - 3 - MAX (col_width, item_width);
971 if (room > columns)
972 room = 0;
973 len = remaining;
975 if (room < len)
977 unsigned int i;
979 for (i = 0; help[i]; i++)
981 if (i >= room && len != remaining)
982 break;
983 if (help[i] == ' ')
984 len = i;
985 else if ((help[i] == '-' || help[i] == '/')
986 && help[i + 1] != ' '
987 && i > 0 && ISALPHA (help[i - 1]))
988 len = i + 1;
992 printf (" %-*.*s %.*s\n", col_width, item_width, item, len, help);
993 item_width = 0;
994 while (help[len] == ' ')
995 len++;
996 help += len;
997 remaining -= len;
999 while (remaining);
1002 /* Print help for a specific front-end, etc. */
1003 static void
1004 print_filtered_help (unsigned int include_flags,
1005 unsigned int exclude_flags,
1006 unsigned int any_flags,
1007 unsigned int columns,
1008 struct gcc_options *opts,
1009 unsigned int lang_mask)
1011 unsigned int i;
1012 const char *help;
1013 bool found = false;
1014 bool displayed = false;
1015 char new_help[128];
1017 if (include_flags == CL_PARAMS)
1019 for (i = 0; i < LAST_PARAM; i++)
1021 const char *param = compiler_params[i].option;
1023 help = compiler_params[i].help;
1024 if (help == NULL || *help == '\0')
1026 if (exclude_flags & CL_UNDOCUMENTED)
1027 continue;
1028 help = undocumented_msg;
1031 /* Get the translation. */
1032 help = _(help);
1034 if (!opts->x_quiet_flag)
1036 snprintf (new_help, sizeof (new_help),
1037 _("default %d minimum %d maximum %d"),
1038 compiler_params[i].default_value,
1039 compiler_params[i].min_value,
1040 compiler_params[i].max_value);
1041 help = new_help;
1043 wrap_help (help, param, strlen (param), columns);
1045 putchar ('\n');
1046 return;
1049 if (!opts->x_help_printed)
1050 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
1052 if (!opts->x_help_enum_printed)
1053 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
1055 for (i = 0; i < cl_options_count; i++)
1057 const struct cl_option *option = cl_options + i;
1058 unsigned int len;
1059 const char *opt;
1060 const char *tab;
1062 if (include_flags == 0
1063 || ((option->flags & include_flags) != include_flags))
1065 if ((option->flags & any_flags) == 0)
1066 continue;
1069 /* Skip unwanted switches. */
1070 if ((option->flags & exclude_flags) != 0)
1071 continue;
1073 /* The driver currently prints its own help text. */
1074 if ((option->flags & CL_DRIVER) != 0
1075 && (option->flags & (((1U << cl_lang_count) - 1)
1076 | CL_COMMON | CL_TARGET)) == 0)
1077 continue;
1079 found = true;
1080 /* Skip switches that have already been printed. */
1081 if (opts->x_help_printed[i])
1082 continue;
1084 opts->x_help_printed[i] = true;
1086 help = option->help;
1087 if (help == NULL)
1089 if (exclude_flags & CL_UNDOCUMENTED)
1090 continue;
1091 help = undocumented_msg;
1094 /* Get the translation. */
1095 help = _(help);
1097 /* Find the gap between the name of the
1098 option and its descriptive text. */
1099 tab = strchr (help, '\t');
1100 if (tab)
1102 len = tab - help;
1103 opt = help;
1104 help = tab + 1;
1106 else
1108 opt = option->opt_text;
1109 len = strlen (opt);
1112 /* With the -Q option enabled we change the descriptive text associated
1113 with an option to be an indication of its current setting. */
1114 if (!opts->x_quiet_flag)
1116 void *flag_var = option_flag_var (i, opts);
1118 if (len < (LEFT_COLUMN + 2))
1119 strcpy (new_help, "\t\t");
1120 else
1121 strcpy (new_help, "\t");
1123 if (flag_var != NULL
1124 && option->var_type != CLVC_DEFER)
1126 if (option->flags & CL_JOINED)
1128 if (option->var_type == CLVC_STRING)
1130 if (* (const char **) flag_var != NULL)
1131 snprintf (new_help + strlen (new_help),
1132 sizeof (new_help) - strlen (new_help),
1133 "%s", * (const char **) flag_var);
1135 else if (option->var_type == CLVC_ENUM)
1137 const struct cl_enum *e = &cl_enums[option->var_enum];
1138 int value;
1139 const char *arg = NULL;
1141 value = e->get (flag_var);
1142 enum_value_to_arg (e->values, &arg, value, lang_mask);
1143 if (arg == NULL)
1144 arg = _("[default]");
1145 snprintf (new_help + strlen (new_help),
1146 sizeof (new_help) - strlen (new_help),
1147 "%s", arg);
1149 else
1150 sprintf (new_help + strlen (new_help),
1151 "%#x", * (int *) flag_var);
1153 else
1154 strcat (new_help, option_enabled (i, opts)
1155 ? _("[enabled]") : _("[disabled]"));
1158 help = new_help;
1161 wrap_help (help, opt, len, columns);
1162 displayed = true;
1164 if (option->var_type == CLVC_ENUM
1165 && opts->x_help_enum_printed[option->var_enum] != 2)
1166 opts->x_help_enum_printed[option->var_enum] = 1;
1169 if (! found)
1171 unsigned int langs = include_flags & CL_LANG_ALL;
1173 if (langs == 0)
1174 printf (_(" No options with the desired characteristics were found\n"));
1175 else
1177 unsigned int i;
1179 /* PR 31349: Tell the user how to see all of the
1180 options supported by a specific front end. */
1181 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1182 if ((1U << i) & langs)
1183 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end\n"),
1184 lang_names[i], lang_names[i]);
1188 else if (! displayed)
1189 printf (_(" All options with the desired characteristics have already been displayed\n"));
1191 putchar ('\n');
1193 /* Print details of enumerated option arguments, if those
1194 enumerations have help text headings provided. If no help text
1195 is provided, presume that the possible values are listed in the
1196 help text for the relevant options. */
1197 for (i = 0; i < cl_enums_count; i++)
1199 unsigned int j, pos;
1201 if (opts->x_help_enum_printed[i] != 1)
1202 continue;
1203 if (cl_enums[i].help == NULL)
1204 continue;
1205 printf (" %s\n ", _(cl_enums[i].help));
1206 pos = 4;
1207 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1209 unsigned int len = strlen (cl_enums[i].values[j].arg);
1211 if (pos > 4 && pos + 1 + len <= columns)
1213 printf (" %s", cl_enums[i].values[j].arg);
1214 pos += 1 + len;
1216 else
1218 if (pos > 4)
1220 printf ("\n ");
1221 pos = 4;
1223 printf ("%s", cl_enums[i].values[j].arg);
1224 pos += len;
1227 printf ("\n\n");
1228 opts->x_help_enum_printed[i] = 2;
1232 /* Display help for a specified type of option.
1233 The options must have ALL of the INCLUDE_FLAGS set
1234 ANY of the flags in the ANY_FLAGS set
1235 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1236 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1237 static void
1238 print_specific_help (unsigned int include_flags,
1239 unsigned int exclude_flags,
1240 unsigned int any_flags,
1241 struct gcc_options *opts,
1242 unsigned int lang_mask)
1244 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1245 const char * description = NULL;
1246 const char * descrip_extra = "";
1247 size_t i;
1248 unsigned int flag;
1250 /* Sanity check: Make sure that we do not have more
1251 languages than we have bits available to enumerate them. */
1252 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1254 /* If we have not done so already, obtain
1255 the desired maximum width of the output. */
1256 if (opts->x_help_columns == 0)
1258 opts->x_help_columns = get_terminal_width ();
1259 if (opts->x_help_columns == INT_MAX)
1260 /* Use a reasonable default. */
1261 opts->x_help_columns = 80;
1264 /* Decide upon the title for the options that we are going to display. */
1265 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1267 switch (flag & include_flags)
1269 case 0:
1270 case CL_DRIVER:
1271 break;
1273 case CL_TARGET:
1274 description = _("The following options are target specific");
1275 break;
1276 case CL_WARNING:
1277 description = _("The following options control compiler warning messages");
1278 break;
1279 case CL_OPTIMIZATION:
1280 description = _("The following options control optimizations");
1281 break;
1282 case CL_COMMON:
1283 description = _("The following options are language-independent");
1284 break;
1285 case CL_PARAMS:
1286 description = _("The --param option recognizes the following as parameters");
1287 break;
1288 default:
1289 if (i >= cl_lang_count)
1290 break;
1291 if (exclude_flags & all_langs_mask)
1292 description = _("The following options are specific to just the language ");
1293 else
1294 description = _("The following options are supported by the language ");
1295 descrip_extra = lang_names [i];
1296 break;
1300 if (description == NULL)
1302 if (any_flags == 0)
1304 if (include_flags & CL_UNDOCUMENTED)
1305 description = _("The following options are not documented");
1306 else if (include_flags & CL_SEPARATE)
1307 description = _("The following options take separate arguments");
1308 else if (include_flags & CL_JOINED)
1309 description = _("The following options take joined arguments");
1310 else
1312 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1313 include_flags);
1314 return;
1317 else
1319 if (any_flags & all_langs_mask)
1320 description = _("The following options are language-related");
1321 else
1322 description = _("The following options are language-independent");
1326 printf ("%s%s:\n", description, descrip_extra);
1327 print_filtered_help (include_flags, exclude_flags, any_flags,
1328 opts->x_help_columns, opts, lang_mask);
1331 /* Enable FDO-related flags. */
1333 static void
1334 enable_fdo_optimizations (struct gcc_options *opts,
1335 struct gcc_options *opts_set,
1336 int value)
1338 if (!opts_set->x_flag_branch_probabilities)
1339 opts->x_flag_branch_probabilities = value;
1340 if (!opts_set->x_flag_profile_values)
1341 opts->x_flag_profile_values = value;
1342 if (!opts_set->x_flag_unroll_loops)
1343 opts->x_flag_unroll_loops = value;
1344 if (!opts_set->x_flag_peel_loops)
1345 opts->x_flag_peel_loops = value;
1346 if (!opts_set->x_flag_tracer)
1347 opts->x_flag_tracer = value;
1348 if (!opts_set->x_flag_value_profile_transformations)
1349 opts->x_flag_value_profile_transformations = value;
1350 if (!opts_set->x_flag_inline_functions)
1351 opts->x_flag_inline_functions = value;
1352 if (!opts_set->x_flag_ipa_cp)
1353 opts->x_flag_ipa_cp = value;
1354 if (!opts_set->x_flag_ipa_cp_clone
1355 && value && opts->x_flag_ipa_cp)
1356 opts->x_flag_ipa_cp_clone = value;
1357 if (!opts_set->x_flag_ipa_cp_alignment
1358 && value && opts->x_flag_ipa_cp)
1359 opts->x_flag_ipa_cp_alignment = value;
1360 if (!opts_set->x_flag_predictive_commoning)
1361 opts->x_flag_predictive_commoning = value;
1362 if (!opts_set->x_flag_unswitch_loops)
1363 opts->x_flag_unswitch_loops = value;
1364 if (!opts_set->x_flag_gcse_after_reload)
1365 opts->x_flag_gcse_after_reload = value;
1366 if (!opts_set->x_flag_tree_loop_vectorize
1367 && !opts_set->x_flag_tree_vectorize)
1368 opts->x_flag_tree_loop_vectorize = value;
1369 if (!opts_set->x_flag_tree_slp_vectorize
1370 && !opts_set->x_flag_tree_vectorize)
1371 opts->x_flag_tree_slp_vectorize = value;
1372 if (!opts_set->x_flag_vect_cost_model)
1373 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1374 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1375 opts->x_flag_tree_loop_distribute_patterns = value;
1378 /* Handle target- and language-independent options. Return zero to
1379 generate an "unknown option" message. Only options that need
1380 extra handling need to be listed here; if you simply want
1381 DECODED->value assigned to a variable, it happens automatically. */
1383 bool
1384 common_handle_option (struct gcc_options *opts,
1385 struct gcc_options *opts_set,
1386 const struct cl_decoded_option *decoded,
1387 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1388 location_t loc,
1389 const struct cl_option_handlers *handlers,
1390 diagnostic_context *dc)
1392 size_t scode = decoded->opt_index;
1393 const char *arg = decoded->arg;
1394 int value = decoded->value;
1395 enum opt_code code = (enum opt_code) scode;
1397 gcc_assert (decoded->canonical_option_num_elements <= 2);
1399 switch (code)
1401 case OPT__param:
1402 handle_param (opts, opts_set, loc, arg);
1403 break;
1405 case OPT__help:
1407 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1408 unsigned int undoc_mask;
1409 unsigned int i;
1411 if (lang_mask == CL_DRIVER)
1412 break;
1414 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1416 : CL_UNDOCUMENTED);
1417 /* First display any single language specific options. */
1418 for (i = 0; i < cl_lang_count; i++)
1419 print_specific_help
1420 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1421 lang_mask);
1422 /* Next display any multi language specific options. */
1423 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1424 /* Then display any remaining, non-language options. */
1425 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1426 if (i != CL_DRIVER)
1427 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1428 opts->x_exit_after_options = true;
1429 break;
1432 case OPT__target_help:
1433 if (lang_mask == CL_DRIVER)
1434 break;
1436 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1437 opts->x_exit_after_options = true;
1438 break;
1440 case OPT__help_:
1442 const char * a = arg;
1443 unsigned int include_flags = 0;
1444 /* Note - by default we include undocumented options when listing
1445 specific classes. If you only want to see documented options
1446 then add ",^undocumented" to the --help= option. E.g.:
1448 --help=target,^undocumented */
1449 unsigned int exclude_flags = 0;
1451 if (lang_mask == CL_DRIVER)
1452 break;
1454 /* Walk along the argument string, parsing each word in turn.
1455 The format is:
1456 arg = [^]{word}[,{arg}]
1457 word = {optimizers|target|warnings|undocumented|
1458 params|common|<language>} */
1459 while (* a != 0)
1461 static const struct
1463 const char * string;
1464 unsigned int flag;
1466 specifics[] =
1468 { "optimizers", CL_OPTIMIZATION },
1469 { "target", CL_TARGET },
1470 { "warnings", CL_WARNING },
1471 { "undocumented", CL_UNDOCUMENTED },
1472 { "params", CL_PARAMS },
1473 { "joined", CL_JOINED },
1474 { "separate", CL_SEPARATE },
1475 { "common", CL_COMMON },
1476 { NULL, 0 }
1478 unsigned int * pflags;
1479 const char * comma;
1480 unsigned int lang_flag, specific_flag;
1481 unsigned int len;
1482 unsigned int i;
1484 if (* a == '^')
1486 ++ a;
1487 pflags = & exclude_flags;
1489 else
1490 pflags = & include_flags;
1492 comma = strchr (a, ',');
1493 if (comma == NULL)
1494 len = strlen (a);
1495 else
1496 len = comma - a;
1497 if (len == 0)
1499 a = comma + 1;
1500 continue;
1503 /* Check to see if the string matches an option class name. */
1504 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1505 if (strncasecmp (a, specifics[i].string, len) == 0)
1507 specific_flag = specifics[i].flag;
1508 break;
1511 /* Check to see if the string matches a language name.
1512 Note - we rely upon the alpha-sorted nature of the entries in
1513 the lang_names array, specifically that shorter names appear
1514 before their longer variants. (i.e. C before C++). That way
1515 when we are attempting to match --help=c for example we will
1516 match with C first and not C++. */
1517 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1518 if (strncasecmp (a, lang_names[i], len) == 0)
1520 lang_flag = 1U << i;
1521 break;
1524 if (specific_flag != 0)
1526 if (lang_flag == 0)
1527 * pflags |= specific_flag;
1528 else
1530 /* The option's argument matches both the start of a
1531 language name and the start of an option class name.
1532 We have a special case for when the user has
1533 specified "--help=c", but otherwise we have to issue
1534 a warning. */
1535 if (strncasecmp (a, "c", len) == 0)
1536 * pflags |= lang_flag;
1537 else
1538 warning_at (loc, 0,
1539 "--help argument %q.*s is ambiguous, "
1540 "please be more specific",
1541 len, a);
1544 else if (lang_flag != 0)
1545 * pflags |= lang_flag;
1546 else
1547 warning_at (loc, 0,
1548 "unrecognized argument to --help= option: %q.*s",
1549 len, a);
1551 if (comma == NULL)
1552 break;
1553 a = comma + 1;
1556 if (include_flags)
1557 print_specific_help (include_flags, exclude_flags, 0, opts,
1558 lang_mask);
1559 opts->x_exit_after_options = true;
1560 break;
1563 case OPT__version:
1564 if (lang_mask == CL_DRIVER)
1565 break;
1567 opts->x_exit_after_options = true;
1568 break;
1570 case OPT_fsanitize_:
1571 case OPT_fsanitize_recover_:
1573 const char *p = arg;
1574 unsigned int *flag
1575 = code == OPT_fsanitize_ ? &opts->x_flag_sanitize
1576 : &opts->x_flag_sanitize_recover;
1577 while (*p != 0)
1579 static const struct
1581 const char *const name;
1582 unsigned int flag;
1583 size_t len;
1584 } spec[] =
1586 { "address", SANITIZE_ADDRESS | SANITIZE_USER_ADDRESS,
1587 sizeof "address" - 1 },
1588 { "kernel-address", SANITIZE_ADDRESS | SANITIZE_KERNEL_ADDRESS,
1589 sizeof "kernel-address" - 1 },
1590 { "thread", SANITIZE_THREAD, sizeof "thread" - 1 },
1591 { "leak", SANITIZE_LEAK, sizeof "leak" - 1 },
1592 { "shift", SANITIZE_SHIFT, sizeof "shift" - 1 },
1593 { "integer-divide-by-zero", SANITIZE_DIVIDE,
1594 sizeof "integer-divide-by-zero" - 1 },
1595 { "undefined", SANITIZE_UNDEFINED, sizeof "undefined" - 1 },
1596 { "unreachable", SANITIZE_UNREACHABLE,
1597 sizeof "unreachable" - 1 },
1598 { "vla-bound", SANITIZE_VLA, sizeof "vla-bound" - 1 },
1599 { "return", SANITIZE_RETURN, sizeof "return" - 1 },
1600 { "null", SANITIZE_NULL, sizeof "null" - 1 },
1601 { "signed-integer-overflow", SANITIZE_SI_OVERFLOW,
1602 sizeof "signed-integer-overflow" -1 },
1603 { "bool", SANITIZE_BOOL, sizeof "bool" - 1 },
1604 { "enum", SANITIZE_ENUM, sizeof "enum" - 1 },
1605 { "float-divide-by-zero", SANITIZE_FLOAT_DIVIDE,
1606 sizeof "float-divide-by-zero" - 1 },
1607 { "float-cast-overflow", SANITIZE_FLOAT_CAST,
1608 sizeof "float-cast-overflow" - 1 },
1609 { "bounds", SANITIZE_BOUNDS, sizeof "bounds" - 1 },
1610 { "bounds-strict", SANITIZE_BOUNDS | SANITIZE_BOUNDS_STRICT,
1611 sizeof "bounds-strict" - 1 },
1612 { "alignment", SANITIZE_ALIGNMENT, sizeof "alignment" - 1 },
1613 { "nonnull-attribute", SANITIZE_NONNULL_ATTRIBUTE,
1614 sizeof "nonnull-attribute" - 1 },
1615 { "returns-nonnull-attribute",
1616 SANITIZE_RETURNS_NONNULL_ATTRIBUTE,
1617 sizeof "returns-nonnull-attribute" - 1 },
1618 { "object-size", SANITIZE_OBJECT_SIZE,
1619 sizeof "object-size" - 1 },
1620 { "vptr", SANITIZE_VPTR, sizeof "vptr" - 1 },
1621 { "all", ~0, sizeof "all" - 1 },
1622 { NULL, 0, 0 }
1624 const char *comma;
1625 size_t len, i;
1626 bool found = false;
1628 comma = strchr (p, ',');
1629 if (comma == NULL)
1630 len = strlen (p);
1631 else
1632 len = comma - p;
1633 if (len == 0)
1635 p = comma + 1;
1636 continue;
1639 /* Check to see if the string matches an option class name. */
1640 for (i = 0; spec[i].name != NULL; ++i)
1641 if (len == spec[i].len
1642 && memcmp (p, spec[i].name, len) == 0)
1644 /* Handle both -fsanitize and -fno-sanitize cases. */
1645 if (value && spec[i].flag == ~0U)
1647 if (code == OPT_fsanitize_)
1648 error_at (loc, "-fsanitize=all option is not valid");
1649 else
1650 *flag |= ~(SANITIZE_USER_ADDRESS | SANITIZE_THREAD
1651 | SANITIZE_LEAK);
1653 else if (value)
1654 *flag |= spec[i].flag;
1655 else
1656 *flag &= ~spec[i].flag;
1657 found = true;
1658 break;
1661 if (! found)
1662 error_at (loc,
1663 "unrecognized argument to -fsanitize%s= option: %q.*s",
1664 code == OPT_fsanitize_ ? "" : "-recover", (int) len, p);
1666 if (comma == NULL)
1667 break;
1668 p = comma + 1;
1671 if (code != OPT_fsanitize_)
1672 break;
1674 /* Kernel ASan implies normal ASan but does not yet support
1675 all features. */
1676 if (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS)
1678 maybe_set_param_value (PARAM_ASAN_INSTRUMENTATION_WITH_CALL_THRESHOLD, 0,
1679 opts->x_param_values,
1680 opts_set->x_param_values);
1681 maybe_set_param_value (PARAM_ASAN_GLOBALS, 0,
1682 opts->x_param_values,
1683 opts_set->x_param_values);
1684 maybe_set_param_value (PARAM_ASAN_STACK, 0,
1685 opts->x_param_values,
1686 opts_set->x_param_values);
1687 maybe_set_param_value (PARAM_ASAN_USE_AFTER_RETURN, 0,
1688 opts->x_param_values,
1689 opts_set->x_param_values);
1692 break;
1695 case OPT_fasan_shadow_offset_:
1696 /* Deferred. */
1697 break;
1699 case OPT_fsanitize_recover:
1700 if (value)
1701 opts->x_flag_sanitize_recover
1702 |= SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT;
1703 else
1704 opts->x_flag_sanitize_recover
1705 &= ~(SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT);
1706 break;
1708 case OPT_O:
1709 case OPT_Os:
1710 case OPT_Ofast:
1711 case OPT_Og:
1712 /* Currently handled in a prescan. */
1713 break;
1715 case OPT_Werror:
1716 dc->warning_as_error_requested = value;
1717 break;
1719 case OPT_Werror_:
1720 if (lang_mask == CL_DRIVER)
1721 break;
1723 enable_warning_as_error (arg, value, lang_mask, handlers,
1724 opts, opts_set, loc, dc);
1725 break;
1727 case OPT_Wlarger_than_:
1728 opts->x_larger_than_size = value;
1729 opts->x_warn_larger_than = value != -1;
1730 break;
1732 case OPT_Wfatal_errors:
1733 dc->fatal_errors = value;
1734 break;
1736 case OPT_Wframe_larger_than_:
1737 opts->x_frame_larger_than_size = value;
1738 opts->x_warn_frame_larger_than = value != -1;
1739 break;
1741 case OPT_Wstack_usage_:
1742 opts->x_warn_stack_usage = value;
1743 opts->x_flag_stack_usage_info = value != -1;
1744 break;
1746 case OPT_Wstrict_aliasing:
1747 set_Wstrict_aliasing (opts, value);
1748 break;
1750 case OPT_Wstrict_overflow:
1751 opts->x_warn_strict_overflow = (value
1752 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1753 : 0);
1754 break;
1756 case OPT_Wsystem_headers:
1757 dc->dc_warn_system_headers = value;
1758 break;
1760 case OPT_aux_info:
1761 opts->x_flag_gen_aux_info = 1;
1762 break;
1764 case OPT_auxbase_strip:
1766 char *tmp = xstrdup (arg);
1767 strip_off_ending (tmp, strlen (tmp));
1768 if (tmp[0])
1769 opts->x_aux_base_name = tmp;
1770 else
1771 free (tmp);
1773 break;
1775 case OPT_d:
1776 decode_d_option (arg, opts, loc, dc);
1777 break;
1779 case OPT_fcall_used_:
1780 case OPT_fcall_saved_:
1781 /* Deferred. */
1782 break;
1784 case OPT_fdbg_cnt_:
1785 /* Deferred. */
1786 break;
1788 case OPT_fdbg_cnt_list:
1789 /* Deferred. */
1790 opts->x_exit_after_options = true;
1791 break;
1793 case OPT_fdebug_prefix_map_:
1794 /* Deferred. */
1795 break;
1797 case OPT_fdiagnostics_show_location_:
1798 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1799 break;
1801 case OPT_fdiagnostics_show_caret:
1802 dc->show_caret = value;
1803 break;
1805 case OPT_fdiagnostics_color_:
1806 diagnostic_color_init (dc, value);
1807 break;
1809 case OPT_fdiagnostics_show_option:
1810 dc->show_option_requested = value;
1811 break;
1813 case OPT_fdump_:
1814 /* Deferred. */
1815 break;
1817 case OPT_ffast_math:
1818 set_fast_math_flags (opts, value);
1819 break;
1821 case OPT_funsafe_math_optimizations:
1822 set_unsafe_math_optimizations_flags (opts, value);
1823 break;
1825 case OPT_ffixed_:
1826 /* Deferred. */
1827 break;
1829 case OPT_finline_limit_:
1830 set_param_value ("max-inline-insns-single", value / 2,
1831 opts->x_param_values, opts_set->x_param_values);
1832 set_param_value ("max-inline-insns-auto", value / 2,
1833 opts->x_param_values, opts_set->x_param_values);
1834 break;
1836 case OPT_finstrument_functions_exclude_function_list_:
1837 add_comma_separated_to_vector
1838 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1839 break;
1841 case OPT_finstrument_functions_exclude_file_list_:
1842 add_comma_separated_to_vector
1843 (&opts->x_flag_instrument_functions_exclude_files, arg);
1844 break;
1846 case OPT_fmessage_length_:
1847 pp_set_line_maximum_length (dc->printer, value);
1848 diagnostic_set_caret_max_width (dc, value);
1849 break;
1851 case OPT_fopt_info:
1852 case OPT_fopt_info_:
1853 /* Deferred. */
1854 break;
1856 case OPT_foffload_:
1857 /* Deferred. */
1858 break;
1860 #ifndef ACCEL_COMPILER
1861 case OPT_foffload_abi_:
1862 error_at (loc, "-foffload-abi option can be specified only for "
1863 "offload compiler");
1864 break;
1865 #endif
1867 case OPT_fpack_struct_:
1868 if (value <= 0 || (value & (value - 1)) || value > 16)
1869 error_at (loc,
1870 "structure alignment must be a small power of two, not %d",
1871 value);
1872 else
1873 opts->x_initial_max_fld_align = value;
1874 break;
1876 case OPT_fplugin_:
1877 case OPT_fplugin_arg_:
1878 /* Deferred. */
1879 break;
1881 case OPT_fprofile_use_:
1882 opts->x_profile_data_prefix = xstrdup (arg);
1883 opts->x_flag_profile_use = true;
1884 value = true;
1885 /* No break here - do -fprofile-use processing. */
1886 case OPT_fprofile_use:
1887 enable_fdo_optimizations (opts, opts_set, value);
1888 if (!opts_set->x_flag_profile_reorder_functions)
1889 opts->x_flag_profile_reorder_functions = value;
1890 /* Indirect call profiling should do all useful transformations
1891 speculative devirtualization does. */
1892 if (!opts_set->x_flag_devirtualize_speculatively
1893 && opts->x_flag_value_profile_transformations)
1894 opts->x_flag_devirtualize_speculatively = false;
1895 break;
1897 case OPT_fauto_profile_:
1898 opts->x_auto_profile_file = xstrdup (arg);
1899 opts->x_flag_auto_profile = true;
1900 value = true;
1901 /* No break here - do -fauto-profile processing. */
1902 case OPT_fauto_profile:
1903 enable_fdo_optimizations (opts, opts_set, value);
1904 if (!opts_set->x_flag_profile_correction)
1905 opts->x_flag_profile_correction = value;
1906 maybe_set_param_value (
1907 PARAM_EARLY_INLINER_MAX_ITERATIONS, 10,
1908 opts->x_param_values, opts_set->x_param_values);
1909 break;
1911 case OPT_fprofile_generate_:
1912 opts->x_profile_data_prefix = xstrdup (arg);
1913 value = true;
1914 /* No break here - do -fprofile-generate processing. */
1915 case OPT_fprofile_generate:
1916 if (!opts_set->x_profile_arc_flag)
1917 opts->x_profile_arc_flag = value;
1918 if (!opts_set->x_flag_profile_values)
1919 opts->x_flag_profile_values = value;
1920 if (!opts_set->x_flag_inline_functions)
1921 opts->x_flag_inline_functions = value;
1922 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1923 quadratic. Disable the pass until better memory representation
1924 is done. */
1925 if (!opts_set->x_flag_ipa_reference)
1926 opts->x_flag_ipa_reference = false;
1927 break;
1929 case OPT_ftree_vectorize:
1930 if (!opts_set->x_flag_tree_loop_vectorize)
1931 opts->x_flag_tree_loop_vectorize = value;
1932 if (!opts_set->x_flag_tree_slp_vectorize)
1933 opts->x_flag_tree_slp_vectorize = value;
1934 break;
1935 case OPT_fshow_column:
1936 dc->show_column = value;
1937 break;
1939 case OPT_frandom_seed:
1940 /* The real switch is -fno-random-seed. */
1941 if (value)
1942 return false;
1943 /* Deferred. */
1944 break;
1946 case OPT_frandom_seed_:
1947 /* Deferred. */
1948 break;
1950 case OPT_fsched_verbose_:
1951 #ifdef INSN_SCHEDULING
1952 /* Handled with Var in common.opt. */
1953 break;
1954 #else
1955 return false;
1956 #endif
1958 case OPT_fsched_stalled_insns_:
1959 opts->x_flag_sched_stalled_insns = value;
1960 if (opts->x_flag_sched_stalled_insns == 0)
1961 opts->x_flag_sched_stalled_insns = -1;
1962 break;
1964 case OPT_fsched_stalled_insns_dep_:
1965 opts->x_flag_sched_stalled_insns_dep = value;
1966 break;
1968 case OPT_fstack_check_:
1969 if (!strcmp (arg, "no"))
1970 opts->x_flag_stack_check = NO_STACK_CHECK;
1971 else if (!strcmp (arg, "generic"))
1972 /* This is the old stack checking method. */
1973 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1974 ? FULL_BUILTIN_STACK_CHECK
1975 : GENERIC_STACK_CHECK;
1976 else if (!strcmp (arg, "specific"))
1977 /* This is the new stack checking method. */
1978 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1979 ? FULL_BUILTIN_STACK_CHECK
1980 : STACK_CHECK_STATIC_BUILTIN
1981 ? STATIC_BUILTIN_STACK_CHECK
1982 : GENERIC_STACK_CHECK;
1983 else
1984 warning_at (loc, 0, "unknown stack check parameter %qs", arg);
1985 break;
1987 case OPT_fstack_limit:
1988 /* The real switch is -fno-stack-limit. */
1989 if (value)
1990 return false;
1991 /* Deferred. */
1992 break;
1994 case OPT_fstack_limit_register_:
1995 case OPT_fstack_limit_symbol_:
1996 /* Deferred. */
1997 break;
1999 case OPT_fstack_usage:
2000 opts->x_flag_stack_usage = value;
2001 opts->x_flag_stack_usage_info = value != 0;
2002 break;
2004 case OPT_g:
2005 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
2006 loc);
2007 break;
2009 case OPT_gcoff:
2010 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
2011 break;
2013 case OPT_gdwarf:
2014 if (arg && strlen (arg) != 0)
2016 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
2017 "use %<-gdwarf-%s%> for DWARF version "
2018 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
2019 break;
2021 else
2022 value = opts->x_dwarf_version;
2024 /* FALLTHRU */
2025 case OPT_gdwarf_:
2026 if (value < 2 || value > 5)
2027 error_at (loc, "dwarf version %d is not supported", value);
2028 else
2029 opts->x_dwarf_version = value;
2030 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
2031 break;
2033 case OPT_gsplit_dwarf:
2034 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
2035 loc);
2036 break;
2038 case OPT_ggdb:
2039 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
2040 break;
2042 case OPT_gstabs:
2043 case OPT_gstabs_:
2044 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
2045 loc);
2046 break;
2048 case OPT_gvms:
2049 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
2050 break;
2052 case OPT_gxcoff:
2053 case OPT_gxcoff_:
2054 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
2055 loc);
2056 break;
2058 case OPT_gz:
2059 case OPT_gz_:
2060 /* Handled completely via specs. */
2061 break;
2063 case OPT_pedantic_errors:
2064 dc->pedantic_errors = 1;
2065 control_warning_option (OPT_Wpedantic, DK_ERROR, value,
2066 loc, lang_mask,
2067 handlers, opts, opts_set,
2068 dc);
2069 break;
2071 case OPT_flto:
2072 opts->x_flag_lto = value ? "" : NULL;
2073 break;
2075 case OPT_w:
2076 dc->dc_inhibit_warnings = true;
2077 break;
2079 case OPT_fmax_errors_:
2080 dc->max_errors = value;
2081 break;
2083 case OPT_fuse_ld_bfd:
2084 case OPT_fuse_ld_gold:
2085 case OPT_fuse_linker_plugin:
2086 /* No-op. Used by the driver and passed to us because it starts with f.*/
2087 break;
2089 case OPT_fwrapv:
2090 if (value)
2091 opts->x_flag_trapv = 0;
2092 break;
2094 case OPT_ftrapv:
2095 if (value)
2096 opts->x_flag_wrapv = 0;
2097 break;
2099 case OPT_fipa_icf:
2100 opts->x_flag_ipa_icf_functions = value;
2101 opts->x_flag_ipa_icf_variables = value;
2102 break;
2104 default:
2105 /* If the flag was handled in a standard way, assume the lack of
2106 processing here is intentional. */
2107 gcc_assert (option_flag_var (scode, opts));
2108 break;
2111 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
2112 loc, handlers, dc);
2113 return true;
2116 /* Handle --param NAME=VALUE. */
2117 static void
2118 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
2119 location_t loc, const char *carg)
2121 char *equal, *arg;
2122 int value;
2124 arg = xstrdup (carg);
2125 equal = strchr (arg, '=');
2126 if (!equal)
2127 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
2128 arg);
2129 else
2131 *equal = '\0';
2133 enum compiler_param index;
2134 if (!find_param (arg, &index))
2135 error_at (loc, "invalid --param name %qs", arg);
2136 else
2138 if (!param_string_value_p (index, equal + 1, &value))
2139 value = integral_argument (equal + 1);
2141 if (value == -1)
2142 error_at (loc, "invalid --param value %qs", equal + 1);
2143 else
2144 set_param_value (arg, value,
2145 opts->x_param_values, opts_set->x_param_values);
2149 free (arg);
2152 /* Used to set the level of strict aliasing warnings in OPTS,
2153 when no level is specified (i.e., when -Wstrict-aliasing, and not
2154 -Wstrict-aliasing=level was given).
2155 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
2156 and 0 otherwise. After calling this function, wstrict_aliasing will be
2157 set to the default value of -Wstrict_aliasing=level, currently 3. */
2158 static void
2159 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
2161 gcc_assert (onoff == 0 || onoff == 1);
2162 if (onoff != 0)
2163 opts->x_warn_strict_aliasing = 3;
2164 else
2165 opts->x_warn_strict_aliasing = 0;
2168 /* The following routines are useful in setting all the flags that
2169 -ffast-math and -fno-fast-math imply. */
2170 static void
2171 set_fast_math_flags (struct gcc_options *opts, int set)
2173 if (!opts->frontend_set_flag_unsafe_math_optimizations)
2175 opts->x_flag_unsafe_math_optimizations = set;
2176 set_unsafe_math_optimizations_flags (opts, set);
2178 if (!opts->frontend_set_flag_finite_math_only)
2179 opts->x_flag_finite_math_only = set;
2180 if (!opts->frontend_set_flag_errno_math)
2181 opts->x_flag_errno_math = !set;
2182 if (set)
2184 if (!opts->frontend_set_flag_signaling_nans)
2185 opts->x_flag_signaling_nans = 0;
2186 if (!opts->frontend_set_flag_rounding_math)
2187 opts->x_flag_rounding_math = 0;
2188 if (!opts->frontend_set_flag_cx_limited_range)
2189 opts->x_flag_cx_limited_range = 1;
2193 /* When -funsafe-math-optimizations is set the following
2194 flags are set as well. */
2195 static void
2196 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
2198 if (!opts->frontend_set_flag_trapping_math)
2199 opts->x_flag_trapping_math = !set;
2200 if (!opts->frontend_set_flag_signed_zeros)
2201 opts->x_flag_signed_zeros = !set;
2202 if (!opts->frontend_set_flag_associative_math)
2203 opts->x_flag_associative_math = set;
2204 if (!opts->frontend_set_flag_reciprocal_math)
2205 opts->x_flag_reciprocal_math = set;
2208 /* Return true iff flags in OPTS are set as if -ffast-math. */
2209 bool
2210 fast_math_flags_set_p (const struct gcc_options *opts)
2212 return (!opts->x_flag_trapping_math
2213 && opts->x_flag_unsafe_math_optimizations
2214 && opts->x_flag_finite_math_only
2215 && !opts->x_flag_signed_zeros
2216 && !opts->x_flag_errno_math);
2219 /* Return true iff flags are set as if -ffast-math but using the flags stored
2220 in the struct cl_optimization structure. */
2221 bool
2222 fast_math_flags_struct_set_p (struct cl_optimization *opt)
2224 return (!opt->x_flag_trapping_math
2225 && opt->x_flag_unsafe_math_optimizations
2226 && opt->x_flag_finite_math_only
2227 && !opt->x_flag_signed_zeros
2228 && !opt->x_flag_errno_math);
2231 /* Handle a debug output -g switch for options OPTS
2232 (OPTS_SET->x_write_symbols storing whether a debug type was passed
2233 explicitly), location LOC. EXTENDED is true or false to support
2234 extended output (2 is special and means "-ggdb" was given). */
2235 static void
2236 set_debug_level (enum debug_info_type type, int extended, const char *arg,
2237 struct gcc_options *opts, struct gcc_options *opts_set,
2238 location_t loc)
2240 opts->x_use_gnu_debug_info_extensions = extended;
2242 if (type == NO_DEBUG)
2244 if (opts->x_write_symbols == NO_DEBUG)
2246 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
2248 if (extended == 2)
2250 #if defined DWARF2_DEBUGGING_INFO || defined DWARF2_LINENO_DEBUGGING_INFO
2251 opts->x_write_symbols = DWARF2_DEBUG;
2252 #elif defined DBX_DEBUGGING_INFO
2253 opts->x_write_symbols = DBX_DEBUG;
2254 #endif
2257 if (opts->x_write_symbols == NO_DEBUG)
2258 warning_at (loc, 0, "target system does not support debug output");
2261 else
2263 /* Does it conflict with an already selected type? */
2264 if (opts_set->x_write_symbols != NO_DEBUG
2265 && opts->x_write_symbols != NO_DEBUG
2266 && type != opts->x_write_symbols)
2267 error_at (loc, "debug format %qs conflicts with prior selection",
2268 debug_type_names[type]);
2269 opts->x_write_symbols = type;
2270 opts_set->x_write_symbols = type;
2273 /* A debug flag without a level defaults to level 2.
2274 If off or at level 1, set it to level 2, but if already
2275 at level 3, don't lower it. */
2276 if (*arg == '\0')
2278 if (opts->x_debug_info_level < DINFO_LEVEL_NORMAL)
2279 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2281 else
2283 int argval = integral_argument (arg);
2284 if (argval == -1)
2285 error_at (loc, "unrecognised debug output level %qs", arg);
2286 else if (argval > 3)
2287 error_at (loc, "debug output level %qs is too high", arg);
2288 else
2289 opts->x_debug_info_level = (enum debug_info_levels) argval;
2293 /* Arrange to dump core on error for diagnostic context DC. (The
2294 regular error message is still printed first, except in the case of
2295 abort ().) */
2297 static void
2298 setup_core_dumping (diagnostic_context *dc)
2300 #ifdef SIGABRT
2301 signal (SIGABRT, SIG_DFL);
2302 #endif
2303 #if defined(HAVE_SETRLIMIT)
2305 struct rlimit rlim;
2306 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2307 fatal_error (input_location, "getting core file size maximum limit: %m");
2308 rlim.rlim_cur = rlim.rlim_max;
2309 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2310 fatal_error (input_location,
2311 "setting core file size limit to maximum: %m");
2313 #endif
2314 diagnostic_abort_on_error (dc);
2317 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2318 diagnostic context DC. */
2320 static void
2321 decode_d_option (const char *arg, struct gcc_options *opts,
2322 location_t loc, diagnostic_context *dc)
2324 int c;
2326 while (*arg)
2327 switch (c = *arg++)
2329 case 'A':
2330 opts->x_flag_debug_asm = 1;
2331 break;
2332 case 'p':
2333 opts->x_flag_print_asm_name = 1;
2334 break;
2335 case 'P':
2336 opts->x_flag_dump_rtl_in_asm = 1;
2337 opts->x_flag_print_asm_name = 1;
2338 break;
2339 case 'x':
2340 opts->x_rtl_dump_and_exit = 1;
2341 break;
2342 case 'D': /* These are handled by the preprocessor. */
2343 case 'I':
2344 case 'M':
2345 case 'N':
2346 case 'U':
2347 break;
2348 case 'H':
2349 setup_core_dumping (dc);
2350 break;
2351 case 'a':
2352 opts->x_flag_dump_all_passed = true;
2353 break;
2355 default:
2356 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2357 break;
2361 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2362 mask LANG_MASK, option handlers HANDLERS) as an error for option
2363 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2364 NULL), location LOC. This is used by -Werror=. */
2366 static void
2367 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2368 const struct cl_option_handlers *handlers,
2369 struct gcc_options *opts,
2370 struct gcc_options *opts_set,
2371 location_t loc, diagnostic_context *dc)
2373 char *new_option;
2374 int option_index;
2376 new_option = XNEWVEC (char, strlen (arg) + 2);
2377 new_option[0] = 'W';
2378 strcpy (new_option + 1, arg);
2379 option_index = find_opt (new_option, lang_mask);
2380 if (option_index == OPT_SPECIAL_unknown)
2381 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2382 else if (!(cl_options[option_index].flags & CL_WARNING))
2383 error_at (loc, "-Werror=%s: -%s is not an option that controls warnings",
2384 arg, new_option);
2385 else
2387 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2389 control_warning_option (option_index, (int) kind, value,
2390 loc, lang_mask,
2391 handlers, opts, opts_set, dc);
2393 free (new_option);
2396 /* Return malloced memory for the name of the option OPTION_INDEX
2397 which enabled a diagnostic (context CONTEXT), originally of type
2398 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2399 as -Werror. */
2401 char *
2402 option_name (diagnostic_context *context, int option_index,
2403 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2405 if (option_index)
2407 /* A warning classified as an error. */
2408 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2409 && diag_kind == DK_ERROR)
2410 return concat (cl_options[OPT_Werror_].opt_text,
2411 /* Skip over "-W". */
2412 cl_options[option_index].opt_text + 2,
2413 NULL);
2414 /* A warning with option. */
2415 else
2416 return xstrdup (cl_options[option_index].opt_text);
2418 /* A warning without option classified as an error. */
2419 else if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2420 || diag_kind == DK_WARNING)
2421 && context->warning_as_error_requested)
2422 return xstrdup (cl_options[OPT_Werror].opt_text);
2423 else
2424 return NULL;