vectorizer cost model enhancement
[official-gcc.git] / gcc / opts.c
blobb1fadb162328121290ab69d33e0815a27cc5d0db
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;
282 memset (opts_set, 0, sizeof (*opts_set));
284 opts->x_param_values = XNEWVEC (int, num_params);
285 opts_set->x_param_values = XCNEWVEC (int, num_params);
286 init_param_values (opts->x_param_values);
288 /* Initialize whether `char' is signed. */
289 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
290 /* Set this to a special "uninitialized" value. The actual default
291 is set after target options have been processed. */
292 opts->x_flag_short_enums = 2;
294 /* Initialize target_flags before default_options_optimization
295 so the latter can modify it. */
296 opts->x_target_flags = targetm_common.default_target_flags;
298 /* Some targets have ABI-specified unwind tables. */
299 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
301 /* Some targets have other target-specific initialization. */
302 targetm_common.option_init_struct (opts);
305 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
306 -Ofast if FAST is set, -Og if DEBUG is set), apply the option DEFAULT_OPT
307 to OPTS and OPTS_SET, diagnostic context DC, location LOC, with language
308 mask LANG_MASK and option handlers HANDLERS. */
310 static void
311 maybe_default_option (struct gcc_options *opts,
312 struct gcc_options *opts_set,
313 const struct default_options *default_opt,
314 int level, bool size, bool fast, bool debug,
315 unsigned int lang_mask,
316 const struct cl_option_handlers *handlers,
317 location_t loc,
318 diagnostic_context *dc)
320 const struct cl_option *option = &cl_options[default_opt->opt_index];
321 bool enabled;
323 if (size)
324 gcc_assert (level == 2);
325 if (fast)
326 gcc_assert (level == 3);
327 if (debug)
328 gcc_assert (level == 1);
330 switch (default_opt->levels)
332 case OPT_LEVELS_ALL:
333 enabled = true;
334 break;
336 case OPT_LEVELS_0_ONLY:
337 enabled = (level == 0);
338 break;
340 case OPT_LEVELS_1_PLUS:
341 enabled = (level >= 1);
342 break;
344 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
345 enabled = (level >= 1 && !size && !debug);
346 break;
348 case OPT_LEVELS_1_PLUS_NOT_DEBUG:
349 enabled = (level >= 1 && !debug);
350 break;
352 case OPT_LEVELS_2_PLUS:
353 enabled = (level >= 2);
354 break;
356 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
357 enabled = (level >= 2 && !size && !debug);
358 break;
360 case OPT_LEVELS_3_PLUS:
361 enabled = (level >= 3);
362 break;
364 case OPT_LEVELS_3_PLUS_AND_SIZE:
365 enabled = (level >= 3 || size);
366 break;
368 case OPT_LEVELS_SIZE:
369 enabled = size;
370 break;
372 case OPT_LEVELS_FAST:
373 enabled = fast;
374 break;
376 case OPT_LEVELS_NONE:
377 default:
378 gcc_unreachable ();
381 if (enabled)
382 handle_generated_option (opts, opts_set, default_opt->opt_index,
383 default_opt->arg, default_opt->value,
384 lang_mask, DK_UNSPECIFIED, loc,
385 handlers, dc);
386 else if (default_opt->arg == NULL
387 && !option->cl_reject_negative)
388 handle_generated_option (opts, opts_set, default_opt->opt_index,
389 default_opt->arg, !default_opt->value,
390 lang_mask, DK_UNSPECIFIED, loc,
391 handlers, dc);
394 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
395 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
396 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
397 language mask LANG_MASK and option handlers HANDLERS. */
399 static void
400 maybe_default_options (struct gcc_options *opts,
401 struct gcc_options *opts_set,
402 const struct default_options *default_opts,
403 int level, bool size, bool fast, bool debug,
404 unsigned int lang_mask,
405 const struct cl_option_handlers *handlers,
406 location_t loc,
407 diagnostic_context *dc)
409 size_t i;
411 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
412 maybe_default_option (opts, opts_set, &default_opts[i],
413 level, size, fast, debug,
414 lang_mask, handlers, loc, dc);
417 /* Table of options enabled by default at different levels. */
419 static const struct default_options default_options_table[] =
421 /* -O1 optimizations. */
422 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
423 #ifdef DELAY_SLOTS
424 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
425 #endif
426 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
427 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
428 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
429 { OPT_LEVELS_1_PLUS, OPT_fif_conversion, NULL, 1 },
430 { OPT_LEVELS_1_PLUS, OPT_fif_conversion2, NULL, 1 },
431 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
432 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
433 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
434 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
435 { OPT_LEVELS_1_PLUS, OPT_fshrink_wrap, NULL, 1 },
436 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
437 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
438 { OPT_LEVELS_1_PLUS, OPT_ftree_bit_ccp, NULL, 1 },
439 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
440 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
441 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
442 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
443 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_sra, NULL, 1 },
444 { OPT_LEVELS_1_PLUS, OPT_ftree_copyrename, NULL, 1 },
445 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
446 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
447 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
448 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
449 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
450 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
451 { OPT_LEVELS_1_PLUS, OPT_ftree_slsr, NULL, 1 },
453 /* -O2 optimizations. */
454 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
455 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
456 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
457 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
458 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
459 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
460 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
461 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
462 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
463 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
464 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
465 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
466 #ifdef INSN_SCHEDULING
467 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
468 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
469 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
470 #endif
471 { OPT_LEVELS_2_PLUS, OPT_fregmove, NULL, 1 },
472 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
473 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
474 { OPT_LEVELS_2_PLUS, OPT_freorder_blocks, NULL, 1 },
475 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
476 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
477 { OPT_LEVELS_2_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
478 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
479 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
480 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
481 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
482 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
483 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
484 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
488 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
489 { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
490 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
491 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
493 /* -O3 optimizations. */
494 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
495 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
496 /* Inlining of functions reducing size is a good idea with -Os
497 regardless of them being declared inline. */
498 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
499 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
500 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
501 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
502 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
503 { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
504 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
505 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
506 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
508 /* -Ofast adds optimizations to -O3. */
509 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
511 { OPT_LEVELS_NONE, 0, NULL, 0 }
514 /* Default the options in OPTS and OPTS_SET based on the optimization
515 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
516 void
517 default_options_optimization (struct gcc_options *opts,
518 struct gcc_options *opts_set,
519 struct cl_decoded_option *decoded_options,
520 unsigned int decoded_options_count,
521 location_t loc,
522 unsigned int lang_mask,
523 const struct cl_option_handlers *handlers,
524 diagnostic_context *dc)
526 unsigned int i;
527 int opt2;
529 /* Scan to see what optimization level has been specified. That will
530 determine the default value of many flags. */
531 for (i = 1; i < decoded_options_count; i++)
533 struct cl_decoded_option *opt = &decoded_options[i];
534 switch (opt->opt_index)
536 case OPT_O:
537 if (*opt->arg == '\0')
539 opts->x_optimize = 1;
540 opts->x_optimize_size = 0;
541 opts->x_optimize_fast = 0;
542 opts->x_optimize_debug = 0;
544 else
546 const int optimize_val = integral_argument (opt->arg);
547 if (optimize_val == -1)
548 error_at (loc, "argument to %<-O%> should be a non-negative "
549 "integer, %<g%>, %<s%> or %<fast%>");
550 else
552 opts->x_optimize = optimize_val;
553 if ((unsigned int) opts->x_optimize > 255)
554 opts->x_optimize = 255;
555 opts->x_optimize_size = 0;
556 opts->x_optimize_fast = 0;
557 opts->x_optimize_debug = 0;
560 break;
562 case OPT_Os:
563 opts->x_optimize_size = 1;
565 /* Optimizing for size forces optimize to be 2. */
566 opts->x_optimize = 2;
567 opts->x_optimize_fast = 0;
568 opts->x_optimize_debug = 0;
569 break;
571 case OPT_Ofast:
572 /* -Ofast only adds flags to -O3. */
573 opts->x_optimize_size = 0;
574 opts->x_optimize = 3;
575 opts->x_optimize_fast = 1;
576 opts->x_optimize_debug = 0;
577 break;
579 case OPT_Og:
580 /* -Og selects optimization level 1. */
581 opts->x_optimize_size = 0;
582 opts->x_optimize = 1;
583 opts->x_optimize_fast = 0;
584 opts->x_optimize_debug = 1;
585 break;
587 default:
588 /* Ignore other options in this prescan. */
589 break;
593 maybe_default_options (opts, opts_set, default_options_table,
594 opts->x_optimize, opts->x_optimize_size,
595 opts->x_optimize_fast, opts->x_optimize_debug,
596 lang_mask, handlers, loc, dc);
598 /* -O2 param settings. */
599 opt2 = (opts->x_optimize >= 2);
601 /* Track fields in field-sensitive alias analysis. */
602 maybe_set_param_value
603 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
604 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
605 opts->x_param_values, opts_set->x_param_values);
607 /* For -O1 only do loop invariant motion for very small loops. */
608 maybe_set_param_value
609 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
610 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
611 opts->x_param_values, opts_set->x_param_values);
613 if (opts->x_optimize_size)
614 /* We want to crossjump as much as possible. */
615 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
616 opts->x_param_values, opts_set->x_param_values);
617 else
618 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
619 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
620 opts->x_param_values, opts_set->x_param_values);
622 /* Allow default optimizations to be specified on a per-machine basis. */
623 maybe_default_options (opts, opts_set,
624 targetm_common.option_optimization_table,
625 opts->x_optimize, opts->x_optimize_size,
626 opts->x_optimize_fast, opts->x_optimize_debug,
627 lang_mask, handlers, loc, dc);
630 /* After all options at LOC have been read into OPTS and OPTS_SET,
631 finalize settings of those options and diagnose incompatible
632 combinations. */
633 void
634 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
635 location_t loc)
637 enum unwind_info_type ui_except;
639 if (opts->x_dump_base_name && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name))
641 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
642 OPTS->X_DUMP_DIR_NAME directory. Then try to make
643 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
644 directory, typically the directory to contain the object
645 file. */
646 if (opts->x_dump_dir_name)
647 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
648 opts->x_dump_base_name, NULL);
649 else if (opts->x_aux_base_name
650 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
652 const char *aux_base;
654 base_of_path (opts->x_aux_base_name, &aux_base);
655 if (opts->x_aux_base_name != aux_base)
657 int dir_len = aux_base - opts->x_aux_base_name;
658 char *new_dump_base_name
659 = XOBNEWVEC (&opts_obstack, char,
660 strlen (opts->x_dump_base_name) + dir_len + 1);
662 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
663 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
664 /* Append existing OPTS->X_DUMP_BASE_NAME. */
665 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
666 opts->x_dump_base_name = new_dump_base_name;
671 /* Handle related options for unit-at-a-time, toplevel-reorder, and
672 section-anchors. */
673 if (!opts->x_flag_unit_at_a_time)
675 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
676 error_at (loc, "section anchors must be disabled when unit-at-a-time "
677 "is disabled");
678 opts->x_flag_section_anchors = 0;
679 if (opts->x_flag_toplevel_reorder == 1)
680 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
681 "is disabled");
682 opts->x_flag_toplevel_reorder = 0;
685 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
686 sorry ("transactional memory is not supported with non-call exceptions");
688 /* Unless the user has asked for section anchors, we disable toplevel
689 reordering at -O0 to disable transformations that might be surprising
690 to end users and to get -fno-toplevel-reorder tested. */
691 if (!opts->x_optimize
692 && opts->x_flag_toplevel_reorder == 2
693 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
695 opts->x_flag_toplevel_reorder = 0;
696 opts->x_flag_section_anchors = 0;
698 if (!opts->x_flag_toplevel_reorder)
700 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
701 error_at (loc, "section anchors must be disabled when toplevel reorder"
702 " is disabled");
703 opts->x_flag_section_anchors = 0;
706 if (!opts->x_flag_opts_finished)
708 if (opts->x_flag_pie)
709 opts->x_flag_pic = opts->x_flag_pie;
710 if (opts->x_flag_pic && !opts->x_flag_pie)
711 opts->x_flag_shlib = 1;
712 opts->x_flag_opts_finished = true;
715 if (opts->x_optimize == 0)
717 /* Inlining does not work if not optimizing,
718 so force it not to be done. */
719 opts->x_warn_inline = 0;
720 opts->x_flag_no_inline = 1;
723 /* The optimization to partition hot and cold basic blocks into separate
724 sections of the .o and executable files does not work (currently)
725 with exception handling. This is because there is no support for
726 generating unwind info. If opts->x_flag_exceptions is turned on
727 we need to turn off the partitioning optimization. */
729 ui_except = targetm_common.except_unwind_info (opts);
731 if (opts->x_flag_exceptions
732 && opts->x_flag_reorder_blocks_and_partition
733 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
735 inform (loc,
736 "-freorder-blocks-and-partition does not work "
737 "with exceptions on this architecture");
738 opts->x_flag_reorder_blocks_and_partition = 0;
739 opts->x_flag_reorder_blocks = 1;
742 /* If user requested unwind info, then turn off the partitioning
743 optimization. */
745 if (opts->x_flag_unwind_tables
746 && !targetm_common.unwind_tables_default
747 && opts->x_flag_reorder_blocks_and_partition
748 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
750 inform (loc,
751 "-freorder-blocks-and-partition does not support "
752 "unwind info on this architecture");
753 opts->x_flag_reorder_blocks_and_partition = 0;
754 opts->x_flag_reorder_blocks = 1;
757 /* If the target requested unwind info, then turn off the partitioning
758 optimization with a different message. Likewise, if the target does not
759 support named sections. */
761 if (opts->x_flag_reorder_blocks_and_partition
762 && (!targetm_common.have_named_sections
763 || (opts->x_flag_unwind_tables
764 && targetm_common.unwind_tables_default
765 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
767 inform (loc,
768 "-freorder-blocks-and-partition does not work "
769 "on this architecture");
770 opts->x_flag_reorder_blocks_and_partition = 0;
771 opts->x_flag_reorder_blocks = 1;
774 if (opts->x_flag_reorder_blocks_and_partition
775 && !opts_set->x_flag_reorder_functions)
776 opts->x_flag_reorder_functions = 1;
778 /* Pipelining of outer loops is only possible when general pipelining
779 capabilities are requested. */
780 if (!opts->x_flag_sel_sched_pipelining)
781 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
783 if (opts->x_flag_conserve_stack)
785 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
786 opts->x_param_values, opts_set->x_param_values);
787 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
788 opts->x_param_values, opts_set->x_param_values);
791 if (opts->x_flag_lto)
793 #ifdef ENABLE_LTO
794 opts->x_flag_generate_lto = 1;
796 /* When generating IL, do not operate in whole-program mode.
797 Otherwise, symbols will be privatized too early, causing link
798 errors later. */
799 opts->x_flag_whole_program = 0;
800 #else
801 error_at (loc, "LTO support has not been enabled in this configuration");
802 #endif
803 if (!opts->x_flag_fat_lto_objects && !HAVE_LTO_PLUGIN)
804 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin.");
806 if ((opts->x_flag_lto_partition_balanced != 0) + (opts->x_flag_lto_partition_1to1 != 0)
807 + (opts->x_flag_lto_partition_none != 0) >= 1)
809 if ((opts->x_flag_lto_partition_balanced != 0)
810 + (opts->x_flag_lto_partition_1to1 != 0)
811 + (opts->x_flag_lto_partition_none != 0) > 1)
812 error_at (loc, "only one -flto-partition value can be specified");
815 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
816 default value if they choose based on other options. */
817 if (opts->x_flag_split_stack == -1)
818 opts->x_flag_split_stack = 0;
819 else if (opts->x_flag_split_stack)
821 if (!targetm_common.supports_split_stack (true, opts))
823 error_at (loc, "%<-fsplit-stack%> is not supported by "
824 "this compiler configuration");
825 opts->x_flag_split_stack = 0;
829 /* Tune vectorization related parametees according to cost model. */
830 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
832 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
833 6, opts->x_param_values, opts_set->x_param_values);
834 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
835 0, opts->x_param_values, opts_set->x_param_values);
836 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
837 0, opts->x_param_values, opts_set->x_param_values);
840 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
841 is disabled. */
842 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
843 || !opts->x_flag_tree_loop_if_convert)
844 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
845 opts->x_param_values, opts_set->x_param_values);
847 /* The -gsplit-dwarf option requires -gpubnames. */
848 if (opts->x_dwarf_split_debug_info)
849 opts->x_debug_generate_pub_sections = 1;
852 #define LEFT_COLUMN 27
854 /* Output ITEM, of length ITEM_WIDTH, in the left column,
855 followed by word-wrapped HELP in a second column. */
856 static void
857 wrap_help (const char *help,
858 const char *item,
859 unsigned int item_width,
860 unsigned int columns)
862 unsigned int col_width = LEFT_COLUMN;
863 unsigned int remaining, room, len;
865 remaining = strlen (help);
869 room = columns - 3 - MAX (col_width, item_width);
870 if (room > columns)
871 room = 0;
872 len = remaining;
874 if (room < len)
876 unsigned int i;
878 for (i = 0; help[i]; i++)
880 if (i >= room && len != remaining)
881 break;
882 if (help[i] == ' ')
883 len = i;
884 else if ((help[i] == '-' || help[i] == '/')
885 && help[i + 1] != ' '
886 && i > 0 && ISALPHA (help[i - 1]))
887 len = i + 1;
891 printf( " %-*.*s %.*s\n", col_width, item_width, item, len, help);
892 item_width = 0;
893 while (help[len] == ' ')
894 len++;
895 help += len;
896 remaining -= len;
898 while (remaining);
901 /* Print help for a specific front-end, etc. */
902 static void
903 print_filtered_help (unsigned int include_flags,
904 unsigned int exclude_flags,
905 unsigned int any_flags,
906 unsigned int columns,
907 struct gcc_options *opts,
908 unsigned int lang_mask)
910 unsigned int i;
911 const char *help;
912 bool found = false;
913 bool displayed = false;
915 if (include_flags == CL_PARAMS)
917 for (i = 0; i < LAST_PARAM; i++)
919 const char *param = compiler_params[i].option;
921 help = compiler_params[i].help;
922 if (help == NULL || *help == '\0')
924 if (exclude_flags & CL_UNDOCUMENTED)
925 continue;
926 help = undocumented_msg;
929 /* Get the translation. */
930 help = _(help);
932 wrap_help (help, param, strlen (param), columns);
934 putchar ('\n');
935 return;
938 if (!opts->x_help_printed)
939 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
941 if (!opts->x_help_enum_printed)
942 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
944 for (i = 0; i < cl_options_count; i++)
946 char new_help[128];
947 const struct cl_option *option = cl_options + i;
948 unsigned int len;
949 const char *opt;
950 const char *tab;
952 if (include_flags == 0
953 || ((option->flags & include_flags) != include_flags))
955 if ((option->flags & any_flags) == 0)
956 continue;
959 /* Skip unwanted switches. */
960 if ((option->flags & exclude_flags) != 0)
961 continue;
963 /* The driver currently prints its own help text. */
964 if ((option->flags & CL_DRIVER) != 0
965 && (option->flags & (((1U << cl_lang_count) - 1)
966 | CL_COMMON | CL_TARGET)) == 0)
967 continue;
969 found = true;
970 /* Skip switches that have already been printed. */
971 if (opts->x_help_printed[i])
972 continue;
974 opts->x_help_printed[i] = true;
976 help = option->help;
977 if (help == NULL)
979 if (exclude_flags & CL_UNDOCUMENTED)
980 continue;
981 help = undocumented_msg;
984 /* Get the translation. */
985 help = _(help);
987 /* Find the gap between the name of the
988 option and its descriptive text. */
989 tab = strchr (help, '\t');
990 if (tab)
992 len = tab - help;
993 opt = help;
994 help = tab + 1;
996 else
998 opt = option->opt_text;
999 len = strlen (opt);
1002 /* With the -Q option enabled we change the descriptive text associated
1003 with an option to be an indication of its current setting. */
1004 if (!opts->x_quiet_flag)
1006 void *flag_var = option_flag_var (i, opts);
1008 if (len < (LEFT_COLUMN + 2))
1009 strcpy (new_help, "\t\t");
1010 else
1011 strcpy (new_help, "\t");
1013 if (flag_var != NULL
1014 && option->var_type != CLVC_DEFER)
1016 if (option->flags & CL_JOINED)
1018 if (option->var_type == CLVC_STRING)
1020 if (* (const char **) flag_var != NULL)
1021 snprintf (new_help + strlen (new_help),
1022 sizeof (new_help) - strlen (new_help),
1023 * (const char **) flag_var);
1025 else if (option->var_type == CLVC_ENUM)
1027 const struct cl_enum *e = &cl_enums[option->var_enum];
1028 int value;
1029 const char *arg = NULL;
1031 value = e->get (flag_var);
1032 enum_value_to_arg (e->values, &arg, value, lang_mask);
1033 if (arg == NULL)
1034 arg = _("[default]");
1035 snprintf (new_help + strlen (new_help),
1036 sizeof (new_help) - strlen (new_help),
1037 arg);
1039 else
1040 sprintf (new_help + strlen (new_help),
1041 "%#x", * (int *) flag_var);
1043 else
1044 strcat (new_help, option_enabled (i, opts)
1045 ? _("[enabled]") : _("[disabled]"));
1048 help = new_help;
1051 wrap_help (help, opt, len, columns);
1052 displayed = true;
1054 if (option->var_type == CLVC_ENUM
1055 && opts->x_help_enum_printed[option->var_enum] != 2)
1056 opts->x_help_enum_printed[option->var_enum] = 1;
1059 if (! found)
1061 unsigned int langs = include_flags & CL_LANG_ALL;
1063 if (langs == 0)
1064 printf (_(" No options with the desired characteristics were found\n"));
1065 else
1067 unsigned int i;
1069 /* PR 31349: Tell the user how to see all of the
1070 options supported by a specific front end. */
1071 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1072 if ((1U << i) & langs)
1073 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end\n"),
1074 lang_names[i], lang_names[i]);
1078 else if (! displayed)
1079 printf (_(" All options with the desired characteristics have already been displayed\n"));
1081 putchar ('\n');
1083 /* Print details of enumerated option arguments, if those
1084 enumerations have help text headings provided. If no help text
1085 is provided, presume that the possible values are listed in the
1086 help text for the relevant options. */
1087 for (i = 0; i < cl_enums_count; i++)
1089 unsigned int j, pos;
1091 if (opts->x_help_enum_printed[i] != 1)
1092 continue;
1093 if (cl_enums[i].help == NULL)
1094 continue;
1095 printf (" %s\n ", _(cl_enums[i].help));
1096 pos = 4;
1097 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1099 unsigned int len = strlen (cl_enums[i].values[j].arg);
1101 if (pos > 4 && pos + 1 + len <= columns)
1103 printf (" %s", cl_enums[i].values[j].arg);
1104 pos += 1 + len;
1106 else
1108 if (pos > 4)
1110 printf ("\n ");
1111 pos = 4;
1113 printf ("%s", cl_enums[i].values[j].arg);
1114 pos += len;
1117 printf ("\n\n");
1118 opts->x_help_enum_printed[i] = 2;
1122 /* Display help for a specified type of option.
1123 The options must have ALL of the INCLUDE_FLAGS set
1124 ANY of the flags in the ANY_FLAGS set
1125 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1126 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1127 static void
1128 print_specific_help (unsigned int include_flags,
1129 unsigned int exclude_flags,
1130 unsigned int any_flags,
1131 struct gcc_options *opts,
1132 unsigned int lang_mask)
1134 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1135 const char * description = NULL;
1136 const char * descrip_extra = "";
1137 size_t i;
1138 unsigned int flag;
1140 /* Sanity check: Make sure that we do not have more
1141 languages than we have bits available to enumerate them. */
1142 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1144 /* If we have not done so already, obtain
1145 the desired maximum width of the output. */
1146 if (opts->x_help_columns == 0)
1148 const char *p;
1150 p = getenv ("COLUMNS");
1151 if (p != NULL)
1153 int value = atoi (p);
1155 if (value > 0)
1156 opts->x_help_columns = value;
1159 if (opts->x_help_columns == 0)
1160 /* Use a reasonable default. */
1161 opts->x_help_columns = 80;
1164 /* Decide upon the title for the options that we are going to display. */
1165 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1167 switch (flag & include_flags)
1169 case 0:
1170 case CL_DRIVER:
1171 break;
1173 case CL_TARGET:
1174 description = _("The following options are target specific");
1175 break;
1176 case CL_WARNING:
1177 description = _("The following options control compiler warning messages");
1178 break;
1179 case CL_OPTIMIZATION:
1180 description = _("The following options control optimizations");
1181 break;
1182 case CL_COMMON:
1183 description = _("The following options are language-independent");
1184 break;
1185 case CL_PARAMS:
1186 description = _("The --param option recognizes the following as parameters");
1187 break;
1188 default:
1189 if (i >= cl_lang_count)
1190 break;
1191 if (exclude_flags & all_langs_mask)
1192 description = _("The following options are specific to just the language ");
1193 else
1194 description = _("The following options are supported by the language ");
1195 descrip_extra = lang_names [i];
1196 break;
1200 if (description == NULL)
1202 if (any_flags == 0)
1204 if (include_flags & CL_UNDOCUMENTED)
1205 description = _("The following options are not documented");
1206 else if (include_flags & CL_SEPARATE)
1207 description = _("The following options take separate arguments");
1208 else if (include_flags & CL_JOINED)
1209 description = _("The following options take joined arguments");
1210 else
1212 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1213 include_flags);
1214 return;
1217 else
1219 if (any_flags & all_langs_mask)
1220 description = _("The following options are language-related");
1221 else
1222 description = _("The following options are language-independent");
1226 printf ("%s%s:\n", description, descrip_extra);
1227 print_filtered_help (include_flags, exclude_flags, any_flags,
1228 opts->x_help_columns, opts, lang_mask);
1231 /* Handle target- and language-independent options. Return zero to
1232 generate an "unknown option" message. Only options that need
1233 extra handling need to be listed here; if you simply want
1234 DECODED->value assigned to a variable, it happens automatically. */
1236 bool
1237 common_handle_option (struct gcc_options *opts,
1238 struct gcc_options *opts_set,
1239 const struct cl_decoded_option *decoded,
1240 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1241 location_t loc,
1242 const struct cl_option_handlers *handlers,
1243 diagnostic_context *dc)
1245 size_t scode = decoded->opt_index;
1246 const char *arg = decoded->arg;
1247 int value = decoded->value;
1248 enum opt_code code = (enum opt_code) scode;
1250 gcc_assert (decoded->canonical_option_num_elements <= 2);
1252 switch (code)
1254 case OPT__param:
1255 handle_param (opts, opts_set, loc, arg);
1256 break;
1258 case OPT__help:
1260 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1261 unsigned int undoc_mask;
1262 unsigned int i;
1264 if (lang_mask == CL_DRIVER)
1265 break;;
1267 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1269 : CL_UNDOCUMENTED);
1270 /* First display any single language specific options. */
1271 for (i = 0; i < cl_lang_count; i++)
1272 print_specific_help
1273 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1274 lang_mask);
1275 /* Next display any multi language specific options. */
1276 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1277 /* Then display any remaining, non-language options. */
1278 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1279 if (i != CL_DRIVER)
1280 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1281 opts->x_exit_after_options = true;
1282 break;
1285 case OPT__target_help:
1286 if (lang_mask == CL_DRIVER)
1287 break;
1289 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1290 opts->x_exit_after_options = true;
1291 break;
1293 case OPT__help_:
1295 const char * a = arg;
1296 unsigned int include_flags = 0;
1297 /* Note - by default we include undocumented options when listing
1298 specific classes. If you only want to see documented options
1299 then add ",^undocumented" to the --help= option. E.g.:
1301 --help=target,^undocumented */
1302 unsigned int exclude_flags = 0;
1304 if (lang_mask == CL_DRIVER)
1305 break;
1307 /* Walk along the argument string, parsing each word in turn.
1308 The format is:
1309 arg = [^]{word}[,{arg}]
1310 word = {optimizers|target|warnings|undocumented|
1311 params|common|<language>} */
1312 while (* a != 0)
1314 static const struct
1316 const char * string;
1317 unsigned int flag;
1319 specifics[] =
1321 { "optimizers", CL_OPTIMIZATION },
1322 { "target", CL_TARGET },
1323 { "warnings", CL_WARNING },
1324 { "undocumented", CL_UNDOCUMENTED },
1325 { "params", CL_PARAMS },
1326 { "joined", CL_JOINED },
1327 { "separate", CL_SEPARATE },
1328 { "common", CL_COMMON },
1329 { NULL, 0 }
1331 unsigned int * pflags;
1332 const char * comma;
1333 unsigned int lang_flag, specific_flag;
1334 unsigned int len;
1335 unsigned int i;
1337 if (* a == '^')
1339 ++ a;
1340 pflags = & exclude_flags;
1342 else
1343 pflags = & include_flags;
1345 comma = strchr (a, ',');
1346 if (comma == NULL)
1347 len = strlen (a);
1348 else
1349 len = comma - a;
1350 if (len == 0)
1352 a = comma + 1;
1353 continue;
1356 /* Check to see if the string matches an option class name. */
1357 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1358 if (strncasecmp (a, specifics[i].string, len) == 0)
1360 specific_flag = specifics[i].flag;
1361 break;
1364 /* Check to see if the string matches a language name.
1365 Note - we rely upon the alpha-sorted nature of the entries in
1366 the lang_names array, specifically that shorter names appear
1367 before their longer variants. (i.e. C before C++). That way
1368 when we are attempting to match --help=c for example we will
1369 match with C first and not C++. */
1370 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1371 if (strncasecmp (a, lang_names[i], len) == 0)
1373 lang_flag = 1U << i;
1374 break;
1377 if (specific_flag != 0)
1379 if (lang_flag == 0)
1380 * pflags |= specific_flag;
1381 else
1383 /* The option's argument matches both the start of a
1384 language name and the start of an option class name.
1385 We have a special case for when the user has
1386 specified "--help=c", but otherwise we have to issue
1387 a warning. */
1388 if (strncasecmp (a, "c", len) == 0)
1389 * pflags |= lang_flag;
1390 else
1391 warning_at (loc, 0,
1392 "--help argument %q.*s is ambiguous, "
1393 "please be more specific",
1394 len, a);
1397 else if (lang_flag != 0)
1398 * pflags |= lang_flag;
1399 else
1400 warning_at (loc, 0,
1401 "unrecognized argument to --help= option: %q.*s",
1402 len, a);
1404 if (comma == NULL)
1405 break;
1406 a = comma + 1;
1409 if (include_flags)
1410 print_specific_help (include_flags, exclude_flags, 0, opts,
1411 lang_mask);
1412 opts->x_exit_after_options = true;
1413 break;
1416 case OPT__version:
1417 if (lang_mask == CL_DRIVER)
1418 break;
1420 opts->x_exit_after_options = true;
1421 break;
1423 case OPT_fsanitize_:
1425 const char *p = arg;
1426 while (*p != 0)
1428 static const struct
1430 const char *const name;
1431 unsigned int flag;
1432 size_t len;
1433 } spec[] =
1435 { "address", SANITIZE_ADDRESS, sizeof "address" - 1 },
1436 { "thread", SANITIZE_THREAD, sizeof "thread" - 1 },
1437 { "shift", SANITIZE_SHIFT, sizeof "shift" - 1 },
1438 { "integer-divide-by-zero", SANITIZE_DIVIDE,
1439 sizeof "integer-divide-by-zero" - 1 },
1440 { "undefined", SANITIZE_UNDEFINED, sizeof "undefined" - 1 },
1441 { "unreachable", SANITIZE_UNREACHABLE,
1442 sizeof "unreachable" - 1 },
1443 { NULL, 0, 0 }
1445 const char *comma;
1446 size_t len, i;
1447 bool found = false;
1449 comma = strchr (p, ',');
1450 if (comma == NULL)
1451 len = strlen (p);
1452 else
1453 len = comma - p;
1454 if (len == 0)
1456 p = comma + 1;
1457 continue;
1460 /* Check to see if the string matches an option class name. */
1461 for (i = 0; spec[i].name != NULL; ++i)
1462 if (len == spec[i].len
1463 && memcmp (p, spec[i].name, len) == 0)
1465 /* Handle both -fsanitize and -fno-sanitize cases. */
1466 if (value)
1467 flag_sanitize |= spec[i].flag;
1468 else
1469 flag_sanitize &= ~spec[i].flag;
1470 found = true;
1471 break;
1474 if (! found)
1475 warning_at (loc, 0,
1476 "unrecognized argument to -fsanitize= option: %q.*s",
1477 (int) len, p);
1479 if (comma == NULL)
1480 break;
1481 p = comma + 1;
1484 break;
1487 case OPT_O:
1488 case OPT_Os:
1489 case OPT_Ofast:
1490 case OPT_Og:
1491 /* Currently handled in a prescan. */
1492 break;
1494 case OPT_Werror:
1495 dc->warning_as_error_requested = value;
1496 break;
1498 case OPT_Werror_:
1499 if (lang_mask == CL_DRIVER)
1500 break;
1502 enable_warning_as_error (arg, value, lang_mask, handlers,
1503 opts, opts_set, loc, dc);
1504 break;
1506 case OPT_Wlarger_than_:
1507 opts->x_larger_than_size = value;
1508 opts->x_warn_larger_than = value != -1;
1509 break;
1511 case OPT_Wfatal_errors:
1512 dc->fatal_errors = value;
1513 break;
1515 case OPT_Wframe_larger_than_:
1516 opts->x_frame_larger_than_size = value;
1517 opts->x_warn_frame_larger_than = value != -1;
1518 break;
1520 case OPT_Wstack_usage_:
1521 opts->x_warn_stack_usage = value;
1522 opts->x_flag_stack_usage_info = value != -1;
1523 break;
1525 case OPT_Wstrict_aliasing:
1526 set_Wstrict_aliasing (opts, value);
1527 break;
1529 case OPT_Wstrict_overflow:
1530 opts->x_warn_strict_overflow = (value
1531 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1532 : 0);
1533 break;
1535 case OPT_Wsystem_headers:
1536 dc->dc_warn_system_headers = value;
1537 break;
1539 case OPT_aux_info:
1540 opts->x_flag_gen_aux_info = 1;
1541 break;
1543 case OPT_auxbase_strip:
1545 char *tmp = xstrdup (arg);
1546 strip_off_ending (tmp, strlen (tmp));
1547 if (tmp[0])
1548 opts->x_aux_base_name = tmp;
1549 else
1550 free (tmp);
1552 break;
1554 case OPT_d:
1555 decode_d_option (arg, opts, loc, dc);
1556 break;
1558 case OPT_fcall_used_:
1559 case OPT_fcall_saved_:
1560 /* Deferred. */
1561 break;
1563 case OPT_fdbg_cnt_:
1564 case OPT_fdbg_cnt_list:
1565 /* Deferred. */
1566 break;
1568 case OPT_fdebug_prefix_map_:
1569 /* Deferred. */
1570 break;
1572 case OPT_fdiagnostics_show_location_:
1573 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1574 break;
1576 case OPT_fdiagnostics_show_caret:
1577 dc->show_caret = value;
1578 break;
1580 case OPT_fdiagnostics_color_:
1581 pp_show_color (dc->printer)
1582 = colorize_init ((diagnostic_color_rule_t) value);
1583 break;
1585 case OPT_fdiagnostics_show_option:
1586 dc->show_option_requested = value;
1587 break;
1589 case OPT_fdump_:
1590 /* Deferred. */
1591 break;
1593 case OPT_ffast_math:
1594 set_fast_math_flags (opts, value);
1595 break;
1597 case OPT_funsafe_math_optimizations:
1598 set_unsafe_math_optimizations_flags (opts, value);
1599 break;
1601 case OPT_ffixed_:
1602 /* Deferred. */
1603 break;
1605 case OPT_finline_limit_:
1606 set_param_value ("max-inline-insns-single", value / 2,
1607 opts->x_param_values, opts_set->x_param_values);
1608 set_param_value ("max-inline-insns-auto", value / 2,
1609 opts->x_param_values, opts_set->x_param_values);
1610 break;
1612 case OPT_finstrument_functions_exclude_function_list_:
1613 add_comma_separated_to_vector
1614 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1615 break;
1617 case OPT_finstrument_functions_exclude_file_list_:
1618 add_comma_separated_to_vector
1619 (&opts->x_flag_instrument_functions_exclude_files, arg);
1620 break;
1622 case OPT_fmessage_length_:
1623 pp_set_line_maximum_length (dc->printer, value);
1624 diagnostic_set_caret_max_width (dc, value);
1625 break;
1627 case OPT_fopt_info:
1628 case OPT_fopt_info_:
1629 /* Deferred. */
1630 break;
1632 case OPT_fpack_struct_:
1633 if (value <= 0 || (value & (value - 1)) || value > 16)
1634 error_at (loc,
1635 "structure alignment must be a small power of two, not %d",
1636 value);
1637 else
1638 opts->x_initial_max_fld_align = value;
1639 break;
1641 case OPT_fplugin_:
1642 case OPT_fplugin_arg_:
1643 /* Deferred. */
1644 break;
1646 case OPT_fprofile_use_:
1647 opts->x_profile_data_prefix = xstrdup (arg);
1648 opts->x_flag_profile_use = true;
1649 value = true;
1650 /* No break here - do -fprofile-use processing. */
1651 case OPT_fprofile_use:
1652 if (!opts_set->x_flag_branch_probabilities)
1653 opts->x_flag_branch_probabilities = value;
1654 if (!opts_set->x_flag_profile_values)
1655 opts->x_flag_profile_values = value;
1656 if (!opts_set->x_flag_unroll_loops)
1657 opts->x_flag_unroll_loops = value;
1658 if (!opts_set->x_flag_peel_loops)
1659 opts->x_flag_peel_loops = value;
1660 if (!opts_set->x_flag_tracer)
1661 opts->x_flag_tracer = value;
1662 if (!opts_set->x_flag_value_profile_transformations)
1663 opts->x_flag_value_profile_transformations = value;
1664 if (!opts_set->x_flag_inline_functions)
1665 opts->x_flag_inline_functions = value;
1666 if (!opts_set->x_flag_ipa_cp)
1667 opts->x_flag_ipa_cp = value;
1668 if (!opts_set->x_flag_ipa_cp_clone
1669 && value && opts->x_flag_ipa_cp)
1670 opts->x_flag_ipa_cp_clone = value;
1671 if (!opts_set->x_flag_predictive_commoning)
1672 opts->x_flag_predictive_commoning = value;
1673 if (!opts_set->x_flag_unswitch_loops)
1674 opts->x_flag_unswitch_loops = value;
1675 if (!opts_set->x_flag_gcse_after_reload)
1676 opts->x_flag_gcse_after_reload = value;
1677 if (!opts_set->x_flag_tree_loop_vectorize
1678 && !opts_set->x_flag_tree_vectorize)
1679 opts->x_flag_tree_loop_vectorize = value;
1680 if (!opts_set->x_flag_tree_slp_vectorize
1681 && !opts_set->x_flag_tree_vectorize)
1682 opts->x_flag_tree_slp_vectorize = value;
1683 if (!opts_set->x_flag_vect_cost_model)
1684 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1685 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1686 opts->x_flag_tree_loop_distribute_patterns = value;
1687 /* Indirect call profiling should do all useful transformations
1688 speculative devirutalization does. */
1689 if (!opts_set->x_flag_devirtualize_speculatively
1690 && opts->x_flag_value_profile_transformations)
1691 opts->x_flag_devirtualize_speculatively = false;
1692 break;
1694 case OPT_fprofile_generate_:
1695 opts->x_profile_data_prefix = xstrdup (arg);
1696 value = true;
1697 /* No break here - do -fprofile-generate processing. */
1698 case OPT_fprofile_generate:
1699 if (!opts_set->x_profile_arc_flag)
1700 opts->x_profile_arc_flag = value;
1701 if (!opts_set->x_flag_profile_values)
1702 opts->x_flag_profile_values = value;
1703 if (!opts_set->x_flag_inline_functions)
1704 opts->x_flag_inline_functions = value;
1705 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1706 quadratic. Disable the pass until better memory representation
1707 is done. */
1708 if (!opts_set->x_flag_ipa_reference && opts->x_in_lto_p)
1709 opts->x_flag_ipa_reference = false;
1710 break;
1712 case OPT_ftree_vectorize:
1713 if (!opts_set->x_flag_tree_loop_vectorize)
1714 opts->x_flag_tree_loop_vectorize = value;
1715 if (!opts_set->x_flag_tree_slp_vectorize)
1716 opts->x_flag_tree_slp_vectorize = value;
1717 break;
1718 case OPT_fshow_column:
1719 dc->show_column = value;
1720 break;
1722 case OPT_frandom_seed:
1723 /* The real switch is -fno-random-seed. */
1724 if (value)
1725 return false;
1726 /* Deferred. */
1727 break;
1729 case OPT_frandom_seed_:
1730 /* Deferred. */
1731 break;
1733 case OPT_fsched_verbose_:
1734 #ifdef INSN_SCHEDULING
1735 /* Handled with Var in common.opt. */
1736 break;
1737 #else
1738 return false;
1739 #endif
1741 case OPT_fsched_stalled_insns_:
1742 opts->x_flag_sched_stalled_insns = value;
1743 if (opts->x_flag_sched_stalled_insns == 0)
1744 opts->x_flag_sched_stalled_insns = -1;
1745 break;
1747 case OPT_fsched_stalled_insns_dep_:
1748 opts->x_flag_sched_stalled_insns_dep = value;
1749 break;
1751 case OPT_fstack_check_:
1752 if (!strcmp (arg, "no"))
1753 opts->x_flag_stack_check = NO_STACK_CHECK;
1754 else if (!strcmp (arg, "generic"))
1755 /* This is the old stack checking method. */
1756 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1757 ? FULL_BUILTIN_STACK_CHECK
1758 : GENERIC_STACK_CHECK;
1759 else if (!strcmp (arg, "specific"))
1760 /* This is the new stack checking method. */
1761 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1762 ? FULL_BUILTIN_STACK_CHECK
1763 : STACK_CHECK_STATIC_BUILTIN
1764 ? STATIC_BUILTIN_STACK_CHECK
1765 : GENERIC_STACK_CHECK;
1766 else
1767 warning_at (loc, 0, "unknown stack check parameter \"%s\"", arg);
1768 break;
1770 case OPT_fstack_limit:
1771 /* The real switch is -fno-stack-limit. */
1772 if (value)
1773 return false;
1774 /* Deferred. */
1775 break;
1777 case OPT_fstack_limit_register_:
1778 case OPT_fstack_limit_symbol_:
1779 /* Deferred. */
1780 break;
1782 case OPT_fstack_usage:
1783 opts->x_flag_stack_usage = value;
1784 opts->x_flag_stack_usage_info = value != 0;
1785 break;
1787 case OPT_ftree_vectorizer_verbose_:
1788 /* -ftree-vectorizer-verbose is deprecated. It is defined in
1789 -terms of fopt-info=N. */
1790 /* Deferred. */
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;