2013-06-11 Richard Biener <rguenther@suse.de>
[official-gcc.git] / gcc / opts.c
blob6856c3c8090a83ee148ad0da2e29c1f69e4467c8
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_fipa_sra, NULL, 1 },
483 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
484 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
488 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
489 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
491 /* -O3 optimizations. */
492 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
493 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
494 /* Inlining of functions reducing size is a good idea with -Os
495 regardless of them being declared inline. */
496 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
497 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
498 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
499 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
500 { OPT_LEVELS_3_PLUS, OPT_ftree_vectorize, NULL, 1 },
501 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model, NULL, 1 },
502 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
503 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
505 /* -Ofast adds optimizations to -O3. */
506 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
508 { OPT_LEVELS_NONE, 0, NULL, 0 }
511 /* Default the options in OPTS and OPTS_SET based on the optimization
512 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
513 void
514 default_options_optimization (struct gcc_options *opts,
515 struct gcc_options *opts_set,
516 struct cl_decoded_option *decoded_options,
517 unsigned int decoded_options_count,
518 location_t loc,
519 unsigned int lang_mask,
520 const struct cl_option_handlers *handlers,
521 diagnostic_context *dc)
523 unsigned int i;
524 int opt2;
526 /* Scan to see what optimization level has been specified. That will
527 determine the default value of many flags. */
528 for (i = 1; i < decoded_options_count; i++)
530 struct cl_decoded_option *opt = &decoded_options[i];
531 switch (opt->opt_index)
533 case OPT_O:
534 if (*opt->arg == '\0')
536 opts->x_optimize = 1;
537 opts->x_optimize_size = 0;
538 opts->x_optimize_fast = 0;
539 opts->x_optimize_debug = 0;
541 else
543 const int optimize_val = integral_argument (opt->arg);
544 if (optimize_val == -1)
545 error_at (loc, "argument to %<-O%> should be a non-negative "
546 "integer, %<g%>, %<s%> or %<fast%>");
547 else
549 opts->x_optimize = optimize_val;
550 if ((unsigned int) opts->x_optimize > 255)
551 opts->x_optimize = 255;
552 opts->x_optimize_size = 0;
553 opts->x_optimize_fast = 0;
554 opts->x_optimize_debug = 0;
557 break;
559 case OPT_Os:
560 opts->x_optimize_size = 1;
562 /* Optimizing for size forces optimize to be 2. */
563 opts->x_optimize = 2;
564 opts->x_optimize_fast = 0;
565 opts->x_optimize_debug = 0;
566 break;
568 case OPT_Ofast:
569 /* -Ofast only adds flags to -O3. */
570 opts->x_optimize_size = 0;
571 opts->x_optimize = 3;
572 opts->x_optimize_fast = 1;
573 opts->x_optimize_debug = 0;
574 break;
576 case OPT_Og:
577 /* -Og selects optimization level 1. */
578 opts->x_optimize_size = 0;
579 opts->x_optimize = 1;
580 opts->x_optimize_fast = 0;
581 opts->x_optimize_debug = 1;
582 break;
584 default:
585 /* Ignore other options in this prescan. */
586 break;
590 maybe_default_options (opts, opts_set, default_options_table,
591 opts->x_optimize, opts->x_optimize_size,
592 opts->x_optimize_fast, opts->x_optimize_debug,
593 lang_mask, handlers, loc, dc);
595 /* -O2 param settings. */
596 opt2 = (opts->x_optimize >= 2);
598 /* Track fields in field-sensitive alias analysis. */
599 maybe_set_param_value
600 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
601 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
602 opts->x_param_values, opts_set->x_param_values);
604 /* For -O1 only do loop invariant motion for very small loops. */
605 maybe_set_param_value
606 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
607 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
608 opts->x_param_values, opts_set->x_param_values);
610 if (opts->x_optimize_size)
611 /* We want to crossjump as much as possible. */
612 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
613 opts->x_param_values, opts_set->x_param_values);
614 else
615 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
616 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
617 opts->x_param_values, opts_set->x_param_values);
619 /* Allow default optimizations to be specified on a per-machine basis. */
620 maybe_default_options (opts, opts_set,
621 targetm_common.option_optimization_table,
622 opts->x_optimize, opts->x_optimize_size,
623 opts->x_optimize_fast, opts->x_optimize_debug,
624 lang_mask, handlers, loc, dc);
627 /* After all options at LOC have been read into OPTS and OPTS_SET,
628 finalize settings of those options and diagnose incompatible
629 combinations. */
630 void
631 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
632 location_t loc)
634 enum unwind_info_type ui_except;
636 if (opts->x_dump_base_name && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name))
638 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
639 OPTS->X_DUMP_DIR_NAME directory. Then try to make
640 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
641 directory, typically the directory to contain the object
642 file. */
643 if (opts->x_dump_dir_name)
644 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
645 opts->x_dump_base_name, NULL);
646 else if (opts->x_aux_base_name
647 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
649 const char *aux_base;
651 base_of_path (opts->x_aux_base_name, &aux_base);
652 if (opts->x_aux_base_name != aux_base)
654 int dir_len = aux_base - opts->x_aux_base_name;
655 char *new_dump_base_name
656 = XOBNEWVEC (&opts_obstack, char,
657 strlen (opts->x_dump_base_name) + dir_len + 1);
659 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
660 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
661 /* Append existing OPTS->X_DUMP_BASE_NAME. */
662 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
663 opts->x_dump_base_name = new_dump_base_name;
668 /* Handle related options for unit-at-a-time, toplevel-reorder, and
669 section-anchors. */
670 if (!opts->x_flag_unit_at_a_time)
672 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
673 error_at (loc, "section anchors must be disabled when unit-at-a-time "
674 "is disabled");
675 opts->x_flag_section_anchors = 0;
676 if (opts->x_flag_toplevel_reorder == 1)
677 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
678 "is disabled");
679 opts->x_flag_toplevel_reorder = 0;
682 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
683 sorry ("transactional memory is not supported with non-call exceptions");
685 /* Unless the user has asked for section anchors, we disable toplevel
686 reordering at -O0 to disable transformations that might be surprising
687 to end users and to get -fno-toplevel-reorder tested. */
688 if (!opts->x_optimize
689 && opts->x_flag_toplevel_reorder == 2
690 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
692 opts->x_flag_toplevel_reorder = 0;
693 opts->x_flag_section_anchors = 0;
695 if (!opts->x_flag_toplevel_reorder)
697 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
698 error_at (loc, "section anchors must be disabled when toplevel reorder"
699 " is disabled");
700 opts->x_flag_section_anchors = 0;
703 if (!opts->x_flag_opts_finished)
705 if (opts->x_flag_pie)
706 opts->x_flag_pic = opts->x_flag_pie;
707 if (opts->x_flag_pic && !opts->x_flag_pie)
708 opts->x_flag_shlib = 1;
709 opts->x_flag_opts_finished = true;
712 if (opts->x_optimize == 0)
714 /* Inlining does not work if not optimizing,
715 so force it not to be done. */
716 opts->x_warn_inline = 0;
717 opts->x_flag_no_inline = 1;
720 /* The optimization to partition hot and cold basic blocks into separate
721 sections of the .o and executable files does not work (currently)
722 with exception handling. This is because there is no support for
723 generating unwind info. If opts->x_flag_exceptions is turned on
724 we need to turn off the partitioning optimization. */
726 ui_except = targetm_common.except_unwind_info (opts);
728 if (opts->x_flag_exceptions
729 && opts->x_flag_reorder_blocks_and_partition
730 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
732 inform (loc,
733 "-freorder-blocks-and-partition does not work "
734 "with exceptions on this architecture");
735 opts->x_flag_reorder_blocks_and_partition = 0;
736 opts->x_flag_reorder_blocks = 1;
739 /* If user requested unwind info, then turn off the partitioning
740 optimization. */
742 if (opts->x_flag_unwind_tables
743 && !targetm_common.unwind_tables_default
744 && opts->x_flag_reorder_blocks_and_partition
745 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
747 inform (loc,
748 "-freorder-blocks-and-partition does not support "
749 "unwind info on this architecture");
750 opts->x_flag_reorder_blocks_and_partition = 0;
751 opts->x_flag_reorder_blocks = 1;
754 /* If the target requested unwind info, then turn off the partitioning
755 optimization with a different message. Likewise, if the target does not
756 support named sections. */
758 if (opts->x_flag_reorder_blocks_and_partition
759 && (!targetm_common.have_named_sections
760 || (opts->x_flag_unwind_tables
761 && targetm_common.unwind_tables_default
762 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
764 inform (loc,
765 "-freorder-blocks-and-partition does not work "
766 "on this architecture");
767 opts->x_flag_reorder_blocks_and_partition = 0;
768 opts->x_flag_reorder_blocks = 1;
771 if (opts->x_flag_reorder_blocks_and_partition
772 && !opts_set->x_flag_reorder_functions)
773 opts->x_flag_reorder_functions = 1;
775 /* Pipelining of outer loops is only possible when general pipelining
776 capabilities are requested. */
777 if (!opts->x_flag_sel_sched_pipelining)
778 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
780 if (opts->x_flag_conserve_stack)
782 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
783 opts->x_param_values, opts_set->x_param_values);
784 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
785 opts->x_param_values, opts_set->x_param_values);
788 if (opts->x_flag_lto)
790 #ifdef ENABLE_LTO
791 opts->x_flag_generate_lto = 1;
793 /* When generating IL, do not operate in whole-program mode.
794 Otherwise, symbols will be privatized too early, causing link
795 errors later. */
796 opts->x_flag_whole_program = 0;
797 #else
798 error_at (loc, "LTO support has not been enabled in this configuration");
799 #endif
800 if (!opts->x_flag_fat_lto_objects && !HAVE_LTO_PLUGIN)
801 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin.");
803 if ((opts->x_flag_lto_partition_balanced != 0) + (opts->x_flag_lto_partition_1to1 != 0)
804 + (opts->x_flag_lto_partition_none != 0) >= 1)
806 if ((opts->x_flag_lto_partition_balanced != 0)
807 + (opts->x_flag_lto_partition_1to1 != 0)
808 + (opts->x_flag_lto_partition_none != 0) > 1)
809 error_at (loc, "only one -flto-partition value can be specified");
812 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
813 default value if they choose based on other options. */
814 if (opts->x_flag_split_stack == -1)
815 opts->x_flag_split_stack = 0;
816 else if (opts->x_flag_split_stack)
818 if (!targetm_common.supports_split_stack (true, opts))
820 error_at (loc, "%<-fsplit-stack%> is not supported by "
821 "this compiler configuration");
822 opts->x_flag_split_stack = 0;
826 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
827 is disabled. */
828 if (!opts->x_flag_tree_vectorize || !opts->x_flag_tree_loop_if_convert)
829 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
830 opts->x_param_values, opts_set->x_param_values);
832 /* The -gsplit-dwarf option requires -gpubnames. */
833 if (opts->x_dwarf_split_debug_info)
834 opts->x_debug_generate_pub_sections = 1;
837 #define LEFT_COLUMN 27
839 /* Output ITEM, of length ITEM_WIDTH, in the left column,
840 followed by word-wrapped HELP in a second column. */
841 static void
842 wrap_help (const char *help,
843 const char *item,
844 unsigned int item_width,
845 unsigned int columns)
847 unsigned int col_width = LEFT_COLUMN;
848 unsigned int remaining, room, len;
850 remaining = strlen (help);
854 room = columns - 3 - MAX (col_width, item_width);
855 if (room > columns)
856 room = 0;
857 len = remaining;
859 if (room < len)
861 unsigned int i;
863 for (i = 0; help[i]; i++)
865 if (i >= room && len != remaining)
866 break;
867 if (help[i] == ' ')
868 len = i;
869 else if ((help[i] == '-' || help[i] == '/')
870 && help[i + 1] != ' '
871 && i > 0 && ISALPHA (help[i - 1]))
872 len = i + 1;
876 printf( " %-*.*s %.*s\n", col_width, item_width, item, len, help);
877 item_width = 0;
878 while (help[len] == ' ')
879 len++;
880 help += len;
881 remaining -= len;
883 while (remaining);
886 /* Print help for a specific front-end, etc. */
887 static void
888 print_filtered_help (unsigned int include_flags,
889 unsigned int exclude_flags,
890 unsigned int any_flags,
891 unsigned int columns,
892 struct gcc_options *opts,
893 unsigned int lang_mask)
895 unsigned int i;
896 const char *help;
897 bool found = false;
898 bool displayed = false;
900 if (include_flags == CL_PARAMS)
902 for (i = 0; i < LAST_PARAM; i++)
904 const char *param = compiler_params[i].option;
906 help = compiler_params[i].help;
907 if (help == NULL || *help == '\0')
909 if (exclude_flags & CL_UNDOCUMENTED)
910 continue;
911 help = undocumented_msg;
914 /* Get the translation. */
915 help = _(help);
917 wrap_help (help, param, strlen (param), columns);
919 putchar ('\n');
920 return;
923 if (!opts->x_help_printed)
924 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
926 if (!opts->x_help_enum_printed)
927 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
929 for (i = 0; i < cl_options_count; i++)
931 char new_help[128];
932 const struct cl_option *option = cl_options + i;
933 unsigned int len;
934 const char *opt;
935 const char *tab;
937 if (include_flags == 0
938 || ((option->flags & include_flags) != include_flags))
940 if ((option->flags & any_flags) == 0)
941 continue;
944 /* Skip unwanted switches. */
945 if ((option->flags & exclude_flags) != 0)
946 continue;
948 /* The driver currently prints its own help text. */
949 if ((option->flags & CL_DRIVER) != 0
950 && (option->flags & (((1U << cl_lang_count) - 1)
951 | CL_COMMON | CL_TARGET)) == 0)
952 continue;
954 found = true;
955 /* Skip switches that have already been printed. */
956 if (opts->x_help_printed[i])
957 continue;
959 opts->x_help_printed[i] = true;
961 help = option->help;
962 if (help == NULL)
964 if (exclude_flags & CL_UNDOCUMENTED)
965 continue;
966 help = undocumented_msg;
969 /* Get the translation. */
970 help = _(help);
972 /* Find the gap between the name of the
973 option and its descriptive text. */
974 tab = strchr (help, '\t');
975 if (tab)
977 len = tab - help;
978 opt = help;
979 help = tab + 1;
981 else
983 opt = option->opt_text;
984 len = strlen (opt);
987 /* With the -Q option enabled we change the descriptive text associated
988 with an option to be an indication of its current setting. */
989 if (!opts->x_quiet_flag)
991 void *flag_var = option_flag_var (i, opts);
993 if (len < (LEFT_COLUMN + 2))
994 strcpy (new_help, "\t\t");
995 else
996 strcpy (new_help, "\t");
998 if (flag_var != NULL
999 && option->var_type != CLVC_DEFER)
1001 if (option->flags & CL_JOINED)
1003 if (option->var_type == CLVC_STRING)
1005 if (* (const char **) flag_var != NULL)
1006 snprintf (new_help + strlen (new_help),
1007 sizeof (new_help) - strlen (new_help),
1008 * (const char **) flag_var);
1010 else if (option->var_type == CLVC_ENUM)
1012 const struct cl_enum *e = &cl_enums[option->var_enum];
1013 int value;
1014 const char *arg = NULL;
1016 value = e->get (flag_var);
1017 enum_value_to_arg (e->values, &arg, value, lang_mask);
1018 if (arg == NULL)
1019 arg = _("[default]");
1020 snprintf (new_help + strlen (new_help),
1021 sizeof (new_help) - strlen (new_help),
1022 arg);
1024 else
1025 sprintf (new_help + strlen (new_help),
1026 "%#x", * (int *) flag_var);
1028 else
1029 strcat (new_help, option_enabled (i, opts)
1030 ? _("[enabled]") : _("[disabled]"));
1033 help = new_help;
1036 wrap_help (help, opt, len, columns);
1037 displayed = true;
1039 if (option->var_type == CLVC_ENUM
1040 && opts->x_help_enum_printed[option->var_enum] != 2)
1041 opts->x_help_enum_printed[option->var_enum] = 1;
1044 if (! found)
1046 unsigned int langs = include_flags & CL_LANG_ALL;
1048 if (langs == 0)
1049 printf (_(" No options with the desired characteristics were found\n"));
1050 else
1052 unsigned int i;
1054 /* PR 31349: Tell the user how to see all of the
1055 options supported by a specific front end. */
1056 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1057 if ((1U << i) & langs)
1058 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end\n"),
1059 lang_names[i], lang_names[i]);
1063 else if (! displayed)
1064 printf (_(" All options with the desired characteristics have already been displayed\n"));
1066 putchar ('\n');
1068 /* Print details of enumerated option arguments, if those
1069 enumerations have help text headings provided. If no help text
1070 is provided, presume that the possible values are listed in the
1071 help text for the relevant options. */
1072 for (i = 0; i < cl_enums_count; i++)
1074 unsigned int j, pos;
1076 if (opts->x_help_enum_printed[i] != 1)
1077 continue;
1078 if (cl_enums[i].help == NULL)
1079 continue;
1080 printf (" %s\n ", _(cl_enums[i].help));
1081 pos = 4;
1082 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1084 unsigned int len = strlen (cl_enums[i].values[j].arg);
1086 if (pos > 4 && pos + 1 + len <= columns)
1088 printf (" %s", cl_enums[i].values[j].arg);
1089 pos += 1 + len;
1091 else
1093 if (pos > 4)
1095 printf ("\n ");
1096 pos = 4;
1098 printf ("%s", cl_enums[i].values[j].arg);
1099 pos += len;
1102 printf ("\n\n");
1103 opts->x_help_enum_printed[i] = 2;
1107 /* Display help for a specified type of option.
1108 The options must have ALL of the INCLUDE_FLAGS set
1109 ANY of the flags in the ANY_FLAGS set
1110 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1111 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1112 static void
1113 print_specific_help (unsigned int include_flags,
1114 unsigned int exclude_flags,
1115 unsigned int any_flags,
1116 struct gcc_options *opts,
1117 unsigned int lang_mask)
1119 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1120 const char * description = NULL;
1121 const char * descrip_extra = "";
1122 size_t i;
1123 unsigned int flag;
1125 /* Sanity check: Make sure that we do not have more
1126 languages than we have bits available to enumerate them. */
1127 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1129 /* If we have not done so already, obtain
1130 the desired maximum width of the output. */
1131 if (opts->x_help_columns == 0)
1133 const char *p;
1135 p = getenv ("COLUMNS");
1136 if (p != NULL)
1138 int value = atoi (p);
1140 if (value > 0)
1141 opts->x_help_columns = value;
1144 if (opts->x_help_columns == 0)
1145 /* Use a reasonable default. */
1146 opts->x_help_columns = 80;
1149 /* Decide upon the title for the options that we are going to display. */
1150 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1152 switch (flag & include_flags)
1154 case 0:
1155 case CL_DRIVER:
1156 break;
1158 case CL_TARGET:
1159 description = _("The following options are target specific");
1160 break;
1161 case CL_WARNING:
1162 description = _("The following options control compiler warning messages");
1163 break;
1164 case CL_OPTIMIZATION:
1165 description = _("The following options control optimizations");
1166 break;
1167 case CL_COMMON:
1168 description = _("The following options are language-independent");
1169 break;
1170 case CL_PARAMS:
1171 description = _("The --param option recognizes the following as parameters");
1172 break;
1173 default:
1174 if (i >= cl_lang_count)
1175 break;
1176 if (exclude_flags & all_langs_mask)
1177 description = _("The following options are specific to just the language ");
1178 else
1179 description = _("The following options are supported by the language ");
1180 descrip_extra = lang_names [i];
1181 break;
1185 if (description == NULL)
1187 if (any_flags == 0)
1189 if (include_flags & CL_UNDOCUMENTED)
1190 description = _("The following options are not documented");
1191 else if (include_flags & CL_SEPARATE)
1192 description = _("The following options take separate arguments");
1193 else if (include_flags & CL_JOINED)
1194 description = _("The following options take joined arguments");
1195 else
1197 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1198 include_flags);
1199 return;
1202 else
1204 if (any_flags & all_langs_mask)
1205 description = _("The following options are language-related");
1206 else
1207 description = _("The following options are language-independent");
1211 printf ("%s%s:\n", description, descrip_extra);
1212 print_filtered_help (include_flags, exclude_flags, any_flags,
1213 opts->x_help_columns, opts, lang_mask);
1216 /* Handle target- and language-independent options. Return zero to
1217 generate an "unknown option" message. Only options that need
1218 extra handling need to be listed here; if you simply want
1219 DECODED->value assigned to a variable, it happens automatically. */
1221 bool
1222 common_handle_option (struct gcc_options *opts,
1223 struct gcc_options *opts_set,
1224 const struct cl_decoded_option *decoded,
1225 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1226 location_t loc,
1227 const struct cl_option_handlers *handlers,
1228 diagnostic_context *dc)
1230 size_t scode = decoded->opt_index;
1231 const char *arg = decoded->arg;
1232 int value = decoded->value;
1233 enum opt_code code = (enum opt_code) scode;
1235 gcc_assert (decoded->canonical_option_num_elements <= 2);
1237 switch (code)
1239 case OPT__param:
1240 handle_param (opts, opts_set, loc, arg);
1241 break;
1243 case OPT__help:
1245 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1246 unsigned int undoc_mask;
1247 unsigned int i;
1249 if (lang_mask == CL_DRIVER)
1250 break;;
1252 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1254 : CL_UNDOCUMENTED);
1255 /* First display any single language specific options. */
1256 for (i = 0; i < cl_lang_count; i++)
1257 print_specific_help
1258 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1259 lang_mask);
1260 /* Next display any multi language specific options. */
1261 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1262 /* Then display any remaining, non-language options. */
1263 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1264 if (i != CL_DRIVER)
1265 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1266 opts->x_exit_after_options = true;
1267 break;
1270 case OPT__target_help:
1271 if (lang_mask == CL_DRIVER)
1272 break;
1274 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1275 opts->x_exit_after_options = true;
1276 break;
1278 case OPT__help_:
1280 const char * a = arg;
1281 unsigned int include_flags = 0;
1282 /* Note - by default we include undocumented options when listing
1283 specific classes. If you only want to see documented options
1284 then add ",^undocumented" to the --help= option. E.g.:
1286 --help=target,^undocumented */
1287 unsigned int exclude_flags = 0;
1289 if (lang_mask == CL_DRIVER)
1290 break;
1292 /* Walk along the argument string, parsing each word in turn.
1293 The format is:
1294 arg = [^]{word}[,{arg}]
1295 word = {optimizers|target|warnings|undocumented|
1296 params|common|<language>} */
1297 while (* a != 0)
1299 static const struct
1301 const char * string;
1302 unsigned int flag;
1304 specifics[] =
1306 { "optimizers", CL_OPTIMIZATION },
1307 { "target", CL_TARGET },
1308 { "warnings", CL_WARNING },
1309 { "undocumented", CL_UNDOCUMENTED },
1310 { "params", CL_PARAMS },
1311 { "joined", CL_JOINED },
1312 { "separate", CL_SEPARATE },
1313 { "common", CL_COMMON },
1314 { NULL, 0 }
1316 unsigned int * pflags;
1317 const char * comma;
1318 unsigned int lang_flag, specific_flag;
1319 unsigned int len;
1320 unsigned int i;
1322 if (* a == '^')
1324 ++ a;
1325 pflags = & exclude_flags;
1327 else
1328 pflags = & include_flags;
1330 comma = strchr (a, ',');
1331 if (comma == NULL)
1332 len = strlen (a);
1333 else
1334 len = comma - a;
1335 if (len == 0)
1337 a = comma + 1;
1338 continue;
1341 /* Check to see if the string matches an option class name. */
1342 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1343 if (strncasecmp (a, specifics[i].string, len) == 0)
1345 specific_flag = specifics[i].flag;
1346 break;
1349 /* Check to see if the string matches a language name.
1350 Note - we rely upon the alpha-sorted nature of the entries in
1351 the lang_names array, specifically that shorter names appear
1352 before their longer variants. (i.e. C before C++). That way
1353 when we are attempting to match --help=c for example we will
1354 match with C first and not C++. */
1355 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1356 if (strncasecmp (a, lang_names[i], len) == 0)
1358 lang_flag = 1U << i;
1359 break;
1362 if (specific_flag != 0)
1364 if (lang_flag == 0)
1365 * pflags |= specific_flag;
1366 else
1368 /* The option's argument matches both the start of a
1369 language name and the start of an option class name.
1370 We have a special case for when the user has
1371 specified "--help=c", but otherwise we have to issue
1372 a warning. */
1373 if (strncasecmp (a, "c", len) == 0)
1374 * pflags |= lang_flag;
1375 else
1376 warning_at (loc, 0,
1377 "--help argument %q.*s is ambiguous, "
1378 "please be more specific",
1379 len, a);
1382 else if (lang_flag != 0)
1383 * pflags |= lang_flag;
1384 else
1385 warning_at (loc, 0,
1386 "unrecognized argument to --help= option: %q.*s",
1387 len, a);
1389 if (comma == NULL)
1390 break;
1391 a = comma + 1;
1394 if (include_flags)
1395 print_specific_help (include_flags, exclude_flags, 0, opts,
1396 lang_mask);
1397 opts->x_exit_after_options = true;
1398 break;
1401 case OPT__version:
1402 if (lang_mask == CL_DRIVER)
1403 break;
1405 opts->x_exit_after_options = true;
1406 break;
1408 case OPT_O:
1409 case OPT_Os:
1410 case OPT_Ofast:
1411 case OPT_Og:
1412 /* Currently handled in a prescan. */
1413 break;
1415 case OPT_Werror:
1416 dc->warning_as_error_requested = value;
1417 break;
1419 case OPT_Werror_:
1420 if (lang_mask == CL_DRIVER)
1421 break;
1423 enable_warning_as_error (arg, value, lang_mask, handlers,
1424 opts, opts_set, loc, dc);
1425 break;
1427 case OPT_Wlarger_than_:
1428 opts->x_larger_than_size = value;
1429 opts->x_warn_larger_than = value != -1;
1430 break;
1432 case OPT_Wfatal_errors:
1433 dc->fatal_errors = value;
1434 break;
1436 case OPT_Wframe_larger_than_:
1437 opts->x_frame_larger_than_size = value;
1438 opts->x_warn_frame_larger_than = value != -1;
1439 break;
1441 case OPT_Wstack_usage_:
1442 opts->x_warn_stack_usage = value;
1443 opts->x_flag_stack_usage_info = value != -1;
1444 break;
1446 case OPT_Wstrict_aliasing:
1447 set_Wstrict_aliasing (opts, value);
1448 break;
1450 case OPT_Wstrict_overflow:
1451 opts->x_warn_strict_overflow = (value
1452 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1453 : 0);
1454 break;
1456 case OPT_Wsystem_headers:
1457 dc->dc_warn_system_headers = value;
1458 break;
1460 case OPT_aux_info:
1461 opts->x_flag_gen_aux_info = 1;
1462 break;
1464 case OPT_auxbase_strip:
1466 char *tmp = xstrdup (arg);
1467 strip_off_ending (tmp, strlen (tmp));
1468 if (tmp[0])
1469 opts->x_aux_base_name = tmp;
1470 else
1471 free (tmp);
1473 break;
1475 case OPT_d:
1476 decode_d_option (arg, opts, loc, dc);
1477 break;
1479 case OPT_fcall_used_:
1480 case OPT_fcall_saved_:
1481 /* Deferred. */
1482 break;
1484 case OPT_fdbg_cnt_:
1485 case OPT_fdbg_cnt_list:
1486 /* Deferred. */
1487 break;
1489 case OPT_fdebug_prefix_map_:
1490 /* Deferred. */
1491 break;
1493 case OPT_fdiagnostics_show_location_:
1494 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1495 break;
1497 case OPT_fdiagnostics_show_caret:
1498 dc->show_caret = value;
1499 break;
1501 case OPT_fdiagnostics_color_:
1502 pp_show_color (dc->printer)
1503 = colorize_init ((diagnostic_color_rule_t) value);
1504 break;
1506 case OPT_fdiagnostics_show_option:
1507 dc->show_option_requested = value;
1508 break;
1510 case OPT_fdump_:
1511 /* Deferred. */
1512 break;
1514 case OPT_ffast_math:
1515 set_fast_math_flags (opts, value);
1516 break;
1518 case OPT_funsafe_math_optimizations:
1519 set_unsafe_math_optimizations_flags (opts, value);
1520 break;
1522 case OPT_ffixed_:
1523 /* Deferred. */
1524 break;
1526 case OPT_finline_limit_:
1527 set_param_value ("max-inline-insns-single", value / 2,
1528 opts->x_param_values, opts_set->x_param_values);
1529 set_param_value ("max-inline-insns-auto", value / 2,
1530 opts->x_param_values, opts_set->x_param_values);
1531 break;
1533 case OPT_finstrument_functions_exclude_function_list_:
1534 add_comma_separated_to_vector
1535 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1536 break;
1538 case OPT_finstrument_functions_exclude_file_list_:
1539 add_comma_separated_to_vector
1540 (&opts->x_flag_instrument_functions_exclude_files, arg);
1541 break;
1543 case OPT_fmessage_length_:
1544 pp_set_line_maximum_length (dc->printer, value);
1545 diagnostic_set_caret_max_width (dc, value);
1546 break;
1548 case OPT_fopt_info:
1549 case OPT_fopt_info_:
1550 /* Deferred. */
1551 break;
1553 case OPT_fpack_struct_:
1554 if (value <= 0 || (value & (value - 1)) || value > 16)
1555 error_at (loc,
1556 "structure alignment must be a small power of two, not %d",
1557 value);
1558 else
1559 opts->x_initial_max_fld_align = value;
1560 break;
1562 case OPT_fplugin_:
1563 case OPT_fplugin_arg_:
1564 /* Deferred. */
1565 break;
1567 case OPT_fprofile_use_:
1568 opts->x_profile_data_prefix = xstrdup (arg);
1569 opts->x_flag_profile_use = true;
1570 value = true;
1571 /* No break here - do -fprofile-use processing. */
1572 case OPT_fprofile_use:
1573 if (!opts_set->x_flag_branch_probabilities)
1574 opts->x_flag_branch_probabilities = value;
1575 if (!opts_set->x_flag_profile_values)
1576 opts->x_flag_profile_values = value;
1577 if (!opts_set->x_flag_unroll_loops)
1578 opts->x_flag_unroll_loops = value;
1579 if (!opts_set->x_flag_peel_loops)
1580 opts->x_flag_peel_loops = value;
1581 if (!opts_set->x_flag_tracer)
1582 opts->x_flag_tracer = value;
1583 if (!opts_set->x_flag_value_profile_transformations)
1584 opts->x_flag_value_profile_transformations = value;
1585 if (!opts_set->x_flag_inline_functions)
1586 opts->x_flag_inline_functions = value;
1587 if (!opts_set->x_flag_ipa_cp)
1588 opts->x_flag_ipa_cp = value;
1589 if (!opts_set->x_flag_ipa_cp_clone
1590 && value && opts->x_flag_ipa_cp)
1591 opts->x_flag_ipa_cp_clone = value;
1592 if (!opts_set->x_flag_predictive_commoning)
1593 opts->x_flag_predictive_commoning = value;
1594 if (!opts_set->x_flag_unswitch_loops)
1595 opts->x_flag_unswitch_loops = value;
1596 if (!opts_set->x_flag_gcse_after_reload)
1597 opts->x_flag_gcse_after_reload = value;
1598 if (!opts_set->x_flag_tree_vectorize)
1599 opts->x_flag_tree_vectorize = value;
1600 if (!opts_set->x_flag_vect_cost_model)
1601 opts->x_flag_vect_cost_model = value;
1602 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1603 opts->x_flag_tree_loop_distribute_patterns = value;
1604 break;
1606 case OPT_fprofile_generate_:
1607 opts->x_profile_data_prefix = xstrdup (arg);
1608 value = true;
1609 /* No break here - do -fprofile-generate processing. */
1610 case OPT_fprofile_generate:
1611 if (!opts_set->x_profile_arc_flag)
1612 opts->x_profile_arc_flag = value;
1613 if (!opts_set->x_flag_profile_values)
1614 opts->x_flag_profile_values = value;
1615 if (!opts_set->x_flag_inline_functions)
1616 opts->x_flag_inline_functions = value;
1617 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1618 quadratic. Disable the pass until better memory representation
1619 is done. */
1620 if (!opts_set->x_flag_ipa_reference && opts->x_in_lto_p)
1621 opts->x_flag_ipa_reference = false;
1622 break;
1624 case OPT_fshow_column:
1625 dc->show_column = value;
1626 break;
1628 case OPT_frandom_seed:
1629 /* The real switch is -fno-random-seed. */
1630 if (value)
1631 return false;
1632 /* Deferred. */
1633 break;
1635 case OPT_frandom_seed_:
1636 /* Deferred. */
1637 break;
1639 case OPT_fsched_verbose_:
1640 #ifdef INSN_SCHEDULING
1641 /* Handled with Var in common.opt. */
1642 break;
1643 #else
1644 return false;
1645 #endif
1647 case OPT_fsched_stalled_insns_:
1648 opts->x_flag_sched_stalled_insns = value;
1649 if (opts->x_flag_sched_stalled_insns == 0)
1650 opts->x_flag_sched_stalled_insns = -1;
1651 break;
1653 case OPT_fsched_stalled_insns_dep_:
1654 opts->x_flag_sched_stalled_insns_dep = value;
1655 break;
1657 case OPT_fstack_check_:
1658 if (!strcmp (arg, "no"))
1659 opts->x_flag_stack_check = NO_STACK_CHECK;
1660 else if (!strcmp (arg, "generic"))
1661 /* This is the old stack checking method. */
1662 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1663 ? FULL_BUILTIN_STACK_CHECK
1664 : GENERIC_STACK_CHECK;
1665 else if (!strcmp (arg, "specific"))
1666 /* This is the new stack checking method. */
1667 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1668 ? FULL_BUILTIN_STACK_CHECK
1669 : STACK_CHECK_STATIC_BUILTIN
1670 ? STATIC_BUILTIN_STACK_CHECK
1671 : GENERIC_STACK_CHECK;
1672 else
1673 warning_at (loc, 0, "unknown stack check parameter \"%s\"", arg);
1674 break;
1676 case OPT_fstack_limit:
1677 /* The real switch is -fno-stack-limit. */
1678 if (value)
1679 return false;
1680 /* Deferred. */
1681 break;
1683 case OPT_fstack_limit_register_:
1684 case OPT_fstack_limit_symbol_:
1685 /* Deferred. */
1686 break;
1688 case OPT_fstack_usage:
1689 opts->x_flag_stack_usage = value;
1690 opts->x_flag_stack_usage_info = value != 0;
1691 break;
1693 case OPT_ftree_vectorizer_verbose_:
1694 /* -ftree-vectorizer-verbose is deprecated. It is defined in
1695 -terms of fopt-info=N. */
1696 /* Deferred. */
1697 break;
1699 case OPT_g:
1700 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
1701 loc);
1702 break;
1704 case OPT_gcoff:
1705 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
1706 break;
1708 case OPT_gdwarf:
1709 if (arg && strlen (arg) != 0)
1711 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
1712 "use %<-gdwarf-%s%> for DWARF version "
1713 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
1714 break;
1716 else
1717 value = opts->x_dwarf_version;
1719 /* FALLTHRU */
1720 case OPT_gdwarf_:
1721 if (value < 2 || value > 4)
1722 error_at (loc, "dwarf version %d is not supported", value);
1723 else
1724 opts->x_dwarf_version = value;
1725 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
1726 break;
1728 case OPT_gsplit_dwarf:
1729 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
1730 loc);
1731 break;
1733 case OPT_ggdb:
1734 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
1735 break;
1737 case OPT_gstabs:
1738 case OPT_gstabs_:
1739 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
1740 loc);
1741 break;
1743 case OPT_gvms:
1744 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
1745 break;
1747 case OPT_gxcoff:
1748 case OPT_gxcoff_:
1749 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
1750 loc);
1751 break;
1753 case OPT_pedantic_errors:
1754 dc->pedantic_errors = 1;
1755 control_warning_option (OPT_Wpedantic, DK_ERROR, value,
1756 loc, lang_mask,
1757 handlers, opts, opts_set,
1758 dc);
1759 break;
1761 case OPT_flto:
1762 opts->x_flag_lto = value ? "" : NULL;
1763 break;
1765 case OPT_w:
1766 dc->dc_inhibit_warnings = true;
1767 break;
1769 case OPT_fmax_errors_:
1770 dc->max_errors = value;
1771 break;
1773 case OPT_fuse_ld_bfd:
1774 case OPT_fuse_ld_gold:
1775 case OPT_fuse_linker_plugin:
1776 /* No-op. Used by the driver and passed to us because it starts with f.*/
1777 break;
1779 case OPT_fwrapv:
1780 if (value)
1781 opts->x_flag_trapv = 0;
1782 break;
1784 case OPT_ftrapv:
1785 if (value)
1786 opts->x_flag_wrapv = 0;
1787 break;
1789 default:
1790 /* If the flag was handled in a standard way, assume the lack of
1791 processing here is intentional. */
1792 gcc_assert (option_flag_var (scode, opts));
1793 break;
1796 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
1797 loc, handlers, dc);
1798 return true;
1801 /* Handle --param NAME=VALUE. */
1802 static void
1803 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
1804 location_t loc, const char *carg)
1806 char *equal, *arg;
1807 int value;
1809 arg = xstrdup (carg);
1810 equal = strchr (arg, '=');
1811 if (!equal)
1812 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
1813 arg);
1814 else
1816 value = integral_argument (equal + 1);
1817 if (value == -1)
1818 error_at (loc, "invalid --param value %qs", equal + 1);
1819 else
1821 *equal = '\0';
1822 set_param_value (arg, value,
1823 opts->x_param_values, opts_set->x_param_values);
1827 free (arg);
1830 /* Used to set the level of strict aliasing warnings in OPTS,
1831 when no level is specified (i.e., when -Wstrict-aliasing, and not
1832 -Wstrict-aliasing=level was given).
1833 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
1834 and 0 otherwise. After calling this function, wstrict_aliasing will be
1835 set to the default value of -Wstrict_aliasing=level, currently 3. */
1836 static void
1837 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
1839 gcc_assert (onoff == 0 || onoff == 1);
1840 if (onoff != 0)
1841 opts->x_warn_strict_aliasing = 3;
1842 else
1843 opts->x_warn_strict_aliasing = 0;
1846 /* The following routines are useful in setting all the flags that
1847 -ffast-math and -fno-fast-math imply. */
1848 static void
1849 set_fast_math_flags (struct gcc_options *opts, int set)
1851 if (!opts->frontend_set_flag_unsafe_math_optimizations)
1853 opts->x_flag_unsafe_math_optimizations = set;
1854 set_unsafe_math_optimizations_flags (opts, set);
1856 if (!opts->frontend_set_flag_finite_math_only)
1857 opts->x_flag_finite_math_only = set;
1858 if (!opts->frontend_set_flag_errno_math)
1859 opts->x_flag_errno_math = !set;
1860 if (set)
1862 if (!opts->frontend_set_flag_signaling_nans)
1863 opts->x_flag_signaling_nans = 0;
1864 if (!opts->frontend_set_flag_rounding_math)
1865 opts->x_flag_rounding_math = 0;
1866 if (!opts->frontend_set_flag_cx_limited_range)
1867 opts->x_flag_cx_limited_range = 1;
1871 /* When -funsafe-math-optimizations is set the following
1872 flags are set as well. */
1873 static void
1874 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
1876 if (!opts->frontend_set_flag_trapping_math)
1877 opts->x_flag_trapping_math = !set;
1878 if (!opts->frontend_set_flag_signed_zeros)
1879 opts->x_flag_signed_zeros = !set;
1880 if (!opts->frontend_set_flag_associative_math)
1881 opts->x_flag_associative_math = set;
1882 if (!opts->frontend_set_flag_reciprocal_math)
1883 opts->x_flag_reciprocal_math = set;
1886 /* Return true iff flags in OPTS are set as if -ffast-math. */
1887 bool
1888 fast_math_flags_set_p (const struct gcc_options *opts)
1890 return (!opts->x_flag_trapping_math
1891 && opts->x_flag_unsafe_math_optimizations
1892 && opts->x_flag_finite_math_only
1893 && !opts->x_flag_signed_zeros
1894 && !opts->x_flag_errno_math);
1897 /* Return true iff flags are set as if -ffast-math but using the flags stored
1898 in the struct cl_optimization structure. */
1899 bool
1900 fast_math_flags_struct_set_p (struct cl_optimization *opt)
1902 return (!opt->x_flag_trapping_math
1903 && opt->x_flag_unsafe_math_optimizations
1904 && opt->x_flag_finite_math_only
1905 && !opt->x_flag_signed_zeros
1906 && !opt->x_flag_errno_math);
1909 /* Handle a debug output -g switch for options OPTS
1910 (OPTS_SET->x_write_symbols storing whether a debug type was passed
1911 explicitly), location LOC. EXTENDED is true or false to support
1912 extended output (2 is special and means "-ggdb" was given). */
1913 static void
1914 set_debug_level (enum debug_info_type type, int extended, const char *arg,
1915 struct gcc_options *opts, struct gcc_options *opts_set,
1916 location_t loc)
1918 opts->x_use_gnu_debug_info_extensions = extended;
1920 if (type == NO_DEBUG)
1922 if (opts->x_write_symbols == NO_DEBUG)
1924 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
1926 if (extended == 2)
1928 #ifdef DWARF2_DEBUGGING_INFO
1929 opts->x_write_symbols = DWARF2_DEBUG;
1930 #elif defined DBX_DEBUGGING_INFO
1931 opts->x_write_symbols = DBX_DEBUG;
1932 #endif
1935 if (opts->x_write_symbols == NO_DEBUG)
1936 warning_at (loc, 0, "target system does not support debug output");
1939 else
1941 /* Does it conflict with an already selected type? */
1942 if (opts_set->x_write_symbols != NO_DEBUG
1943 && opts->x_write_symbols != NO_DEBUG
1944 && type != opts->x_write_symbols)
1945 error_at (loc, "debug format \"%s\" conflicts with prior selection",
1946 debug_type_names[type]);
1947 opts->x_write_symbols = type;
1948 opts_set->x_write_symbols = type;
1951 /* A debug flag without a level defaults to level 2. */
1952 if (*arg == '\0')
1954 if (!opts->x_debug_info_level)
1955 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
1957 else
1959 int argval = integral_argument (arg);
1960 if (argval == -1)
1961 error_at (loc, "unrecognised debug output level \"%s\"", arg);
1962 else if (argval > 3)
1963 error_at (loc, "debug output level %s is too high", arg);
1964 else
1965 opts->x_debug_info_level = (enum debug_info_levels) argval;
1969 /* Arrange to dump core on error for diagnostic context DC. (The
1970 regular error message is still printed first, except in the case of
1971 abort ().) */
1973 static void
1974 setup_core_dumping (diagnostic_context *dc)
1976 #ifdef SIGABRT
1977 signal (SIGABRT, SIG_DFL);
1978 #endif
1979 #if defined(HAVE_SETRLIMIT)
1981 struct rlimit rlim;
1982 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
1983 fatal_error ("getting core file size maximum limit: %m");
1984 rlim.rlim_cur = rlim.rlim_max;
1985 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
1986 fatal_error ("setting core file size limit to maximum: %m");
1988 #endif
1989 diagnostic_abort_on_error (dc);
1992 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
1993 diagnostic context DC. */
1995 static void
1996 decode_d_option (const char *arg, struct gcc_options *opts,
1997 location_t loc, diagnostic_context *dc)
1999 int c;
2001 while (*arg)
2002 switch (c = *arg++)
2004 case 'A':
2005 opts->x_flag_debug_asm = 1;
2006 break;
2007 case 'p':
2008 opts->x_flag_print_asm_name = 1;
2009 break;
2010 case 'P':
2011 opts->x_flag_dump_rtl_in_asm = 1;
2012 opts->x_flag_print_asm_name = 1;
2013 break;
2014 case 'x':
2015 opts->x_rtl_dump_and_exit = 1;
2016 break;
2017 case 'D': /* These are handled by the preprocessor. */
2018 case 'I':
2019 case 'M':
2020 case 'N':
2021 case 'U':
2022 break;
2023 case 'H':
2024 setup_core_dumping (dc);
2025 break;
2026 case 'a':
2027 opts->x_flag_dump_all_passed = true;
2028 break;
2030 default:
2031 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2032 break;
2036 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2037 mask LANG_MASK, option handlers HANDLERS) as an error for option
2038 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2039 NULL), location LOC. This is used by -Werror=. */
2041 static void
2042 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2043 const struct cl_option_handlers *handlers,
2044 struct gcc_options *opts,
2045 struct gcc_options *opts_set,
2046 location_t loc, diagnostic_context *dc)
2048 char *new_option;
2049 int option_index;
2051 new_option = XNEWVEC (char, strlen (arg) + 2);
2052 new_option[0] = 'W';
2053 strcpy (new_option + 1, arg);
2054 option_index = find_opt (new_option, lang_mask);
2055 if (option_index == OPT_SPECIAL_unknown)
2057 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2059 else
2061 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2063 control_warning_option (option_index, (int) kind, value,
2064 loc, lang_mask,
2065 handlers, opts, opts_set, dc);
2067 free (new_option);
2070 /* Return malloced memory for the name of the option OPTION_INDEX
2071 which enabled a diagnostic (context CONTEXT), originally of type
2072 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2073 as -Werror. */
2075 char *
2076 option_name (diagnostic_context *context, int option_index,
2077 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2079 if (option_index)
2081 /* A warning classified as an error. */
2082 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2083 && diag_kind == DK_ERROR)
2084 return concat (cl_options[OPT_Werror_].opt_text,
2085 /* Skip over "-W". */
2086 cl_options[option_index].opt_text + 2,
2087 NULL);
2088 /* A warning with option. */
2089 else
2090 return xstrdup (cl_options[option_index].opt_text);
2092 /* A warning without option classified as an error. */
2093 else if (orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2094 || diag_kind == DK_WARNING)
2096 if (context->warning_as_error_requested)
2097 return xstrdup (cl_options[OPT_Werror].opt_text);
2098 else
2099 return xstrdup (_("enabled by default"));
2101 else
2102 return NULL;