Merged trunk revision 225993 into the hsa branch.
[official-gcc.git] / gcc / opts.c
blobd377f18f7bcaf684e37d15fb23ea5761046f509e
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_fshrink_wrap, NULL, 1 },
445 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
446 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
447 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_bit_ccp, NULL, 1 },
448 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
449 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
450 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
451 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
452 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_sra, NULL, 1 },
453 { OPT_LEVELS_1_PLUS, OPT_ftree_copyrename, NULL, 1 },
454 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
455 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
456 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
457 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
458 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
459 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
460 { OPT_LEVELS_1_PLUS, OPT_ftree_slsr, NULL, 1 },
461 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fbranch_count_reg, NULL, 1 },
462 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fmove_loop_invariants, NULL, 1 },
463 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_pta, NULL, 1 },
464 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fssa_phiopt, NULL, 1 },
466 /* -O2 optimizations. */
467 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
468 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
469 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
470 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
471 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
472 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
473 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
474 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
475 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
476 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
477 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
478 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
479 #ifdef INSN_SCHEDULING
480 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
481 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
482 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
483 #endif
484 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_freorder_blocks, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
488 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
489 { OPT_LEVELS_2_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
490 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
491 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
492 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
493 { OPT_LEVELS_2_PLUS, OPT_fipa_cp_alignment, NULL, 1 },
494 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
495 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
496 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
497 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
498 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
499 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
500 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
501 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
502 { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
503 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
504 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
505 { OPT_LEVELS_2_PLUS, OPT_fipa_icf, NULL, 1 },
506 { OPT_LEVELS_2_PLUS, OPT_fisolate_erroneous_paths_dereference, NULL, 1 },
507 { OPT_LEVELS_2_PLUS, OPT_fipa_ra, NULL, 1 },
508 { OPT_LEVELS_2_PLUS, OPT_flra_remat, NULL, 1 },
510 /* -O3 optimizations. */
511 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
512 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
513 /* Inlining of functions reducing size is a good idea with -Os
514 regardless of them being declared inline. */
515 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
516 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
517 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
518 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
519 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
520 { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
521 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
522 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
523 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
525 /* -Ofast adds optimizations to -O3. */
526 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
528 { OPT_LEVELS_NONE, 0, NULL, 0 }
531 /* Default the options in OPTS and OPTS_SET based on the optimization
532 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
533 void
534 default_options_optimization (struct gcc_options *opts,
535 struct gcc_options *opts_set,
536 struct cl_decoded_option *decoded_options,
537 unsigned int decoded_options_count,
538 location_t loc,
539 unsigned int lang_mask,
540 const struct cl_option_handlers *handlers,
541 diagnostic_context *dc)
543 unsigned int i;
544 int opt2;
546 /* Scan to see what optimization level has been specified. That will
547 determine the default value of many flags. */
548 for (i = 1; i < decoded_options_count; i++)
550 struct cl_decoded_option *opt = &decoded_options[i];
551 switch (opt->opt_index)
553 case OPT_O:
554 if (*opt->arg == '\0')
556 opts->x_optimize = 1;
557 opts->x_optimize_size = 0;
558 opts->x_optimize_fast = 0;
559 opts->x_optimize_debug = 0;
561 else
563 const int optimize_val = integral_argument (opt->arg);
564 if (optimize_val == -1)
565 error_at (loc, "argument to %<-O%> should be a non-negative "
566 "integer, %<g%>, %<s%> or %<fast%>");
567 else
569 opts->x_optimize = optimize_val;
570 if ((unsigned int) opts->x_optimize > 255)
571 opts->x_optimize = 255;
572 opts->x_optimize_size = 0;
573 opts->x_optimize_fast = 0;
574 opts->x_optimize_debug = 0;
577 break;
579 case OPT_Os:
580 opts->x_optimize_size = 1;
582 /* Optimizing for size forces optimize to be 2. */
583 opts->x_optimize = 2;
584 opts->x_optimize_fast = 0;
585 opts->x_optimize_debug = 0;
586 break;
588 case OPT_Ofast:
589 /* -Ofast only adds flags to -O3. */
590 opts->x_optimize_size = 0;
591 opts->x_optimize = 3;
592 opts->x_optimize_fast = 1;
593 opts->x_optimize_debug = 0;
594 break;
596 case OPT_Og:
597 /* -Og selects optimization level 1. */
598 opts->x_optimize_size = 0;
599 opts->x_optimize = 1;
600 opts->x_optimize_fast = 0;
601 opts->x_optimize_debug = 1;
602 break;
604 default:
605 /* Ignore other options in this prescan. */
606 break;
610 maybe_default_options (opts, opts_set, default_options_table,
611 opts->x_optimize, opts->x_optimize_size,
612 opts->x_optimize_fast, opts->x_optimize_debug,
613 lang_mask, handlers, loc, dc);
615 /* -O2 param settings. */
616 opt2 = (opts->x_optimize >= 2);
618 /* Track fields in field-sensitive alias analysis. */
619 maybe_set_param_value
620 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
621 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
622 opts->x_param_values, opts_set->x_param_values);
624 /* For -O1 only do loop invariant motion for very small loops. */
625 maybe_set_param_value
626 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
627 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
628 opts->x_param_values, opts_set->x_param_values);
630 /* At -Ofast, allow store motion to introduce potential race conditions. */
631 maybe_set_param_value
632 (PARAM_ALLOW_STORE_DATA_RACES,
633 opts->x_optimize_fast ? 1
634 : default_param_value (PARAM_ALLOW_STORE_DATA_RACES),
635 opts->x_param_values, opts_set->x_param_values);
637 if (opts->x_optimize_size)
638 /* We want to crossjump as much as possible. */
639 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
640 opts->x_param_values, opts_set->x_param_values);
641 else
642 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
643 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
644 opts->x_param_values, opts_set->x_param_values);
646 /* Restrict the amount of work combine does at -Og while retaining
647 most of its useful transforms. */
648 if (opts->x_optimize_debug)
649 maybe_set_param_value (PARAM_MAX_COMBINE_INSNS, 2,
650 opts->x_param_values, opts_set->x_param_values);
652 /* Allow default optimizations to be specified on a per-machine basis. */
653 maybe_default_options (opts, opts_set,
654 targetm_common.option_optimization_table,
655 opts->x_optimize, opts->x_optimize_size,
656 opts->x_optimize_fast, opts->x_optimize_debug,
657 lang_mask, handlers, loc, dc);
660 /* After all options at LOC have been read into OPTS and OPTS_SET,
661 finalize settings of those options and diagnose incompatible
662 combinations. */
663 void
664 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
665 location_t loc)
667 enum unwind_info_type ui_except;
669 if (opts->x_dump_base_name
670 && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name)
671 && ! opts->x_dump_base_name_prefixed)
673 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
674 OPTS->X_DUMP_DIR_NAME directory. Then try to make
675 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
676 directory, typically the directory to contain the object
677 file. */
678 if (opts->x_dump_dir_name)
679 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
680 opts->x_dump_base_name, NULL);
681 else if (opts->x_aux_base_name
682 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
684 const char *aux_base;
686 base_of_path (opts->x_aux_base_name, &aux_base);
687 if (opts->x_aux_base_name != aux_base)
689 int dir_len = aux_base - opts->x_aux_base_name;
690 char *new_dump_base_name
691 = XOBNEWVEC (&opts_obstack, char,
692 strlen (opts->x_dump_base_name) + dir_len + 1);
694 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
695 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
696 /* Append existing OPTS->X_DUMP_BASE_NAME. */
697 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
698 opts->x_dump_base_name = new_dump_base_name;
701 opts->x_dump_base_name_prefixed = true;
704 /* Handle related options for unit-at-a-time, toplevel-reorder, and
705 section-anchors. */
706 if (!opts->x_flag_unit_at_a_time)
708 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
709 error_at (loc, "section anchors must be disabled when unit-at-a-time "
710 "is disabled");
711 opts->x_flag_section_anchors = 0;
712 if (opts->x_flag_toplevel_reorder == 1)
713 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
714 "is disabled");
715 opts->x_flag_toplevel_reorder = 0;
718 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
719 sorry ("transactional memory is not supported with non-call exceptions");
721 /* Unless the user has asked for section anchors, we disable toplevel
722 reordering at -O0 to disable transformations that might be surprising
723 to end users and to get -fno-toplevel-reorder tested. */
724 if (!opts->x_optimize
725 && opts->x_flag_toplevel_reorder == 2
726 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
728 opts->x_flag_toplevel_reorder = 0;
729 opts->x_flag_section_anchors = 0;
731 if (!opts->x_flag_toplevel_reorder)
733 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
734 error_at (loc, "section anchors must be disabled when toplevel reorder"
735 " is disabled");
736 opts->x_flag_section_anchors = 0;
739 if (!opts->x_flag_opts_finished)
741 /* We initialize opts->x_flag_pie to -1 so that targets can set a
742 default value. */
743 if (opts->x_flag_pie == -1)
745 if (opts->x_flag_pic == 0)
746 opts->x_flag_pie = DEFAULT_FLAG_PIE;
747 else
748 opts->x_flag_pie = 0;
750 if (opts->x_flag_pie)
751 opts->x_flag_pic = opts->x_flag_pie;
752 if (opts->x_flag_pic && !opts->x_flag_pie)
753 opts->x_flag_shlib = 1;
754 opts->x_flag_opts_finished = true;
757 if (opts->x_optimize == 0)
759 /* Inlining does not work if not optimizing,
760 so force it not to be done. */
761 opts->x_warn_inline = 0;
762 opts->x_flag_no_inline = 1;
765 /* The optimization to partition hot and cold basic blocks into separate
766 sections of the .o and executable files does not work (currently)
767 with exception handling. This is because there is no support for
768 generating unwind info. If opts->x_flag_exceptions is turned on
769 we need to turn off the partitioning optimization. */
771 ui_except = targetm_common.except_unwind_info (opts);
773 if (opts->x_flag_exceptions
774 && opts->x_flag_reorder_blocks_and_partition
775 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
777 if (opts_set->x_flag_reorder_blocks_and_partition)
778 inform (loc,
779 "-freorder-blocks-and-partition does not work "
780 "with exceptions on this architecture");
781 opts->x_flag_reorder_blocks_and_partition = 0;
782 opts->x_flag_reorder_blocks = 1;
785 /* If user requested unwind info, then turn off the partitioning
786 optimization. */
788 if (opts->x_flag_unwind_tables
789 && !targetm_common.unwind_tables_default
790 && opts->x_flag_reorder_blocks_and_partition
791 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
793 if (opts_set->x_flag_reorder_blocks_and_partition)
794 inform (loc,
795 "-freorder-blocks-and-partition does not support "
796 "unwind info on this architecture");
797 opts->x_flag_reorder_blocks_and_partition = 0;
798 opts->x_flag_reorder_blocks = 1;
801 /* If the target requested unwind info, then turn off the partitioning
802 optimization with a different message. Likewise, if the target does not
803 support named sections. */
805 if (opts->x_flag_reorder_blocks_and_partition
806 && (!targetm_common.have_named_sections
807 || (opts->x_flag_unwind_tables
808 && targetm_common.unwind_tables_default
809 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
811 if (opts_set->x_flag_reorder_blocks_and_partition)
812 inform (loc,
813 "-freorder-blocks-and-partition does not work "
814 "on this architecture");
815 opts->x_flag_reorder_blocks_and_partition = 0;
816 opts->x_flag_reorder_blocks = 1;
819 if (opts->x_flag_reorder_blocks_and_partition
820 && !opts_set->x_flag_reorder_functions)
821 opts->x_flag_reorder_functions = 1;
823 /* Pipelining of outer loops is only possible when general pipelining
824 capabilities are requested. */
825 if (!opts->x_flag_sel_sched_pipelining)
826 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
828 if (opts->x_flag_conserve_stack)
830 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
831 opts->x_param_values, opts_set->x_param_values);
832 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
833 opts->x_param_values, opts_set->x_param_values);
836 if (opts->x_flag_lto)
838 #ifdef ENABLE_LTO
839 opts->x_flag_generate_lto = 1;
841 /* When generating IL, do not operate in whole-program mode.
842 Otherwise, symbols will be privatized too early, causing link
843 errors later. */
844 opts->x_flag_whole_program = 0;
845 #else
846 error_at (loc, "LTO support has not been enabled in this configuration");
847 #endif
848 if (!opts->x_flag_fat_lto_objects
849 && (!HAVE_LTO_PLUGIN
850 || (opts_set->x_flag_use_linker_plugin
851 && !opts->x_flag_use_linker_plugin)))
853 if (opts_set->x_flag_fat_lto_objects)
854 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin");
855 opts->x_flag_fat_lto_objects = 1;
859 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
860 default value if they choose based on other options. */
861 if (opts->x_flag_split_stack == -1)
862 opts->x_flag_split_stack = 0;
863 else if (opts->x_flag_split_stack)
865 if (!targetm_common.supports_split_stack (true, opts))
867 error_at (loc, "%<-fsplit-stack%> is not supported by "
868 "this compiler configuration");
869 opts->x_flag_split_stack = 0;
873 /* Tune vectorization related parametees according to cost model. */
874 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
876 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
877 6, opts->x_param_values, opts_set->x_param_values);
878 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
879 0, opts->x_param_values, opts_set->x_param_values);
880 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
881 0, opts->x_param_values, opts_set->x_param_values);
884 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
885 is disabled. */
886 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
887 || !opts->x_flag_tree_loop_if_convert)
888 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
889 opts->x_param_values, opts_set->x_param_values);
891 /* The -gsplit-dwarf option requires -ggnu-pubnames. */
892 if (opts->x_dwarf_split_debug_info)
893 opts->x_debug_generate_pub_sections = 2;
895 /* Userspace and kernel ASan conflict with each other. */
897 if ((opts->x_flag_sanitize & SANITIZE_USER_ADDRESS)
898 && (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS))
899 error_at (loc,
900 "-fsanitize=address is incompatible with "
901 "-fsanitize=kernel-address");
903 /* And with TSan. */
905 if ((opts->x_flag_sanitize & SANITIZE_ADDRESS)
906 && (opts->x_flag_sanitize & SANITIZE_THREAD))
907 error_at (loc,
908 "-fsanitize=address and -fsanitize=kernel-address "
909 "are incompatible with -fsanitize=thread");
911 /* Error recovery is not allowed for ASan and TSan. */
913 if (opts->x_flag_sanitize_recover & SANITIZE_USER_ADDRESS)
914 error_at (loc, "-fsanitize-recover=address is not supported");
916 if (opts->x_flag_sanitize_recover & SANITIZE_THREAD)
917 error_at (loc, "-fsanitize-recover=thread is not supported");
919 if (opts->x_flag_sanitize_recover & SANITIZE_LEAK)
920 error_at (loc, "-fsanitize-recover=leak is not supported");
922 /* When instrumenting the pointers, we don't want to remove
923 the null pointer checks. */
924 if (opts->x_flag_sanitize & (SANITIZE_NULL | SANITIZE_NONNULL_ATTRIBUTE
925 | SANITIZE_RETURNS_NONNULL_ATTRIBUTE))
926 opts->x_flag_delete_null_pointer_checks = 0;
928 /* Aggressive compiler optimizations may cause false negatives. */
929 if (opts->x_flag_sanitize)
931 opts->x_flag_aggressive_loop_optimizations = 0;
932 opts->x_flag_strict_overflow = 0;
936 #define LEFT_COLUMN 27
938 /* Output ITEM, of length ITEM_WIDTH, in the left column,
939 followed by word-wrapped HELP in a second column. */
940 static void
941 wrap_help (const char *help,
942 const char *item,
943 unsigned int item_width,
944 unsigned int columns)
946 unsigned int col_width = LEFT_COLUMN;
947 unsigned int remaining, room, len;
949 remaining = strlen (help);
953 room = columns - 3 - MAX (col_width, item_width);
954 if (room > columns)
955 room = 0;
956 len = remaining;
958 if (room < len)
960 unsigned int i;
962 for (i = 0; help[i]; i++)
964 if (i >= room && len != remaining)
965 break;
966 if (help[i] == ' ')
967 len = i;
968 else if ((help[i] == '-' || help[i] == '/')
969 && help[i + 1] != ' '
970 && i > 0 && ISALPHA (help[i - 1]))
971 len = i + 1;
975 printf (" %-*.*s %.*s\n", col_width, item_width, item, len, help);
976 item_width = 0;
977 while (help[len] == ' ')
978 len++;
979 help += len;
980 remaining -= len;
982 while (remaining);
985 /* Print help for a specific front-end, etc. */
986 static void
987 print_filtered_help (unsigned int include_flags,
988 unsigned int exclude_flags,
989 unsigned int any_flags,
990 unsigned int columns,
991 struct gcc_options *opts,
992 unsigned int lang_mask)
994 unsigned int i;
995 const char *help;
996 bool found = false;
997 bool displayed = false;
998 char new_help[128];
1000 if (include_flags == CL_PARAMS)
1002 for (i = 0; i < LAST_PARAM; i++)
1004 const char *param = compiler_params[i].option;
1006 help = compiler_params[i].help;
1007 if (help == NULL || *help == '\0')
1009 if (exclude_flags & CL_UNDOCUMENTED)
1010 continue;
1011 help = undocumented_msg;
1014 /* Get the translation. */
1015 help = _(help);
1017 if (!opts->x_quiet_flag)
1019 snprintf (new_help, sizeof (new_help),
1020 _("default %d minimum %d maximum %d"),
1021 compiler_params[i].default_value,
1022 compiler_params[i].min_value,
1023 compiler_params[i].max_value);
1024 help = new_help;
1026 wrap_help (help, param, strlen (param), columns);
1028 putchar ('\n');
1029 return;
1032 if (!opts->x_help_printed)
1033 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
1035 if (!opts->x_help_enum_printed)
1036 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
1038 for (i = 0; i < cl_options_count; i++)
1040 const struct cl_option *option = cl_options + i;
1041 unsigned int len;
1042 const char *opt;
1043 const char *tab;
1045 if (include_flags == 0
1046 || ((option->flags & include_flags) != include_flags))
1048 if ((option->flags & any_flags) == 0)
1049 continue;
1052 /* Skip unwanted switches. */
1053 if ((option->flags & exclude_flags) != 0)
1054 continue;
1056 /* The driver currently prints its own help text. */
1057 if ((option->flags & CL_DRIVER) != 0
1058 && (option->flags & (((1U << cl_lang_count) - 1)
1059 | CL_COMMON | CL_TARGET)) == 0)
1060 continue;
1062 found = true;
1063 /* Skip switches that have already been printed. */
1064 if (opts->x_help_printed[i])
1065 continue;
1067 opts->x_help_printed[i] = true;
1069 help = option->help;
1070 if (help == NULL)
1072 if (exclude_flags & CL_UNDOCUMENTED)
1073 continue;
1074 help = undocumented_msg;
1077 /* Get the translation. */
1078 help = _(help);
1080 /* Find the gap between the name of the
1081 option and its descriptive text. */
1082 tab = strchr (help, '\t');
1083 if (tab)
1085 len = tab - help;
1086 opt = help;
1087 help = tab + 1;
1089 else
1091 opt = option->opt_text;
1092 len = strlen (opt);
1095 /* With the -Q option enabled we change the descriptive text associated
1096 with an option to be an indication of its current setting. */
1097 if (!opts->x_quiet_flag)
1099 void *flag_var = option_flag_var (i, opts);
1101 if (len < (LEFT_COLUMN + 2))
1102 strcpy (new_help, "\t\t");
1103 else
1104 strcpy (new_help, "\t");
1106 if (flag_var != NULL
1107 && option->var_type != CLVC_DEFER)
1109 if (option->flags & CL_JOINED)
1111 if (option->var_type == CLVC_STRING)
1113 if (* (const char **) flag_var != NULL)
1114 snprintf (new_help + strlen (new_help),
1115 sizeof (new_help) - strlen (new_help),
1116 "%s", * (const char **) flag_var);
1118 else if (option->var_type == CLVC_ENUM)
1120 const struct cl_enum *e = &cl_enums[option->var_enum];
1121 int value;
1122 const char *arg = NULL;
1124 value = e->get (flag_var);
1125 enum_value_to_arg (e->values, &arg, value, lang_mask);
1126 if (arg == NULL)
1127 arg = _("[default]");
1128 snprintf (new_help + strlen (new_help),
1129 sizeof (new_help) - strlen (new_help),
1130 "%s", arg);
1132 else
1133 sprintf (new_help + strlen (new_help),
1134 "%#x", * (int *) flag_var);
1136 else
1137 strcat (new_help, option_enabled (i, opts)
1138 ? _("[enabled]") : _("[disabled]"));
1141 help = new_help;
1144 wrap_help (help, opt, len, columns);
1145 displayed = true;
1147 if (option->var_type == CLVC_ENUM
1148 && opts->x_help_enum_printed[option->var_enum] != 2)
1149 opts->x_help_enum_printed[option->var_enum] = 1;
1152 if (! found)
1154 unsigned int langs = include_flags & CL_LANG_ALL;
1156 if (langs == 0)
1157 printf (_(" No options with the desired characteristics were found\n"));
1158 else
1160 unsigned int i;
1162 /* PR 31349: Tell the user how to see all of the
1163 options supported by a specific front end. */
1164 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1165 if ((1U << i) & langs)
1166 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end\n"),
1167 lang_names[i], lang_names[i]);
1171 else if (! displayed)
1172 printf (_(" All options with the desired characteristics have already been displayed\n"));
1174 putchar ('\n');
1176 /* Print details of enumerated option arguments, if those
1177 enumerations have help text headings provided. If no help text
1178 is provided, presume that the possible values are listed in the
1179 help text for the relevant options. */
1180 for (i = 0; i < cl_enums_count; i++)
1182 unsigned int j, pos;
1184 if (opts->x_help_enum_printed[i] != 1)
1185 continue;
1186 if (cl_enums[i].help == NULL)
1187 continue;
1188 printf (" %s\n ", _(cl_enums[i].help));
1189 pos = 4;
1190 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1192 unsigned int len = strlen (cl_enums[i].values[j].arg);
1194 if (pos > 4 && pos + 1 + len <= columns)
1196 printf (" %s", cl_enums[i].values[j].arg);
1197 pos += 1 + len;
1199 else
1201 if (pos > 4)
1203 printf ("\n ");
1204 pos = 4;
1206 printf ("%s", cl_enums[i].values[j].arg);
1207 pos += len;
1210 printf ("\n\n");
1211 opts->x_help_enum_printed[i] = 2;
1215 /* Display help for a specified type of option.
1216 The options must have ALL of the INCLUDE_FLAGS set
1217 ANY of the flags in the ANY_FLAGS set
1218 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1219 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1220 static void
1221 print_specific_help (unsigned int include_flags,
1222 unsigned int exclude_flags,
1223 unsigned int any_flags,
1224 struct gcc_options *opts,
1225 unsigned int lang_mask)
1227 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1228 const char * description = NULL;
1229 const char * descrip_extra = "";
1230 size_t i;
1231 unsigned int flag;
1233 /* Sanity check: Make sure that we do not have more
1234 languages than we have bits available to enumerate them. */
1235 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1237 /* If we have not done so already, obtain
1238 the desired maximum width of the output. */
1239 if (opts->x_help_columns == 0)
1241 opts->x_help_columns = get_terminal_width ();
1242 if (opts->x_help_columns == INT_MAX)
1243 /* Use a reasonable default. */
1244 opts->x_help_columns = 80;
1247 /* Decide upon the title for the options that we are going to display. */
1248 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1250 switch (flag & include_flags)
1252 case 0:
1253 case CL_DRIVER:
1254 break;
1256 case CL_TARGET:
1257 description = _("The following options are target specific");
1258 break;
1259 case CL_WARNING:
1260 description = _("The following options control compiler warning messages");
1261 break;
1262 case CL_OPTIMIZATION:
1263 description = _("The following options control optimizations");
1264 break;
1265 case CL_COMMON:
1266 description = _("The following options are language-independent");
1267 break;
1268 case CL_PARAMS:
1269 description = _("The --param option recognizes the following as parameters");
1270 break;
1271 default:
1272 if (i >= cl_lang_count)
1273 break;
1274 if (exclude_flags & all_langs_mask)
1275 description = _("The following options are specific to just the language ");
1276 else
1277 description = _("The following options are supported by the language ");
1278 descrip_extra = lang_names [i];
1279 break;
1283 if (description == NULL)
1285 if (any_flags == 0)
1287 if (include_flags & CL_UNDOCUMENTED)
1288 description = _("The following options are not documented");
1289 else if (include_flags & CL_SEPARATE)
1290 description = _("The following options take separate arguments");
1291 else if (include_flags & CL_JOINED)
1292 description = _("The following options take joined arguments");
1293 else
1295 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1296 include_flags);
1297 return;
1300 else
1302 if (any_flags & all_langs_mask)
1303 description = _("The following options are language-related");
1304 else
1305 description = _("The following options are language-independent");
1309 printf ("%s%s:\n", description, descrip_extra);
1310 print_filtered_help (include_flags, exclude_flags, any_flags,
1311 opts->x_help_columns, opts, lang_mask);
1314 /* Enable FDO-related flags. */
1316 static void
1317 enable_fdo_optimizations (struct gcc_options *opts,
1318 struct gcc_options *opts_set,
1319 int value)
1321 if (!opts_set->x_flag_branch_probabilities)
1322 opts->x_flag_branch_probabilities = value;
1323 if (!opts_set->x_flag_profile_values)
1324 opts->x_flag_profile_values = value;
1325 if (!opts_set->x_flag_unroll_loops)
1326 opts->x_flag_unroll_loops = value;
1327 if (!opts_set->x_flag_peel_loops)
1328 opts->x_flag_peel_loops = value;
1329 if (!opts_set->x_flag_tracer)
1330 opts->x_flag_tracer = value;
1331 if (!opts_set->x_flag_value_profile_transformations)
1332 opts->x_flag_value_profile_transformations = value;
1333 if (!opts_set->x_flag_inline_functions)
1334 opts->x_flag_inline_functions = value;
1335 if (!opts_set->x_flag_ipa_cp)
1336 opts->x_flag_ipa_cp = value;
1337 if (!opts_set->x_flag_ipa_cp_clone
1338 && value && opts->x_flag_ipa_cp)
1339 opts->x_flag_ipa_cp_clone = value;
1340 if (!opts_set->x_flag_ipa_cp_alignment
1341 && value && opts->x_flag_ipa_cp)
1342 opts->x_flag_ipa_cp_alignment = value;
1343 if (!opts_set->x_flag_predictive_commoning)
1344 opts->x_flag_predictive_commoning = value;
1345 if (!opts_set->x_flag_unswitch_loops)
1346 opts->x_flag_unswitch_loops = value;
1347 if (!opts_set->x_flag_gcse_after_reload)
1348 opts->x_flag_gcse_after_reload = value;
1349 if (!opts_set->x_flag_tree_loop_vectorize
1350 && !opts_set->x_flag_tree_vectorize)
1351 opts->x_flag_tree_loop_vectorize = value;
1352 if (!opts_set->x_flag_tree_slp_vectorize
1353 && !opts_set->x_flag_tree_vectorize)
1354 opts->x_flag_tree_slp_vectorize = value;
1355 if (!opts_set->x_flag_vect_cost_model)
1356 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1357 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1358 opts->x_flag_tree_loop_distribute_patterns = value;
1361 /* Handle target- and language-independent options. Return zero to
1362 generate an "unknown option" message. Only options that need
1363 extra handling need to be listed here; if you simply want
1364 DECODED->value assigned to a variable, it happens automatically. */
1366 bool
1367 common_handle_option (struct gcc_options *opts,
1368 struct gcc_options *opts_set,
1369 const struct cl_decoded_option *decoded,
1370 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1371 location_t loc,
1372 const struct cl_option_handlers *handlers,
1373 diagnostic_context *dc)
1375 size_t scode = decoded->opt_index;
1376 const char *arg = decoded->arg;
1377 int value = decoded->value;
1378 enum opt_code code = (enum opt_code) scode;
1380 gcc_assert (decoded->canonical_option_num_elements <= 2);
1382 switch (code)
1384 case OPT__param:
1385 handle_param (opts, opts_set, loc, arg);
1386 break;
1388 case OPT__help:
1390 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1391 unsigned int undoc_mask;
1392 unsigned int i;
1394 if (lang_mask == CL_DRIVER)
1395 break;
1397 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1399 : CL_UNDOCUMENTED);
1400 /* First display any single language specific options. */
1401 for (i = 0; i < cl_lang_count; i++)
1402 print_specific_help
1403 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1404 lang_mask);
1405 /* Next display any multi language specific options. */
1406 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1407 /* Then display any remaining, non-language options. */
1408 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1409 if (i != CL_DRIVER)
1410 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1411 opts->x_exit_after_options = true;
1412 break;
1415 case OPT__target_help:
1416 if (lang_mask == CL_DRIVER)
1417 break;
1419 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1420 opts->x_exit_after_options = true;
1421 break;
1423 case OPT__help_:
1425 const char * a = arg;
1426 unsigned int include_flags = 0;
1427 /* Note - by default we include undocumented options when listing
1428 specific classes. If you only want to see documented options
1429 then add ",^undocumented" to the --help= option. E.g.:
1431 --help=target,^undocumented */
1432 unsigned int exclude_flags = 0;
1434 if (lang_mask == CL_DRIVER)
1435 break;
1437 /* Walk along the argument string, parsing each word in turn.
1438 The format is:
1439 arg = [^]{word}[,{arg}]
1440 word = {optimizers|target|warnings|undocumented|
1441 params|common|<language>} */
1442 while (* a != 0)
1444 static const struct
1446 const char * string;
1447 unsigned int flag;
1449 specifics[] =
1451 { "optimizers", CL_OPTIMIZATION },
1452 { "target", CL_TARGET },
1453 { "warnings", CL_WARNING },
1454 { "undocumented", CL_UNDOCUMENTED },
1455 { "params", CL_PARAMS },
1456 { "joined", CL_JOINED },
1457 { "separate", CL_SEPARATE },
1458 { "common", CL_COMMON },
1459 { NULL, 0 }
1461 unsigned int * pflags;
1462 const char * comma;
1463 unsigned int lang_flag, specific_flag;
1464 unsigned int len;
1465 unsigned int i;
1467 if (* a == '^')
1469 ++ a;
1470 pflags = & exclude_flags;
1472 else
1473 pflags = & include_flags;
1475 comma = strchr (a, ',');
1476 if (comma == NULL)
1477 len = strlen (a);
1478 else
1479 len = comma - a;
1480 if (len == 0)
1482 a = comma + 1;
1483 continue;
1486 /* Check to see if the string matches an option class name. */
1487 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1488 if (strncasecmp (a, specifics[i].string, len) == 0)
1490 specific_flag = specifics[i].flag;
1491 break;
1494 /* Check to see if the string matches a language name.
1495 Note - we rely upon the alpha-sorted nature of the entries in
1496 the lang_names array, specifically that shorter names appear
1497 before their longer variants. (i.e. C before C++). That way
1498 when we are attempting to match --help=c for example we will
1499 match with C first and not C++. */
1500 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1501 if (strncasecmp (a, lang_names[i], len) == 0)
1503 lang_flag = 1U << i;
1504 break;
1507 if (specific_flag != 0)
1509 if (lang_flag == 0)
1510 * pflags |= specific_flag;
1511 else
1513 /* The option's argument matches both the start of a
1514 language name and the start of an option class name.
1515 We have a special case for when the user has
1516 specified "--help=c", but otherwise we have to issue
1517 a warning. */
1518 if (strncasecmp (a, "c", len) == 0)
1519 * pflags |= lang_flag;
1520 else
1521 warning_at (loc, 0,
1522 "--help argument %q.*s is ambiguous, "
1523 "please be more specific",
1524 len, a);
1527 else if (lang_flag != 0)
1528 * pflags |= lang_flag;
1529 else
1530 warning_at (loc, 0,
1531 "unrecognized argument to --help= option: %q.*s",
1532 len, a);
1534 if (comma == NULL)
1535 break;
1536 a = comma + 1;
1539 if (include_flags)
1540 print_specific_help (include_flags, exclude_flags, 0, opts,
1541 lang_mask);
1542 opts->x_exit_after_options = true;
1543 break;
1546 case OPT__version:
1547 if (lang_mask == CL_DRIVER)
1548 break;
1550 opts->x_exit_after_options = true;
1551 break;
1553 case OPT_fsanitize_:
1554 case OPT_fsanitize_recover_:
1556 const char *p = arg;
1557 unsigned int *flag
1558 = code == OPT_fsanitize_ ? &opts->x_flag_sanitize
1559 : &opts->x_flag_sanitize_recover;
1560 while (*p != 0)
1562 static const struct
1564 const char *const name;
1565 unsigned int flag;
1566 size_t len;
1567 } spec[] =
1569 { "address", SANITIZE_ADDRESS | SANITIZE_USER_ADDRESS,
1570 sizeof "address" - 1 },
1571 { "kernel-address", SANITIZE_ADDRESS | SANITIZE_KERNEL_ADDRESS,
1572 sizeof "kernel-address" - 1 },
1573 { "thread", SANITIZE_THREAD, sizeof "thread" - 1 },
1574 { "leak", SANITIZE_LEAK, sizeof "leak" - 1 },
1575 { "shift", SANITIZE_SHIFT, sizeof "shift" - 1 },
1576 { "integer-divide-by-zero", SANITIZE_DIVIDE,
1577 sizeof "integer-divide-by-zero" - 1 },
1578 { "undefined", SANITIZE_UNDEFINED, sizeof "undefined" - 1 },
1579 { "unreachable", SANITIZE_UNREACHABLE,
1580 sizeof "unreachable" - 1 },
1581 { "vla-bound", SANITIZE_VLA, sizeof "vla-bound" - 1 },
1582 { "return", SANITIZE_RETURN, sizeof "return" - 1 },
1583 { "null", SANITIZE_NULL, sizeof "null" - 1 },
1584 { "signed-integer-overflow", SANITIZE_SI_OVERFLOW,
1585 sizeof "signed-integer-overflow" -1 },
1586 { "bool", SANITIZE_BOOL, sizeof "bool" - 1 },
1587 { "enum", SANITIZE_ENUM, sizeof "enum" - 1 },
1588 { "float-divide-by-zero", SANITIZE_FLOAT_DIVIDE,
1589 sizeof "float-divide-by-zero" - 1 },
1590 { "float-cast-overflow", SANITIZE_FLOAT_CAST,
1591 sizeof "float-cast-overflow" - 1 },
1592 { "bounds", SANITIZE_BOUNDS, sizeof "bounds" - 1 },
1593 { "bounds-strict", SANITIZE_BOUNDS | SANITIZE_BOUNDS_STRICT,
1594 sizeof "bounds-strict" - 1 },
1595 { "alignment", SANITIZE_ALIGNMENT, sizeof "alignment" - 1 },
1596 { "nonnull-attribute", SANITIZE_NONNULL_ATTRIBUTE,
1597 sizeof "nonnull-attribute" - 1 },
1598 { "returns-nonnull-attribute",
1599 SANITIZE_RETURNS_NONNULL_ATTRIBUTE,
1600 sizeof "returns-nonnull-attribute" - 1 },
1601 { "object-size", SANITIZE_OBJECT_SIZE,
1602 sizeof "object-size" - 1 },
1603 { "vptr", SANITIZE_VPTR, sizeof "vptr" - 1 },
1604 { "all", ~0, sizeof "all" - 1 },
1605 { NULL, 0, 0 }
1607 const char *comma;
1608 size_t len, i;
1609 bool found = false;
1611 comma = strchr (p, ',');
1612 if (comma == NULL)
1613 len = strlen (p);
1614 else
1615 len = comma - p;
1616 if (len == 0)
1618 p = comma + 1;
1619 continue;
1622 /* Check to see if the string matches an option class name. */
1623 for (i = 0; spec[i].name != NULL; ++i)
1624 if (len == spec[i].len
1625 && memcmp (p, spec[i].name, len) == 0)
1627 /* Handle both -fsanitize and -fno-sanitize cases. */
1628 if (value && spec[i].flag == ~0U)
1630 if (code == OPT_fsanitize_)
1631 error_at (loc, "-fsanitize=all option is not valid");
1632 else
1633 *flag |= ~(SANITIZE_USER_ADDRESS | SANITIZE_THREAD
1634 | SANITIZE_LEAK);
1636 else if (value)
1637 *flag |= spec[i].flag;
1638 else
1639 *flag &= ~spec[i].flag;
1640 found = true;
1641 break;
1644 if (! found)
1645 error_at (loc,
1646 "unrecognized argument to -fsanitize%s= option: %q.*s",
1647 code == OPT_fsanitize_ ? "" : "-recover", (int) len, p);
1649 if (comma == NULL)
1650 break;
1651 p = comma + 1;
1654 if (code != OPT_fsanitize_)
1655 break;
1657 /* Kernel ASan implies normal ASan but does not yet support
1658 all features. */
1659 if (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS)
1661 maybe_set_param_value (PARAM_ASAN_INSTRUMENTATION_WITH_CALL_THRESHOLD, 0,
1662 opts->x_param_values,
1663 opts_set->x_param_values);
1664 maybe_set_param_value (PARAM_ASAN_GLOBALS, 0,
1665 opts->x_param_values,
1666 opts_set->x_param_values);
1667 maybe_set_param_value (PARAM_ASAN_STACK, 0,
1668 opts->x_param_values,
1669 opts_set->x_param_values);
1670 maybe_set_param_value (PARAM_ASAN_USE_AFTER_RETURN, 0,
1671 opts->x_param_values,
1672 opts_set->x_param_values);
1675 break;
1678 case OPT_fasan_shadow_offset_:
1679 /* Deferred. */
1680 break;
1682 case OPT_fsanitize_recover:
1683 if (value)
1684 opts->x_flag_sanitize_recover
1685 |= SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT;
1686 else
1687 opts->x_flag_sanitize_recover
1688 &= ~(SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT);
1689 break;
1691 case OPT_O:
1692 case OPT_Os:
1693 case OPT_Ofast:
1694 case OPT_Og:
1695 /* Currently handled in a prescan. */
1696 break;
1698 case OPT_Werror:
1699 dc->warning_as_error_requested = value;
1700 break;
1702 case OPT_Werror_:
1703 if (lang_mask == CL_DRIVER)
1704 break;
1706 enable_warning_as_error (arg, value, lang_mask, handlers,
1707 opts, opts_set, loc, dc);
1708 break;
1710 case OPT_Wlarger_than_:
1711 opts->x_larger_than_size = value;
1712 opts->x_warn_larger_than = value != -1;
1713 break;
1715 case OPT_Wfatal_errors:
1716 dc->fatal_errors = value;
1717 break;
1719 case OPT_Wframe_larger_than_:
1720 opts->x_frame_larger_than_size = value;
1721 opts->x_warn_frame_larger_than = value != -1;
1722 break;
1724 case OPT_Wstack_usage_:
1725 opts->x_warn_stack_usage = value;
1726 opts->x_flag_stack_usage_info = value != -1;
1727 break;
1729 case OPT_Wstrict_aliasing:
1730 set_Wstrict_aliasing (opts, value);
1731 break;
1733 case OPT_Wstrict_overflow:
1734 opts->x_warn_strict_overflow = (value
1735 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1736 : 0);
1737 break;
1739 case OPT_Wsystem_headers:
1740 dc->dc_warn_system_headers = value;
1741 break;
1743 case OPT_aux_info:
1744 opts->x_flag_gen_aux_info = 1;
1745 break;
1747 case OPT_auxbase_strip:
1749 char *tmp = xstrdup (arg);
1750 strip_off_ending (tmp, strlen (tmp));
1751 if (tmp[0])
1752 opts->x_aux_base_name = tmp;
1753 else
1754 free (tmp);
1756 break;
1758 case OPT_d:
1759 decode_d_option (arg, opts, loc, dc);
1760 break;
1762 case OPT_fcall_used_:
1763 case OPT_fcall_saved_:
1764 /* Deferred. */
1765 break;
1767 case OPT_fdbg_cnt_:
1768 /* Deferred. */
1769 break;
1771 case OPT_fdbg_cnt_list:
1772 /* Deferred. */
1773 opts->x_exit_after_options = true;
1774 break;
1776 case OPT_fdebug_prefix_map_:
1777 /* Deferred. */
1778 break;
1780 case OPT_fdiagnostics_show_location_:
1781 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1782 break;
1784 case OPT_fdiagnostics_show_caret:
1785 dc->show_caret = value;
1786 break;
1788 case OPT_fdiagnostics_color_:
1789 diagnostic_color_init (dc, value);
1790 break;
1792 case OPT_fdiagnostics_show_option:
1793 dc->show_option_requested = value;
1794 break;
1796 case OPT_fdump_:
1797 /* Deferred. */
1798 break;
1800 case OPT_ffast_math:
1801 set_fast_math_flags (opts, value);
1802 break;
1804 case OPT_funsafe_math_optimizations:
1805 set_unsafe_math_optimizations_flags (opts, value);
1806 break;
1808 case OPT_ffixed_:
1809 /* Deferred. */
1810 break;
1812 case OPT_finline_limit_:
1813 set_param_value ("max-inline-insns-single", value / 2,
1814 opts->x_param_values, opts_set->x_param_values);
1815 set_param_value ("max-inline-insns-auto", value / 2,
1816 opts->x_param_values, opts_set->x_param_values);
1817 break;
1819 case OPT_finstrument_functions_exclude_function_list_:
1820 add_comma_separated_to_vector
1821 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1822 break;
1824 case OPT_finstrument_functions_exclude_file_list_:
1825 add_comma_separated_to_vector
1826 (&opts->x_flag_instrument_functions_exclude_files, arg);
1827 break;
1829 case OPT_fmessage_length_:
1830 pp_set_line_maximum_length (dc->printer, value);
1831 diagnostic_set_caret_max_width (dc, value);
1832 break;
1834 case OPT_fopt_info:
1835 case OPT_fopt_info_:
1836 /* Deferred. */
1837 break;
1839 case OPT_foffload_:
1841 const char *p = arg;
1842 opts->x_flag_disable_hsa = true;
1843 while (*p != 0)
1845 const char *comma = strchr (p, ',');
1847 if ((strncmp (p, "disable", 7) == 0)
1848 && (p[7] == ',' || p[7] == '\0'))
1850 opts->x_flag_disable_hsa = true;
1851 break;
1854 if ((strncmp (p, "hsa", 3) == 0)
1855 && (p[3] == ',' || p[3] == '\0'))
1857 #ifdef ENABLE_HSA
1858 opts->x_flag_disable_hsa = false;
1859 #else
1860 sorry ("HSA has not been enabled during configuration");
1861 #endif
1863 if (!comma)
1864 break;
1865 p = comma + 1;
1867 break;
1870 #ifndef ACCEL_COMPILER
1871 case OPT_foffload_abi_:
1872 error_at (loc, "-foffload-abi option can be specified only for "
1873 "offload compiler");
1874 break;
1875 #endif
1877 case OPT_fpack_struct_:
1878 if (value <= 0 || (value & (value - 1)) || value > 16)
1879 error_at (loc,
1880 "structure alignment must be a small power of two, not %d",
1881 value);
1882 else
1883 opts->x_initial_max_fld_align = value;
1884 break;
1886 case OPT_fplugin_:
1887 case OPT_fplugin_arg_:
1888 /* Deferred. */
1889 break;
1891 case OPT_fprofile_use_:
1892 opts->x_profile_data_prefix = xstrdup (arg);
1893 opts->x_flag_profile_use = true;
1894 value = true;
1895 /* No break here - do -fprofile-use processing. */
1896 case OPT_fprofile_use:
1897 enable_fdo_optimizations (opts, opts_set, value);
1898 if (!opts_set->x_flag_profile_reorder_functions)
1899 opts->x_flag_profile_reorder_functions = value;
1900 /* Indirect call profiling should do all useful transformations
1901 speculative devirtualization does. */
1902 if (!opts_set->x_flag_devirtualize_speculatively
1903 && opts->x_flag_value_profile_transformations)
1904 opts->x_flag_devirtualize_speculatively = false;
1905 break;
1907 case OPT_fauto_profile_:
1908 opts->x_auto_profile_file = xstrdup (arg);
1909 opts->x_flag_auto_profile = true;
1910 value = true;
1911 /* No break here - do -fauto-profile processing. */
1912 case OPT_fauto_profile:
1913 enable_fdo_optimizations (opts, opts_set, value);
1914 if (!opts_set->x_flag_profile_correction)
1915 opts->x_flag_profile_correction = value;
1916 maybe_set_param_value (
1917 PARAM_EARLY_INLINER_MAX_ITERATIONS, 10,
1918 opts->x_param_values, opts_set->x_param_values);
1919 break;
1921 case OPT_fprofile_generate_:
1922 opts->x_profile_data_prefix = xstrdup (arg);
1923 value = true;
1924 /* No break here - do -fprofile-generate processing. */
1925 case OPT_fprofile_generate:
1926 if (!opts_set->x_profile_arc_flag)
1927 opts->x_profile_arc_flag = value;
1928 if (!opts_set->x_flag_profile_values)
1929 opts->x_flag_profile_values = value;
1930 if (!opts_set->x_flag_inline_functions)
1931 opts->x_flag_inline_functions = value;
1932 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1933 quadratic. Disable the pass until better memory representation
1934 is done. */
1935 if (!opts_set->x_flag_ipa_reference)
1936 opts->x_flag_ipa_reference = false;
1937 break;
1939 case OPT_ftree_vectorize:
1940 if (!opts_set->x_flag_tree_loop_vectorize)
1941 opts->x_flag_tree_loop_vectorize = value;
1942 if (!opts_set->x_flag_tree_slp_vectorize)
1943 opts->x_flag_tree_slp_vectorize = value;
1944 break;
1945 case OPT_fshow_column:
1946 dc->show_column = value;
1947 break;
1949 case OPT_frandom_seed:
1950 /* The real switch is -fno-random-seed. */
1951 if (value)
1952 return false;
1953 /* Deferred. */
1954 break;
1956 case OPT_frandom_seed_:
1957 /* Deferred. */
1958 break;
1960 case OPT_fsched_verbose_:
1961 #ifdef INSN_SCHEDULING
1962 /* Handled with Var in common.opt. */
1963 break;
1964 #else
1965 return false;
1966 #endif
1968 case OPT_fsched_stalled_insns_:
1969 opts->x_flag_sched_stalled_insns = value;
1970 if (opts->x_flag_sched_stalled_insns == 0)
1971 opts->x_flag_sched_stalled_insns = -1;
1972 break;
1974 case OPT_fsched_stalled_insns_dep_:
1975 opts->x_flag_sched_stalled_insns_dep = value;
1976 break;
1978 case OPT_fstack_check_:
1979 if (!strcmp (arg, "no"))
1980 opts->x_flag_stack_check = NO_STACK_CHECK;
1981 else if (!strcmp (arg, "generic"))
1982 /* This is the old stack checking method. */
1983 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1984 ? FULL_BUILTIN_STACK_CHECK
1985 : GENERIC_STACK_CHECK;
1986 else if (!strcmp (arg, "specific"))
1987 /* This is the new stack checking method. */
1988 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1989 ? FULL_BUILTIN_STACK_CHECK
1990 : STACK_CHECK_STATIC_BUILTIN
1991 ? STATIC_BUILTIN_STACK_CHECK
1992 : GENERIC_STACK_CHECK;
1993 else
1994 warning_at (loc, 0, "unknown stack check parameter %qs", arg);
1995 break;
1997 case OPT_fstack_limit:
1998 /* The real switch is -fno-stack-limit. */
1999 if (value)
2000 return false;
2001 /* Deferred. */
2002 break;
2004 case OPT_fstack_limit_register_:
2005 case OPT_fstack_limit_symbol_:
2006 /* Deferred. */
2007 break;
2009 case OPT_fstack_usage:
2010 opts->x_flag_stack_usage = value;
2011 opts->x_flag_stack_usage_info = value != 0;
2012 break;
2014 case OPT_g:
2015 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
2016 loc);
2017 break;
2019 case OPT_gcoff:
2020 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
2021 break;
2023 case OPT_gdwarf:
2024 if (arg && strlen (arg) != 0)
2026 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
2027 "use %<-gdwarf-%s%> for DWARF version "
2028 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
2029 break;
2031 else
2032 value = opts->x_dwarf_version;
2034 /* FALLTHRU */
2035 case OPT_gdwarf_:
2036 if (value < 2 || value > 5)
2037 error_at (loc, "dwarf version %d is not supported", value);
2038 else
2039 opts->x_dwarf_version = value;
2040 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
2041 break;
2043 case OPT_gsplit_dwarf:
2044 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
2045 loc);
2046 break;
2048 case OPT_ggdb:
2049 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
2050 break;
2052 case OPT_gstabs:
2053 case OPT_gstabs_:
2054 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
2055 loc);
2056 break;
2058 case OPT_gvms:
2059 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
2060 break;
2062 case OPT_gxcoff:
2063 case OPT_gxcoff_:
2064 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
2065 loc);
2066 break;
2068 case OPT_gz:
2069 case OPT_gz_:
2070 /* Handled completely via specs. */
2071 break;
2073 case OPT_pedantic_errors:
2074 dc->pedantic_errors = 1;
2075 control_warning_option (OPT_Wpedantic, DK_ERROR, value,
2076 loc, lang_mask,
2077 handlers, opts, opts_set,
2078 dc);
2079 break;
2081 case OPT_flto:
2082 opts->x_flag_lto = value ? "" : NULL;
2083 break;
2085 case OPT_w:
2086 dc->dc_inhibit_warnings = true;
2087 break;
2089 case OPT_fmax_errors_:
2090 dc->max_errors = value;
2091 break;
2093 case OPT_fuse_ld_bfd:
2094 case OPT_fuse_ld_gold:
2095 case OPT_fuse_linker_plugin:
2096 /* No-op. Used by the driver and passed to us because it starts with f.*/
2097 break;
2099 case OPT_fwrapv:
2100 if (value)
2101 opts->x_flag_trapv = 0;
2102 break;
2104 case OPT_ftrapv:
2105 if (value)
2106 opts->x_flag_wrapv = 0;
2107 break;
2109 case OPT_fipa_icf:
2110 opts->x_flag_ipa_icf_functions = value;
2111 opts->x_flag_ipa_icf_variables = value;
2112 break;
2114 default:
2115 /* If the flag was handled in a standard way, assume the lack of
2116 processing here is intentional. */
2117 gcc_assert (option_flag_var (scode, opts));
2118 break;
2121 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
2122 loc, handlers, dc);
2123 return true;
2126 /* Handle --param NAME=VALUE. */
2127 static void
2128 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
2129 location_t loc, const char *carg)
2131 char *equal, *arg;
2132 int value;
2134 arg = xstrdup (carg);
2135 equal = strchr (arg, '=');
2136 if (!equal)
2137 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
2138 arg);
2139 else
2141 value = integral_argument (equal + 1);
2142 if (value == -1)
2143 error_at (loc, "invalid --param value %qs", equal + 1);
2144 else
2146 *equal = '\0';
2147 set_param_value (arg, value,
2148 opts->x_param_values, opts_set->x_param_values);
2152 free (arg);
2155 /* Used to set the level of strict aliasing warnings in OPTS,
2156 when no level is specified (i.e., when -Wstrict-aliasing, and not
2157 -Wstrict-aliasing=level was given).
2158 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
2159 and 0 otherwise. After calling this function, wstrict_aliasing will be
2160 set to the default value of -Wstrict_aliasing=level, currently 3. */
2161 static void
2162 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
2164 gcc_assert (onoff == 0 || onoff == 1);
2165 if (onoff != 0)
2166 opts->x_warn_strict_aliasing = 3;
2167 else
2168 opts->x_warn_strict_aliasing = 0;
2171 /* The following routines are useful in setting all the flags that
2172 -ffast-math and -fno-fast-math imply. */
2173 static void
2174 set_fast_math_flags (struct gcc_options *opts, int set)
2176 if (!opts->frontend_set_flag_unsafe_math_optimizations)
2178 opts->x_flag_unsafe_math_optimizations = set;
2179 set_unsafe_math_optimizations_flags (opts, set);
2181 if (!opts->frontend_set_flag_finite_math_only)
2182 opts->x_flag_finite_math_only = set;
2183 if (!opts->frontend_set_flag_errno_math)
2184 opts->x_flag_errno_math = !set;
2185 if (set)
2187 if (!opts->frontend_set_flag_signaling_nans)
2188 opts->x_flag_signaling_nans = 0;
2189 if (!opts->frontend_set_flag_rounding_math)
2190 opts->x_flag_rounding_math = 0;
2191 if (!opts->frontend_set_flag_cx_limited_range)
2192 opts->x_flag_cx_limited_range = 1;
2196 /* When -funsafe-math-optimizations is set the following
2197 flags are set as well. */
2198 static void
2199 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
2201 if (!opts->frontend_set_flag_trapping_math)
2202 opts->x_flag_trapping_math = !set;
2203 if (!opts->frontend_set_flag_signed_zeros)
2204 opts->x_flag_signed_zeros = !set;
2205 if (!opts->frontend_set_flag_associative_math)
2206 opts->x_flag_associative_math = set;
2207 if (!opts->frontend_set_flag_reciprocal_math)
2208 opts->x_flag_reciprocal_math = set;
2211 /* Return true iff flags in OPTS are set as if -ffast-math. */
2212 bool
2213 fast_math_flags_set_p (const struct gcc_options *opts)
2215 return (!opts->x_flag_trapping_math
2216 && opts->x_flag_unsafe_math_optimizations
2217 && opts->x_flag_finite_math_only
2218 && !opts->x_flag_signed_zeros
2219 && !opts->x_flag_errno_math);
2222 /* Return true iff flags are set as if -ffast-math but using the flags stored
2223 in the struct cl_optimization structure. */
2224 bool
2225 fast_math_flags_struct_set_p (struct cl_optimization *opt)
2227 return (!opt->x_flag_trapping_math
2228 && opt->x_flag_unsafe_math_optimizations
2229 && opt->x_flag_finite_math_only
2230 && !opt->x_flag_signed_zeros
2231 && !opt->x_flag_errno_math);
2234 /* Handle a debug output -g switch for options OPTS
2235 (OPTS_SET->x_write_symbols storing whether a debug type was passed
2236 explicitly), location LOC. EXTENDED is true or false to support
2237 extended output (2 is special and means "-ggdb" was given). */
2238 static void
2239 set_debug_level (enum debug_info_type type, int extended, const char *arg,
2240 struct gcc_options *opts, struct gcc_options *opts_set,
2241 location_t loc)
2243 opts->x_use_gnu_debug_info_extensions = extended;
2245 if (type == NO_DEBUG)
2247 if (opts->x_write_symbols == NO_DEBUG)
2249 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
2251 if (extended == 2)
2253 #ifdef DWARF2_DEBUGGING_INFO
2254 opts->x_write_symbols = DWARF2_DEBUG;
2255 #elif defined DBX_DEBUGGING_INFO
2256 opts->x_write_symbols = DBX_DEBUG;
2257 #endif
2260 if (opts->x_write_symbols == NO_DEBUG)
2261 warning_at (loc, 0, "target system does not support debug output");
2264 else
2266 /* Does it conflict with an already selected type? */
2267 if (opts_set->x_write_symbols != NO_DEBUG
2268 && opts->x_write_symbols != NO_DEBUG
2269 && type != opts->x_write_symbols)
2270 error_at (loc, "debug format %qs conflicts with prior selection",
2271 debug_type_names[type]);
2272 opts->x_write_symbols = type;
2273 opts_set->x_write_symbols = type;
2276 /* A debug flag without a level defaults to level 2.
2277 If off or at level 1, set it to level 2, but if already
2278 at level 3, don't lower it. */
2279 if (*arg == '\0')
2281 if (opts->x_debug_info_level < DINFO_LEVEL_NORMAL)
2282 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2284 else
2286 int argval = integral_argument (arg);
2287 if (argval == -1)
2288 error_at (loc, "unrecognised debug output level %qs", arg);
2289 else if (argval > 3)
2290 error_at (loc, "debug output level %qs is too high", arg);
2291 else
2292 opts->x_debug_info_level = (enum debug_info_levels) argval;
2296 /* Arrange to dump core on error for diagnostic context DC. (The
2297 regular error message is still printed first, except in the case of
2298 abort ().) */
2300 static void
2301 setup_core_dumping (diagnostic_context *dc)
2303 #ifdef SIGABRT
2304 signal (SIGABRT, SIG_DFL);
2305 #endif
2306 #if defined(HAVE_SETRLIMIT)
2308 struct rlimit rlim;
2309 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2310 fatal_error (input_location, "getting core file size maximum limit: %m");
2311 rlim.rlim_cur = rlim.rlim_max;
2312 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2313 fatal_error (input_location,
2314 "setting core file size limit to maximum: %m");
2316 #endif
2317 diagnostic_abort_on_error (dc);
2320 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2321 diagnostic context DC. */
2323 static void
2324 decode_d_option (const char *arg, struct gcc_options *opts,
2325 location_t loc, diagnostic_context *dc)
2327 int c;
2329 while (*arg)
2330 switch (c = *arg++)
2332 case 'A':
2333 opts->x_flag_debug_asm = 1;
2334 break;
2335 case 'p':
2336 opts->x_flag_print_asm_name = 1;
2337 break;
2338 case 'P':
2339 opts->x_flag_dump_rtl_in_asm = 1;
2340 opts->x_flag_print_asm_name = 1;
2341 break;
2342 case 'x':
2343 opts->x_rtl_dump_and_exit = 1;
2344 break;
2345 case 'D': /* These are handled by the preprocessor. */
2346 case 'I':
2347 case 'M':
2348 case 'N':
2349 case 'U':
2350 break;
2351 case 'H':
2352 setup_core_dumping (dc);
2353 break;
2354 case 'a':
2355 opts->x_flag_dump_all_passed = true;
2356 break;
2358 default:
2359 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2360 break;
2364 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2365 mask LANG_MASK, option handlers HANDLERS) as an error for option
2366 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2367 NULL), location LOC. This is used by -Werror=. */
2369 static void
2370 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2371 const struct cl_option_handlers *handlers,
2372 struct gcc_options *opts,
2373 struct gcc_options *opts_set,
2374 location_t loc, diagnostic_context *dc)
2376 char *new_option;
2377 int option_index;
2379 new_option = XNEWVEC (char, strlen (arg) + 2);
2380 new_option[0] = 'W';
2381 strcpy (new_option + 1, arg);
2382 option_index = find_opt (new_option, lang_mask);
2383 if (option_index == OPT_SPECIAL_unknown)
2385 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2387 else
2389 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2391 control_warning_option (option_index, (int) kind, value,
2392 loc, lang_mask,
2393 handlers, opts, opts_set, dc);
2395 free (new_option);
2398 /* Return malloced memory for the name of the option OPTION_INDEX
2399 which enabled a diagnostic (context CONTEXT), originally of type
2400 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2401 as -Werror. */
2403 char *
2404 option_name (diagnostic_context *context, int option_index,
2405 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2407 if (option_index)
2409 /* A warning classified as an error. */
2410 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2411 && diag_kind == DK_ERROR)
2412 return concat (cl_options[OPT_Werror_].opt_text,
2413 /* Skip over "-W". */
2414 cl_options[option_index].opt_text + 2,
2415 NULL);
2416 /* A warning with option. */
2417 else
2418 return xstrdup (cl_options[option_index].opt_text);
2420 /* A warning without option classified as an error. */
2421 else if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2422 || diag_kind == DK_WARNING)
2423 && context->warning_as_error_requested)
2424 return xstrdup (cl_options[OPT_Werror].opt_text);
2425 else
2426 return NULL;