* genattr-common.c: New. Based on genattr.c.
[official-gcc.git] / gcc / opts.c
blobc3e7bc7e3e1b16df72041183a5c07ab479361f42
1 /* Command line option handling.
2 Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011
3 Free Software Foundation, Inc.
4 Contributed by Neil Booth.
6 This file is part of GCC.
8 GCC is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 3, or (at your option) any later
11 version.
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 for more details.
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING3. If not see
20 <http://www.gnu.org/licenses/>. */
22 #include "config.h"
23 #include "system.h"
24 #include "intl.h"
25 #include "coretypes.h"
26 #include "tm.h" /* For STACK_CHECK_BUILTIN,
27 STACK_CHECK_STATIC_BUILTIN, DEFAULT_GDB_EXTENSIONS,
28 DWARF2_DEBUGGING_INFO and DBX_DEBUGGING_INFO. */
29 #include "opts.h"
30 #include "options.h"
31 #include "flags.h"
32 #include "params.h"
33 #include "diagnostic.h"
34 #include "opts-diagnostic.h"
35 #include "insn-attr-common.h"
36 #include "common/common-target.h"
38 /* Parse the -femit-struct-debug-detailed option value
39 and set the flag variables. */
41 #define MATCH( prefix, string ) \
42 ((strncmp (prefix, string, sizeof prefix - 1) == 0) \
43 ? ((string += sizeof prefix - 1), 1) : 0)
45 void
46 set_struct_debug_option (struct gcc_options *opts, location_t loc,
47 const char *spec)
49 /* various labels for comparison */
50 static const char dfn_lbl[] = "dfn:", dir_lbl[] = "dir:", ind_lbl[] = "ind:";
51 static const char ord_lbl[] = "ord:", gen_lbl[] = "gen:";
52 static const char none_lbl[] = "none", any_lbl[] = "any";
53 static const char base_lbl[] = "base", sys_lbl[] = "sys";
55 enum debug_struct_file files = DINFO_STRUCT_FILE_ANY;
56 /* Default is to apply to as much as possible. */
57 enum debug_info_usage usage = DINFO_USAGE_NUM_ENUMS;
58 int ord = 1, gen = 1;
60 /* What usage? */
61 if (MATCH (dfn_lbl, spec))
62 usage = DINFO_USAGE_DFN;
63 else if (MATCH (dir_lbl, spec))
64 usage = DINFO_USAGE_DIR_USE;
65 else if (MATCH (ind_lbl, spec))
66 usage = DINFO_USAGE_IND_USE;
68 /* Generics or not? */
69 if (MATCH (ord_lbl, spec))
70 gen = 0;
71 else if (MATCH (gen_lbl, spec))
72 ord = 0;
74 /* What allowable environment? */
75 if (MATCH (none_lbl, spec))
76 files = DINFO_STRUCT_FILE_NONE;
77 else if (MATCH (any_lbl, spec))
78 files = DINFO_STRUCT_FILE_ANY;
79 else if (MATCH (sys_lbl, spec))
80 files = DINFO_STRUCT_FILE_SYS;
81 else if (MATCH (base_lbl, spec))
82 files = DINFO_STRUCT_FILE_BASE;
83 else
84 error_at (loc,
85 "argument %qs to %<-femit-struct-debug-detailed%> "
86 "not recognized",
87 spec);
89 /* Effect the specification. */
90 if (usage == DINFO_USAGE_NUM_ENUMS)
92 if (ord)
94 opts->x_debug_struct_ordinary[DINFO_USAGE_DFN] = files;
95 opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE] = files;
96 opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE] = files;
98 if (gen)
100 opts->x_debug_struct_generic[DINFO_USAGE_DFN] = files;
101 opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE] = files;
102 opts->x_debug_struct_generic[DINFO_USAGE_IND_USE] = files;
105 else
107 if (ord)
108 opts->x_debug_struct_ordinary[usage] = files;
109 if (gen)
110 opts->x_debug_struct_generic[usage] = files;
113 if (*spec == ',')
114 set_struct_debug_option (opts, loc, spec+1);
115 else
117 /* No more -femit-struct-debug-detailed specifications.
118 Do final checks. */
119 if (*spec != '\0')
120 error_at (loc,
121 "argument %qs to %<-femit-struct-debug-detailed%> unknown",
122 spec);
123 if (opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE]
124 < opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE]
125 || opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE]
126 < opts->x_debug_struct_generic[DINFO_USAGE_IND_USE])
127 error_at (loc,
128 "%<-femit-struct-debug-detailed=dir:...%> must allow "
129 "at least as much as "
130 "%<-femit-struct-debug-detailed=ind:...%>");
134 /* Handle -ftree-vectorizer-verbose=VAL for options OPTS. */
136 static void
137 vect_set_verbosity_level (struct gcc_options *opts, int val)
139 if (val < MAX_VERBOSITY_LEVEL)
140 opts->x_user_vect_verbosity_level = (enum vect_verbosity_levels) val;
141 else
142 opts->x_user_vect_verbosity_level
143 = (enum vect_verbosity_levels) (MAX_VERBOSITY_LEVEL - 1);
147 /* Strip off a legitimate source ending from the input string NAME of
148 length LEN. Rather than having to know the names used by all of
149 our front ends, we strip off an ending of a period followed by
150 up to five characters. (Java uses ".class".) */
152 void
153 strip_off_ending (char *name, int len)
155 int i;
156 for (i = 2; i < 6 && len > i; i++)
158 if (name[len - i] == '.')
160 name[len - i] = '\0';
161 break;
166 /* Find the base name of a path, stripping off both directories and
167 a single final extension. */
169 base_of_path (const char *path, const char **base_out)
171 const char *base = path;
172 const char *dot = 0;
173 const char *p = path;
174 char c = *p;
175 while (c)
177 if (IS_DIR_SEPARATOR(c))
179 base = p + 1;
180 dot = 0;
182 else if (c == '.')
183 dot = p;
184 c = *++p;
186 if (!dot)
187 dot = p;
188 *base_out = base;
189 return dot - base;
192 /* What to print when a switch has no documentation. */
193 static const char undocumented_msg[] = N_("This switch lacks documentation");
195 typedef char *char_p; /* For DEF_VEC_P. */
196 DEF_VEC_P(char_p);
197 DEF_VEC_ALLOC_P(char_p,heap);
199 static void handle_param (struct gcc_options *opts,
200 struct gcc_options *opts_set, location_t loc,
201 const char *carg);
202 static void set_debug_level (enum debug_info_type type, int extended,
203 const char *arg, struct gcc_options *opts,
204 struct gcc_options *opts_set,
205 location_t loc);
206 static void set_fast_math_flags (struct gcc_options *opts, int set);
207 static void decode_d_option (const char *arg, struct gcc_options *opts,
208 location_t loc, diagnostic_context *dc);
209 static void set_unsafe_math_optimizations_flags (struct gcc_options *opts,
210 int set);
211 static void enable_warning_as_error (const char *arg, int value,
212 unsigned int lang_mask,
213 const struct cl_option_handlers *handlers,
214 struct gcc_options *opts,
215 struct gcc_options *opts_set,
216 location_t loc,
217 diagnostic_context *dc);
219 /* Handle a back-end option; arguments and return value as for
220 handle_option. */
222 bool
223 target_handle_option (struct gcc_options *opts,
224 struct gcc_options *opts_set,
225 const struct cl_decoded_option *decoded,
226 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
227 location_t loc,
228 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
229 diagnostic_context *dc)
231 gcc_assert (dc == global_dc);
232 gcc_assert (kind == DK_UNSPECIFIED);
233 return targetm_common.handle_option (opts, opts_set, decoded, loc);
236 /* Add comma-separated strings to a char_p vector. */
238 static void
239 add_comma_separated_to_vector (void **pvec, const char *arg)
241 char *tmp;
242 char *r;
243 char *w;
244 char *token_start;
245 VEC(char_p,heap) *vec = (VEC(char_p,heap) *) *pvec;
247 /* We never free this string. */
248 tmp = xstrdup (arg);
250 r = tmp;
251 w = tmp;
252 token_start = tmp;
254 while (*r != '\0')
256 if (*r == ',')
258 *w++ = '\0';
259 ++r;
260 VEC_safe_push (char_p, heap, vec, token_start);
261 token_start = w;
263 if (*r == '\\' && r[1] == ',')
265 *w++ = ',';
266 r += 2;
268 else
269 *w++ = *r++;
271 if (*token_start != '\0')
272 VEC_safe_push (char_p, heap, vec, token_start);
274 *pvec = vec;
277 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
279 void
280 init_options_struct (struct gcc_options *opts, struct gcc_options *opts_set)
282 size_t num_params = get_num_compiler_params ();
284 *opts = global_options_init;
285 memset (opts_set, 0, sizeof (*opts_set));
287 opts->x_param_values = XNEWVEC (int, num_params);
288 opts_set->x_param_values = XCNEWVEC (int, num_params);
289 init_param_values (opts->x_param_values);
291 /* Initialize whether `char' is signed. */
292 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
293 /* Set this to a special "uninitialized" value. The actual default
294 is set after target options have been processed. */
295 opts->x_flag_short_enums = 2;
297 /* Initialize target_flags before default_options_optimization
298 so the latter can modify it. */
299 opts->x_target_flags = targetm_common.default_target_flags;
301 /* Some targets have ABI-specified unwind tables. */
302 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
304 /* Some targets have other target-specific initialization. */
305 targetm_common.option_init_struct (opts);
308 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
309 -Ofast if FAST is set), apply the option DEFAULT_OPT to OPTS and
310 OPTS_SET, diagnostic context DC, location LOC, with language mask
311 LANG_MASK and option handlers HANDLERS. */
313 static void
314 maybe_default_option (struct gcc_options *opts,
315 struct gcc_options *opts_set,
316 const struct default_options *default_opt,
317 int level, bool size, bool fast,
318 unsigned int lang_mask,
319 const struct cl_option_handlers *handlers,
320 location_t loc,
321 diagnostic_context *dc)
323 const struct cl_option *option = &cl_options[default_opt->opt_index];
324 bool enabled;
326 if (size)
327 gcc_assert (level == 2);
328 if (fast)
329 gcc_assert (level == 3);
331 switch (default_opt->levels)
333 case OPT_LEVELS_ALL:
334 enabled = true;
335 break;
337 case OPT_LEVELS_0_ONLY:
338 enabled = (level == 0);
339 break;
341 case OPT_LEVELS_1_PLUS:
342 enabled = (level >= 1);
343 break;
345 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
346 enabled = (level >= 1 && !size);
347 break;
349 case OPT_LEVELS_2_PLUS:
350 enabled = (level >= 2);
351 break;
353 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
354 enabled = (level >= 2 && !size);
355 break;
357 case OPT_LEVELS_3_PLUS:
358 enabled = (level >= 3);
359 break;
361 case OPT_LEVELS_3_PLUS_AND_SIZE:
362 enabled = (level >= 3 || size);
363 break;
365 case OPT_LEVELS_SIZE:
366 enabled = size;
367 break;
369 case OPT_LEVELS_FAST:
370 enabled = fast;
371 break;
373 case OPT_LEVELS_NONE:
374 default:
375 gcc_unreachable ();
378 if (enabled)
379 handle_generated_option (opts, opts_set, default_opt->opt_index,
380 default_opt->arg, default_opt->value,
381 lang_mask, DK_UNSPECIFIED, loc,
382 handlers, dc);
383 else if (default_opt->arg == NULL
384 && !option->cl_reject_negative)
385 handle_generated_option (opts, opts_set, default_opt->opt_index,
386 default_opt->arg, !default_opt->value,
387 lang_mask, DK_UNSPECIFIED, loc,
388 handlers, dc);
391 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
392 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
393 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
394 language mask LANG_MASK and option handlers HANDLERS. */
396 static void
397 maybe_default_options (struct gcc_options *opts,
398 struct gcc_options *opts_set,
399 const struct default_options *default_opts,
400 int level, bool size, bool fast,
401 unsigned int lang_mask,
402 const struct cl_option_handlers *handlers,
403 location_t loc,
404 diagnostic_context *dc)
406 size_t i;
408 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
409 maybe_default_option (opts, opts_set, &default_opts[i],
410 level, size, fast, lang_mask, handlers, loc, dc);
413 /* Table of options enabled by default at different levels. */
415 static const struct default_options default_options_table[] =
417 /* -O1 optimizations. */
418 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
419 #ifdef DELAY_SLOTS
420 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
421 #endif
422 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
423 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
424 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
425 { OPT_LEVELS_1_PLUS, OPT_fif_conversion, NULL, 1 },
426 { OPT_LEVELS_1_PLUS, OPT_fif_conversion2, NULL, 1 },
427 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
428 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
429 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
430 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
431 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
432 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
433 { OPT_LEVELS_1_PLUS, OPT_ftree_bit_ccp, NULL, 1 },
434 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
435 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
436 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
437 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
438 { OPT_LEVELS_1_PLUS, OPT_ftree_sra, NULL, 1 },
439 { OPT_LEVELS_1_PLUS, OPT_ftree_copyrename, NULL, 1 },
440 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
441 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
442 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
443 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
444 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
445 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
447 /* -O2 optimizations. */
448 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
449 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
450 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
451 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
452 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
453 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
454 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
455 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
456 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
457 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
458 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
459 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
460 #ifdef INSN_SCHEDULING
461 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
462 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
463 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
464 #endif
465 { OPT_LEVELS_2_PLUS, OPT_fregmove, NULL, 1 },
466 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
467 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
468 { OPT_LEVELS_2_PLUS, OPT_freorder_blocks, NULL, 1 },
469 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
470 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
471 { OPT_LEVELS_2_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
472 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
473 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
474 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
475 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
476 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
477 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
478 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
479 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
480 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
482 /* -O3 optimizations. */
483 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
484 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
485 /* Inlining of functions reducing size is a good idea with -Os
486 regardless of them being declared inline. */
487 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
488 { OPT_LEVELS_1_PLUS, OPT_finline_functions_called_once, NULL, 1 },
489 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
490 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
491 { OPT_LEVELS_3_PLUS, OPT_ftree_vectorize, NULL, 1 },
492 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
494 /* -Ofast adds optimizations to -O3. */
495 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
497 { OPT_LEVELS_NONE, 0, NULL, 0 }
500 /* Default the options in OPTS and OPTS_SET based on the optimization
501 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
502 void
503 default_options_optimization (struct gcc_options *opts,
504 struct gcc_options *opts_set,
505 struct cl_decoded_option *decoded_options,
506 unsigned int decoded_options_count,
507 location_t loc,
508 unsigned int lang_mask,
509 const struct cl_option_handlers *handlers,
510 diagnostic_context *dc)
512 unsigned int i;
513 int opt2;
515 /* Scan to see what optimization level has been specified. That will
516 determine the default value of many flags. */
517 for (i = 1; i < decoded_options_count; i++)
519 struct cl_decoded_option *opt = &decoded_options[i];
520 switch (opt->opt_index)
522 case OPT_O:
523 if (*opt->arg == '\0')
525 opts->x_optimize = 1;
526 opts->x_optimize_size = 0;
527 opts->x_optimize_fast = 0;
529 else
531 const int optimize_val = integral_argument (opt->arg);
532 if (optimize_val == -1)
533 error_at (loc,
534 "argument to %qs should be a non-negative integer",
535 "-O");
536 else
538 opts->x_optimize = optimize_val;
539 if ((unsigned int) opts->x_optimize > 255)
540 opts->x_optimize = 255;
541 opts->x_optimize_size = 0;
542 opts->x_optimize_fast = 0;
545 break;
547 case OPT_Os:
548 opts->x_optimize_size = 1;
550 /* Optimizing for size forces optimize to be 2. */
551 opts->x_optimize = 2;
552 opts->x_optimize_fast = 0;
553 break;
555 case OPT_Ofast:
556 /* -Ofast only adds flags to -O3. */
557 opts->x_optimize_size = 0;
558 opts->x_optimize = 3;
559 opts->x_optimize_fast = 1;
560 break;
562 default:
563 /* Ignore other options in this prescan. */
564 break;
568 maybe_default_options (opts, opts_set, default_options_table,
569 opts->x_optimize, opts->x_optimize_size,
570 opts->x_optimize_fast, lang_mask, handlers, loc, dc);
572 /* -O2 param settings. */
573 opt2 = (opts->x_optimize >= 2);
575 /* Track fields in field-sensitive alias analysis. */
576 maybe_set_param_value
577 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
578 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
579 opts->x_param_values, opts_set->x_param_values);
581 /* For -O1 only do loop invariant motion for very small loops. */
582 maybe_set_param_value
583 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
584 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
585 opts->x_param_values, opts_set->x_param_values);
587 if (opts->x_optimize_size)
588 /* We want to crossjump as much as possible. */
589 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
590 opts->x_param_values, opts_set->x_param_values);
591 else
592 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
593 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
594 opts->x_param_values, opts_set->x_param_values);
596 /* Allow default optimizations to be specified on a per-machine basis. */
597 maybe_default_options (opts, opts_set,
598 targetm_common.option_optimization_table,
599 opts->x_optimize, opts->x_optimize_size,
600 opts->x_optimize_fast, lang_mask, handlers, loc, dc);
603 /* After all options at LOC have been read into OPTS and OPTS_SET,
604 finalize settings of those options and diagnose incompatible
605 combinations. */
606 void
607 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
608 location_t loc)
610 enum unwind_info_type ui_except;
612 if (opts->x_dump_base_name && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name))
614 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
615 OPTS->X_DUMP_DIR_NAME directory. Then try to make
616 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
617 directory, typically the directory to contain the object
618 file. */
619 if (opts->x_dump_dir_name)
620 opts->x_dump_base_name = concat (opts->x_dump_dir_name,
621 opts->x_dump_base_name, NULL);
622 else if (opts->x_aux_base_name
623 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
625 const char *aux_base;
627 base_of_path (opts->x_aux_base_name, &aux_base);
628 if (opts->x_aux_base_name != aux_base)
630 int dir_len = aux_base - opts->x_aux_base_name;
631 char *new_dump_base_name =
632 XNEWVEC (char, strlen (opts->x_dump_base_name) + dir_len + 1);
634 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
635 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
636 /* Append existing OPTS->X_DUMP_BASE_NAME. */
637 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
638 opts->x_dump_base_name = new_dump_base_name;
643 /* Handle related options for unit-at-a-time, toplevel-reorder, and
644 section-anchors. */
645 if (!opts->x_flag_unit_at_a_time)
647 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
648 error_at (loc, "section anchors must be disabled when unit-at-a-time "
649 "is disabled");
650 opts->x_flag_section_anchors = 0;
651 if (opts->x_flag_toplevel_reorder == 1)
652 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
653 "is disabled");
654 opts->x_flag_toplevel_reorder = 0;
657 /* -Wmissing-noreturn is alias for -Wsuggest-attribute=noreturn. */
658 if (opts->x_warn_missing_noreturn)
659 opts->x_warn_suggest_attribute_noreturn = true;
661 /* Unless the user has asked for section anchors, we disable toplevel
662 reordering at -O0 to disable transformations that might be surprising
663 to end users and to get -fno-toplevel-reorder tested. */
664 if (!opts->x_optimize
665 && opts->x_flag_toplevel_reorder == 2
666 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
668 opts->x_flag_toplevel_reorder = 0;
669 opts->x_flag_section_anchors = 0;
671 if (!opts->x_flag_toplevel_reorder)
673 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
674 error_at (loc, "section anchors must be disabled when toplevel reorder"
675 " is disabled");
676 opts->x_flag_section_anchors = 0;
679 if (!opts->x_flag_opts_finished)
681 if (opts->x_flag_pie)
682 opts->x_flag_pic = opts->x_flag_pie;
683 if (opts->x_flag_pic && !opts->x_flag_pie)
684 opts->x_flag_shlib = 1;
685 opts->x_flag_opts_finished = true;
688 if (opts->x_optimize == 0)
690 /* Inlining does not work if not optimizing,
691 so force it not to be done. */
692 opts->x_warn_inline = 0;
693 opts->x_flag_no_inline = 1;
696 /* The optimization to partition hot and cold basic blocks into separate
697 sections of the .o and executable files does not work (currently)
698 with exception handling. This is because there is no support for
699 generating unwind info. If opts->x_flag_exceptions is turned on
700 we need to turn off the partitioning optimization. */
702 ui_except = targetm_common.except_unwind_info (opts);
704 if (opts->x_flag_exceptions
705 && opts->x_flag_reorder_blocks_and_partition
706 && (ui_except == UI_SJLJ || ui_except == UI_TARGET))
708 inform (loc,
709 "-freorder-blocks-and-partition does not work "
710 "with exceptions on this architecture");
711 opts->x_flag_reorder_blocks_and_partition = 0;
712 opts->x_flag_reorder_blocks = 1;
715 /* If user requested unwind info, then turn off the partitioning
716 optimization. */
718 if (opts->x_flag_unwind_tables
719 && !targetm_common.unwind_tables_default
720 && opts->x_flag_reorder_blocks_and_partition
721 && (ui_except == UI_SJLJ || ui_except == UI_TARGET))
723 inform (loc,
724 "-freorder-blocks-and-partition does not support "
725 "unwind info on this architecture");
726 opts->x_flag_reorder_blocks_and_partition = 0;
727 opts->x_flag_reorder_blocks = 1;
730 /* If the target requested unwind info, then turn off the partitioning
731 optimization with a different message. Likewise, if the target does not
732 support named sections. */
734 if (opts->x_flag_reorder_blocks_and_partition
735 && (!targetm_common.have_named_sections
736 || (opts->x_flag_unwind_tables
737 && targetm_common.unwind_tables_default
738 && (ui_except == UI_SJLJ || ui_except == UI_TARGET))))
740 inform (loc,
741 "-freorder-blocks-and-partition does not work "
742 "on this architecture");
743 opts->x_flag_reorder_blocks_and_partition = 0;
744 opts->x_flag_reorder_blocks = 1;
747 if (opts->x_flag_reorder_blocks_and_partition
748 && !opts_set->x_flag_reorder_functions)
749 opts->x_flag_reorder_functions = 1;
751 /* Pipelining of outer loops is only possible when general pipelining
752 capabilities are requested. */
753 if (!opts->x_flag_sel_sched_pipelining)
754 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
756 if (opts->x_flag_conserve_stack)
758 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
759 opts->x_param_values, opts_set->x_param_values);
760 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
761 opts->x_param_values, opts_set->x_param_values);
763 if (opts->x_flag_wpa || opts->x_flag_ltrans)
765 /* These passes are not WHOPR compatible yet. */
766 opts->x_flag_ipa_pta = 0;
769 if (opts->x_flag_lto)
771 #ifdef ENABLE_LTO
772 opts->x_flag_generate_lto = 1;
774 /* When generating IL, do not operate in whole-program mode.
775 Otherwise, symbols will be privatized too early, causing link
776 errors later. */
777 opts->x_flag_whole_program = 0;
778 #else
779 error_at (loc, "LTO support has not been enabled in this configuration");
780 #endif
782 if ((opts->x_flag_lto_partition_balanced != 0) + (opts->x_flag_lto_partition_1to1 != 0)
783 + (opts->x_flag_lto_partition_none != 0) >= 1)
785 if ((opts->x_flag_lto_partition_balanced != 0)
786 + (opts->x_flag_lto_partition_1to1 != 0)
787 + (opts->x_flag_lto_partition_none != 0) > 1)
788 error_at (loc, "only one -flto-partition value can be specified");
791 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
792 default value if they choose based on other options. */
793 if (opts->x_flag_split_stack == -1)
794 opts->x_flag_split_stack = 0;
795 else if (opts->x_flag_split_stack)
797 if (!targetm_common.supports_split_stack (true, opts))
799 error_at (loc, "%<-fsplit-stack%> is not supported by "
800 "this compiler configuration");
801 opts->x_flag_split_stack = 0;
805 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
806 is disabled. */
807 if (!opts->x_flag_tree_vectorize || !opts->x_flag_tree_loop_if_convert)
808 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
809 opts->x_param_values, opts_set->x_param_values);
811 /* This replaces set_Wunused. */
812 if (opts->x_warn_unused_function == -1)
813 opts->x_warn_unused_function = opts->x_warn_unused;
814 if (opts->x_warn_unused_label == -1)
815 opts->x_warn_unused_label = opts->x_warn_unused;
816 /* Wunused-parameter is enabled if both -Wunused -Wextra are enabled. */
817 if (opts->x_warn_unused_parameter == -1)
818 opts->x_warn_unused_parameter = (opts->x_warn_unused
819 && opts->x_extra_warnings);
820 if (opts->x_warn_unused_variable == -1)
821 opts->x_warn_unused_variable = opts->x_warn_unused;
822 /* Wunused-but-set-parameter is enabled if both -Wunused -Wextra are
823 enabled. */
824 if (opts->x_warn_unused_but_set_parameter == -1)
825 opts->x_warn_unused_but_set_parameter = (opts->x_warn_unused
826 && opts->x_extra_warnings);
827 if (opts->x_warn_unused_but_set_variable == -1)
828 opts->x_warn_unused_but_set_variable = opts->x_warn_unused;
829 if (opts->x_warn_unused_value == -1)
830 opts->x_warn_unused_value = opts->x_warn_unused;
832 /* This replaces set_Wextra. */
833 if (opts->x_warn_uninitialized == -1)
834 opts->x_warn_uninitialized = opts->x_extra_warnings;
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 (!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 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1251 : CL_UNDOCUMENTED);
1252 /* First display any single language specific options. */
1253 for (i = 0; i < cl_lang_count; i++)
1254 print_specific_help
1255 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1256 lang_mask);
1257 /* Next display any multi language specific options. */
1258 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1259 /* Then display any remaining, non-language options. */
1260 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1261 if (i != CL_DRIVER)
1262 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1263 opts->x_exit_after_options = true;
1264 break;
1267 case OPT__target_help:
1268 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1269 opts->x_exit_after_options = true;
1270 break;
1272 case OPT__help_:
1274 const char * a = arg;
1275 unsigned int include_flags = 0;
1276 /* Note - by default we include undocumented options when listing
1277 specific classes. If you only want to see documented options
1278 then add ",^undocumented" to the --help= option. E.g.:
1280 --help=target,^undocumented */
1281 unsigned int exclude_flags = 0;
1283 /* Walk along the argument string, parsing each word in turn.
1284 The format is:
1285 arg = [^]{word}[,{arg}]
1286 word = {optimizers|target|warnings|undocumented|
1287 params|common|<language>} */
1288 while (* a != 0)
1290 static const struct
1292 const char * string;
1293 unsigned int flag;
1295 specifics[] =
1297 { "optimizers", CL_OPTIMIZATION },
1298 { "target", CL_TARGET },
1299 { "warnings", CL_WARNING },
1300 { "undocumented", CL_UNDOCUMENTED },
1301 { "params", CL_PARAMS },
1302 { "joined", CL_JOINED },
1303 { "separate", CL_SEPARATE },
1304 { "common", CL_COMMON },
1305 { NULL, 0 }
1307 unsigned int * pflags;
1308 const char * comma;
1309 unsigned int lang_flag, specific_flag;
1310 unsigned int len;
1311 unsigned int i;
1313 if (* a == '^')
1315 ++ a;
1316 pflags = & exclude_flags;
1318 else
1319 pflags = & include_flags;
1321 comma = strchr (a, ',');
1322 if (comma == NULL)
1323 len = strlen (a);
1324 else
1325 len = comma - a;
1326 if (len == 0)
1328 a = comma + 1;
1329 continue;
1332 /* Check to see if the string matches an option class name. */
1333 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1334 if (strncasecmp (a, specifics[i].string, len) == 0)
1336 specific_flag = specifics[i].flag;
1337 break;
1340 /* Check to see if the string matches a language name.
1341 Note - we rely upon the alpha-sorted nature of the entries in
1342 the lang_names array, specifically that shorter names appear
1343 before their longer variants. (i.e. C before C++). That way
1344 when we are attempting to match --help=c for example we will
1345 match with C first and not C++. */
1346 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1347 if (strncasecmp (a, lang_names[i], len) == 0)
1349 lang_flag = 1U << i;
1350 break;
1353 if (specific_flag != 0)
1355 if (lang_flag == 0)
1356 * pflags |= specific_flag;
1357 else
1359 /* The option's argument matches both the start of a
1360 language name and the start of an option class name.
1361 We have a special case for when the user has
1362 specified "--help=c", but otherwise we have to issue
1363 a warning. */
1364 if (strncasecmp (a, "c", len) == 0)
1365 * pflags |= lang_flag;
1366 else
1367 warning_at (loc, 0,
1368 "--help argument %q.*s is ambiguous, "
1369 "please be more specific",
1370 len, a);
1373 else if (lang_flag != 0)
1374 * pflags |= lang_flag;
1375 else
1376 warning_at (loc, 0,
1377 "unrecognized argument to --help= option: %q.*s",
1378 len, a);
1380 if (comma == NULL)
1381 break;
1382 a = comma + 1;
1385 if (include_flags)
1386 print_specific_help (include_flags, exclude_flags, 0, opts,
1387 lang_mask);
1388 opts->x_exit_after_options = true;
1389 break;
1392 case OPT__version:
1393 opts->x_exit_after_options = true;
1394 break;
1396 case OPT_O:
1397 case OPT_Os:
1398 case OPT_Ofast:
1399 /* Currently handled in a prescan. */
1400 break;
1402 case OPT_Werror_:
1403 enable_warning_as_error (arg, value, lang_mask, handlers,
1404 opts, opts_set, loc, dc);
1405 break;
1407 case OPT_Wlarger_than_:
1408 opts->x_larger_than_size = value;
1409 opts->x_warn_larger_than = value != -1;
1410 break;
1412 case OPT_Wfatal_errors:
1413 dc->fatal_errors = value;
1414 break;
1416 case OPT_Wframe_larger_than_:
1417 opts->x_frame_larger_than_size = value;
1418 opts->x_warn_frame_larger_than = value != -1;
1419 break;
1421 case OPT_Wstack_usage_:
1422 opts->x_warn_stack_usage = value;
1423 opts->x_flag_stack_usage_info = value != -1;
1424 break;
1426 case OPT_Wstrict_aliasing:
1427 set_Wstrict_aliasing (opts, value);
1428 break;
1430 case OPT_Wstrict_overflow:
1431 opts->x_warn_strict_overflow = (value
1432 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1433 : 0);
1434 break;
1436 case OPT_Wsystem_headers:
1437 dc->dc_warn_system_headers = value;
1438 break;
1440 case OPT_aux_info:
1441 opts->x_flag_gen_aux_info = 1;
1442 break;
1444 case OPT_auxbase_strip:
1446 char *tmp = xstrdup (arg);
1447 strip_off_ending (tmp, strlen (tmp));
1448 if (tmp[0])
1449 opts->x_aux_base_name = tmp;
1451 break;
1453 case OPT_d:
1454 decode_d_option (arg, opts, loc, dc);
1455 break;
1457 case OPT_fcall_used_:
1458 case OPT_fcall_saved_:
1459 /* Deferred. */
1460 break;
1462 case OPT_fdbg_cnt_:
1463 case OPT_fdbg_cnt_list:
1464 /* Deferred. */
1465 break;
1467 case OPT_fdebug_prefix_map_:
1468 /* Deferred. */
1469 break;
1471 case OPT_fdiagnostics_show_location_:
1472 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1473 break;
1475 case OPT_fdiagnostics_show_option:
1476 dc->show_option_requested = value;
1477 break;
1479 case OPT_fdump_:
1480 /* Deferred. */
1481 break;
1483 case OPT_ffast_math:
1484 set_fast_math_flags (opts, value);
1485 break;
1487 case OPT_funsafe_math_optimizations:
1488 set_unsafe_math_optimizations_flags (opts, value);
1489 break;
1491 case OPT_ffixed_:
1492 /* Deferred. */
1493 break;
1495 case OPT_finline_limit_:
1496 set_param_value ("max-inline-insns-single", value / 2,
1497 opts->x_param_values, opts_set->x_param_values);
1498 set_param_value ("max-inline-insns-auto", value / 2,
1499 opts->x_param_values, opts_set->x_param_values);
1500 break;
1502 case OPT_finstrument_functions_exclude_function_list_:
1503 add_comma_separated_to_vector
1504 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1505 break;
1507 case OPT_finstrument_functions_exclude_file_list_:
1508 add_comma_separated_to_vector
1509 (&opts->x_flag_instrument_functions_exclude_files, arg);
1510 break;
1512 case OPT_fmessage_length_:
1513 pp_set_line_maximum_length (dc->printer, value);
1514 break;
1516 case OPT_fpack_struct_:
1517 if (value <= 0 || (value & (value - 1)) || value > 16)
1518 error_at (loc,
1519 "structure alignment must be a small power of two, not %d",
1520 value);
1521 else
1522 opts->x_initial_max_fld_align = value;
1523 break;
1525 case OPT_fplugin_:
1526 case OPT_fplugin_arg_:
1527 /* Deferred. */
1528 break;
1530 case OPT_fprofile_use_:
1531 opts->x_profile_data_prefix = xstrdup (arg);
1532 opts->x_flag_profile_use = true;
1533 value = true;
1534 /* No break here - do -fprofile-use processing. */
1535 case OPT_fprofile_use:
1536 if (!opts_set->x_flag_branch_probabilities)
1537 opts->x_flag_branch_probabilities = value;
1538 if (!opts_set->x_flag_profile_values)
1539 opts->x_flag_profile_values = value;
1540 if (!opts_set->x_flag_unroll_loops)
1541 opts->x_flag_unroll_loops = value;
1542 if (!opts_set->x_flag_peel_loops)
1543 opts->x_flag_peel_loops = value;
1544 if (!opts_set->x_flag_tracer)
1545 opts->x_flag_tracer = value;
1546 if (!opts_set->x_flag_value_profile_transformations)
1547 opts->x_flag_value_profile_transformations = value;
1548 if (!opts_set->x_flag_inline_functions)
1549 opts->x_flag_inline_functions = value;
1550 if (!opts_set->x_flag_ipa_cp)
1551 opts->x_flag_ipa_cp = value;
1552 if (!opts_set->x_flag_ipa_cp_clone
1553 && value && opts->x_flag_ipa_cp)
1554 opts->x_flag_ipa_cp_clone = value;
1555 if (!opts_set->x_flag_predictive_commoning)
1556 opts->x_flag_predictive_commoning = value;
1557 if (!opts_set->x_flag_unswitch_loops)
1558 opts->x_flag_unswitch_loops = value;
1559 if (!opts_set->x_flag_gcse_after_reload)
1560 opts->x_flag_gcse_after_reload = value;
1561 break;
1563 case OPT_fprofile_generate_:
1564 opts->x_profile_data_prefix = xstrdup (arg);
1565 value = true;
1566 /* No break here - do -fprofile-generate processing. */
1567 case OPT_fprofile_generate:
1568 if (!opts_set->x_profile_arc_flag)
1569 opts->x_profile_arc_flag = value;
1570 if (!opts_set->x_flag_profile_values)
1571 opts->x_flag_profile_values = value;
1572 if (!opts_set->x_flag_value_profile_transformations)
1573 opts->x_flag_value_profile_transformations = value;
1574 if (!opts_set->x_flag_inline_functions)
1575 opts->x_flag_inline_functions = value;
1576 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1577 quadratic. Disable the pass until better memory representation
1578 is done. */
1579 if (!opts_set->x_flag_ipa_reference && in_lto_p)
1580 opts->x_flag_ipa_reference = false;
1581 break;
1583 case OPT_fshow_column:
1584 dc->show_column = value;
1585 break;
1587 case OPT_frandom_seed:
1588 /* The real switch is -fno-random-seed. */
1589 if (value)
1590 return false;
1591 /* Deferred. */
1592 break;
1594 case OPT_frandom_seed_:
1595 /* Deferred. */
1596 break;
1598 case OPT_fsched_verbose_:
1599 #ifdef INSN_SCHEDULING
1600 /* Handled with Var in common.opt. */
1601 break;
1602 #else
1603 return false;
1604 #endif
1606 case OPT_fsched_stalled_insns_:
1607 opts->x_flag_sched_stalled_insns = value;
1608 if (opts->x_flag_sched_stalled_insns == 0)
1609 opts->x_flag_sched_stalled_insns = -1;
1610 break;
1612 case OPT_fsched_stalled_insns_dep_:
1613 opts->x_flag_sched_stalled_insns_dep = value;
1614 break;
1616 case OPT_fstack_check_:
1617 if (!strcmp (arg, "no"))
1618 opts->x_flag_stack_check = NO_STACK_CHECK;
1619 else if (!strcmp (arg, "generic"))
1620 /* This is the old stack checking method. */
1621 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1622 ? FULL_BUILTIN_STACK_CHECK
1623 : GENERIC_STACK_CHECK;
1624 else if (!strcmp (arg, "specific"))
1625 /* This is the new stack checking method. */
1626 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1627 ? FULL_BUILTIN_STACK_CHECK
1628 : STACK_CHECK_STATIC_BUILTIN
1629 ? STATIC_BUILTIN_STACK_CHECK
1630 : GENERIC_STACK_CHECK;
1631 else
1632 warning_at (loc, 0, "unknown stack check parameter \"%s\"", arg);
1633 break;
1635 case OPT_fstack_limit:
1636 /* The real switch is -fno-stack-limit. */
1637 if (value)
1638 return false;
1639 /* Deferred. */
1640 break;
1642 case OPT_fstack_limit_register_:
1643 case OPT_fstack_limit_symbol_:
1644 /* Deferred. */
1645 break;
1647 case OPT_fstack_usage:
1648 opts->x_flag_stack_usage = value;
1649 opts->x_flag_stack_usage_info = value != 0;
1650 break;
1652 case OPT_ftree_vectorizer_verbose_:
1653 vect_set_verbosity_level (opts, value);
1654 break;
1656 case OPT_g:
1657 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
1658 loc);
1659 break;
1661 case OPT_gcoff:
1662 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
1663 break;
1665 case OPT_gdwarf_:
1666 if (value < 2 || value > 4)
1667 error_at (loc, "dwarf version %d is not supported", value);
1668 else
1669 dwarf_version = value;
1670 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
1671 break;
1673 case OPT_ggdb:
1674 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
1675 break;
1677 case OPT_gstabs:
1678 case OPT_gstabs_:
1679 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
1680 loc);
1681 break;
1683 case OPT_gvms:
1684 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
1685 break;
1687 case OPT_gxcoff:
1688 case OPT_gxcoff_:
1689 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
1690 loc);
1691 break;
1693 case OPT_pedantic_errors:
1694 opts->x_pedantic = 1;
1695 dc->pedantic_errors = 1;
1696 break;
1698 case OPT_flto:
1699 opts->x_flag_lto = value ? "" : NULL;
1700 break;
1702 case OPT_w:
1703 dc->dc_inhibit_warnings = true;
1704 break;
1706 case OPT_fmax_errors_:
1707 dc->max_errors = value;
1708 break;
1710 case OPT_fuse_linker_plugin:
1711 /* No-op. Used by the driver and passed to us because it starts with f.*/
1712 break;
1714 case OPT_Wuninitialized:
1715 /* Also turn on maybe uninitialized warning. */
1716 warn_maybe_uninitialized = value;
1717 break;
1719 default:
1720 /* If the flag was handled in a standard way, assume the lack of
1721 processing here is intentional. */
1722 gcc_assert (option_flag_var (scode, opts));
1723 break;
1726 return true;
1729 /* Handle --param NAME=VALUE. */
1730 static void
1731 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
1732 location_t loc, const char *carg)
1734 char *equal, *arg;
1735 int value;
1737 arg = xstrdup (carg);
1738 equal = strchr (arg, '=');
1739 if (!equal)
1740 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
1741 arg);
1742 else
1744 value = integral_argument (equal + 1);
1745 if (value == -1)
1746 error_at (loc, "invalid --param value %qs", equal + 1);
1747 else
1749 *equal = '\0';
1750 set_param_value (arg, value,
1751 opts->x_param_values, opts_set->x_param_values);
1755 free (arg);
1758 /* Used to set the level of strict aliasing warnings in OPTS,
1759 when no level is specified (i.e., when -Wstrict-aliasing, and not
1760 -Wstrict-aliasing=level was given).
1761 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
1762 and 0 otherwise. After calling this function, wstrict_aliasing will be
1763 set to the default value of -Wstrict_aliasing=level, currently 3. */
1764 void
1765 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
1767 gcc_assert (onoff == 0 || onoff == 1);
1768 if (onoff != 0)
1769 opts->x_warn_strict_aliasing = 3;
1770 else
1771 opts->x_warn_strict_aliasing = 0;
1774 /* The following routines are useful in setting all the flags that
1775 -ffast-math and -fno-fast-math imply. */
1776 static void
1777 set_fast_math_flags (struct gcc_options *opts, int set)
1779 if (!opts->frontend_set_flag_unsafe_math_optimizations)
1781 opts->x_flag_unsafe_math_optimizations = set;
1782 set_unsafe_math_optimizations_flags (opts, set);
1784 if (!opts->frontend_set_flag_finite_math_only)
1785 opts->x_flag_finite_math_only = set;
1786 if (!opts->frontend_set_flag_errno_math)
1787 opts->x_flag_errno_math = !set;
1788 if (set)
1790 if (!opts->frontend_set_flag_signaling_nans)
1791 opts->x_flag_signaling_nans = 0;
1792 if (!opts->frontend_set_flag_rounding_math)
1793 opts->x_flag_rounding_math = 0;
1794 if (!opts->frontend_set_flag_cx_limited_range)
1795 opts->x_flag_cx_limited_range = 1;
1799 /* When -funsafe-math-optimizations is set the following
1800 flags are set as well. */
1801 static void
1802 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
1804 if (!opts->frontend_set_flag_trapping_math)
1805 opts->x_flag_trapping_math = !set;
1806 if (!opts->frontend_set_flag_signed_zeros)
1807 opts->x_flag_signed_zeros = !set;
1808 if (!opts->frontend_set_flag_associative_math)
1809 opts->x_flag_associative_math = set;
1810 if (!opts->frontend_set_flag_reciprocal_math)
1811 opts->x_flag_reciprocal_math = set;
1814 /* Return true iff flags in OPTS are set as if -ffast-math. */
1815 bool
1816 fast_math_flags_set_p (const struct gcc_options *opts)
1818 return (!opts->x_flag_trapping_math
1819 && opts->x_flag_unsafe_math_optimizations
1820 && opts->x_flag_finite_math_only
1821 && !opts->x_flag_signed_zeros
1822 && !opts->x_flag_errno_math);
1825 /* Return true iff flags are set as if -ffast-math but using the flags stored
1826 in the struct cl_optimization structure. */
1827 bool
1828 fast_math_flags_struct_set_p (struct cl_optimization *opt)
1830 return (!opt->x_flag_trapping_math
1831 && opt->x_flag_unsafe_math_optimizations
1832 && opt->x_flag_finite_math_only
1833 && !opt->x_flag_signed_zeros
1834 && !opt->x_flag_errno_math);
1837 /* Handle a debug output -g switch for options OPTS
1838 (OPTS_SET->x_write_symbols storing whether a debug type was passed
1839 explicitly), location LOC. EXTENDED is true or false to support
1840 extended output (2 is special and means "-ggdb" was given). */
1841 static void
1842 set_debug_level (enum debug_info_type type, int extended, const char *arg,
1843 struct gcc_options *opts, struct gcc_options *opts_set,
1844 location_t loc)
1846 opts->x_use_gnu_debug_info_extensions = extended;
1848 if (type == NO_DEBUG)
1850 if (opts->x_write_symbols == NO_DEBUG)
1852 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
1854 if (extended == 2)
1856 #ifdef DWARF2_DEBUGGING_INFO
1857 opts->x_write_symbols = DWARF2_DEBUG;
1858 #elif defined DBX_DEBUGGING_INFO
1859 opts->x_write_symbols = DBX_DEBUG;
1860 #endif
1863 if (opts->x_write_symbols == NO_DEBUG)
1864 warning_at (loc, 0, "target system does not support debug output");
1867 else
1869 /* Does it conflict with an already selected type? */
1870 if (opts_set->x_write_symbols != NO_DEBUG
1871 && opts->x_write_symbols != NO_DEBUG
1872 && type != opts->x_write_symbols)
1873 error_at (loc, "debug format \"%s\" conflicts with prior selection",
1874 debug_type_names[type]);
1875 opts->x_write_symbols = type;
1876 opts_set->x_write_symbols = type;
1879 /* A debug flag without a level defaults to level 2. */
1880 if (*arg == '\0')
1882 if (!opts->x_debug_info_level)
1883 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
1885 else
1887 int argval = integral_argument (arg);
1888 if (argval == -1)
1889 error_at (loc, "unrecognised debug output level \"%s\"", arg);
1890 else if (argval > 3)
1891 error_at (loc, "debug output level %s is too high", arg);
1892 else
1893 opts->x_debug_info_level = (enum debug_info_levels) argval;
1897 /* Arrange to dump core on error for diagnostic context DC. (The
1898 regular error message is still printed first, except in the case of
1899 abort ().) */
1901 static void
1902 setup_core_dumping (diagnostic_context *dc)
1904 #ifdef SIGABRT
1905 signal (SIGABRT, SIG_DFL);
1906 #endif
1907 #if defined(HAVE_SETRLIMIT)
1909 struct rlimit rlim;
1910 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
1911 fatal_error ("getting core file size maximum limit: %m");
1912 rlim.rlim_cur = rlim.rlim_max;
1913 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
1914 fatal_error ("setting core file size limit to maximum: %m");
1916 #endif
1917 diagnostic_abort_on_error (dc);
1920 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
1921 diagnostic context DC. */
1923 static void
1924 decode_d_option (const char *arg, struct gcc_options *opts,
1925 location_t loc, diagnostic_context *dc)
1927 int c;
1929 while (*arg)
1930 switch (c = *arg++)
1932 case 'A':
1933 opts->x_flag_debug_asm = 1;
1934 break;
1935 case 'p':
1936 opts->x_flag_print_asm_name = 1;
1937 break;
1938 case 'P':
1939 opts->x_flag_dump_rtl_in_asm = 1;
1940 opts->x_flag_print_asm_name = 1;
1941 break;
1942 case 'v':
1943 opts->x_graph_dump_format = vcg;
1944 break;
1945 case 'x':
1946 opts->x_rtl_dump_and_exit = 1;
1947 break;
1948 case 'D': /* These are handled by the preprocessor. */
1949 case 'I':
1950 case 'M':
1951 case 'N':
1952 case 'U':
1953 break;
1954 case 'H':
1955 setup_core_dumping (dc);
1956 break;
1957 case 'a':
1958 opts->x_flag_dump_all_passed = true;
1959 break;
1961 default:
1962 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
1963 break;
1967 /* Enable (or disable if VALUE is 0) a warning option ARG (language
1968 mask LANG_MASK, option handlers HANDLERS) as an error for option
1969 structures OPTS and OPTS_SET, diagnostic context DC (possibly
1970 NULL), location LOC. This is used by -Werror=. */
1972 static void
1973 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
1974 const struct cl_option_handlers *handlers,
1975 struct gcc_options *opts,
1976 struct gcc_options *opts_set,
1977 location_t loc, diagnostic_context *dc)
1979 char *new_option;
1980 int option_index;
1982 new_option = XNEWVEC (char, strlen (arg) + 2);
1983 new_option[0] = 'W';
1984 strcpy (new_option + 1, arg);
1985 option_index = find_opt (new_option, lang_mask);
1986 if (option_index == OPT_SPECIAL_unknown)
1988 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
1990 else
1992 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
1994 control_warning_option (option_index, (int) kind, value,
1995 loc, lang_mask,
1996 handlers, opts, opts_set, dc);
1997 if (option_index == OPT_Wuninitialized)
1998 enable_warning_as_error ("maybe-uninitialized", value, lang_mask,
1999 handlers, opts, opts_set, loc, dc);
2001 free (new_option);
2004 /* Return malloced memory for the name of the option OPTION_INDEX
2005 which enabled a diagnostic (context CONTEXT), originally of type
2006 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2007 as -Werror. */
2009 char *
2010 option_name (diagnostic_context *context, int option_index,
2011 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2013 if (option_index)
2015 /* A warning classified as an error. */
2016 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2017 && diag_kind == DK_ERROR)
2018 return concat (cl_options[OPT_Werror_].opt_text,
2019 /* Skip over "-W". */
2020 cl_options[option_index].opt_text + 2,
2021 NULL);
2022 /* A warning with option. */
2023 else
2024 return xstrdup (cl_options[option_index].opt_text);
2026 /* A warning without option classified as an error. */
2027 else if (orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2028 || diag_kind == DK_WARNING)
2030 if (context->warning_as_error_requested)
2031 return xstrdup (cl_options[OPT_Werror].opt_text);
2032 else
2033 return xstrdup (_("enabled by default"));
2035 else
2036 return NULL;