2014-03-18 Richard Biener <rguenther@suse.de>
[official-gcc.git] / gcc / opts.c
blobfdc903f9271a7b8c13e26fb24c9bc00332f5b315
1 /* Command line option handling.
2 Copyright (C) 2002-2014 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 },
457 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fbranch_count_reg, NULL, 1 },
458 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fmove_loop_invariants, NULL, 1 },
459 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_pta, NULL, 1 },
461 /* -O2 optimizations. */
462 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
463 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
464 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
465 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
466 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
467 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
468 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
469 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
470 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
471 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
472 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
473 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
474 #ifdef INSN_SCHEDULING
475 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
476 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
477 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
478 #endif
479 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
480 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
481 { OPT_LEVELS_2_PLUS, OPT_freorder_blocks, NULL, 1 },
482 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
483 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
484 { OPT_LEVELS_2_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
488 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
489 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
490 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
491 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
492 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
493 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
494 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
495 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
496 { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
497 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
498 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
499 { OPT_LEVELS_2_PLUS, OPT_fisolate_erroneous_paths_dereference, NULL, 1 },
501 /* -O3 optimizations. */
502 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
503 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
504 /* Inlining of functions reducing size is a good idea with -Os
505 regardless of them being declared inline. */
506 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
507 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
508 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
509 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
510 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
511 { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
512 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
513 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
514 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
516 /* -Ofast adds optimizations to -O3. */
517 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
519 { OPT_LEVELS_NONE, 0, NULL, 0 }
522 /* Default the options in OPTS and OPTS_SET based on the optimization
523 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
524 void
525 default_options_optimization (struct gcc_options *opts,
526 struct gcc_options *opts_set,
527 struct cl_decoded_option *decoded_options,
528 unsigned int decoded_options_count,
529 location_t loc,
530 unsigned int lang_mask,
531 const struct cl_option_handlers *handlers,
532 diagnostic_context *dc)
534 unsigned int i;
535 int opt2;
537 /* Scan to see what optimization level has been specified. That will
538 determine the default value of many flags. */
539 for (i = 1; i < decoded_options_count; i++)
541 struct cl_decoded_option *opt = &decoded_options[i];
542 switch (opt->opt_index)
544 case OPT_O:
545 if (*opt->arg == '\0')
547 opts->x_optimize = 1;
548 opts->x_optimize_size = 0;
549 opts->x_optimize_fast = 0;
550 opts->x_optimize_debug = 0;
552 else
554 const int optimize_val = integral_argument (opt->arg);
555 if (optimize_val == -1)
556 error_at (loc, "argument to %<-O%> should be a non-negative "
557 "integer, %<g%>, %<s%> or %<fast%>");
558 else
560 opts->x_optimize = optimize_val;
561 if ((unsigned int) opts->x_optimize > 255)
562 opts->x_optimize = 255;
563 opts->x_optimize_size = 0;
564 opts->x_optimize_fast = 0;
565 opts->x_optimize_debug = 0;
568 break;
570 case OPT_Os:
571 opts->x_optimize_size = 1;
573 /* Optimizing for size forces optimize to be 2. */
574 opts->x_optimize = 2;
575 opts->x_optimize_fast = 0;
576 opts->x_optimize_debug = 0;
577 break;
579 case OPT_Ofast:
580 /* -Ofast only adds flags to -O3. */
581 opts->x_optimize_size = 0;
582 opts->x_optimize = 3;
583 opts->x_optimize_fast = 1;
584 opts->x_optimize_debug = 0;
585 break;
587 case OPT_Og:
588 /* -Og selects optimization level 1. */
589 opts->x_optimize_size = 0;
590 opts->x_optimize = 1;
591 opts->x_optimize_fast = 0;
592 opts->x_optimize_debug = 1;
593 break;
595 default:
596 /* Ignore other options in this prescan. */
597 break;
601 maybe_default_options (opts, opts_set, default_options_table,
602 opts->x_optimize, opts->x_optimize_size,
603 opts->x_optimize_fast, opts->x_optimize_debug,
604 lang_mask, handlers, loc, dc);
606 /* -O2 param settings. */
607 opt2 = (opts->x_optimize >= 2);
609 /* Track fields in field-sensitive alias analysis. */
610 maybe_set_param_value
611 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
612 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
613 opts->x_param_values, opts_set->x_param_values);
615 /* For -O1 only do loop invariant motion for very small loops. */
616 maybe_set_param_value
617 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
618 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
619 opts->x_param_values, opts_set->x_param_values);
621 if (opts->x_optimize_size)
622 /* We want to crossjump as much as possible. */
623 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
624 opts->x_param_values, opts_set->x_param_values);
625 else
626 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
627 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
628 opts->x_param_values, opts_set->x_param_values);
630 /* Allow default optimizations to be specified on a per-machine basis. */
631 maybe_default_options (opts, opts_set,
632 targetm_common.option_optimization_table,
633 opts->x_optimize, opts->x_optimize_size,
634 opts->x_optimize_fast, opts->x_optimize_debug,
635 lang_mask, handlers, loc, dc);
638 /* After all options at LOC have been read into OPTS and OPTS_SET,
639 finalize settings of those options and diagnose incompatible
640 combinations. */
641 void
642 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
643 location_t loc)
645 enum unwind_info_type ui_except;
647 if (opts->x_dump_base_name
648 && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name)
649 && ! opts->x_dump_base_name_prefixed)
651 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
652 OPTS->X_DUMP_DIR_NAME directory. Then try to make
653 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
654 directory, typically the directory to contain the object
655 file. */
656 if (opts->x_dump_dir_name)
657 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
658 opts->x_dump_base_name, NULL);
659 else if (opts->x_aux_base_name
660 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
662 const char *aux_base;
664 base_of_path (opts->x_aux_base_name, &aux_base);
665 if (opts->x_aux_base_name != aux_base)
667 int dir_len = aux_base - opts->x_aux_base_name;
668 char *new_dump_base_name
669 = XOBNEWVEC (&opts_obstack, char,
670 strlen (opts->x_dump_base_name) + dir_len + 1);
672 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
673 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
674 /* Append existing OPTS->X_DUMP_BASE_NAME. */
675 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
676 opts->x_dump_base_name = new_dump_base_name;
679 opts->x_dump_base_name_prefixed = true;
682 /* Handle related options for unit-at-a-time, toplevel-reorder, and
683 section-anchors. */
684 if (!opts->x_flag_unit_at_a_time)
686 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
687 error_at (loc, "section anchors must be disabled when unit-at-a-time "
688 "is disabled");
689 opts->x_flag_section_anchors = 0;
690 if (opts->x_flag_toplevel_reorder == 1)
691 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
692 "is disabled");
693 opts->x_flag_toplevel_reorder = 0;
696 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
697 sorry ("transactional memory is not supported with non-call exceptions");
699 /* Unless the user has asked for section anchors, we disable toplevel
700 reordering at -O0 to disable transformations that might be surprising
701 to end users and to get -fno-toplevel-reorder tested. */
702 if (!opts->x_optimize
703 && opts->x_flag_toplevel_reorder == 2
704 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
706 opts->x_flag_toplevel_reorder = 0;
707 opts->x_flag_section_anchors = 0;
709 if (!opts->x_flag_toplevel_reorder)
711 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
712 error_at (loc, "section anchors must be disabled when toplevel reorder"
713 " is disabled");
714 opts->x_flag_section_anchors = 0;
717 if (!opts->x_flag_opts_finished)
719 if (opts->x_flag_pie)
720 opts->x_flag_pic = opts->x_flag_pie;
721 if (opts->x_flag_pic && !opts->x_flag_pie)
722 opts->x_flag_shlib = 1;
723 opts->x_flag_opts_finished = true;
726 if (opts->x_optimize == 0)
728 /* Inlining does not work if not optimizing,
729 so force it not to be done. */
730 opts->x_warn_inline = 0;
731 opts->x_flag_no_inline = 1;
734 /* The optimization to partition hot and cold basic blocks into separate
735 sections of the .o and executable files does not work (currently)
736 with exception handling. This is because there is no support for
737 generating unwind info. If opts->x_flag_exceptions is turned on
738 we need to turn off the partitioning optimization. */
740 ui_except = targetm_common.except_unwind_info (opts);
742 if (opts->x_flag_exceptions
743 && opts->x_flag_reorder_blocks_and_partition
744 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
746 if (opts_set->x_flag_reorder_blocks_and_partition)
747 inform (loc,
748 "-freorder-blocks-and-partition does not work "
749 "with exceptions on this architecture");
750 opts->x_flag_reorder_blocks_and_partition = 0;
751 opts->x_flag_reorder_blocks = 1;
754 /* If user requested unwind info, then turn off the partitioning
755 optimization. */
757 if (opts->x_flag_unwind_tables
758 && !targetm_common.unwind_tables_default
759 && opts->x_flag_reorder_blocks_and_partition
760 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
762 if (opts_set->x_flag_reorder_blocks_and_partition)
763 inform (loc,
764 "-freorder-blocks-and-partition does not support "
765 "unwind info on this architecture");
766 opts->x_flag_reorder_blocks_and_partition = 0;
767 opts->x_flag_reorder_blocks = 1;
770 /* If the target requested unwind info, then turn off the partitioning
771 optimization with a different message. Likewise, if the target does not
772 support named sections. */
774 if (opts->x_flag_reorder_blocks_and_partition
775 && (!targetm_common.have_named_sections
776 || (opts->x_flag_unwind_tables
777 && targetm_common.unwind_tables_default
778 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
780 if (opts_set->x_flag_reorder_blocks_and_partition)
781 inform (loc,
782 "-freorder-blocks-and-partition does not work "
783 "on this architecture");
784 opts->x_flag_reorder_blocks_and_partition = 0;
785 opts->x_flag_reorder_blocks = 1;
788 if (opts->x_flag_reorder_blocks_and_partition
789 && !opts_set->x_flag_reorder_functions)
790 opts->x_flag_reorder_functions = 1;
792 /* Pipelining of outer loops is only possible when general pipelining
793 capabilities are requested. */
794 if (!opts->x_flag_sel_sched_pipelining)
795 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
797 if (opts->x_flag_conserve_stack)
799 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
800 opts->x_param_values, opts_set->x_param_values);
801 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
802 opts->x_param_values, opts_set->x_param_values);
805 if (opts->x_flag_lto)
807 #ifdef ENABLE_LTO
808 opts->x_flag_generate_lto = 1;
810 /* When generating IL, do not operate in whole-program mode.
811 Otherwise, symbols will be privatized too early, causing link
812 errors later. */
813 opts->x_flag_whole_program = 0;
814 #else
815 error_at (loc, "LTO support has not been enabled in this configuration");
816 #endif
817 if (!opts->x_flag_fat_lto_objects
818 && (!HAVE_LTO_PLUGIN
819 || (opts_set->x_flag_use_linker_plugin
820 && !opts->x_flag_use_linker_plugin)))
822 if (opts_set->x_flag_fat_lto_objects)
823 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin");
824 opts->x_flag_fat_lto_objects = 1;
827 if ((opts->x_flag_lto_partition_balanced != 0) + (opts->x_flag_lto_partition_1to1 != 0)
828 + (opts->x_flag_lto_partition_none != 0) >= 1)
830 if ((opts->x_flag_lto_partition_balanced != 0)
831 + (opts->x_flag_lto_partition_1to1 != 0)
832 + (opts->x_flag_lto_partition_none != 0) > 1)
833 error_at (loc, "only one -flto-partition value can be specified");
836 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
837 default value if they choose based on other options. */
838 if (opts->x_flag_split_stack == -1)
839 opts->x_flag_split_stack = 0;
840 else if (opts->x_flag_split_stack)
842 if (!targetm_common.supports_split_stack (true, opts))
844 error_at (loc, "%<-fsplit-stack%> is not supported by "
845 "this compiler configuration");
846 opts->x_flag_split_stack = 0;
850 /* Tune vectorization related parametees according to cost model. */
851 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
853 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
854 6, opts->x_param_values, opts_set->x_param_values);
855 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
856 0, opts->x_param_values, opts_set->x_param_values);
857 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
858 0, opts->x_param_values, opts_set->x_param_values);
861 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
862 is disabled. */
863 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
864 || !opts->x_flag_tree_loop_if_convert)
865 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
866 opts->x_param_values, opts_set->x_param_values);
868 /* The -gsplit-dwarf option requires -gpubnames. */
869 if (opts->x_dwarf_split_debug_info)
870 opts->x_debug_generate_pub_sections = 1;
873 #define LEFT_COLUMN 27
875 /* Output ITEM, of length ITEM_WIDTH, in the left column,
876 followed by word-wrapped HELP in a second column. */
877 static void
878 wrap_help (const char *help,
879 const char *item,
880 unsigned int item_width,
881 unsigned int columns)
883 unsigned int col_width = LEFT_COLUMN;
884 unsigned int remaining, room, len;
886 remaining = strlen (help);
890 room = columns - 3 - MAX (col_width, item_width);
891 if (room > columns)
892 room = 0;
893 len = remaining;
895 if (room < len)
897 unsigned int i;
899 for (i = 0; help[i]; i++)
901 if (i >= room && len != remaining)
902 break;
903 if (help[i] == ' ')
904 len = i;
905 else if ((help[i] == '-' || help[i] == '/')
906 && help[i + 1] != ' '
907 && i > 0 && ISALPHA (help[i - 1]))
908 len = i + 1;
912 printf (" %-*.*s %.*s\n", col_width, item_width, item, len, help);
913 item_width = 0;
914 while (help[len] == ' ')
915 len++;
916 help += len;
917 remaining -= len;
919 while (remaining);
922 /* Print help for a specific front-end, etc. */
923 static void
924 print_filtered_help (unsigned int include_flags,
925 unsigned int exclude_flags,
926 unsigned int any_flags,
927 unsigned int columns,
928 struct gcc_options *opts,
929 unsigned int lang_mask)
931 unsigned int i;
932 const char *help;
933 bool found = false;
934 bool displayed = false;
936 if (include_flags == CL_PARAMS)
938 for (i = 0; i < LAST_PARAM; i++)
940 const char *param = compiler_params[i].option;
942 help = compiler_params[i].help;
943 if (help == NULL || *help == '\0')
945 if (exclude_flags & CL_UNDOCUMENTED)
946 continue;
947 help = undocumented_msg;
950 /* Get the translation. */
951 help = _(help);
953 wrap_help (help, param, strlen (param), columns);
955 putchar ('\n');
956 return;
959 if (!opts->x_help_printed)
960 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
962 if (!opts->x_help_enum_printed)
963 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
965 for (i = 0; i < cl_options_count; i++)
967 char new_help[128];
968 const struct cl_option *option = cl_options + i;
969 unsigned int len;
970 const char *opt;
971 const char *tab;
973 if (include_flags == 0
974 || ((option->flags & include_flags) != include_flags))
976 if ((option->flags & any_flags) == 0)
977 continue;
980 /* Skip unwanted switches. */
981 if ((option->flags & exclude_flags) != 0)
982 continue;
984 /* The driver currently prints its own help text. */
985 if ((option->flags & CL_DRIVER) != 0
986 && (option->flags & (((1U << cl_lang_count) - 1)
987 | CL_COMMON | CL_TARGET)) == 0)
988 continue;
990 found = true;
991 /* Skip switches that have already been printed. */
992 if (opts->x_help_printed[i])
993 continue;
995 opts->x_help_printed[i] = true;
997 help = option->help;
998 if (help == NULL)
1000 if (exclude_flags & CL_UNDOCUMENTED)
1001 continue;
1002 help = undocumented_msg;
1005 /* Get the translation. */
1006 help = _(help);
1008 /* Find the gap between the name of the
1009 option and its descriptive text. */
1010 tab = strchr (help, '\t');
1011 if (tab)
1013 len = tab - help;
1014 opt = help;
1015 help = tab + 1;
1017 else
1019 opt = option->opt_text;
1020 len = strlen (opt);
1023 /* With the -Q option enabled we change the descriptive text associated
1024 with an option to be an indication of its current setting. */
1025 if (!opts->x_quiet_flag)
1027 void *flag_var = option_flag_var (i, opts);
1029 if (len < (LEFT_COLUMN + 2))
1030 strcpy (new_help, "\t\t");
1031 else
1032 strcpy (new_help, "\t");
1034 if (flag_var != NULL
1035 && option->var_type != CLVC_DEFER)
1037 if (option->flags & CL_JOINED)
1039 if (option->var_type == CLVC_STRING)
1041 if (* (const char **) flag_var != NULL)
1042 snprintf (new_help + strlen (new_help),
1043 sizeof (new_help) - strlen (new_help),
1044 * (const char **) flag_var);
1046 else if (option->var_type == CLVC_ENUM)
1048 const struct cl_enum *e = &cl_enums[option->var_enum];
1049 int value;
1050 const char *arg = NULL;
1052 value = e->get (flag_var);
1053 enum_value_to_arg (e->values, &arg, value, lang_mask);
1054 if (arg == NULL)
1055 arg = _("[default]");
1056 snprintf (new_help + strlen (new_help),
1057 sizeof (new_help) - strlen (new_help),
1058 arg);
1060 else
1061 sprintf (new_help + strlen (new_help),
1062 "%#x", * (int *) flag_var);
1064 else
1065 strcat (new_help, option_enabled (i, opts)
1066 ? _("[enabled]") : _("[disabled]"));
1069 help = new_help;
1072 wrap_help (help, opt, len, columns);
1073 displayed = true;
1075 if (option->var_type == CLVC_ENUM
1076 && opts->x_help_enum_printed[option->var_enum] != 2)
1077 opts->x_help_enum_printed[option->var_enum] = 1;
1080 if (! found)
1082 unsigned int langs = include_flags & CL_LANG_ALL;
1084 if (langs == 0)
1085 printf (_(" No options with the desired characteristics were found\n"));
1086 else
1088 unsigned int i;
1090 /* PR 31349: Tell the user how to see all of the
1091 options supported by a specific front end. */
1092 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1093 if ((1U << i) & langs)
1094 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end\n"),
1095 lang_names[i], lang_names[i]);
1099 else if (! displayed)
1100 printf (_(" All options with the desired characteristics have already been displayed\n"));
1102 putchar ('\n');
1104 /* Print details of enumerated option arguments, if those
1105 enumerations have help text headings provided. If no help text
1106 is provided, presume that the possible values are listed in the
1107 help text for the relevant options. */
1108 for (i = 0; i < cl_enums_count; i++)
1110 unsigned int j, pos;
1112 if (opts->x_help_enum_printed[i] != 1)
1113 continue;
1114 if (cl_enums[i].help == NULL)
1115 continue;
1116 printf (" %s\n ", _(cl_enums[i].help));
1117 pos = 4;
1118 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1120 unsigned int len = strlen (cl_enums[i].values[j].arg);
1122 if (pos > 4 && pos + 1 + len <= columns)
1124 printf (" %s", cl_enums[i].values[j].arg);
1125 pos += 1 + len;
1127 else
1129 if (pos > 4)
1131 printf ("\n ");
1132 pos = 4;
1134 printf ("%s", cl_enums[i].values[j].arg);
1135 pos += len;
1138 printf ("\n\n");
1139 opts->x_help_enum_printed[i] = 2;
1143 /* Display help for a specified type of option.
1144 The options must have ALL of the INCLUDE_FLAGS set
1145 ANY of the flags in the ANY_FLAGS set
1146 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1147 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1148 static void
1149 print_specific_help (unsigned int include_flags,
1150 unsigned int exclude_flags,
1151 unsigned int any_flags,
1152 struct gcc_options *opts,
1153 unsigned int lang_mask)
1155 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1156 const char * description = NULL;
1157 const char * descrip_extra = "";
1158 size_t i;
1159 unsigned int flag;
1161 /* Sanity check: Make sure that we do not have more
1162 languages than we have bits available to enumerate them. */
1163 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1165 /* If we have not done so already, obtain
1166 the desired maximum width of the output. */
1167 if (opts->x_help_columns == 0)
1169 const char *p;
1171 p = getenv ("COLUMNS");
1172 if (p != NULL)
1174 int value = atoi (p);
1176 if (value > 0)
1177 opts->x_help_columns = value;
1180 if (opts->x_help_columns == 0)
1181 /* Use a reasonable default. */
1182 opts->x_help_columns = 80;
1185 /* Decide upon the title for the options that we are going to display. */
1186 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1188 switch (flag & include_flags)
1190 case 0:
1191 case CL_DRIVER:
1192 break;
1194 case CL_TARGET:
1195 description = _("The following options are target specific");
1196 break;
1197 case CL_WARNING:
1198 description = _("The following options control compiler warning messages");
1199 break;
1200 case CL_OPTIMIZATION:
1201 description = _("The following options control optimizations");
1202 break;
1203 case CL_COMMON:
1204 description = _("The following options are language-independent");
1205 break;
1206 case CL_PARAMS:
1207 description = _("The --param option recognizes the following as parameters");
1208 break;
1209 default:
1210 if (i >= cl_lang_count)
1211 break;
1212 if (exclude_flags & all_langs_mask)
1213 description = _("The following options are specific to just the language ");
1214 else
1215 description = _("The following options are supported by the language ");
1216 descrip_extra = lang_names [i];
1217 break;
1221 if (description == NULL)
1223 if (any_flags == 0)
1225 if (include_flags & CL_UNDOCUMENTED)
1226 description = _("The following options are not documented");
1227 else if (include_flags & CL_SEPARATE)
1228 description = _("The following options take separate arguments");
1229 else if (include_flags & CL_JOINED)
1230 description = _("The following options take joined arguments");
1231 else
1233 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1234 include_flags);
1235 return;
1238 else
1240 if (any_flags & all_langs_mask)
1241 description = _("The following options are language-related");
1242 else
1243 description = _("The following options are language-independent");
1247 printf ("%s%s:\n", description, descrip_extra);
1248 print_filtered_help (include_flags, exclude_flags, any_flags,
1249 opts->x_help_columns, opts, lang_mask);
1252 /* Handle target- and language-independent options. Return zero to
1253 generate an "unknown option" message. Only options that need
1254 extra handling need to be listed here; if you simply want
1255 DECODED->value assigned to a variable, it happens automatically. */
1257 bool
1258 common_handle_option (struct gcc_options *opts,
1259 struct gcc_options *opts_set,
1260 const struct cl_decoded_option *decoded,
1261 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1262 location_t loc,
1263 const struct cl_option_handlers *handlers,
1264 diagnostic_context *dc)
1266 size_t scode = decoded->opt_index;
1267 const char *arg = decoded->arg;
1268 int value = decoded->value;
1269 enum opt_code code = (enum opt_code) scode;
1271 gcc_assert (decoded->canonical_option_num_elements <= 2);
1273 switch (code)
1275 case OPT__param:
1276 handle_param (opts, opts_set, loc, arg);
1277 break;
1279 case OPT__help:
1281 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1282 unsigned int undoc_mask;
1283 unsigned int i;
1285 if (lang_mask == CL_DRIVER)
1286 break;;
1288 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1290 : CL_UNDOCUMENTED);
1291 /* First display any single language specific options. */
1292 for (i = 0; i < cl_lang_count; i++)
1293 print_specific_help
1294 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1295 lang_mask);
1296 /* Next display any multi language specific options. */
1297 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1298 /* Then display any remaining, non-language options. */
1299 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1300 if (i != CL_DRIVER)
1301 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1302 opts->x_exit_after_options = true;
1303 break;
1306 case OPT__target_help:
1307 if (lang_mask == CL_DRIVER)
1308 break;
1310 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1311 opts->x_exit_after_options = true;
1312 break;
1314 case OPT__help_:
1316 const char * a = arg;
1317 unsigned int include_flags = 0;
1318 /* Note - by default we include undocumented options when listing
1319 specific classes. If you only want to see documented options
1320 then add ",^undocumented" to the --help= option. E.g.:
1322 --help=target,^undocumented */
1323 unsigned int exclude_flags = 0;
1325 if (lang_mask == CL_DRIVER)
1326 break;
1328 /* Walk along the argument string, parsing each word in turn.
1329 The format is:
1330 arg = [^]{word}[,{arg}]
1331 word = {optimizers|target|warnings|undocumented|
1332 params|common|<language>} */
1333 while (* a != 0)
1335 static const struct
1337 const char * string;
1338 unsigned int flag;
1340 specifics[] =
1342 { "optimizers", CL_OPTIMIZATION },
1343 { "target", CL_TARGET },
1344 { "warnings", CL_WARNING },
1345 { "undocumented", CL_UNDOCUMENTED },
1346 { "params", CL_PARAMS },
1347 { "joined", CL_JOINED },
1348 { "separate", CL_SEPARATE },
1349 { "common", CL_COMMON },
1350 { NULL, 0 }
1352 unsigned int * pflags;
1353 const char * comma;
1354 unsigned int lang_flag, specific_flag;
1355 unsigned int len;
1356 unsigned int i;
1358 if (* a == '^')
1360 ++ a;
1361 pflags = & exclude_flags;
1363 else
1364 pflags = & include_flags;
1366 comma = strchr (a, ',');
1367 if (comma == NULL)
1368 len = strlen (a);
1369 else
1370 len = comma - a;
1371 if (len == 0)
1373 a = comma + 1;
1374 continue;
1377 /* Check to see if the string matches an option class name. */
1378 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1379 if (strncasecmp (a, specifics[i].string, len) == 0)
1381 specific_flag = specifics[i].flag;
1382 break;
1385 /* Check to see if the string matches a language name.
1386 Note - we rely upon the alpha-sorted nature of the entries in
1387 the lang_names array, specifically that shorter names appear
1388 before their longer variants. (i.e. C before C++). That way
1389 when we are attempting to match --help=c for example we will
1390 match with C first and not C++. */
1391 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1392 if (strncasecmp (a, lang_names[i], len) == 0)
1394 lang_flag = 1U << i;
1395 break;
1398 if (specific_flag != 0)
1400 if (lang_flag == 0)
1401 * pflags |= specific_flag;
1402 else
1404 /* The option's argument matches both the start of a
1405 language name and the start of an option class name.
1406 We have a special case for when the user has
1407 specified "--help=c", but otherwise we have to issue
1408 a warning. */
1409 if (strncasecmp (a, "c", len) == 0)
1410 * pflags |= lang_flag;
1411 else
1412 warning_at (loc, 0,
1413 "--help argument %q.*s is ambiguous, "
1414 "please be more specific",
1415 len, a);
1418 else if (lang_flag != 0)
1419 * pflags |= lang_flag;
1420 else
1421 warning_at (loc, 0,
1422 "unrecognized argument to --help= option: %q.*s",
1423 len, a);
1425 if (comma == NULL)
1426 break;
1427 a = comma + 1;
1430 if (include_flags)
1431 print_specific_help (include_flags, exclude_flags, 0, opts,
1432 lang_mask);
1433 opts->x_exit_after_options = true;
1434 break;
1437 case OPT__version:
1438 if (lang_mask == CL_DRIVER)
1439 break;
1441 opts->x_exit_after_options = true;
1442 break;
1444 case OPT_fsanitize_:
1446 const char *p = arg;
1447 while (*p != 0)
1449 static const struct
1451 const char *const name;
1452 unsigned int flag;
1453 size_t len;
1454 } spec[] =
1456 { "address", SANITIZE_ADDRESS, sizeof "address" - 1 },
1457 { "thread", SANITIZE_THREAD, sizeof "thread" - 1 },
1458 { "leak", SANITIZE_LEAK, sizeof "leak" - 1 },
1459 { "shift", SANITIZE_SHIFT, sizeof "shift" - 1 },
1460 { "integer-divide-by-zero", SANITIZE_DIVIDE,
1461 sizeof "integer-divide-by-zero" - 1 },
1462 { "undefined", SANITIZE_UNDEFINED, sizeof "undefined" - 1 },
1463 { "unreachable", SANITIZE_UNREACHABLE,
1464 sizeof "unreachable" - 1 },
1465 { "vla-bound", SANITIZE_VLA, sizeof "vla-bound" - 1 },
1466 { "return", SANITIZE_RETURN, sizeof "return" - 1 },
1467 { "null", SANITIZE_NULL, sizeof "null" - 1 },
1468 { "signed-integer-overflow", SANITIZE_SI_OVERFLOW,
1469 sizeof "signed-integer-overflow" -1 },
1470 { "bool", SANITIZE_BOOL, sizeof "bool" - 1 },
1471 { "enum", SANITIZE_ENUM, sizeof "enum" - 1 },
1472 { NULL, 0, 0 }
1474 const char *comma;
1475 size_t len, i;
1476 bool found = false;
1478 comma = strchr (p, ',');
1479 if (comma == NULL)
1480 len = strlen (p);
1481 else
1482 len = comma - p;
1483 if (len == 0)
1485 p = comma + 1;
1486 continue;
1489 /* Check to see if the string matches an option class name. */
1490 for (i = 0; spec[i].name != NULL; ++i)
1491 if (len == spec[i].len
1492 && memcmp (p, spec[i].name, len) == 0)
1494 /* Handle both -fsanitize and -fno-sanitize cases. */
1495 if (value)
1496 flag_sanitize |= spec[i].flag;
1497 else
1498 flag_sanitize &= ~spec[i].flag;
1499 found = true;
1500 break;
1503 if (! found)
1504 warning_at (loc, 0,
1505 "unrecognized argument to -fsanitize= option: %q.*s",
1506 (int) len, p);
1508 if (comma == NULL)
1509 break;
1510 p = comma + 1;
1513 /* When instrumenting the pointers, we don't want to remove
1514 the null pointer checks. */
1515 if (flag_sanitize & SANITIZE_NULL)
1516 opts->x_flag_delete_null_pointer_checks = 0;
1517 break;
1520 case OPT_O:
1521 case OPT_Os:
1522 case OPT_Ofast:
1523 case OPT_Og:
1524 /* Currently handled in a prescan. */
1525 break;
1527 case OPT_Werror:
1528 dc->warning_as_error_requested = value;
1529 break;
1531 case OPT_Werror_:
1532 if (lang_mask == CL_DRIVER)
1533 break;
1535 enable_warning_as_error (arg, value, lang_mask, handlers,
1536 opts, opts_set, loc, dc);
1537 break;
1539 case OPT_Wlarger_than_:
1540 opts->x_larger_than_size = value;
1541 opts->x_warn_larger_than = value != -1;
1542 break;
1544 case OPT_Wfatal_errors:
1545 dc->fatal_errors = value;
1546 break;
1548 case OPT_Wframe_larger_than_:
1549 opts->x_frame_larger_than_size = value;
1550 opts->x_warn_frame_larger_than = value != -1;
1551 break;
1553 case OPT_Wstack_usage_:
1554 opts->x_warn_stack_usage = value;
1555 opts->x_flag_stack_usage_info = value != -1;
1556 break;
1558 case OPT_Wstrict_aliasing:
1559 set_Wstrict_aliasing (opts, value);
1560 break;
1562 case OPT_Wstrict_overflow:
1563 opts->x_warn_strict_overflow = (value
1564 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1565 : 0);
1566 break;
1568 case OPT_Wsystem_headers:
1569 dc->dc_warn_system_headers = value;
1570 break;
1572 case OPT_aux_info:
1573 opts->x_flag_gen_aux_info = 1;
1574 break;
1576 case OPT_auxbase_strip:
1578 char *tmp = xstrdup (arg);
1579 strip_off_ending (tmp, strlen (tmp));
1580 if (tmp[0])
1581 opts->x_aux_base_name = tmp;
1582 else
1583 free (tmp);
1585 break;
1587 case OPT_d:
1588 decode_d_option (arg, opts, loc, dc);
1589 break;
1591 case OPT_fcall_used_:
1592 case OPT_fcall_saved_:
1593 /* Deferred. */
1594 break;
1596 case OPT_fdbg_cnt_:
1597 case OPT_fdbg_cnt_list:
1598 /* Deferred. */
1599 break;
1601 case OPT_fdebug_prefix_map_:
1602 /* Deferred. */
1603 break;
1605 case OPT_fdiagnostics_show_location_:
1606 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1607 break;
1609 case OPT_fdiagnostics_show_caret:
1610 dc->show_caret = value;
1611 break;
1613 case OPT_fdiagnostics_color_:
1614 pp_show_color (dc->printer)
1615 = colorize_init ((diagnostic_color_rule_t) value);
1616 break;
1618 case OPT_fdiagnostics_show_option:
1619 dc->show_option_requested = value;
1620 break;
1622 case OPT_fdump_:
1623 /* Deferred. */
1624 break;
1626 case OPT_ffast_math:
1627 set_fast_math_flags (opts, value);
1628 break;
1630 case OPT_funsafe_math_optimizations:
1631 set_unsafe_math_optimizations_flags (opts, value);
1632 break;
1634 case OPT_ffixed_:
1635 /* Deferred. */
1636 break;
1638 case OPT_finline_limit_:
1639 set_param_value ("max-inline-insns-single", value / 2,
1640 opts->x_param_values, opts_set->x_param_values);
1641 set_param_value ("max-inline-insns-auto", value / 2,
1642 opts->x_param_values, opts_set->x_param_values);
1643 break;
1645 case OPT_finstrument_functions_exclude_function_list_:
1646 add_comma_separated_to_vector
1647 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1648 break;
1650 case OPT_finstrument_functions_exclude_file_list_:
1651 add_comma_separated_to_vector
1652 (&opts->x_flag_instrument_functions_exclude_files, arg);
1653 break;
1655 case OPT_fmessage_length_:
1656 pp_set_line_maximum_length (dc->printer, value);
1657 diagnostic_set_caret_max_width (dc, value);
1658 break;
1660 case OPT_fopt_info:
1661 case OPT_fopt_info_:
1662 /* Deferred. */
1663 break;
1665 case OPT_fpack_struct_:
1666 if (value <= 0 || (value & (value - 1)) || value > 16)
1667 error_at (loc,
1668 "structure alignment must be a small power of two, not %d",
1669 value);
1670 else
1671 opts->x_initial_max_fld_align = value;
1672 break;
1674 case OPT_fplugin_:
1675 case OPT_fplugin_arg_:
1676 /* Deferred. */
1677 break;
1679 case OPT_fprofile_use_:
1680 opts->x_profile_data_prefix = xstrdup (arg);
1681 opts->x_flag_profile_use = true;
1682 value = true;
1683 /* No break here - do -fprofile-use processing. */
1684 case OPT_fprofile_use:
1685 if (!opts_set->x_flag_branch_probabilities)
1686 opts->x_flag_branch_probabilities = value;
1687 if (!opts_set->x_flag_profile_values)
1688 opts->x_flag_profile_values = value;
1689 if (!opts_set->x_flag_unroll_loops)
1690 opts->x_flag_unroll_loops = value;
1691 if (!opts_set->x_flag_peel_loops)
1692 opts->x_flag_peel_loops = value;
1693 if (!opts_set->x_flag_tracer)
1694 opts->x_flag_tracer = value;
1695 if (!opts_set->x_flag_value_profile_transformations)
1696 opts->x_flag_value_profile_transformations = value;
1697 if (!opts_set->x_flag_inline_functions)
1698 opts->x_flag_inline_functions = value;
1699 if (!opts_set->x_flag_ipa_cp)
1700 opts->x_flag_ipa_cp = value;
1701 if (!opts_set->x_flag_ipa_cp_clone
1702 && value && opts->x_flag_ipa_cp)
1703 opts->x_flag_ipa_cp_clone = value;
1704 if (!opts_set->x_flag_predictive_commoning)
1705 opts->x_flag_predictive_commoning = value;
1706 if (!opts_set->x_flag_unswitch_loops)
1707 opts->x_flag_unswitch_loops = value;
1708 if (!opts_set->x_flag_gcse_after_reload)
1709 opts->x_flag_gcse_after_reload = value;
1710 if (!opts_set->x_flag_tree_loop_vectorize
1711 && !opts_set->x_flag_tree_vectorize)
1712 opts->x_flag_tree_loop_vectorize = value;
1713 if (!opts_set->x_flag_tree_slp_vectorize
1714 && !opts_set->x_flag_tree_vectorize)
1715 opts->x_flag_tree_slp_vectorize = value;
1716 if (!opts_set->x_flag_vect_cost_model)
1717 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1718 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1719 opts->x_flag_tree_loop_distribute_patterns = value;
1720 if (!opts_set->x_flag_profile_reorder_functions)
1721 opts->x_flag_profile_reorder_functions = value;
1722 /* Indirect call profiling should do all useful transformations
1723 speculative devirtualization does. */
1724 if (!opts_set->x_flag_devirtualize_speculatively
1725 && opts->x_flag_value_profile_transformations)
1726 opts->x_flag_devirtualize_speculatively = false;
1727 break;
1729 case OPT_fprofile_generate_:
1730 opts->x_profile_data_prefix = xstrdup (arg);
1731 value = true;
1732 /* No break here - do -fprofile-generate processing. */
1733 case OPT_fprofile_generate:
1734 if (!opts_set->x_profile_arc_flag)
1735 opts->x_profile_arc_flag = value;
1736 if (!opts_set->x_flag_profile_values)
1737 opts->x_flag_profile_values = value;
1738 if (!opts_set->x_flag_inline_functions)
1739 opts->x_flag_inline_functions = value;
1740 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1741 quadratic. Disable the pass until better memory representation
1742 is done. */
1743 if (!opts_set->x_flag_ipa_reference && opts->x_in_lto_p)
1744 opts->x_flag_ipa_reference = false;
1745 break;
1747 case OPT_ftree_vectorize:
1748 if (!opts_set->x_flag_tree_loop_vectorize)
1749 opts->x_flag_tree_loop_vectorize = value;
1750 if (!opts_set->x_flag_tree_slp_vectorize)
1751 opts->x_flag_tree_slp_vectorize = value;
1752 break;
1753 case OPT_fshow_column:
1754 dc->show_column = value;
1755 break;
1757 case OPT_frandom_seed:
1758 /* The real switch is -fno-random-seed. */
1759 if (value)
1760 return false;
1761 /* Deferred. */
1762 break;
1764 case OPT_frandom_seed_:
1765 /* Deferred. */
1766 break;
1768 case OPT_fsched_verbose_:
1769 #ifdef INSN_SCHEDULING
1770 /* Handled with Var in common.opt. */
1771 break;
1772 #else
1773 return false;
1774 #endif
1776 case OPT_fsched_stalled_insns_:
1777 opts->x_flag_sched_stalled_insns = value;
1778 if (opts->x_flag_sched_stalled_insns == 0)
1779 opts->x_flag_sched_stalled_insns = -1;
1780 break;
1782 case OPT_fsched_stalled_insns_dep_:
1783 opts->x_flag_sched_stalled_insns_dep = value;
1784 break;
1786 case OPT_fstack_check_:
1787 if (!strcmp (arg, "no"))
1788 opts->x_flag_stack_check = NO_STACK_CHECK;
1789 else if (!strcmp (arg, "generic"))
1790 /* This is the old stack checking method. */
1791 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1792 ? FULL_BUILTIN_STACK_CHECK
1793 : GENERIC_STACK_CHECK;
1794 else if (!strcmp (arg, "specific"))
1795 /* This is the new stack checking method. */
1796 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1797 ? FULL_BUILTIN_STACK_CHECK
1798 : STACK_CHECK_STATIC_BUILTIN
1799 ? STATIC_BUILTIN_STACK_CHECK
1800 : GENERIC_STACK_CHECK;
1801 else
1802 warning_at (loc, 0, "unknown stack check parameter \"%s\"", arg);
1803 break;
1805 case OPT_fstack_limit:
1806 /* The real switch is -fno-stack-limit. */
1807 if (value)
1808 return false;
1809 /* Deferred. */
1810 break;
1812 case OPT_fstack_limit_register_:
1813 case OPT_fstack_limit_symbol_:
1814 /* Deferred. */
1815 break;
1817 case OPT_fstack_usage:
1818 opts->x_flag_stack_usage = value;
1819 opts->x_flag_stack_usage_info = value != 0;
1820 break;
1822 case OPT_g:
1823 /* -g by itself should force -g2. */
1824 if (*arg == '\0')
1825 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "2", opts, opts_set,
1826 loc);
1827 else
1828 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
1829 loc);
1830 break;
1832 case OPT_gcoff:
1833 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
1834 break;
1836 case OPT_gdwarf:
1837 if (arg && strlen (arg) != 0)
1839 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
1840 "use %<-gdwarf-%s%> for DWARF version "
1841 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
1842 break;
1844 else
1845 value = opts->x_dwarf_version;
1847 /* FALLTHRU */
1848 case OPT_gdwarf_:
1849 if (value < 2 || value > 4)
1850 error_at (loc, "dwarf version %d is not supported", value);
1851 else
1852 opts->x_dwarf_version = value;
1853 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
1854 break;
1856 case OPT_gsplit_dwarf:
1857 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
1858 loc);
1859 break;
1861 case OPT_ggdb:
1862 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
1863 break;
1865 case OPT_gstabs:
1866 case OPT_gstabs_:
1867 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
1868 loc);
1869 break;
1871 case OPT_gvms:
1872 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
1873 break;
1875 case OPT_gxcoff:
1876 case OPT_gxcoff_:
1877 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
1878 loc);
1879 break;
1881 case OPT_pedantic_errors:
1882 dc->pedantic_errors = 1;
1883 control_warning_option (OPT_Wpedantic, DK_ERROR, value,
1884 loc, lang_mask,
1885 handlers, opts, opts_set,
1886 dc);
1887 break;
1889 case OPT_flto:
1890 opts->x_flag_lto = value ? "" : NULL;
1891 break;
1893 case OPT_w:
1894 dc->dc_inhibit_warnings = true;
1895 break;
1897 case OPT_fmax_errors_:
1898 dc->max_errors = value;
1899 break;
1901 case OPT_fuse_ld_bfd:
1902 case OPT_fuse_ld_gold:
1903 case OPT_fuse_linker_plugin:
1904 /* No-op. Used by the driver and passed to us because it starts with f.*/
1905 break;
1907 case OPT_fwrapv:
1908 if (value)
1909 opts->x_flag_trapv = 0;
1910 break;
1912 case OPT_ftrapv:
1913 if (value)
1914 opts->x_flag_wrapv = 0;
1915 break;
1917 default:
1918 /* If the flag was handled in a standard way, assume the lack of
1919 processing here is intentional. */
1920 gcc_assert (option_flag_var (scode, opts));
1921 break;
1924 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
1925 loc, handlers, dc);
1926 return true;
1929 /* Handle --param NAME=VALUE. */
1930 static void
1931 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
1932 location_t loc, const char *carg)
1934 char *equal, *arg;
1935 int value;
1937 arg = xstrdup (carg);
1938 equal = strchr (arg, '=');
1939 if (!equal)
1940 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
1941 arg);
1942 else
1944 value = integral_argument (equal + 1);
1945 if (value == -1)
1946 error_at (loc, "invalid --param value %qs", equal + 1);
1947 else
1949 *equal = '\0';
1950 set_param_value (arg, value,
1951 opts->x_param_values, opts_set->x_param_values);
1955 free (arg);
1958 /* Used to set the level of strict aliasing warnings in OPTS,
1959 when no level is specified (i.e., when -Wstrict-aliasing, and not
1960 -Wstrict-aliasing=level was given).
1961 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
1962 and 0 otherwise. After calling this function, wstrict_aliasing will be
1963 set to the default value of -Wstrict_aliasing=level, currently 3. */
1964 static void
1965 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
1967 gcc_assert (onoff == 0 || onoff == 1);
1968 if (onoff != 0)
1969 opts->x_warn_strict_aliasing = 3;
1970 else
1971 opts->x_warn_strict_aliasing = 0;
1974 /* The following routines are useful in setting all the flags that
1975 -ffast-math and -fno-fast-math imply. */
1976 static void
1977 set_fast_math_flags (struct gcc_options *opts, int set)
1979 if (!opts->frontend_set_flag_unsafe_math_optimizations)
1981 opts->x_flag_unsafe_math_optimizations = set;
1982 set_unsafe_math_optimizations_flags (opts, set);
1984 if (!opts->frontend_set_flag_finite_math_only)
1985 opts->x_flag_finite_math_only = set;
1986 if (!opts->frontend_set_flag_errno_math)
1987 opts->x_flag_errno_math = !set;
1988 if (set)
1990 if (!opts->frontend_set_flag_signaling_nans)
1991 opts->x_flag_signaling_nans = 0;
1992 if (!opts->frontend_set_flag_rounding_math)
1993 opts->x_flag_rounding_math = 0;
1994 if (!opts->frontend_set_flag_cx_limited_range)
1995 opts->x_flag_cx_limited_range = 1;
1999 /* When -funsafe-math-optimizations is set the following
2000 flags are set as well. */
2001 static void
2002 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
2004 if (!opts->frontend_set_flag_trapping_math)
2005 opts->x_flag_trapping_math = !set;
2006 if (!opts->frontend_set_flag_signed_zeros)
2007 opts->x_flag_signed_zeros = !set;
2008 if (!opts->frontend_set_flag_associative_math)
2009 opts->x_flag_associative_math = set;
2010 if (!opts->frontend_set_flag_reciprocal_math)
2011 opts->x_flag_reciprocal_math = set;
2014 /* Return true iff flags in OPTS are set as if -ffast-math. */
2015 bool
2016 fast_math_flags_set_p (const struct gcc_options *opts)
2018 return (!opts->x_flag_trapping_math
2019 && opts->x_flag_unsafe_math_optimizations
2020 && opts->x_flag_finite_math_only
2021 && !opts->x_flag_signed_zeros
2022 && !opts->x_flag_errno_math);
2025 /* Return true iff flags are set as if -ffast-math but using the flags stored
2026 in the struct cl_optimization structure. */
2027 bool
2028 fast_math_flags_struct_set_p (struct cl_optimization *opt)
2030 return (!opt->x_flag_trapping_math
2031 && opt->x_flag_unsafe_math_optimizations
2032 && opt->x_flag_finite_math_only
2033 && !opt->x_flag_signed_zeros
2034 && !opt->x_flag_errno_math);
2037 /* Handle a debug output -g switch for options OPTS
2038 (OPTS_SET->x_write_symbols storing whether a debug type was passed
2039 explicitly), location LOC. EXTENDED is true or false to support
2040 extended output (2 is special and means "-ggdb" was given). */
2041 static void
2042 set_debug_level (enum debug_info_type type, int extended, const char *arg,
2043 struct gcc_options *opts, struct gcc_options *opts_set,
2044 location_t loc)
2046 opts->x_use_gnu_debug_info_extensions = extended;
2048 if (type == NO_DEBUG)
2050 if (opts->x_write_symbols == NO_DEBUG)
2052 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
2054 if (extended == 2)
2056 #ifdef DWARF2_DEBUGGING_INFO
2057 opts->x_write_symbols = DWARF2_DEBUG;
2058 #elif defined DBX_DEBUGGING_INFO
2059 opts->x_write_symbols = DBX_DEBUG;
2060 #endif
2063 if (opts->x_write_symbols == NO_DEBUG)
2064 warning_at (loc, 0, "target system does not support debug output");
2067 else
2069 /* Does it conflict with an already selected type? */
2070 if (opts_set->x_write_symbols != NO_DEBUG
2071 && opts->x_write_symbols != NO_DEBUG
2072 && type != opts->x_write_symbols)
2073 error_at (loc, "debug format \"%s\" conflicts with prior selection",
2074 debug_type_names[type]);
2075 opts->x_write_symbols = type;
2076 opts_set->x_write_symbols = type;
2079 /* A debug flag without a level defaults to level 2. */
2080 if (*arg == '\0')
2082 if (!opts->x_debug_info_level)
2083 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2085 else
2087 int argval = integral_argument (arg);
2088 if (argval == -1)
2089 error_at (loc, "unrecognised debug output level \"%s\"", arg);
2090 else if (argval > 3)
2091 error_at (loc, "debug output level %s is too high", arg);
2092 else
2093 opts->x_debug_info_level = (enum debug_info_levels) argval;
2097 /* Arrange to dump core on error for diagnostic context DC. (The
2098 regular error message is still printed first, except in the case of
2099 abort ().) */
2101 static void
2102 setup_core_dumping (diagnostic_context *dc)
2104 #ifdef SIGABRT
2105 signal (SIGABRT, SIG_DFL);
2106 #endif
2107 #if defined(HAVE_SETRLIMIT)
2109 struct rlimit rlim;
2110 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2111 fatal_error ("getting core file size maximum limit: %m");
2112 rlim.rlim_cur = rlim.rlim_max;
2113 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2114 fatal_error ("setting core file size limit to maximum: %m");
2116 #endif
2117 diagnostic_abort_on_error (dc);
2120 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2121 diagnostic context DC. */
2123 static void
2124 decode_d_option (const char *arg, struct gcc_options *opts,
2125 location_t loc, diagnostic_context *dc)
2127 int c;
2129 while (*arg)
2130 switch (c = *arg++)
2132 case 'A':
2133 opts->x_flag_debug_asm = 1;
2134 break;
2135 case 'p':
2136 opts->x_flag_print_asm_name = 1;
2137 break;
2138 case 'P':
2139 opts->x_flag_dump_rtl_in_asm = 1;
2140 opts->x_flag_print_asm_name = 1;
2141 break;
2142 case 'x':
2143 opts->x_rtl_dump_and_exit = 1;
2144 break;
2145 case 'D': /* These are handled by the preprocessor. */
2146 case 'I':
2147 case 'M':
2148 case 'N':
2149 case 'U':
2150 break;
2151 case 'H':
2152 setup_core_dumping (dc);
2153 break;
2154 case 'a':
2155 opts->x_flag_dump_all_passed = true;
2156 break;
2158 default:
2159 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2160 break;
2164 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2165 mask LANG_MASK, option handlers HANDLERS) as an error for option
2166 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2167 NULL), location LOC. This is used by -Werror=. */
2169 static void
2170 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2171 const struct cl_option_handlers *handlers,
2172 struct gcc_options *opts,
2173 struct gcc_options *opts_set,
2174 location_t loc, diagnostic_context *dc)
2176 char *new_option;
2177 int option_index;
2179 new_option = XNEWVEC (char, strlen (arg) + 2);
2180 new_option[0] = 'W';
2181 strcpy (new_option + 1, arg);
2182 option_index = find_opt (new_option, lang_mask);
2183 if (option_index == OPT_SPECIAL_unknown)
2185 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2187 else
2189 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2191 control_warning_option (option_index, (int) kind, value,
2192 loc, lang_mask,
2193 handlers, opts, opts_set, dc);
2195 free (new_option);
2198 /* Return malloced memory for the name of the option OPTION_INDEX
2199 which enabled a diagnostic (context CONTEXT), originally of type
2200 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2201 as -Werror. */
2203 char *
2204 option_name (diagnostic_context *context, int option_index,
2205 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2207 if (option_index)
2209 /* A warning classified as an error. */
2210 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2211 && diag_kind == DK_ERROR)
2212 return concat (cl_options[OPT_Werror_].opt_text,
2213 /* Skip over "-W". */
2214 cl_options[option_index].opt_text + 2,
2215 NULL);
2216 /* A warning with option. */
2217 else
2218 return xstrdup (cl_options[option_index].opt_text);
2220 /* A warning without option classified as an error. */
2221 else if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2222 || diag_kind == DK_WARNING)
2223 && context->warning_as_error_requested)
2224 return xstrdup (cl_options[OPT_Werror].opt_text);
2225 else
2226 return NULL;