PR sanitizer/59009
[official-gcc.git] / gcc / opts.c
blob3a939ac92b9bb1d03044957268c85f1b3e3f6c4d
1 /* Command line option handling.
2 Copyright (C) 2002-2013 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 "options.h"
27 #include "tm.h" /* For STACK_CHECK_BUILTIN,
28 STACK_CHECK_STATIC_BUILTIN, DEFAULT_GDB_EXTENSIONS,
29 DWARF2_DEBUGGING_INFO and DBX_DEBUGGING_INFO. */
30 #include "flags.h"
31 #include "params.h"
32 #include "diagnostic.h"
33 #include "diagnostic-color.h"
34 #include "opts-diagnostic.h"
35 #include "insn-attr-common.h"
36 #include "common/common-target.h"
38 static void set_Wstrict_aliasing (struct gcc_options *opts, int onoff);
40 /* Indexed by enum debug_info_type. */
41 const char *const debug_type_names[] =
43 "none", "stabs", "coff", "dwarf-2", "xcoff", "vms"
46 /* Parse the -femit-struct-debug-detailed option value
47 and set the flag variables. */
49 #define MATCH( prefix, string ) \
50 ((strncmp (prefix, string, sizeof prefix - 1) == 0) \
51 ? ((string += sizeof prefix - 1), 1) : 0)
53 void
54 set_struct_debug_option (struct gcc_options *opts, location_t loc,
55 const char *spec)
57 /* various labels for comparison */
58 static const char dfn_lbl[] = "dfn:", dir_lbl[] = "dir:", ind_lbl[] = "ind:";
59 static const char ord_lbl[] = "ord:", gen_lbl[] = "gen:";
60 static const char none_lbl[] = "none", any_lbl[] = "any";
61 static const char base_lbl[] = "base", sys_lbl[] = "sys";
63 enum debug_struct_file files = DINFO_STRUCT_FILE_ANY;
64 /* Default is to apply to as much as possible. */
65 enum debug_info_usage usage = DINFO_USAGE_NUM_ENUMS;
66 int ord = 1, gen = 1;
68 /* What usage? */
69 if (MATCH (dfn_lbl, spec))
70 usage = DINFO_USAGE_DFN;
71 else if (MATCH (dir_lbl, spec))
72 usage = DINFO_USAGE_DIR_USE;
73 else if (MATCH (ind_lbl, spec))
74 usage = DINFO_USAGE_IND_USE;
76 /* Generics or not? */
77 if (MATCH (ord_lbl, spec))
78 gen = 0;
79 else if (MATCH (gen_lbl, spec))
80 ord = 0;
82 /* What allowable environment? */
83 if (MATCH (none_lbl, spec))
84 files = DINFO_STRUCT_FILE_NONE;
85 else if (MATCH (any_lbl, spec))
86 files = DINFO_STRUCT_FILE_ANY;
87 else if (MATCH (sys_lbl, spec))
88 files = DINFO_STRUCT_FILE_SYS;
89 else if (MATCH (base_lbl, spec))
90 files = DINFO_STRUCT_FILE_BASE;
91 else
92 error_at (loc,
93 "argument %qs to %<-femit-struct-debug-detailed%> "
94 "not recognized",
95 spec);
97 /* Effect the specification. */
98 if (usage == DINFO_USAGE_NUM_ENUMS)
100 if (ord)
102 opts->x_debug_struct_ordinary[DINFO_USAGE_DFN] = files;
103 opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE] = files;
104 opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE] = files;
106 if (gen)
108 opts->x_debug_struct_generic[DINFO_USAGE_DFN] = files;
109 opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE] = files;
110 opts->x_debug_struct_generic[DINFO_USAGE_IND_USE] = files;
113 else
115 if (ord)
116 opts->x_debug_struct_ordinary[usage] = files;
117 if (gen)
118 opts->x_debug_struct_generic[usage] = files;
121 if (*spec == ',')
122 set_struct_debug_option (opts, loc, spec+1);
123 else
125 /* No more -femit-struct-debug-detailed specifications.
126 Do final checks. */
127 if (*spec != '\0')
128 error_at (loc,
129 "argument %qs to %<-femit-struct-debug-detailed%> unknown",
130 spec);
131 if (opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE]
132 < opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE]
133 || opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE]
134 < opts->x_debug_struct_generic[DINFO_USAGE_IND_USE])
135 error_at (loc,
136 "%<-femit-struct-debug-detailed=dir:...%> must allow "
137 "at least as much as "
138 "%<-femit-struct-debug-detailed=ind:...%>");
142 /* Strip off a legitimate source ending from the input string NAME of
143 length LEN. Rather than having to know the names used by all of
144 our front ends, we strip off an ending of a period followed by
145 up to five characters. (Java uses ".class".) */
147 void
148 strip_off_ending (char *name, int len)
150 int i;
151 for (i = 2; i < 6 && len > i; i++)
153 if (name[len - i] == '.')
155 name[len - i] = '\0';
156 break;
161 /* Find the base name of a path, stripping off both directories and
162 a single final extension. */
164 base_of_path (const char *path, const char **base_out)
166 const char *base = path;
167 const char *dot = 0;
168 const char *p = path;
169 char c = *p;
170 while (c)
172 if (IS_DIR_SEPARATOR (c))
174 base = p + 1;
175 dot = 0;
177 else if (c == '.')
178 dot = p;
179 c = *++p;
181 if (!dot)
182 dot = p;
183 *base_out = base;
184 return dot - base;
187 /* What to print when a switch has no documentation. */
188 static const char undocumented_msg[] = N_("This switch lacks documentation");
190 typedef char *char_p; /* For DEF_VEC_P. */
192 static void handle_param (struct gcc_options *opts,
193 struct gcc_options *opts_set, location_t loc,
194 const char *carg);
195 static void set_debug_level (enum debug_info_type type, int extended,
196 const char *arg, struct gcc_options *opts,
197 struct gcc_options *opts_set,
198 location_t loc);
199 static void set_fast_math_flags (struct gcc_options *opts, int set);
200 static void decode_d_option (const char *arg, struct gcc_options *opts,
201 location_t loc, diagnostic_context *dc);
202 static void set_unsafe_math_optimizations_flags (struct gcc_options *opts,
203 int set);
204 static void enable_warning_as_error (const char *arg, int value,
205 unsigned int lang_mask,
206 const struct cl_option_handlers *handlers,
207 struct gcc_options *opts,
208 struct gcc_options *opts_set,
209 location_t loc,
210 diagnostic_context *dc);
212 /* Handle a back-end option; arguments and return value as for
213 handle_option. */
215 bool
216 target_handle_option (struct gcc_options *opts,
217 struct gcc_options *opts_set,
218 const struct cl_decoded_option *decoded,
219 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
220 location_t loc,
221 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
222 diagnostic_context *dc)
224 gcc_assert (dc == global_dc);
225 gcc_assert (kind == DK_UNSPECIFIED);
226 return targetm_common.handle_option (opts, opts_set, decoded, loc);
229 /* Add comma-separated strings to a char_p vector. */
231 static void
232 add_comma_separated_to_vector (void **pvec, const char *arg)
234 char *tmp;
235 char *r;
236 char *w;
237 char *token_start;
238 vec<char_p> *v = (vec<char_p> *) *pvec;
240 vec_check_alloc (v, 1);
242 /* We never free this string. */
243 tmp = xstrdup (arg);
245 r = tmp;
246 w = tmp;
247 token_start = tmp;
249 while (*r != '\0')
251 if (*r == ',')
253 *w++ = '\0';
254 ++r;
255 v->safe_push (token_start);
256 token_start = w;
258 if (*r == '\\' && r[1] == ',')
260 *w++ = ',';
261 r += 2;
263 else
264 *w++ = *r++;
266 if (*token_start != '\0')
267 v->safe_push (token_start);
269 *pvec = v;
272 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
274 void
275 init_options_struct (struct gcc_options *opts, struct gcc_options *opts_set)
277 size_t num_params = get_num_compiler_params ();
279 gcc_obstack_init (&opts_obstack);
281 *opts = global_options_init;
283 if (opts_set)
284 memset (opts_set, 0, sizeof (*opts_set));
286 opts->x_param_values = XNEWVEC (int, num_params);
288 if (opts_set)
289 opts_set->x_param_values = XCNEWVEC (int, num_params);
291 init_param_values (opts->x_param_values);
293 /* Initialize whether `char' is signed. */
294 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
295 /* Set this to a special "uninitialized" value. The actual default
296 is set after target options have been processed. */
297 opts->x_flag_short_enums = 2;
299 /* Initialize target_flags before default_options_optimization
300 so the latter can modify it. */
301 opts->x_target_flags = targetm_common.default_target_flags;
303 /* Some targets have ABI-specified unwind tables. */
304 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
306 /* Some targets have other target-specific initialization. */
307 targetm_common.option_init_struct (opts);
310 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
311 -Ofast if FAST is set, -Og if DEBUG is set), apply the option DEFAULT_OPT
312 to OPTS and OPTS_SET, diagnostic context DC, location LOC, with language
313 mask LANG_MASK and option handlers HANDLERS. */
315 static void
316 maybe_default_option (struct gcc_options *opts,
317 struct gcc_options *opts_set,
318 const struct default_options *default_opt,
319 int level, bool size, bool fast, bool debug,
320 unsigned int lang_mask,
321 const struct cl_option_handlers *handlers,
322 location_t loc,
323 diagnostic_context *dc)
325 const struct cl_option *option = &cl_options[default_opt->opt_index];
326 bool enabled;
328 if (size)
329 gcc_assert (level == 2);
330 if (fast)
331 gcc_assert (level == 3);
332 if (debug)
333 gcc_assert (level == 1);
335 switch (default_opt->levels)
337 case OPT_LEVELS_ALL:
338 enabled = true;
339 break;
341 case OPT_LEVELS_0_ONLY:
342 enabled = (level == 0);
343 break;
345 case OPT_LEVELS_1_PLUS:
346 enabled = (level >= 1);
347 break;
349 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
350 enabled = (level >= 1 && !size && !debug);
351 break;
353 case OPT_LEVELS_1_PLUS_NOT_DEBUG:
354 enabled = (level >= 1 && !debug);
355 break;
357 case OPT_LEVELS_2_PLUS:
358 enabled = (level >= 2);
359 break;
361 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
362 enabled = (level >= 2 && !size && !debug);
363 break;
365 case OPT_LEVELS_3_PLUS:
366 enabled = (level >= 3);
367 break;
369 case OPT_LEVELS_3_PLUS_AND_SIZE:
370 enabled = (level >= 3 || size);
371 break;
373 case OPT_LEVELS_SIZE:
374 enabled = size;
375 break;
377 case OPT_LEVELS_FAST:
378 enabled = fast;
379 break;
381 case OPT_LEVELS_NONE:
382 default:
383 gcc_unreachable ();
386 if (enabled)
387 handle_generated_option (opts, opts_set, default_opt->opt_index,
388 default_opt->arg, default_opt->value,
389 lang_mask, DK_UNSPECIFIED, loc,
390 handlers, dc);
391 else if (default_opt->arg == NULL
392 && !option->cl_reject_negative)
393 handle_generated_option (opts, opts_set, default_opt->opt_index,
394 default_opt->arg, !default_opt->value,
395 lang_mask, DK_UNSPECIFIED, loc,
396 handlers, dc);
399 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
400 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
401 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
402 language mask LANG_MASK and option handlers HANDLERS. */
404 static void
405 maybe_default_options (struct gcc_options *opts,
406 struct gcc_options *opts_set,
407 const struct default_options *default_opts,
408 int level, bool size, bool fast, bool debug,
409 unsigned int lang_mask,
410 const struct cl_option_handlers *handlers,
411 location_t loc,
412 diagnostic_context *dc)
414 size_t i;
416 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
417 maybe_default_option (opts, opts_set, &default_opts[i],
418 level, size, fast, debug,
419 lang_mask, handlers, loc, dc);
422 /* Table of options enabled by default at different levels. */
424 static const struct default_options default_options_table[] =
426 /* -O1 optimizations. */
427 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
428 #ifdef DELAY_SLOTS
429 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
430 #endif
431 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
432 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
433 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
434 { OPT_LEVELS_1_PLUS, OPT_fif_conversion, NULL, 1 },
435 { OPT_LEVELS_1_PLUS, OPT_fif_conversion2, NULL, 1 },
436 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
437 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
438 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
439 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
440 { OPT_LEVELS_1_PLUS, OPT_fshrink_wrap, NULL, 1 },
441 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
442 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
443 { OPT_LEVELS_1_PLUS, OPT_ftree_bit_ccp, NULL, 1 },
444 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
445 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
446 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
447 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
448 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_sra, NULL, 1 },
449 { OPT_LEVELS_1_PLUS, OPT_ftree_copyrename, NULL, 1 },
450 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
451 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
452 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
453 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
454 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
455 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
456 { OPT_LEVELS_1_PLUS, OPT_ftree_slsr, NULL, 1 },
458 /* -O2 optimizations. */
459 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
460 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
461 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
462 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
463 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
464 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
465 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
466 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
467 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
468 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
469 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
470 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
471 #ifdef INSN_SCHEDULING
472 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
473 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
474 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
475 #endif
476 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
477 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
478 { OPT_LEVELS_2_PLUS, OPT_freorder_blocks, NULL, 1 },
479 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
480 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
481 { OPT_LEVELS_2_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
482 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
483 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
484 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
488 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
489 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
490 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
491 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
492 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
493 { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
494 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
495 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
496 { OPT_LEVELS_2_PLUS, OPT_fisolate_erroneous_paths, NULL, 1 },
498 /* -O3 optimizations. */
499 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
500 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
501 /* Inlining of functions reducing size is a good idea with -Os
502 regardless of them being declared inline. */
503 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
504 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
505 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
506 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
507 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
508 { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
509 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
510 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
511 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
513 /* -Ofast adds optimizations to -O3. */
514 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
516 { OPT_LEVELS_NONE, 0, NULL, 0 }
519 /* Default the options in OPTS and OPTS_SET based on the optimization
520 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
521 void
522 default_options_optimization (struct gcc_options *opts,
523 struct gcc_options *opts_set,
524 struct cl_decoded_option *decoded_options,
525 unsigned int decoded_options_count,
526 location_t loc,
527 unsigned int lang_mask,
528 const struct cl_option_handlers *handlers,
529 diagnostic_context *dc)
531 unsigned int i;
532 int opt2;
534 /* Scan to see what optimization level has been specified. That will
535 determine the default value of many flags. */
536 for (i = 1; i < decoded_options_count; i++)
538 struct cl_decoded_option *opt = &decoded_options[i];
539 switch (opt->opt_index)
541 case OPT_O:
542 if (*opt->arg == '\0')
544 opts->x_optimize = 1;
545 opts->x_optimize_size = 0;
546 opts->x_optimize_fast = 0;
547 opts->x_optimize_debug = 0;
549 else
551 const int optimize_val = integral_argument (opt->arg);
552 if (optimize_val == -1)
553 error_at (loc, "argument to %<-O%> should be a non-negative "
554 "integer, %<g%>, %<s%> or %<fast%>");
555 else
557 opts->x_optimize = optimize_val;
558 if ((unsigned int) opts->x_optimize > 255)
559 opts->x_optimize = 255;
560 opts->x_optimize_size = 0;
561 opts->x_optimize_fast = 0;
562 opts->x_optimize_debug = 0;
565 break;
567 case OPT_Os:
568 opts->x_optimize_size = 1;
570 /* Optimizing for size forces optimize to be 2. */
571 opts->x_optimize = 2;
572 opts->x_optimize_fast = 0;
573 opts->x_optimize_debug = 0;
574 break;
576 case OPT_Ofast:
577 /* -Ofast only adds flags to -O3. */
578 opts->x_optimize_size = 0;
579 opts->x_optimize = 3;
580 opts->x_optimize_fast = 1;
581 opts->x_optimize_debug = 0;
582 break;
584 case OPT_Og:
585 /* -Og selects optimization level 1. */
586 opts->x_optimize_size = 0;
587 opts->x_optimize = 1;
588 opts->x_optimize_fast = 0;
589 opts->x_optimize_debug = 1;
590 break;
592 default:
593 /* Ignore other options in this prescan. */
594 break;
598 maybe_default_options (opts, opts_set, default_options_table,
599 opts->x_optimize, opts->x_optimize_size,
600 opts->x_optimize_fast, opts->x_optimize_debug,
601 lang_mask, handlers, loc, dc);
603 /* -O2 param settings. */
604 opt2 = (opts->x_optimize >= 2);
606 /* Track fields in field-sensitive alias analysis. */
607 maybe_set_param_value
608 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
609 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
610 opts->x_param_values, opts_set->x_param_values);
612 /* For -O1 only do loop invariant motion for very small loops. */
613 maybe_set_param_value
614 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
615 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
616 opts->x_param_values, opts_set->x_param_values);
618 if (opts->x_optimize_size)
619 /* We want to crossjump as much as possible. */
620 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
621 opts->x_param_values, opts_set->x_param_values);
622 else
623 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
624 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
625 opts->x_param_values, opts_set->x_param_values);
627 /* Allow default optimizations to be specified on a per-machine basis. */
628 maybe_default_options (opts, opts_set,
629 targetm_common.option_optimization_table,
630 opts->x_optimize, opts->x_optimize_size,
631 opts->x_optimize_fast, opts->x_optimize_debug,
632 lang_mask, handlers, loc, dc);
635 /* After all options at LOC have been read into OPTS and OPTS_SET,
636 finalize settings of those options and diagnose incompatible
637 combinations. */
638 void
639 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
640 location_t loc)
642 enum unwind_info_type ui_except;
644 if (opts->x_dump_base_name && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name))
646 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
647 OPTS->X_DUMP_DIR_NAME directory. Then try to make
648 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
649 directory, typically the directory to contain the object
650 file. */
651 if (opts->x_dump_dir_name)
652 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
653 opts->x_dump_base_name, NULL);
654 else if (opts->x_aux_base_name
655 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
657 const char *aux_base;
659 base_of_path (opts->x_aux_base_name, &aux_base);
660 if (opts->x_aux_base_name != aux_base)
662 int dir_len = aux_base - opts->x_aux_base_name;
663 char *new_dump_base_name
664 = XOBNEWVEC (&opts_obstack, char,
665 strlen (opts->x_dump_base_name) + dir_len + 1);
667 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
668 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
669 /* Append existing OPTS->X_DUMP_BASE_NAME. */
670 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
671 opts->x_dump_base_name = new_dump_base_name;
676 /* Handle related options for unit-at-a-time, toplevel-reorder, and
677 section-anchors. */
678 if (!opts->x_flag_unit_at_a_time)
680 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
681 error_at (loc, "section anchors must be disabled when unit-at-a-time "
682 "is disabled");
683 opts->x_flag_section_anchors = 0;
684 if (opts->x_flag_toplevel_reorder == 1)
685 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
686 "is disabled");
687 opts->x_flag_toplevel_reorder = 0;
690 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
691 sorry ("transactional memory is not supported with non-call exceptions");
693 /* Unless the user has asked for section anchors, we disable toplevel
694 reordering at -O0 to disable transformations that might be surprising
695 to end users and to get -fno-toplevel-reorder tested. */
696 if (!opts->x_optimize
697 && opts->x_flag_toplevel_reorder == 2
698 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
700 opts->x_flag_toplevel_reorder = 0;
701 opts->x_flag_section_anchors = 0;
703 if (!opts->x_flag_toplevel_reorder)
705 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
706 error_at (loc, "section anchors must be disabled when toplevel reorder"
707 " is disabled");
708 opts->x_flag_section_anchors = 0;
711 if (!opts->x_flag_opts_finished)
713 if (opts->x_flag_pie)
714 opts->x_flag_pic = opts->x_flag_pie;
715 if (opts->x_flag_pic && !opts->x_flag_pie)
716 opts->x_flag_shlib = 1;
717 opts->x_flag_opts_finished = true;
720 if (opts->x_optimize == 0)
722 /* Inlining does not work if not optimizing,
723 so force it not to be done. */
724 opts->x_warn_inline = 0;
725 opts->x_flag_no_inline = 1;
728 /* The optimization to partition hot and cold basic blocks into separate
729 sections of the .o and executable files does not work (currently)
730 with exception handling. This is because there is no support for
731 generating unwind info. If opts->x_flag_exceptions is turned on
732 we need to turn off the partitioning optimization. */
734 ui_except = targetm_common.except_unwind_info (opts);
736 if (opts->x_flag_exceptions
737 && opts->x_flag_reorder_blocks_and_partition
738 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
740 inform (loc,
741 "-freorder-blocks-and-partition does not work "
742 "with exceptions on this architecture");
743 opts->x_flag_reorder_blocks_and_partition = 0;
744 opts->x_flag_reorder_blocks = 1;
747 /* If user requested unwind info, then turn off the partitioning
748 optimization. */
750 if (opts->x_flag_unwind_tables
751 && !targetm_common.unwind_tables_default
752 && opts->x_flag_reorder_blocks_and_partition
753 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
755 inform (loc,
756 "-freorder-blocks-and-partition does not support "
757 "unwind info on this architecture");
758 opts->x_flag_reorder_blocks_and_partition = 0;
759 opts->x_flag_reorder_blocks = 1;
762 /* If the target requested unwind info, then turn off the partitioning
763 optimization with a different message. Likewise, if the target does not
764 support named sections. */
766 if (opts->x_flag_reorder_blocks_and_partition
767 && (!targetm_common.have_named_sections
768 || (opts->x_flag_unwind_tables
769 && targetm_common.unwind_tables_default
770 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
772 inform (loc,
773 "-freorder-blocks-and-partition does not work "
774 "on this architecture");
775 opts->x_flag_reorder_blocks_and_partition = 0;
776 opts->x_flag_reorder_blocks = 1;
779 if (opts->x_flag_reorder_blocks_and_partition
780 && !opts_set->x_flag_reorder_functions)
781 opts->x_flag_reorder_functions = 1;
783 /* Pipelining of outer loops is only possible when general pipelining
784 capabilities are requested. */
785 if (!opts->x_flag_sel_sched_pipelining)
786 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
788 if (opts->x_flag_conserve_stack)
790 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
791 opts->x_param_values, opts_set->x_param_values);
792 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
793 opts->x_param_values, opts_set->x_param_values);
796 if (opts->x_flag_lto)
798 #ifdef ENABLE_LTO
799 opts->x_flag_generate_lto = 1;
801 /* When generating IL, do not operate in whole-program mode.
802 Otherwise, symbols will be privatized too early, causing link
803 errors later. */
804 opts->x_flag_whole_program = 0;
805 #else
806 error_at (loc, "LTO support has not been enabled in this configuration");
807 #endif
808 if (!opts->x_flag_fat_lto_objects && !HAVE_LTO_PLUGIN)
809 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin.");
811 if ((opts->x_flag_lto_partition_balanced != 0) + (opts->x_flag_lto_partition_1to1 != 0)
812 + (opts->x_flag_lto_partition_none != 0) >= 1)
814 if ((opts->x_flag_lto_partition_balanced != 0)
815 + (opts->x_flag_lto_partition_1to1 != 0)
816 + (opts->x_flag_lto_partition_none != 0) > 1)
817 error_at (loc, "only one -flto-partition value can be specified");
820 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
821 default value if they choose based on other options. */
822 if (opts->x_flag_split_stack == -1)
823 opts->x_flag_split_stack = 0;
824 else if (opts->x_flag_split_stack)
826 if (!targetm_common.supports_split_stack (true, opts))
828 error_at (loc, "%<-fsplit-stack%> is not supported by "
829 "this compiler configuration");
830 opts->x_flag_split_stack = 0;
834 /* Tune vectorization related parametees according to cost model. */
835 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
837 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
838 6, opts->x_param_values, opts_set->x_param_values);
839 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
840 0, opts->x_param_values, opts_set->x_param_values);
841 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
842 0, opts->x_param_values, opts_set->x_param_values);
845 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
846 is disabled. */
847 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
848 || !opts->x_flag_tree_loop_if_convert)
849 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
850 opts->x_param_values, opts_set->x_param_values);
852 /* The -gsplit-dwarf option requires -gpubnames. */
853 if (opts->x_dwarf_split_debug_info)
854 opts->x_debug_generate_pub_sections = 1;
857 #define LEFT_COLUMN 27
859 /* Output ITEM, of length ITEM_WIDTH, in the left column,
860 followed by word-wrapped HELP in a second column. */
861 static void
862 wrap_help (const char *help,
863 const char *item,
864 unsigned int item_width,
865 unsigned int columns)
867 unsigned int col_width = LEFT_COLUMN;
868 unsigned int remaining, room, len;
870 remaining = strlen (help);
874 room = columns - 3 - MAX (col_width, item_width);
875 if (room > columns)
876 room = 0;
877 len = remaining;
879 if (room < len)
881 unsigned int i;
883 for (i = 0; help[i]; i++)
885 if (i >= room && len != remaining)
886 break;
887 if (help[i] == ' ')
888 len = i;
889 else if ((help[i] == '-' || help[i] == '/')
890 && help[i + 1] != ' '
891 && i > 0 && ISALPHA (help[i - 1]))
892 len = i + 1;
896 printf (" %-*.*s %.*s\n", col_width, item_width, item, len, help);
897 item_width = 0;
898 while (help[len] == ' ')
899 len++;
900 help += len;
901 remaining -= len;
903 while (remaining);
906 /* Print help for a specific front-end, etc. */
907 static void
908 print_filtered_help (unsigned int include_flags,
909 unsigned int exclude_flags,
910 unsigned int any_flags,
911 unsigned int columns,
912 struct gcc_options *opts,
913 unsigned int lang_mask)
915 unsigned int i;
916 const char *help;
917 bool found = false;
918 bool displayed = false;
920 if (include_flags == CL_PARAMS)
922 for (i = 0; i < LAST_PARAM; i++)
924 const char *param = compiler_params[i].option;
926 help = compiler_params[i].help;
927 if (help == NULL || *help == '\0')
929 if (exclude_flags & CL_UNDOCUMENTED)
930 continue;
931 help = undocumented_msg;
934 /* Get the translation. */
935 help = _(help);
937 wrap_help (help, param, strlen (param), columns);
939 putchar ('\n');
940 return;
943 if (!opts->x_help_printed)
944 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
946 if (!opts->x_help_enum_printed)
947 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
949 for (i = 0; i < cl_options_count; i++)
951 char new_help[128];
952 const struct cl_option *option = cl_options + i;
953 unsigned int len;
954 const char *opt;
955 const char *tab;
957 if (include_flags == 0
958 || ((option->flags & include_flags) != include_flags))
960 if ((option->flags & any_flags) == 0)
961 continue;
964 /* Skip unwanted switches. */
965 if ((option->flags & exclude_flags) != 0)
966 continue;
968 /* The driver currently prints its own help text. */
969 if ((option->flags & CL_DRIVER) != 0
970 && (option->flags & (((1U << cl_lang_count) - 1)
971 | CL_COMMON | CL_TARGET)) == 0)
972 continue;
974 found = true;
975 /* Skip switches that have already been printed. */
976 if (opts->x_help_printed[i])
977 continue;
979 opts->x_help_printed[i] = true;
981 help = option->help;
982 if (help == NULL)
984 if (exclude_flags & CL_UNDOCUMENTED)
985 continue;
986 help = undocumented_msg;
989 /* Get the translation. */
990 help = _(help);
992 /* Find the gap between the name of the
993 option and its descriptive text. */
994 tab = strchr (help, '\t');
995 if (tab)
997 len = tab - help;
998 opt = help;
999 help = tab + 1;
1001 else
1003 opt = option->opt_text;
1004 len = strlen (opt);
1007 /* With the -Q option enabled we change the descriptive text associated
1008 with an option to be an indication of its current setting. */
1009 if (!opts->x_quiet_flag)
1011 void *flag_var = option_flag_var (i, opts);
1013 if (len < (LEFT_COLUMN + 2))
1014 strcpy (new_help, "\t\t");
1015 else
1016 strcpy (new_help, "\t");
1018 if (flag_var != NULL
1019 && option->var_type != CLVC_DEFER)
1021 if (option->flags & CL_JOINED)
1023 if (option->var_type == CLVC_STRING)
1025 if (* (const char **) flag_var != NULL)
1026 snprintf (new_help + strlen (new_help),
1027 sizeof (new_help) - strlen (new_help),
1028 * (const char **) flag_var);
1030 else if (option->var_type == CLVC_ENUM)
1032 const struct cl_enum *e = &cl_enums[option->var_enum];
1033 int value;
1034 const char *arg = NULL;
1036 value = e->get (flag_var);
1037 enum_value_to_arg (e->values, &arg, value, lang_mask);
1038 if (arg == NULL)
1039 arg = _("[default]");
1040 snprintf (new_help + strlen (new_help),
1041 sizeof (new_help) - strlen (new_help),
1042 arg);
1044 else
1045 sprintf (new_help + strlen (new_help),
1046 "%#x", * (int *) flag_var);
1048 else
1049 strcat (new_help, option_enabled (i, opts)
1050 ? _("[enabled]") : _("[disabled]"));
1053 help = new_help;
1056 wrap_help (help, opt, len, columns);
1057 displayed = true;
1059 if (option->var_type == CLVC_ENUM
1060 && opts->x_help_enum_printed[option->var_enum] != 2)
1061 opts->x_help_enum_printed[option->var_enum] = 1;
1064 if (! found)
1066 unsigned int langs = include_flags & CL_LANG_ALL;
1068 if (langs == 0)
1069 printf (_(" No options with the desired characteristics were found\n"));
1070 else
1072 unsigned int i;
1074 /* PR 31349: Tell the user how to see all of the
1075 options supported by a specific front end. */
1076 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1077 if ((1U << i) & langs)
1078 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end\n"),
1079 lang_names[i], lang_names[i]);
1083 else if (! displayed)
1084 printf (_(" All options with the desired characteristics have already been displayed\n"));
1086 putchar ('\n');
1088 /* Print details of enumerated option arguments, if those
1089 enumerations have help text headings provided. If no help text
1090 is provided, presume that the possible values are listed in the
1091 help text for the relevant options. */
1092 for (i = 0; i < cl_enums_count; i++)
1094 unsigned int j, pos;
1096 if (opts->x_help_enum_printed[i] != 1)
1097 continue;
1098 if (cl_enums[i].help == NULL)
1099 continue;
1100 printf (" %s\n ", _(cl_enums[i].help));
1101 pos = 4;
1102 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1104 unsigned int len = strlen (cl_enums[i].values[j].arg);
1106 if (pos > 4 && pos + 1 + len <= columns)
1108 printf (" %s", cl_enums[i].values[j].arg);
1109 pos += 1 + len;
1111 else
1113 if (pos > 4)
1115 printf ("\n ");
1116 pos = 4;
1118 printf ("%s", cl_enums[i].values[j].arg);
1119 pos += len;
1122 printf ("\n\n");
1123 opts->x_help_enum_printed[i] = 2;
1127 /* Display help for a specified type of option.
1128 The options must have ALL of the INCLUDE_FLAGS set
1129 ANY of the flags in the ANY_FLAGS set
1130 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1131 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1132 static void
1133 print_specific_help (unsigned int include_flags,
1134 unsigned int exclude_flags,
1135 unsigned int any_flags,
1136 struct gcc_options *opts,
1137 unsigned int lang_mask)
1139 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1140 const char * description = NULL;
1141 const char * descrip_extra = "";
1142 size_t i;
1143 unsigned int flag;
1145 /* Sanity check: Make sure that we do not have more
1146 languages than we have bits available to enumerate them. */
1147 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1149 /* If we have not done so already, obtain
1150 the desired maximum width of the output. */
1151 if (opts->x_help_columns == 0)
1153 const char *p;
1155 p = getenv ("COLUMNS");
1156 if (p != NULL)
1158 int value = atoi (p);
1160 if (value > 0)
1161 opts->x_help_columns = value;
1164 if (opts->x_help_columns == 0)
1165 /* Use a reasonable default. */
1166 opts->x_help_columns = 80;
1169 /* Decide upon the title for the options that we are going to display. */
1170 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1172 switch (flag & include_flags)
1174 case 0:
1175 case CL_DRIVER:
1176 break;
1178 case CL_TARGET:
1179 description = _("The following options are target specific");
1180 break;
1181 case CL_WARNING:
1182 description = _("The following options control compiler warning messages");
1183 break;
1184 case CL_OPTIMIZATION:
1185 description = _("The following options control optimizations");
1186 break;
1187 case CL_COMMON:
1188 description = _("The following options are language-independent");
1189 break;
1190 case CL_PARAMS:
1191 description = _("The --param option recognizes the following as parameters");
1192 break;
1193 default:
1194 if (i >= cl_lang_count)
1195 break;
1196 if (exclude_flags & all_langs_mask)
1197 description = _("The following options are specific to just the language ");
1198 else
1199 description = _("The following options are supported by the language ");
1200 descrip_extra = lang_names [i];
1201 break;
1205 if (description == NULL)
1207 if (any_flags == 0)
1209 if (include_flags & CL_UNDOCUMENTED)
1210 description = _("The following options are not documented");
1211 else if (include_flags & CL_SEPARATE)
1212 description = _("The following options take separate arguments");
1213 else if (include_flags & CL_JOINED)
1214 description = _("The following options take joined arguments");
1215 else
1217 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1218 include_flags);
1219 return;
1222 else
1224 if (any_flags & all_langs_mask)
1225 description = _("The following options are language-related");
1226 else
1227 description = _("The following options are language-independent");
1231 printf ("%s%s:\n", description, descrip_extra);
1232 print_filtered_help (include_flags, exclude_flags, any_flags,
1233 opts->x_help_columns, opts, lang_mask);
1236 /* Handle target- and language-independent options. Return zero to
1237 generate an "unknown option" message. Only options that need
1238 extra handling need to be listed here; if you simply want
1239 DECODED->value assigned to a variable, it happens automatically. */
1241 bool
1242 common_handle_option (struct gcc_options *opts,
1243 struct gcc_options *opts_set,
1244 const struct cl_decoded_option *decoded,
1245 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1246 location_t loc,
1247 const struct cl_option_handlers *handlers,
1248 diagnostic_context *dc)
1250 size_t scode = decoded->opt_index;
1251 const char *arg = decoded->arg;
1252 int value = decoded->value;
1253 enum opt_code code = (enum opt_code) scode;
1255 gcc_assert (decoded->canonical_option_num_elements <= 2);
1257 switch (code)
1259 case OPT__param:
1260 handle_param (opts, opts_set, loc, arg);
1261 break;
1263 case OPT__help:
1265 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1266 unsigned int undoc_mask;
1267 unsigned int i;
1269 if (lang_mask == CL_DRIVER)
1270 break;;
1272 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1274 : CL_UNDOCUMENTED);
1275 /* First display any single language specific options. */
1276 for (i = 0; i < cl_lang_count; i++)
1277 print_specific_help
1278 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1279 lang_mask);
1280 /* Next display any multi language specific options. */
1281 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1282 /* Then display any remaining, non-language options. */
1283 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1284 if (i != CL_DRIVER)
1285 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1286 opts->x_exit_after_options = true;
1287 break;
1290 case OPT__target_help:
1291 if (lang_mask == CL_DRIVER)
1292 break;
1294 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1295 opts->x_exit_after_options = true;
1296 break;
1298 case OPT__help_:
1300 const char * a = arg;
1301 unsigned int include_flags = 0;
1302 /* Note - by default we include undocumented options when listing
1303 specific classes. If you only want to see documented options
1304 then add ",^undocumented" to the --help= option. E.g.:
1306 --help=target,^undocumented */
1307 unsigned int exclude_flags = 0;
1309 if (lang_mask == CL_DRIVER)
1310 break;
1312 /* Walk along the argument string, parsing each word in turn.
1313 The format is:
1314 arg = [^]{word}[,{arg}]
1315 word = {optimizers|target|warnings|undocumented|
1316 params|common|<language>} */
1317 while (* a != 0)
1319 static const struct
1321 const char * string;
1322 unsigned int flag;
1324 specifics[] =
1326 { "optimizers", CL_OPTIMIZATION },
1327 { "target", CL_TARGET },
1328 { "warnings", CL_WARNING },
1329 { "undocumented", CL_UNDOCUMENTED },
1330 { "params", CL_PARAMS },
1331 { "joined", CL_JOINED },
1332 { "separate", CL_SEPARATE },
1333 { "common", CL_COMMON },
1334 { NULL, 0 }
1336 unsigned int * pflags;
1337 const char * comma;
1338 unsigned int lang_flag, specific_flag;
1339 unsigned int len;
1340 unsigned int i;
1342 if (* a == '^')
1344 ++ a;
1345 pflags = & exclude_flags;
1347 else
1348 pflags = & include_flags;
1350 comma = strchr (a, ',');
1351 if (comma == NULL)
1352 len = strlen (a);
1353 else
1354 len = comma - a;
1355 if (len == 0)
1357 a = comma + 1;
1358 continue;
1361 /* Check to see if the string matches an option class name. */
1362 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1363 if (strncasecmp (a, specifics[i].string, len) == 0)
1365 specific_flag = specifics[i].flag;
1366 break;
1369 /* Check to see if the string matches a language name.
1370 Note - we rely upon the alpha-sorted nature of the entries in
1371 the lang_names array, specifically that shorter names appear
1372 before their longer variants. (i.e. C before C++). That way
1373 when we are attempting to match --help=c for example we will
1374 match with C first and not C++. */
1375 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1376 if (strncasecmp (a, lang_names[i], len) == 0)
1378 lang_flag = 1U << i;
1379 break;
1382 if (specific_flag != 0)
1384 if (lang_flag == 0)
1385 * pflags |= specific_flag;
1386 else
1388 /* The option's argument matches both the start of a
1389 language name and the start of an option class name.
1390 We have a special case for when the user has
1391 specified "--help=c", but otherwise we have to issue
1392 a warning. */
1393 if (strncasecmp (a, "c", len) == 0)
1394 * pflags |= lang_flag;
1395 else
1396 warning_at (loc, 0,
1397 "--help argument %q.*s is ambiguous, "
1398 "please be more specific",
1399 len, a);
1402 else if (lang_flag != 0)
1403 * pflags |= lang_flag;
1404 else
1405 warning_at (loc, 0,
1406 "unrecognized argument to --help= option: %q.*s",
1407 len, a);
1409 if (comma == NULL)
1410 break;
1411 a = comma + 1;
1414 if (include_flags)
1415 print_specific_help (include_flags, exclude_flags, 0, opts,
1416 lang_mask);
1417 opts->x_exit_after_options = true;
1418 break;
1421 case OPT__version:
1422 if (lang_mask == CL_DRIVER)
1423 break;
1425 opts->x_exit_after_options = true;
1426 break;
1428 case OPT_fsanitize_:
1430 const char *p = arg;
1431 while (*p != 0)
1433 static const struct
1435 const char *const name;
1436 unsigned int flag;
1437 size_t len;
1438 } spec[] =
1440 { "address", SANITIZE_ADDRESS, sizeof "address" - 1 },
1441 { "thread", SANITIZE_THREAD, sizeof "thread" - 1 },
1442 { "shift", SANITIZE_SHIFT, sizeof "shift" - 1 },
1443 { "integer-divide-by-zero", SANITIZE_DIVIDE,
1444 sizeof "integer-divide-by-zero" - 1 },
1445 { "undefined", SANITIZE_UNDEFINED, sizeof "undefined" - 1 },
1446 { "unreachable", SANITIZE_UNREACHABLE,
1447 sizeof "unreachable" - 1 },
1448 { "vla-bound", SANITIZE_VLA, sizeof "vla-bound" - 1 },
1449 { NULL, 0, 0 }
1451 const char *comma;
1452 size_t len, i;
1453 bool found = false;
1455 comma = strchr (p, ',');
1456 if (comma == NULL)
1457 len = strlen (p);
1458 else
1459 len = comma - p;
1460 if (len == 0)
1462 p = comma + 1;
1463 continue;
1466 /* Check to see if the string matches an option class name. */
1467 for (i = 0; spec[i].name != NULL; ++i)
1468 if (len == spec[i].len
1469 && memcmp (p, spec[i].name, len) == 0)
1471 /* Handle both -fsanitize and -fno-sanitize cases. */
1472 if (value)
1473 flag_sanitize |= spec[i].flag;
1474 else
1475 flag_sanitize &= ~spec[i].flag;
1476 found = true;
1477 break;
1480 if (! found)
1481 warning_at (loc, 0,
1482 "unrecognized argument to -fsanitize= option: %q.*s",
1483 (int) len, p);
1485 if (comma == NULL)
1486 break;
1487 p = comma + 1;
1490 break;
1493 case OPT_O:
1494 case OPT_Os:
1495 case OPT_Ofast:
1496 case OPT_Og:
1497 /* Currently handled in a prescan. */
1498 break;
1500 case OPT_Werror:
1501 dc->warning_as_error_requested = value;
1502 break;
1504 case OPT_Werror_:
1505 if (lang_mask == CL_DRIVER)
1506 break;
1508 enable_warning_as_error (arg, value, lang_mask, handlers,
1509 opts, opts_set, loc, dc);
1510 break;
1512 case OPT_Wlarger_than_:
1513 opts->x_larger_than_size = value;
1514 opts->x_warn_larger_than = value != -1;
1515 break;
1517 case OPT_Wfatal_errors:
1518 dc->fatal_errors = value;
1519 break;
1521 case OPT_Wframe_larger_than_:
1522 opts->x_frame_larger_than_size = value;
1523 opts->x_warn_frame_larger_than = value != -1;
1524 break;
1526 case OPT_Wstack_usage_:
1527 opts->x_warn_stack_usage = value;
1528 opts->x_flag_stack_usage_info = value != -1;
1529 break;
1531 case OPT_Wstrict_aliasing:
1532 set_Wstrict_aliasing (opts, value);
1533 break;
1535 case OPT_Wstrict_overflow:
1536 opts->x_warn_strict_overflow = (value
1537 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1538 : 0);
1539 break;
1541 case OPT_Wsystem_headers:
1542 dc->dc_warn_system_headers = value;
1543 break;
1545 case OPT_aux_info:
1546 opts->x_flag_gen_aux_info = 1;
1547 break;
1549 case OPT_auxbase_strip:
1551 char *tmp = xstrdup (arg);
1552 strip_off_ending (tmp, strlen (tmp));
1553 if (tmp[0])
1554 opts->x_aux_base_name = tmp;
1555 else
1556 free (tmp);
1558 break;
1560 case OPT_d:
1561 decode_d_option (arg, opts, loc, dc);
1562 break;
1564 case OPT_fcall_used_:
1565 case OPT_fcall_saved_:
1566 /* Deferred. */
1567 break;
1569 case OPT_fdbg_cnt_:
1570 case OPT_fdbg_cnt_list:
1571 /* Deferred. */
1572 break;
1574 case OPT_fdebug_prefix_map_:
1575 /* Deferred. */
1576 break;
1578 case OPT_fdiagnostics_show_location_:
1579 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1580 break;
1582 case OPT_fdiagnostics_show_caret:
1583 dc->show_caret = value;
1584 break;
1586 case OPT_fdiagnostics_color_:
1587 pp_show_color (dc->printer)
1588 = colorize_init ((diagnostic_color_rule_t) value);
1589 break;
1591 case OPT_fdiagnostics_show_option:
1592 dc->show_option_requested = value;
1593 break;
1595 case OPT_fdump_:
1596 /* Deferred. */
1597 break;
1599 case OPT_ffast_math:
1600 set_fast_math_flags (opts, value);
1601 break;
1603 case OPT_funsafe_math_optimizations:
1604 set_unsafe_math_optimizations_flags (opts, value);
1605 break;
1607 case OPT_ffixed_:
1608 /* Deferred. */
1609 break;
1611 case OPT_finline_limit_:
1612 set_param_value ("max-inline-insns-single", value / 2,
1613 opts->x_param_values, opts_set->x_param_values);
1614 set_param_value ("max-inline-insns-auto", value / 2,
1615 opts->x_param_values, opts_set->x_param_values);
1616 break;
1618 case OPT_finstrument_functions_exclude_function_list_:
1619 add_comma_separated_to_vector
1620 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1621 break;
1623 case OPT_finstrument_functions_exclude_file_list_:
1624 add_comma_separated_to_vector
1625 (&opts->x_flag_instrument_functions_exclude_files, arg);
1626 break;
1628 case OPT_fmessage_length_:
1629 pp_set_line_maximum_length (dc->printer, value);
1630 diagnostic_set_caret_max_width (dc, value);
1631 break;
1633 case OPT_fopt_info:
1634 case OPT_fopt_info_:
1635 /* Deferred. */
1636 break;
1638 case OPT_fpack_struct_:
1639 if (value <= 0 || (value & (value - 1)) || value > 16)
1640 error_at (loc,
1641 "structure alignment must be a small power of two, not %d",
1642 value);
1643 else
1644 opts->x_initial_max_fld_align = value;
1645 break;
1647 case OPT_fplugin_:
1648 case OPT_fplugin_arg_:
1649 /* Deferred. */
1650 break;
1652 case OPT_fprofile_use_:
1653 opts->x_profile_data_prefix = xstrdup (arg);
1654 opts->x_flag_profile_use = true;
1655 value = true;
1656 /* No break here - do -fprofile-use processing. */
1657 case OPT_fprofile_use:
1658 if (!opts_set->x_flag_branch_probabilities)
1659 opts->x_flag_branch_probabilities = value;
1660 if (!opts_set->x_flag_profile_values)
1661 opts->x_flag_profile_values = value;
1662 if (!opts_set->x_flag_unroll_loops)
1663 opts->x_flag_unroll_loops = value;
1664 if (!opts_set->x_flag_peel_loops)
1665 opts->x_flag_peel_loops = value;
1666 if (!opts_set->x_flag_tracer)
1667 opts->x_flag_tracer = value;
1668 if (!opts_set->x_flag_value_profile_transformations)
1669 opts->x_flag_value_profile_transformations = value;
1670 if (!opts_set->x_flag_inline_functions)
1671 opts->x_flag_inline_functions = value;
1672 if (!opts_set->x_flag_ipa_cp)
1673 opts->x_flag_ipa_cp = value;
1674 if (!opts_set->x_flag_ipa_cp_clone
1675 && value && opts->x_flag_ipa_cp)
1676 opts->x_flag_ipa_cp_clone = value;
1677 if (!opts_set->x_flag_predictive_commoning)
1678 opts->x_flag_predictive_commoning = value;
1679 if (!opts_set->x_flag_unswitch_loops)
1680 opts->x_flag_unswitch_loops = value;
1681 if (!opts_set->x_flag_gcse_after_reload)
1682 opts->x_flag_gcse_after_reload = value;
1683 if (!opts_set->x_flag_tree_loop_vectorize
1684 && !opts_set->x_flag_tree_vectorize)
1685 opts->x_flag_tree_loop_vectorize = value;
1686 if (!opts_set->x_flag_tree_slp_vectorize
1687 && !opts_set->x_flag_tree_vectorize)
1688 opts->x_flag_tree_slp_vectorize = value;
1689 if (!opts_set->x_flag_vect_cost_model)
1690 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1691 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1692 opts->x_flag_tree_loop_distribute_patterns = value;
1693 /* Indirect call profiling should do all useful transformations
1694 speculative devirutalization does. */
1695 if (!opts_set->x_flag_devirtualize_speculatively
1696 && opts->x_flag_value_profile_transformations)
1697 opts->x_flag_devirtualize_speculatively = false;
1698 break;
1700 case OPT_fprofile_generate_:
1701 opts->x_profile_data_prefix = xstrdup (arg);
1702 value = true;
1703 /* No break here - do -fprofile-generate processing. */
1704 case OPT_fprofile_generate:
1705 if (!opts_set->x_profile_arc_flag)
1706 opts->x_profile_arc_flag = value;
1707 if (!opts_set->x_flag_profile_values)
1708 opts->x_flag_profile_values = value;
1709 if (!opts_set->x_flag_inline_functions)
1710 opts->x_flag_inline_functions = value;
1711 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1712 quadratic. Disable the pass until better memory representation
1713 is done. */
1714 if (!opts_set->x_flag_ipa_reference && opts->x_in_lto_p)
1715 opts->x_flag_ipa_reference = false;
1716 break;
1718 case OPT_ftree_vectorize:
1719 if (!opts_set->x_flag_tree_loop_vectorize)
1720 opts->x_flag_tree_loop_vectorize = value;
1721 if (!opts_set->x_flag_tree_slp_vectorize)
1722 opts->x_flag_tree_slp_vectorize = value;
1723 break;
1724 case OPT_fshow_column:
1725 dc->show_column = value;
1726 break;
1728 case OPT_frandom_seed:
1729 /* The real switch is -fno-random-seed. */
1730 if (value)
1731 return false;
1732 /* Deferred. */
1733 break;
1735 case OPT_frandom_seed_:
1736 /* Deferred. */
1737 break;
1739 case OPT_fsched_verbose_:
1740 #ifdef INSN_SCHEDULING
1741 /* Handled with Var in common.opt. */
1742 break;
1743 #else
1744 return false;
1745 #endif
1747 case OPT_fsched_stalled_insns_:
1748 opts->x_flag_sched_stalled_insns = value;
1749 if (opts->x_flag_sched_stalled_insns == 0)
1750 opts->x_flag_sched_stalled_insns = -1;
1751 break;
1753 case OPT_fsched_stalled_insns_dep_:
1754 opts->x_flag_sched_stalled_insns_dep = value;
1755 break;
1757 case OPT_fstack_check_:
1758 if (!strcmp (arg, "no"))
1759 opts->x_flag_stack_check = NO_STACK_CHECK;
1760 else if (!strcmp (arg, "generic"))
1761 /* This is the old stack checking method. */
1762 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1763 ? FULL_BUILTIN_STACK_CHECK
1764 : GENERIC_STACK_CHECK;
1765 else if (!strcmp (arg, "specific"))
1766 /* This is the new stack checking method. */
1767 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1768 ? FULL_BUILTIN_STACK_CHECK
1769 : STACK_CHECK_STATIC_BUILTIN
1770 ? STATIC_BUILTIN_STACK_CHECK
1771 : GENERIC_STACK_CHECK;
1772 else
1773 warning_at (loc, 0, "unknown stack check parameter \"%s\"", arg);
1774 break;
1776 case OPT_fstack_limit:
1777 /* The real switch is -fno-stack-limit. */
1778 if (value)
1779 return false;
1780 /* Deferred. */
1781 break;
1783 case OPT_fstack_limit_register_:
1784 case OPT_fstack_limit_symbol_:
1785 /* Deferred. */
1786 break;
1788 case OPT_fstack_usage:
1789 opts->x_flag_stack_usage = value;
1790 opts->x_flag_stack_usage_info = value != 0;
1791 break;
1793 case OPT_g:
1794 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
1795 loc);
1796 break;
1798 case OPT_gcoff:
1799 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
1800 break;
1802 case OPT_gdwarf:
1803 if (arg && strlen (arg) != 0)
1805 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
1806 "use %<-gdwarf-%s%> for DWARF version "
1807 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
1808 break;
1810 else
1811 value = opts->x_dwarf_version;
1813 /* FALLTHRU */
1814 case OPT_gdwarf_:
1815 if (value < 2 || value > 4)
1816 error_at (loc, "dwarf version %d is not supported", value);
1817 else
1818 opts->x_dwarf_version = value;
1819 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
1820 break;
1822 case OPT_gsplit_dwarf:
1823 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
1824 loc);
1825 break;
1827 case OPT_ggdb:
1828 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
1829 break;
1831 case OPT_gstabs:
1832 case OPT_gstabs_:
1833 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
1834 loc);
1835 break;
1837 case OPT_gvms:
1838 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
1839 break;
1841 case OPT_gxcoff:
1842 case OPT_gxcoff_:
1843 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
1844 loc);
1845 break;
1847 case OPT_pedantic_errors:
1848 dc->pedantic_errors = 1;
1849 control_warning_option (OPT_Wpedantic, DK_ERROR, value,
1850 loc, lang_mask,
1851 handlers, opts, opts_set,
1852 dc);
1853 break;
1855 case OPT_flto:
1856 opts->x_flag_lto = value ? "" : NULL;
1857 break;
1859 case OPT_w:
1860 dc->dc_inhibit_warnings = true;
1861 break;
1863 case OPT_fmax_errors_:
1864 dc->max_errors = value;
1865 break;
1867 case OPT_fuse_ld_bfd:
1868 case OPT_fuse_ld_gold:
1869 case OPT_fuse_linker_plugin:
1870 /* No-op. Used by the driver and passed to us because it starts with f.*/
1871 break;
1873 case OPT_fwrapv:
1874 if (value)
1875 opts->x_flag_trapv = 0;
1876 break;
1878 case OPT_ftrapv:
1879 if (value)
1880 opts->x_flag_wrapv = 0;
1881 break;
1883 default:
1884 /* If the flag was handled in a standard way, assume the lack of
1885 processing here is intentional. */
1886 gcc_assert (option_flag_var (scode, opts));
1887 break;
1890 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
1891 loc, handlers, dc);
1892 return true;
1895 /* Handle --param NAME=VALUE. */
1896 static void
1897 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
1898 location_t loc, const char *carg)
1900 char *equal, *arg;
1901 int value;
1903 arg = xstrdup (carg);
1904 equal = strchr (arg, '=');
1905 if (!equal)
1906 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
1907 arg);
1908 else
1910 value = integral_argument (equal + 1);
1911 if (value == -1)
1912 error_at (loc, "invalid --param value %qs", equal + 1);
1913 else
1915 *equal = '\0';
1916 set_param_value (arg, value,
1917 opts->x_param_values, opts_set->x_param_values);
1921 free (arg);
1924 /* Used to set the level of strict aliasing warnings in OPTS,
1925 when no level is specified (i.e., when -Wstrict-aliasing, and not
1926 -Wstrict-aliasing=level was given).
1927 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
1928 and 0 otherwise. After calling this function, wstrict_aliasing will be
1929 set to the default value of -Wstrict_aliasing=level, currently 3. */
1930 static void
1931 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
1933 gcc_assert (onoff == 0 || onoff == 1);
1934 if (onoff != 0)
1935 opts->x_warn_strict_aliasing = 3;
1936 else
1937 opts->x_warn_strict_aliasing = 0;
1940 /* The following routines are useful in setting all the flags that
1941 -ffast-math and -fno-fast-math imply. */
1942 static void
1943 set_fast_math_flags (struct gcc_options *opts, int set)
1945 if (!opts->frontend_set_flag_unsafe_math_optimizations)
1947 opts->x_flag_unsafe_math_optimizations = set;
1948 set_unsafe_math_optimizations_flags (opts, set);
1950 if (!opts->frontend_set_flag_finite_math_only)
1951 opts->x_flag_finite_math_only = set;
1952 if (!opts->frontend_set_flag_errno_math)
1953 opts->x_flag_errno_math = !set;
1954 if (set)
1956 if (!opts->frontend_set_flag_signaling_nans)
1957 opts->x_flag_signaling_nans = 0;
1958 if (!opts->frontend_set_flag_rounding_math)
1959 opts->x_flag_rounding_math = 0;
1960 if (!opts->frontend_set_flag_cx_limited_range)
1961 opts->x_flag_cx_limited_range = 1;
1965 /* When -funsafe-math-optimizations is set the following
1966 flags are set as well. */
1967 static void
1968 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
1970 if (!opts->frontend_set_flag_trapping_math)
1971 opts->x_flag_trapping_math = !set;
1972 if (!opts->frontend_set_flag_signed_zeros)
1973 opts->x_flag_signed_zeros = !set;
1974 if (!opts->frontend_set_flag_associative_math)
1975 opts->x_flag_associative_math = set;
1976 if (!opts->frontend_set_flag_reciprocal_math)
1977 opts->x_flag_reciprocal_math = set;
1980 /* Return true iff flags in OPTS are set as if -ffast-math. */
1981 bool
1982 fast_math_flags_set_p (const struct gcc_options *opts)
1984 return (!opts->x_flag_trapping_math
1985 && opts->x_flag_unsafe_math_optimizations
1986 && opts->x_flag_finite_math_only
1987 && !opts->x_flag_signed_zeros
1988 && !opts->x_flag_errno_math);
1991 /* Return true iff flags are set as if -ffast-math but using the flags stored
1992 in the struct cl_optimization structure. */
1993 bool
1994 fast_math_flags_struct_set_p (struct cl_optimization *opt)
1996 return (!opt->x_flag_trapping_math
1997 && opt->x_flag_unsafe_math_optimizations
1998 && opt->x_flag_finite_math_only
1999 && !opt->x_flag_signed_zeros
2000 && !opt->x_flag_errno_math);
2003 /* Handle a debug output -g switch for options OPTS
2004 (OPTS_SET->x_write_symbols storing whether a debug type was passed
2005 explicitly), location LOC. EXTENDED is true or false to support
2006 extended output (2 is special and means "-ggdb" was given). */
2007 static void
2008 set_debug_level (enum debug_info_type type, int extended, const char *arg,
2009 struct gcc_options *opts, struct gcc_options *opts_set,
2010 location_t loc)
2012 opts->x_use_gnu_debug_info_extensions = extended;
2014 if (type == NO_DEBUG)
2016 if (opts->x_write_symbols == NO_DEBUG)
2018 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
2020 if (extended == 2)
2022 #ifdef DWARF2_DEBUGGING_INFO
2023 opts->x_write_symbols = DWARF2_DEBUG;
2024 #elif defined DBX_DEBUGGING_INFO
2025 opts->x_write_symbols = DBX_DEBUG;
2026 #endif
2029 if (opts->x_write_symbols == NO_DEBUG)
2030 warning_at (loc, 0, "target system does not support debug output");
2033 else
2035 /* Does it conflict with an already selected type? */
2036 if (opts_set->x_write_symbols != NO_DEBUG
2037 && opts->x_write_symbols != NO_DEBUG
2038 && type != opts->x_write_symbols)
2039 error_at (loc, "debug format \"%s\" conflicts with prior selection",
2040 debug_type_names[type]);
2041 opts->x_write_symbols = type;
2042 opts_set->x_write_symbols = type;
2045 /* A debug flag without a level defaults to level 2. */
2046 if (*arg == '\0')
2048 if (!opts->x_debug_info_level)
2049 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2051 else
2053 int argval = integral_argument (arg);
2054 if (argval == -1)
2055 error_at (loc, "unrecognised debug output level \"%s\"", arg);
2056 else if (argval > 3)
2057 error_at (loc, "debug output level %s is too high", arg);
2058 else
2059 opts->x_debug_info_level = (enum debug_info_levels) argval;
2063 /* Arrange to dump core on error for diagnostic context DC. (The
2064 regular error message is still printed first, except in the case of
2065 abort ().) */
2067 static void
2068 setup_core_dumping (diagnostic_context *dc)
2070 #ifdef SIGABRT
2071 signal (SIGABRT, SIG_DFL);
2072 #endif
2073 #if defined(HAVE_SETRLIMIT)
2075 struct rlimit rlim;
2076 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2077 fatal_error ("getting core file size maximum limit: %m");
2078 rlim.rlim_cur = rlim.rlim_max;
2079 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2080 fatal_error ("setting core file size limit to maximum: %m");
2082 #endif
2083 diagnostic_abort_on_error (dc);
2086 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2087 diagnostic context DC. */
2089 static void
2090 decode_d_option (const char *arg, struct gcc_options *opts,
2091 location_t loc, diagnostic_context *dc)
2093 int c;
2095 while (*arg)
2096 switch (c = *arg++)
2098 case 'A':
2099 opts->x_flag_debug_asm = 1;
2100 break;
2101 case 'p':
2102 opts->x_flag_print_asm_name = 1;
2103 break;
2104 case 'P':
2105 opts->x_flag_dump_rtl_in_asm = 1;
2106 opts->x_flag_print_asm_name = 1;
2107 break;
2108 case 'x':
2109 opts->x_rtl_dump_and_exit = 1;
2110 break;
2111 case 'D': /* These are handled by the preprocessor. */
2112 case 'I':
2113 case 'M':
2114 case 'N':
2115 case 'U':
2116 break;
2117 case 'H':
2118 setup_core_dumping (dc);
2119 break;
2120 case 'a':
2121 opts->x_flag_dump_all_passed = true;
2122 break;
2124 default:
2125 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2126 break;
2130 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2131 mask LANG_MASK, option handlers HANDLERS) as an error for option
2132 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2133 NULL), location LOC. This is used by -Werror=. */
2135 static void
2136 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2137 const struct cl_option_handlers *handlers,
2138 struct gcc_options *opts,
2139 struct gcc_options *opts_set,
2140 location_t loc, diagnostic_context *dc)
2142 char *new_option;
2143 int option_index;
2145 new_option = XNEWVEC (char, strlen (arg) + 2);
2146 new_option[0] = 'W';
2147 strcpy (new_option + 1, arg);
2148 option_index = find_opt (new_option, lang_mask);
2149 if (option_index == OPT_SPECIAL_unknown)
2151 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2153 else
2155 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2157 control_warning_option (option_index, (int) kind, value,
2158 loc, lang_mask,
2159 handlers, opts, opts_set, dc);
2161 free (new_option);
2164 /* Return malloced memory for the name of the option OPTION_INDEX
2165 which enabled a diagnostic (context CONTEXT), originally of type
2166 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2167 as -Werror. */
2169 char *
2170 option_name (diagnostic_context *context, int option_index,
2171 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2173 if (option_index)
2175 /* A warning classified as an error. */
2176 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2177 && diag_kind == DK_ERROR)
2178 return concat (cl_options[OPT_Werror_].opt_text,
2179 /* Skip over "-W". */
2180 cl_options[option_index].opt_text + 2,
2181 NULL);
2182 /* A warning with option. */
2183 else
2184 return xstrdup (cl_options[option_index].opt_text);
2186 /* A warning without option classified as an error. */
2187 else if (orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2188 || diag_kind == DK_WARNING)
2190 if (context->warning_as_error_requested)
2191 return xstrdup (cl_options[OPT_Werror].opt_text);
2192 else
2193 return xstrdup (_("enabled by default"));
2195 else
2196 return NULL;