2011-03-24 Paolo Bonzini <bonzini@gnu.org>
[official-gcc.git] / gcc / opts.c
blob165d7ec3a553113971b9ffe5f683ad75fa2e52f4
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" /* Needed by rtl.h and used for STACK_CHECK_BUILTIN,
27 STACK_CHECK_STATIC_BUILTIN, DEFAULT_GDB_EXTENSIONS,
28 DWARF2_DEBUGGING_INFO and DBX_DEBUGGING_INFO. */
29 #include "rtl.h" /* Needed by insn-attr.h. */
30 #include "opts.h"
31 #include "options.h"
32 #include "flags.h"
33 #include "params.h"
34 #include "diagnostic.h"
35 #include "opts-diagnostic.h"
36 #include "insn-attr.h" /* For INSN_SCHEDULING and DELAY_SLOTS. */
37 #include "target.h"
39 /* Parse the -femit-struct-debug-detailed option value
40 and set the flag variables. */
42 #define MATCH( prefix, string ) \
43 ((strncmp (prefix, string, sizeof prefix - 1) == 0) \
44 ? ((string += sizeof prefix - 1), 1) : 0)
46 void
47 set_struct_debug_option (struct gcc_options *opts, location_t loc,
48 const char *spec)
50 /* various labels for comparison */
51 static const char dfn_lbl[] = "dfn:", dir_lbl[] = "dir:", ind_lbl[] = "ind:";
52 static const char ord_lbl[] = "ord:", gen_lbl[] = "gen:";
53 static const char none_lbl[] = "none", any_lbl[] = "any";
54 static const char base_lbl[] = "base", sys_lbl[] = "sys";
56 enum debug_struct_file files = DINFO_STRUCT_FILE_ANY;
57 /* Default is to apply to as much as possible. */
58 enum debug_info_usage usage = DINFO_USAGE_NUM_ENUMS;
59 int ord = 1, gen = 1;
61 /* What usage? */
62 if (MATCH (dfn_lbl, spec))
63 usage = DINFO_USAGE_DFN;
64 else if (MATCH (dir_lbl, spec))
65 usage = DINFO_USAGE_DIR_USE;
66 else if (MATCH (ind_lbl, spec))
67 usage = DINFO_USAGE_IND_USE;
69 /* Generics or not? */
70 if (MATCH (ord_lbl, spec))
71 gen = 0;
72 else if (MATCH (gen_lbl, spec))
73 ord = 0;
75 /* What allowable environment? */
76 if (MATCH (none_lbl, spec))
77 files = DINFO_STRUCT_FILE_NONE;
78 else if (MATCH (any_lbl, spec))
79 files = DINFO_STRUCT_FILE_ANY;
80 else if (MATCH (sys_lbl, spec))
81 files = DINFO_STRUCT_FILE_SYS;
82 else if (MATCH (base_lbl, spec))
83 files = DINFO_STRUCT_FILE_BASE;
84 else
85 error_at (loc,
86 "argument %qs to %<-femit-struct-debug-detailed%> "
87 "not recognized",
88 spec);
90 /* Effect the specification. */
91 if (usage == DINFO_USAGE_NUM_ENUMS)
93 if (ord)
95 opts->x_debug_struct_ordinary[DINFO_USAGE_DFN] = files;
96 opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE] = files;
97 opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE] = files;
99 if (gen)
101 opts->x_debug_struct_generic[DINFO_USAGE_DFN] = files;
102 opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE] = files;
103 opts->x_debug_struct_generic[DINFO_USAGE_IND_USE] = files;
106 else
108 if (ord)
109 opts->x_debug_struct_ordinary[usage] = files;
110 if (gen)
111 opts->x_debug_struct_generic[usage] = files;
114 if (*spec == ',')
115 set_struct_debug_option (opts, loc, spec+1);
116 else
118 /* No more -femit-struct-debug-detailed specifications.
119 Do final checks. */
120 if (*spec != '\0')
121 error_at (loc,
122 "argument %qs to %<-femit-struct-debug-detailed%> unknown",
123 spec);
124 if (opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE]
125 < opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE]
126 || opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE]
127 < opts->x_debug_struct_generic[DINFO_USAGE_IND_USE])
128 error_at (loc,
129 "%<-femit-struct-debug-detailed=dir:...%> must allow "
130 "at least as much as "
131 "%<-femit-struct-debug-detailed=ind:...%>");
135 /* Handle -ftree-vectorizer-verbose=VAL for options OPTS. */
137 static void
138 vect_set_verbosity_level (struct gcc_options *opts, int val)
140 if (val < MAX_VERBOSITY_LEVEL)
141 opts->x_user_vect_verbosity_level = (enum vect_verbosity_levels) val;
142 else
143 opts->x_user_vect_verbosity_level
144 = (enum vect_verbosity_levels) (MAX_VERBOSITY_LEVEL - 1);
148 /* Strip off a legitimate source ending from the input string NAME of
149 length LEN. Rather than having to know the names used by all of
150 our front ends, we strip off an ending of a period followed by
151 up to five characters. (Java uses ".class".) */
153 void
154 strip_off_ending (char *name, int len)
156 int i;
157 for (i = 2; i < 6 && len > i; i++)
159 if (name[len - i] == '.')
161 name[len - i] = '\0';
162 break;
167 /* Find the base name of a path, stripping off both directories and
168 a single final extension. */
170 base_of_path (const char *path, const char **base_out)
172 const char *base = path;
173 const char *dot = 0;
174 const char *p = path;
175 char c = *p;
176 while (c)
178 if (IS_DIR_SEPARATOR(c))
180 base = p + 1;
181 dot = 0;
183 else if (c == '.')
184 dot = p;
185 c = *++p;
187 if (!dot)
188 dot = p;
189 *base_out = base;
190 return dot - base;
193 /* What to print when a switch has no documentation. */
194 static const char undocumented_msg[] = N_("This switch lacks documentation");
196 typedef char *char_p; /* For DEF_VEC_P. */
197 DEF_VEC_P(char_p);
198 DEF_VEC_ALLOC_P(char_p,heap);
200 static void handle_param (struct gcc_options *opts,
201 struct gcc_options *opts_set, location_t loc,
202 const char *carg);
203 static void set_debug_level (enum debug_info_type type, int extended,
204 const char *arg, struct gcc_options *opts,
205 struct gcc_options *opts_set,
206 location_t loc);
207 static void set_fast_math_flags (struct gcc_options *opts, int set);
208 static void decode_d_option (const char *arg, struct gcc_options *opts,
209 location_t loc, diagnostic_context *dc);
210 static void set_unsafe_math_optimizations_flags (struct gcc_options *opts,
211 int set);
212 static void enable_warning_as_error (const char *arg, int value,
213 unsigned int lang_mask,
214 const struct cl_option_handlers *handlers,
215 struct gcc_options *opts,
216 struct gcc_options *opts_set,
217 location_t loc,
218 diagnostic_context *dc);
220 /* Handle a back-end option; arguments and return value as for
221 handle_option. */
223 bool
224 target_handle_option (struct gcc_options *opts,
225 struct gcc_options *opts_set,
226 const struct cl_decoded_option *decoded,
227 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
228 location_t loc,
229 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
230 diagnostic_context *dc)
232 gcc_assert (dc == global_dc);
233 gcc_assert (kind == DK_UNSPECIFIED);
234 return targetm.handle_option (opts, opts_set, decoded, loc);
237 /* Add comma-separated strings to a char_p vector. */
239 static void
240 add_comma_separated_to_vector (void **pvec, const char *arg)
242 char *tmp;
243 char *r;
244 char *w;
245 char *token_start;
246 VEC(char_p,heap) *vec = (VEC(char_p,heap) *) *pvec;
248 /* We never free this string. */
249 tmp = xstrdup (arg);
251 r = tmp;
252 w = tmp;
253 token_start = tmp;
255 while (*r != '\0')
257 if (*r == ',')
259 *w++ = '\0';
260 ++r;
261 VEC_safe_push (char_p, heap, vec, token_start);
262 token_start = w;
264 if (*r == '\\' && r[1] == ',')
266 *w++ = ',';
267 r += 2;
269 else
270 *w++ = *r++;
272 if (*token_start != '\0')
273 VEC_safe_push (char_p, heap, vec, token_start);
275 *pvec = vec;
278 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
280 void
281 init_options_struct (struct gcc_options *opts, struct gcc_options *opts_set)
283 size_t num_params = get_num_compiler_params ();
285 *opts = global_options_init;
286 memset (opts_set, 0, sizeof (*opts_set));
288 opts->x_param_values = XNEWVEC (int, num_params);
289 opts_set->x_param_values = XCNEWVEC (int, num_params);
290 init_param_values (opts->x_param_values);
292 /* Use priority coloring if cover classes is not defined for the
293 target. */
294 if (targetm.ira_cover_classes == NULL)
295 opts->x_flag_ira_algorithm = IRA_ALGORITHM_PRIORITY;
297 /* Initialize whether `char' is signed. */
298 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
299 /* Set this to a special "uninitialized" value. The actual default
300 is set after target options have been processed. */
301 opts->x_flag_short_enums = 2;
303 /* Initialize target_flags before targetm.target_option.optimization
304 so the latter can modify it. */
305 opts->x_target_flags = targetm.default_target_flags;
307 /* Some targets have ABI-specified unwind tables. */
308 opts->x_flag_unwind_tables = targetm.unwind_tables_default;
310 /* Some targets have other target-specific initialization. */
311 targetm.target_option.init_struct (opts);
314 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
315 -Ofast if FAST is set), apply the option DEFAULT_OPT to OPTS and
316 OPTS_SET, diagnostic context DC, location LOC, with language mask
317 LANG_MASK and option handlers HANDLERS. */
319 static void
320 maybe_default_option (struct gcc_options *opts,
321 struct gcc_options *opts_set,
322 const struct default_options *default_opt,
323 int level, bool size, bool fast,
324 unsigned int lang_mask,
325 const struct cl_option_handlers *handlers,
326 location_t loc,
327 diagnostic_context *dc)
329 const struct cl_option *option = &cl_options[default_opt->opt_index];
330 bool enabled;
332 if (size)
333 gcc_assert (level == 2);
334 if (fast)
335 gcc_assert (level == 3);
337 switch (default_opt->levels)
339 case OPT_LEVELS_ALL:
340 enabled = true;
341 break;
343 case OPT_LEVELS_0_ONLY:
344 enabled = (level == 0);
345 break;
347 case OPT_LEVELS_1_PLUS:
348 enabled = (level >= 1);
349 break;
351 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
352 enabled = (level >= 1 && !size);
353 break;
355 case OPT_LEVELS_2_PLUS:
356 enabled = (level >= 2);
357 break;
359 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
360 enabled = (level >= 2 && !size);
361 break;
363 case OPT_LEVELS_3_PLUS:
364 enabled = (level >= 3);
365 break;
367 case OPT_LEVELS_3_PLUS_AND_SIZE:
368 enabled = (level >= 3 || size);
369 break;
371 case OPT_LEVELS_SIZE:
372 enabled = size;
373 break;
375 case OPT_LEVELS_FAST:
376 enabled = fast;
377 break;
379 case OPT_LEVELS_NONE:
380 default:
381 gcc_unreachable ();
384 if (enabled)
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);
389 else if (default_opt->arg == NULL
390 && !(option->flags & CL_REJECT_NEGATIVE))
391 handle_generated_option (opts, opts_set, default_opt->opt_index,
392 default_opt->arg, !default_opt->value,
393 lang_mask, DK_UNSPECIFIED, loc,
394 handlers, dc);
397 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
398 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
399 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
400 language mask LANG_MASK and option handlers HANDLERS. */
402 static void
403 maybe_default_options (struct gcc_options *opts,
404 struct gcc_options *opts_set,
405 const struct default_options *default_opts,
406 int level, bool size, bool fast,
407 unsigned int lang_mask,
408 const struct cl_option_handlers *handlers,
409 location_t loc,
410 diagnostic_context *dc)
412 size_t i;
414 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
415 maybe_default_option (opts, opts_set, &default_opts[i],
416 level, size, fast, lang_mask, handlers, loc, dc);
419 /* Table of options enabled by default at different levels. */
421 static const struct default_options default_options_table[] =
423 /* -O1 optimizations. */
424 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
425 #ifdef DELAY_SLOTS
426 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
427 #endif
428 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
429 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
430 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
431 { OPT_LEVELS_1_PLUS, OPT_fif_conversion, NULL, 1 },
432 { OPT_LEVELS_1_PLUS, OPT_fif_conversion2, NULL, 1 },
433 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
434 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
435 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
436 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
437 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
438 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
439 { OPT_LEVELS_1_PLUS, OPT_ftree_bit_ccp, NULL, 1 },
440 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
441 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
442 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
443 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
444 { OPT_LEVELS_1_PLUS, OPT_ftree_sra, NULL, 1 },
445 { OPT_LEVELS_1_PLUS, OPT_ftree_copyrename, NULL, 1 },
446 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
447 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
448 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
449 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
450 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
451 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, 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 },
488 /* -O3 optimizations. */
489 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
490 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
491 /* Inlining of functions reducing size is a good idea with -Os
492 regardless of them being declared inline. */
493 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
494 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
495 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
496 { OPT_LEVELS_3_PLUS, OPT_ftree_vectorize, NULL, 1 },
497 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
499 /* -Ofast adds optimizations to -O3. */
500 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
502 { OPT_LEVELS_NONE, 0, NULL, 0 }
505 /* Default the options in OPTS and OPTS_SET based on the optimization
506 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
507 void
508 default_options_optimization (struct gcc_options *opts,
509 struct gcc_options *opts_set,
510 struct cl_decoded_option *decoded_options,
511 unsigned int decoded_options_count,
512 location_t loc,
513 unsigned int lang_mask,
514 const struct cl_option_handlers *handlers,
515 diagnostic_context *dc)
517 unsigned int i;
518 int opt2;
520 /* Scan to see what optimization level has been specified. That will
521 determine the default value of many flags. */
522 for (i = 1; i < decoded_options_count; i++)
524 struct cl_decoded_option *opt = &decoded_options[i];
525 switch (opt->opt_index)
527 case OPT_O:
528 if (*opt->arg == '\0')
530 opts->x_optimize = 1;
531 opts->x_optimize_size = 0;
532 opts->x_optimize_fast = 0;
534 else
536 const int optimize_val = integral_argument (opt->arg);
537 if (optimize_val == -1)
538 error_at (loc,
539 "argument to %qs should be a non-negative integer",
540 "-O");
541 else
543 opts->x_optimize = optimize_val;
544 if ((unsigned int) opts->x_optimize > 255)
545 opts->x_optimize = 255;
546 opts->x_optimize_size = 0;
547 opts->x_optimize_fast = 0;
550 break;
552 case OPT_Os:
553 opts->x_optimize_size = 1;
555 /* Optimizing for size forces optimize to be 2. */
556 opts->x_optimize = 2;
557 opts->x_optimize_fast = 0;
558 break;
560 case OPT_Ofast:
561 /* -Ofast only adds flags to -O3. */
562 opts->x_optimize_size = 0;
563 opts->x_optimize = 3;
564 opts->x_optimize_fast = 1;
565 break;
567 default:
568 /* Ignore other options in this prescan. */
569 break;
573 maybe_default_options (opts, opts_set, default_options_table,
574 opts->x_optimize, opts->x_optimize_size,
575 opts->x_optimize_fast, lang_mask, handlers, loc, dc);
577 /* -O2 param settings. */
578 opt2 = (opts->x_optimize >= 2);
580 /* Track fields in field-sensitive alias analysis. */
581 maybe_set_param_value
582 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
583 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
584 opts->x_param_values, opts_set->x_param_values);
586 /* For -O1 only do loop invariant motion for very small loops. */
587 maybe_set_param_value
588 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
589 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
590 opts->x_param_values, opts_set->x_param_values);
592 if (opts->x_optimize_size)
593 /* We want to crossjump as much as possible. */
594 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
595 opts->x_param_values, opts_set->x_param_values);
596 else
597 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
598 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
599 opts->x_param_values, opts_set->x_param_values);
601 /* Allow default optimizations to be specified on a per-machine basis. */
602 maybe_default_options (opts, opts_set,
603 targetm.target_option.optimization_table,
604 opts->x_optimize, opts->x_optimize_size,
605 opts->x_optimize_fast, lang_mask, handlers, loc, dc);
608 /* After all options at LOC have been read into OPTS and OPTS_SET,
609 finalize settings of those options and diagnose incompatible
610 combinations. */
611 void
612 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
613 location_t loc)
615 enum unwind_info_type ui_except;
617 if (opts->x_dump_base_name && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name))
619 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
620 OPTS->X_DUMP_DIR_NAME directory. Then try to make
621 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
622 directory, typically the directory to contain the object
623 file. */
624 if (opts->x_dump_dir_name)
625 opts->x_dump_base_name = concat (opts->x_dump_dir_name,
626 opts->x_dump_base_name, NULL);
627 else if (opts->x_aux_base_name
628 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
630 const char *aux_base;
632 base_of_path (opts->x_aux_base_name, &aux_base);
633 if (opts->x_aux_base_name != aux_base)
635 int dir_len = aux_base - opts->x_aux_base_name;
636 char *new_dump_base_name =
637 XNEWVEC (char, strlen (opts->x_dump_base_name) + dir_len + 1);
639 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
640 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
641 /* Append existing OPTS->X_DUMP_BASE_NAME. */
642 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
643 opts->x_dump_base_name = new_dump_base_name;
648 /* Handle related options for unit-at-a-time, toplevel-reorder, and
649 section-anchors. */
650 if (!opts->x_flag_unit_at_a_time)
652 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
653 error_at (loc, "section anchors must be disabled when unit-at-a-time "
654 "is disabled");
655 opts->x_flag_section_anchors = 0;
656 if (opts->x_flag_toplevel_reorder == 1)
657 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
658 "is disabled");
659 opts->x_flag_toplevel_reorder = 0;
662 /* -Wmissing-noreturn is alias for -Wsuggest-attribute=noreturn. */
663 if (opts->x_warn_missing_noreturn)
664 opts->x_warn_suggest_attribute_noreturn = true;
666 /* Unless the user has asked for section anchors, we disable toplevel
667 reordering at -O0 to disable transformations that might be surprising
668 to end users and to get -fno-toplevel-reorder tested. */
669 if (!opts->x_optimize
670 && opts->x_flag_toplevel_reorder == 2
671 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
673 opts->x_flag_toplevel_reorder = 0;
674 opts->x_flag_section_anchors = 0;
676 if (!opts->x_flag_toplevel_reorder)
678 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
679 error_at (loc, "section anchors must be disabled when toplevel reorder"
680 " is disabled");
681 opts->x_flag_section_anchors = 0;
684 if (!opts->x_flag_opts_finished)
686 if (opts->x_flag_pie)
687 opts->x_flag_pic = opts->x_flag_pie;
688 if (opts->x_flag_pic && !opts->x_flag_pie)
689 opts->x_flag_shlib = 1;
690 opts->x_flag_opts_finished = true;
693 if (opts->x_optimize == 0)
695 /* Inlining does not work if not optimizing,
696 so force it not to be done. */
697 opts->x_warn_inline = 0;
698 opts->x_flag_no_inline = 1;
701 /* The optimization to partition hot and cold basic blocks into separate
702 sections of the .o and executable files does not work (currently)
703 with exception handling. This is because there is no support for
704 generating unwind info. If opts->x_flag_exceptions is turned on
705 we need to turn off the partitioning optimization. */
707 ui_except = targetm.except_unwind_info (opts);
709 if (opts->x_flag_exceptions
710 && opts->x_flag_reorder_blocks_and_partition
711 && (ui_except == UI_SJLJ || ui_except == UI_TARGET))
713 inform (loc,
714 "-freorder-blocks-and-partition does not work "
715 "with exceptions on this architecture");
716 opts->x_flag_reorder_blocks_and_partition = 0;
717 opts->x_flag_reorder_blocks = 1;
720 /* If user requested unwind info, then turn off the partitioning
721 optimization. */
723 if (opts->x_flag_unwind_tables
724 && !targetm.unwind_tables_default
725 && opts->x_flag_reorder_blocks_and_partition
726 && (ui_except == UI_SJLJ || ui_except == UI_TARGET))
728 inform (loc,
729 "-freorder-blocks-and-partition does not support "
730 "unwind info on this architecture");
731 opts->x_flag_reorder_blocks_and_partition = 0;
732 opts->x_flag_reorder_blocks = 1;
735 /* If the target requested unwind info, then turn off the partitioning
736 optimization with a different message. Likewise, if the target does not
737 support named sections. */
739 if (opts->x_flag_reorder_blocks_and_partition
740 && (!targetm.have_named_sections
741 || (opts->x_flag_unwind_tables
742 && targetm.unwind_tables_default
743 && (ui_except == UI_SJLJ || ui_except == UI_TARGET))))
745 inform (loc,
746 "-freorder-blocks-and-partition does not work "
747 "on this architecture");
748 opts->x_flag_reorder_blocks_and_partition = 0;
749 opts->x_flag_reorder_blocks = 1;
752 if (opts->x_flag_reorder_blocks_and_partition
753 && !opts_set->x_flag_reorder_functions)
754 opts->x_flag_reorder_functions = 1;
756 /* Pipelining of outer loops is only possible when general pipelining
757 capabilities are requested. */
758 if (!opts->x_flag_sel_sched_pipelining)
759 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
761 if (!targetm.ira_cover_classes
762 && opts->x_flag_ira_algorithm == IRA_ALGORITHM_CB)
764 inform (loc,
765 "-fira-algorithm=CB does not work on this architecture");
766 opts->x_flag_ira_algorithm = IRA_ALGORITHM_PRIORITY;
769 if (opts->x_flag_conserve_stack)
771 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
772 opts->x_param_values, opts_set->x_param_values);
773 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
774 opts->x_param_values, opts_set->x_param_values);
776 if (opts->x_flag_wpa || opts->x_flag_ltrans)
778 /* These passes are not WHOPR compatible yet. */
779 opts->x_flag_ipa_pta = 0;
782 if (opts->x_flag_lto)
784 #ifdef ENABLE_LTO
785 opts->x_flag_generate_lto = 1;
787 /* When generating IL, do not operate in whole-program mode.
788 Otherwise, symbols will be privatized too early, causing link
789 errors later. */
790 opts->x_flag_whole_program = 0;
791 #else
792 error_at (loc, "LTO support has not been enabled in this configuration");
793 #endif
795 if ((opts->x_flag_lto_partition_balanced != 0) + (opts->x_flag_lto_partition_1to1 != 0)
796 + (opts->x_flag_lto_partition_none != 0) >= 1)
798 if ((opts->x_flag_lto_partition_balanced != 0)
799 + (opts->x_flag_lto_partition_1to1 != 0)
800 + (opts->x_flag_lto_partition_none != 0) > 1)
801 error_at (loc, "only one -flto-partition value can be specified");
804 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
805 default value if they choose based on other options. */
806 if (opts->x_flag_split_stack == -1)
807 opts->x_flag_split_stack = 0;
808 else if (opts->x_flag_split_stack)
810 if (!targetm.supports_split_stack (true, opts))
812 error_at (loc, "%<-fsplit-stack%> is not supported by "
813 "this compiler configuration");
814 opts->x_flag_split_stack = 0;
818 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
819 is disabled. */
820 if (!opts->x_flag_tree_vectorize || !opts->x_flag_tree_loop_if_convert)
821 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
822 opts->x_param_values, opts_set->x_param_values);
825 #define LEFT_COLUMN 27
827 /* Output ITEM, of length ITEM_WIDTH, in the left column,
828 followed by word-wrapped HELP in a second column. */
829 static void
830 wrap_help (const char *help,
831 const char *item,
832 unsigned int item_width,
833 unsigned int columns)
835 unsigned int col_width = LEFT_COLUMN;
836 unsigned int remaining, room, len;
838 remaining = strlen (help);
842 room = columns - 3 - MAX (col_width, item_width);
843 if (room > columns)
844 room = 0;
845 len = remaining;
847 if (room < len)
849 unsigned int i;
851 for (i = 0; help[i]; i++)
853 if (i >= room && len != remaining)
854 break;
855 if (help[i] == ' ')
856 len = i;
857 else if ((help[i] == '-' || help[i] == '/')
858 && help[i + 1] != ' '
859 && i > 0 && ISALPHA (help[i - 1]))
860 len = i + 1;
864 printf( " %-*.*s %.*s\n", col_width, item_width, item, len, help);
865 item_width = 0;
866 while (help[len] == ' ')
867 len++;
868 help += len;
869 remaining -= len;
871 while (remaining);
874 /* Print help for a specific front-end, etc. */
875 static void
876 print_filtered_help (unsigned int include_flags,
877 unsigned int exclude_flags,
878 unsigned int any_flags,
879 unsigned int columns,
880 struct gcc_options *opts,
881 unsigned int lang_mask)
883 unsigned int i;
884 const char *help;
885 bool found = false;
886 bool displayed = false;
888 if (include_flags == CL_PARAMS)
890 for (i = 0; i < LAST_PARAM; i++)
892 const char *param = compiler_params[i].option;
894 help = compiler_params[i].help;
895 if (help == NULL || *help == '\0')
897 if (exclude_flags & CL_UNDOCUMENTED)
898 continue;
899 help = undocumented_msg;
902 /* Get the translation. */
903 help = _(help);
905 wrap_help (help, param, strlen (param), columns);
907 putchar ('\n');
908 return;
911 if (!opts->x_help_printed)
912 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
914 if (!opts->x_help_enum_printed)
915 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
917 for (i = 0; i < cl_options_count; i++)
919 char new_help[128];
920 const struct cl_option *option = cl_options + i;
921 unsigned int len;
922 const char *opt;
923 const char *tab;
925 if (include_flags == 0
926 || ((option->flags & include_flags) != include_flags))
928 if ((option->flags & any_flags) == 0)
929 continue;
932 /* Skip unwanted switches. */
933 if ((option->flags & exclude_flags) != 0)
934 continue;
936 /* The driver currently prints its own help text. */
937 if ((option->flags & CL_DRIVER) != 0
938 && (option->flags & (((1U << cl_lang_count) - 1)
939 | CL_COMMON | CL_TARGET)) == 0)
940 continue;
942 found = true;
943 /* Skip switches that have already been printed. */
944 if (opts->x_help_printed[i])
945 continue;
947 opts->x_help_printed[i] = true;
949 help = option->help;
950 if (help == NULL)
952 if (exclude_flags & CL_UNDOCUMENTED)
953 continue;
954 help = undocumented_msg;
957 /* Get the translation. */
958 help = _(help);
960 /* Find the gap between the name of the
961 option and its descriptive text. */
962 tab = strchr (help, '\t');
963 if (tab)
965 len = tab - help;
966 opt = help;
967 help = tab + 1;
969 else
971 opt = option->opt_text;
972 len = strlen (opt);
975 /* With the -Q option enabled we change the descriptive text associated
976 with an option to be an indication of its current setting. */
977 if (!quiet_flag)
979 void *flag_var = option_flag_var (i, opts);
981 if (len < (LEFT_COLUMN + 2))
982 strcpy (new_help, "\t\t");
983 else
984 strcpy (new_help, "\t");
986 if (flag_var != NULL
987 && option->var_type != CLVC_DEFER)
989 if (option->flags & CL_JOINED)
991 if (option->var_type == CLVC_STRING)
993 if (* (const char **) flag_var != NULL)
994 snprintf (new_help + strlen (new_help),
995 sizeof (new_help) - strlen (new_help),
996 * (const char **) flag_var);
998 else if (option->var_type == CLVC_ENUM)
1000 const struct cl_enum *e = &cl_enums[option->var_enum];
1001 int value;
1002 const char *arg = NULL;
1004 value = e->get (flag_var);
1005 enum_value_to_arg (e->values, &arg, value, lang_mask);
1006 if (arg == NULL)
1007 arg = _("[default]");
1008 snprintf (new_help + strlen (new_help),
1009 sizeof (new_help) - strlen (new_help),
1010 arg);
1012 else
1013 sprintf (new_help + strlen (new_help),
1014 "%#x", * (int *) flag_var);
1016 else
1017 strcat (new_help, option_enabled (i, opts)
1018 ? _("[enabled]") : _("[disabled]"));
1021 help = new_help;
1024 wrap_help (help, opt, len, columns);
1025 displayed = true;
1027 if (option->var_type == CLVC_ENUM
1028 && opts->x_help_enum_printed[option->var_enum] != 2)
1029 opts->x_help_enum_printed[option->var_enum] = 1;
1032 if (! found)
1034 unsigned int langs = include_flags & CL_LANG_ALL;
1036 if (langs == 0)
1037 printf (_(" No options with the desired characteristics were found\n"));
1038 else
1040 unsigned int i;
1042 /* PR 31349: Tell the user how to see all of the
1043 options supported by a specific front end. */
1044 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1045 if ((1U << i) & langs)
1046 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end\n"),
1047 lang_names[i], lang_names[i]);
1051 else if (! displayed)
1052 printf (_(" All options with the desired characteristics have already been displayed\n"));
1054 putchar ('\n');
1056 /* Print details of enumerated option arguments, if those
1057 enumerations have help text headings provided. If no help text
1058 is provided, presume that the possible values are listed in the
1059 help text for the relevant options. */
1060 for (i = 0; i < cl_enums_count; i++)
1062 unsigned int j, pos;
1064 if (opts->x_help_enum_printed[i] != 1)
1065 continue;
1066 if (cl_enums[i].help == NULL)
1067 continue;
1068 printf (" %s\n ", _(cl_enums[i].help));
1069 pos = 4;
1070 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1072 unsigned int len = strlen (cl_enums[i].values[j].arg);
1074 if (pos > 4 && pos + 1 + len <= columns)
1076 printf (" %s", cl_enums[i].values[j].arg);
1077 pos += 1 + len;
1079 else
1081 if (pos > 4)
1083 printf ("\n ");
1084 pos = 4;
1086 printf ("%s", cl_enums[i].values[j].arg);
1087 pos += len;
1090 printf ("\n\n");
1091 opts->x_help_enum_printed[i] = 2;
1095 /* Display help for a specified type of option.
1096 The options must have ALL of the INCLUDE_FLAGS set
1097 ANY of the flags in the ANY_FLAGS set
1098 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1099 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1100 static void
1101 print_specific_help (unsigned int include_flags,
1102 unsigned int exclude_flags,
1103 unsigned int any_flags,
1104 struct gcc_options *opts,
1105 unsigned int lang_mask)
1107 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1108 const char * description = NULL;
1109 const char * descrip_extra = "";
1110 size_t i;
1111 unsigned int flag;
1113 /* Sanity check: Make sure that we do not have more
1114 languages than we have bits available to enumerate them. */
1115 gcc_assert ((1U << cl_lang_count) < CL_MIN_OPTION_CLASS);
1117 /* If we have not done so already, obtain
1118 the desired maximum width of the output. */
1119 if (opts->x_help_columns == 0)
1121 const char *p;
1123 p = getenv ("COLUMNS");
1124 if (p != NULL)
1126 int value = atoi (p);
1128 if (value > 0)
1129 opts->x_help_columns = value;
1132 if (opts->x_help_columns == 0)
1133 /* Use a reasonable default. */
1134 opts->x_help_columns = 80;
1137 /* Decide upon the title for the options that we are going to display. */
1138 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1140 switch (flag & include_flags)
1142 case 0:
1143 case CL_DRIVER:
1144 break;
1146 case CL_TARGET:
1147 description = _("The following options are target specific");
1148 break;
1149 case CL_WARNING:
1150 description = _("The following options control compiler warning messages");
1151 break;
1152 case CL_OPTIMIZATION:
1153 description = _("The following options control optimizations");
1154 break;
1155 case CL_COMMON:
1156 description = _("The following options are language-independent");
1157 break;
1158 case CL_PARAMS:
1159 description = _("The --param option recognizes the following as parameters");
1160 break;
1161 default:
1162 if (i >= cl_lang_count)
1163 break;
1164 if (exclude_flags & all_langs_mask)
1165 description = _("The following options are specific to just the language ");
1166 else
1167 description = _("The following options are supported by the language ");
1168 descrip_extra = lang_names [i];
1169 break;
1173 if (description == NULL)
1175 if (any_flags == 0)
1177 if (include_flags & CL_UNDOCUMENTED)
1178 description = _("The following options are not documented");
1179 else if (include_flags & CL_SEPARATE)
1180 description = _("The following options take separate arguments");
1181 else if (include_flags & CL_JOINED)
1182 description = _("The following options take joined arguments");
1183 else
1185 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1186 include_flags);
1187 return;
1190 else
1192 if (any_flags & all_langs_mask)
1193 description = _("The following options are language-related");
1194 else
1195 description = _("The following options are language-independent");
1199 printf ("%s%s:\n", description, descrip_extra);
1200 print_filtered_help (include_flags, exclude_flags, any_flags,
1201 opts->x_help_columns, opts, lang_mask);
1204 /* Handle target- and language-independent options. Return zero to
1205 generate an "unknown option" message. Only options that need
1206 extra handling need to be listed here; if you simply want
1207 DECODED->value assigned to a variable, it happens automatically. */
1209 bool
1210 common_handle_option (struct gcc_options *opts,
1211 struct gcc_options *opts_set,
1212 const struct cl_decoded_option *decoded,
1213 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1214 location_t loc,
1215 const struct cl_option_handlers *handlers,
1216 diagnostic_context *dc)
1218 size_t scode = decoded->opt_index;
1219 const char *arg = decoded->arg;
1220 int value = decoded->value;
1221 enum opt_code code = (enum opt_code) scode;
1223 gcc_assert (decoded->canonical_option_num_elements <= 2);
1225 switch (code)
1227 case OPT__param:
1228 handle_param (opts, opts_set, loc, arg);
1229 break;
1231 case OPT__help:
1233 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1234 unsigned int undoc_mask;
1235 unsigned int i;
1237 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1239 : CL_UNDOCUMENTED);
1240 /* First display any single language specific options. */
1241 for (i = 0; i < cl_lang_count; i++)
1242 print_specific_help
1243 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1244 lang_mask);
1245 /* Next display any multi language specific options. */
1246 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1247 /* Then display any remaining, non-language options. */
1248 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1249 if (i != CL_DRIVER)
1250 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1251 opts->x_exit_after_options = true;
1252 break;
1255 case OPT__target_help:
1256 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1257 opts->x_exit_after_options = true;
1259 /* Allow the target a chance to give the user some additional information. */
1260 if (targetm.help)
1261 targetm.help ();
1262 break;
1264 case OPT__help_:
1266 const char * a = arg;
1267 unsigned int include_flags = 0;
1268 /* Note - by default we include undocumented options when listing
1269 specific classes. If you only want to see documented options
1270 then add ",^undocumented" to the --help= option. E.g.:
1272 --help=target,^undocumented */
1273 unsigned int exclude_flags = 0;
1275 /* Walk along the argument string, parsing each word in turn.
1276 The format is:
1277 arg = [^]{word}[,{arg}]
1278 word = {optimizers|target|warnings|undocumented|
1279 params|common|<language>} */
1280 while (* a != 0)
1282 static const struct
1284 const char * string;
1285 unsigned int flag;
1287 specifics[] =
1289 { "optimizers", CL_OPTIMIZATION },
1290 { "target", CL_TARGET },
1291 { "warnings", CL_WARNING },
1292 { "undocumented", CL_UNDOCUMENTED },
1293 { "params", CL_PARAMS },
1294 { "joined", CL_JOINED },
1295 { "separate", CL_SEPARATE },
1296 { "common", CL_COMMON },
1297 { NULL, 0 }
1299 unsigned int * pflags;
1300 const char * comma;
1301 unsigned int lang_flag, specific_flag;
1302 unsigned int len;
1303 unsigned int i;
1305 if (* a == '^')
1307 ++ a;
1308 pflags = & exclude_flags;
1310 else
1311 pflags = & include_flags;
1313 comma = strchr (a, ',');
1314 if (comma == NULL)
1315 len = strlen (a);
1316 else
1317 len = comma - a;
1318 if (len == 0)
1320 a = comma + 1;
1321 continue;
1324 /* Check to see if the string matches an option class name. */
1325 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1326 if (strncasecmp (a, specifics[i].string, len) == 0)
1328 specific_flag = specifics[i].flag;
1329 break;
1332 /* Check to see if the string matches a language name.
1333 Note - we rely upon the alpha-sorted nature of the entries in
1334 the lang_names array, specifically that shorter names appear
1335 before their longer variants. (i.e. C before C++). That way
1336 when we are attempting to match --help=c for example we will
1337 match with C first and not C++. */
1338 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1339 if (strncasecmp (a, lang_names[i], len) == 0)
1341 lang_flag = 1U << i;
1342 break;
1345 if (specific_flag != 0)
1347 if (lang_flag == 0)
1348 * pflags |= specific_flag;
1349 else
1351 /* The option's argument matches both the start of a
1352 language name and the start of an option class name.
1353 We have a special case for when the user has
1354 specified "--help=c", but otherwise we have to issue
1355 a warning. */
1356 if (strncasecmp (a, "c", len) == 0)
1357 * pflags |= lang_flag;
1358 else
1359 warning_at (loc, 0,
1360 "--help argument %q.*s is ambiguous, "
1361 "please be more specific",
1362 len, a);
1365 else if (lang_flag != 0)
1366 * pflags |= lang_flag;
1367 else
1368 warning_at (loc, 0,
1369 "unrecognized argument to --help= option: %q.*s",
1370 len, a);
1372 if (comma == NULL)
1373 break;
1374 a = comma + 1;
1377 if (include_flags)
1378 print_specific_help (include_flags, exclude_flags, 0, opts,
1379 lang_mask);
1380 opts->x_exit_after_options = true;
1381 break;
1384 case OPT__version:
1385 opts->x_exit_after_options = true;
1386 break;
1388 case OPT_O:
1389 case OPT_Os:
1390 case OPT_Ofast:
1391 /* Currently handled in a prescan. */
1392 break;
1394 case OPT_Werror_:
1395 enable_warning_as_error (arg, value, lang_mask, handlers,
1396 opts, opts_set, loc, dc);
1397 break;
1399 case OPT_Wlarger_than_:
1400 opts->x_larger_than_size = value;
1401 opts->x_warn_larger_than = value != -1;
1402 break;
1404 case OPT_Wfatal_errors:
1405 dc->fatal_errors = value;
1406 break;
1408 case OPT_Wframe_larger_than_:
1409 opts->x_frame_larger_than_size = value;
1410 opts->x_warn_frame_larger_than = value != -1;
1411 break;
1413 case OPT_Wstrict_aliasing:
1414 set_Wstrict_aliasing (opts, value);
1415 break;
1417 case OPT_Wstrict_overflow:
1418 opts->x_warn_strict_overflow = (value
1419 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1420 : 0);
1421 break;
1423 case OPT_Wsystem_headers:
1424 dc->dc_warn_system_headers = value;
1425 break;
1427 case OPT_aux_info:
1428 opts->x_flag_gen_aux_info = 1;
1429 break;
1431 case OPT_auxbase_strip:
1433 char *tmp = xstrdup (arg);
1434 strip_off_ending (tmp, strlen (tmp));
1435 if (tmp[0])
1436 opts->x_aux_base_name = tmp;
1438 break;
1440 case OPT_d:
1441 decode_d_option (arg, opts, loc, dc);
1442 break;
1444 case OPT_fcall_used_:
1445 case OPT_fcall_saved_:
1446 /* Deferred. */
1447 break;
1449 case OPT_fdbg_cnt_:
1450 case OPT_fdbg_cnt_list:
1451 /* Deferred. */
1452 break;
1454 case OPT_fdebug_prefix_map_:
1455 /* Deferred. */
1456 break;
1458 case OPT_fdiagnostics_show_location_:
1459 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1460 break;
1462 case OPT_fdiagnostics_show_option:
1463 dc->show_option_requested = value;
1464 break;
1466 case OPT_fdump_:
1467 /* Deferred. */
1468 break;
1470 case OPT_ffast_math:
1471 set_fast_math_flags (opts, value);
1472 break;
1474 case OPT_funsafe_math_optimizations:
1475 set_unsafe_math_optimizations_flags (opts, value);
1476 break;
1478 case OPT_ffixed_:
1479 /* Deferred. */
1480 break;
1482 case OPT_finline_limit_:
1483 set_param_value ("max-inline-insns-single", value / 2,
1484 opts->x_param_values, opts_set->x_param_values);
1485 set_param_value ("max-inline-insns-auto", value / 2,
1486 opts->x_param_values, opts_set->x_param_values);
1487 break;
1489 case OPT_finstrument_functions_exclude_function_list_:
1490 add_comma_separated_to_vector
1491 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1492 break;
1494 case OPT_finstrument_functions_exclude_file_list_:
1495 add_comma_separated_to_vector
1496 (&opts->x_flag_instrument_functions_exclude_files, arg);
1497 break;
1499 case OPT_fmessage_length_:
1500 pp_set_line_maximum_length (dc->printer, value);
1501 break;
1503 case OPT_fpack_struct_:
1504 if (value <= 0 || (value & (value - 1)) || value > 16)
1505 error_at (loc,
1506 "structure alignment must be a small power of two, not %d",
1507 value);
1508 else
1509 opts->x_initial_max_fld_align = value;
1510 break;
1512 case OPT_fplugin_:
1513 case OPT_fplugin_arg_:
1514 /* Deferred. */
1515 break;
1517 case OPT_fprofile_use_:
1518 opts->x_profile_data_prefix = xstrdup (arg);
1519 opts->x_flag_profile_use = true;
1520 value = true;
1521 /* No break here - do -fprofile-use processing. */
1522 case OPT_fprofile_use:
1523 if (!opts_set->x_flag_branch_probabilities)
1524 opts->x_flag_branch_probabilities = value;
1525 if (!opts_set->x_flag_profile_values)
1526 opts->x_flag_profile_values = value;
1527 if (!opts_set->x_flag_unroll_loops)
1528 opts->x_flag_unroll_loops = value;
1529 if (!opts_set->x_flag_peel_loops)
1530 opts->x_flag_peel_loops = value;
1531 if (!opts_set->x_flag_tracer)
1532 opts->x_flag_tracer = value;
1533 if (!opts_set->x_flag_value_profile_transformations)
1534 opts->x_flag_value_profile_transformations = value;
1535 if (!opts_set->x_flag_inline_functions)
1536 opts->x_flag_inline_functions = value;
1537 if (!opts_set->x_flag_ipa_cp)
1538 opts->x_flag_ipa_cp = value;
1539 if (!opts_set->x_flag_ipa_cp_clone
1540 && value && opts->x_flag_ipa_cp)
1541 opts->x_flag_ipa_cp_clone = value;
1542 if (!opts_set->x_flag_predictive_commoning)
1543 opts->x_flag_predictive_commoning = value;
1544 if (!opts_set->x_flag_unswitch_loops)
1545 opts->x_flag_unswitch_loops = value;
1546 if (!opts_set->x_flag_gcse_after_reload)
1547 opts->x_flag_gcse_after_reload = value;
1548 break;
1550 case OPT_fprofile_generate_:
1551 opts->x_profile_data_prefix = xstrdup (arg);
1552 value = true;
1553 /* No break here - do -fprofile-generate processing. */
1554 case OPT_fprofile_generate:
1555 if (!opts_set->x_profile_arc_flag)
1556 opts->x_profile_arc_flag = value;
1557 if (!opts_set->x_flag_profile_values)
1558 opts->x_flag_profile_values = value;
1559 if (!opts_set->x_flag_value_profile_transformations)
1560 opts->x_flag_value_profile_transformations = value;
1561 if (!opts_set->x_flag_inline_functions)
1562 opts->x_flag_inline_functions = value;
1563 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1564 quadratic. Disable the pass until better memory representation
1565 is done. */
1566 if (!opts_set->x_flag_ipa_reference && in_lto_p)
1567 opts->x_flag_ipa_reference = false;
1568 break;
1570 case OPT_fshow_column:
1571 dc->show_column = value;
1572 break;
1574 case OPT_frandom_seed:
1575 /* The real switch is -fno-random-seed. */
1576 if (value)
1577 return false;
1578 /* Deferred. */
1579 break;
1581 case OPT_frandom_seed_:
1582 /* Deferred. */
1583 break;
1585 case OPT_fsched_verbose_:
1586 #ifdef INSN_SCHEDULING
1587 /* Handled with Var in common.opt. */
1588 break;
1589 #else
1590 return false;
1591 #endif
1593 case OPT_fsched_stalled_insns_:
1594 opts->x_flag_sched_stalled_insns = value;
1595 if (opts->x_flag_sched_stalled_insns == 0)
1596 opts->x_flag_sched_stalled_insns = -1;
1597 break;
1599 case OPT_fsched_stalled_insns_dep_:
1600 opts->x_flag_sched_stalled_insns_dep = value;
1601 break;
1603 case OPT_fstack_check_:
1604 if (!strcmp (arg, "no"))
1605 opts->x_flag_stack_check = NO_STACK_CHECK;
1606 else if (!strcmp (arg, "generic"))
1607 /* This is the old stack checking method. */
1608 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1609 ? FULL_BUILTIN_STACK_CHECK
1610 : GENERIC_STACK_CHECK;
1611 else if (!strcmp (arg, "specific"))
1612 /* This is the new stack checking method. */
1613 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1614 ? FULL_BUILTIN_STACK_CHECK
1615 : STACK_CHECK_STATIC_BUILTIN
1616 ? STATIC_BUILTIN_STACK_CHECK
1617 : GENERIC_STACK_CHECK;
1618 else
1619 warning_at (loc, 0, "unknown stack check parameter \"%s\"", arg);
1620 break;
1622 case OPT_fstack_limit:
1623 /* The real switch is -fno-stack-limit. */
1624 if (value)
1625 return false;
1626 /* Deferred. */
1627 break;
1629 case OPT_fstack_limit_register_:
1630 case OPT_fstack_limit_symbol_:
1631 /* Deferred. */
1632 break;
1634 case OPT_ftree_vectorizer_verbose_:
1635 vect_set_verbosity_level (opts, value);
1636 break;
1638 case OPT_g:
1639 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
1640 loc);
1641 break;
1643 case OPT_gcoff:
1644 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
1645 break;
1647 case OPT_gdwarf_:
1648 if (value < 2 || value > 4)
1649 error_at (loc, "dwarf version %d is not supported", value);
1650 else
1651 dwarf_version = value;
1652 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
1653 break;
1655 case OPT_ggdb:
1656 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
1657 break;
1659 case OPT_gstabs:
1660 case OPT_gstabs_:
1661 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
1662 loc);
1663 break;
1665 case OPT_gvms:
1666 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
1667 break;
1669 case OPT_gxcoff:
1670 case OPT_gxcoff_:
1671 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
1672 loc);
1673 break;
1675 case OPT_pedantic_errors:
1676 opts->x_pedantic = 1;
1677 dc->pedantic_errors = 1;
1678 break;
1680 case OPT_flto:
1681 opts->x_flag_lto = value ? "" : NULL;
1682 break;
1684 case OPT_w:
1685 dc->dc_inhibit_warnings = true;
1686 break;
1688 case OPT_fmax_errors_:
1689 dc->max_errors = value;
1690 break;
1692 case OPT_fuse_linker_plugin:
1693 /* No-op. Used by the driver and passed to us because it starts with f.*/
1694 break;
1696 default:
1697 /* If the flag was handled in a standard way, assume the lack of
1698 processing here is intentional. */
1699 gcc_assert (option_flag_var (scode, opts));
1700 break;
1703 return true;
1706 /* Handle --param NAME=VALUE. */
1707 static void
1708 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
1709 location_t loc, const char *carg)
1711 char *equal, *arg;
1712 int value;
1714 arg = xstrdup (carg);
1715 equal = strchr (arg, '=');
1716 if (!equal)
1717 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
1718 arg);
1719 else
1721 value = integral_argument (equal + 1);
1722 if (value == -1)
1723 error_at (loc, "invalid --param value %qs", equal + 1);
1724 else
1726 *equal = '\0';
1727 set_param_value (arg, value,
1728 opts->x_param_values, opts_set->x_param_values);
1732 free (arg);
1735 /* Used to set the level of strict aliasing warnings in OPTS,
1736 when no level is specified (i.e., when -Wstrict-aliasing, and not
1737 -Wstrict-aliasing=level was given).
1738 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
1739 and 0 otherwise. After calling this function, wstrict_aliasing will be
1740 set to the default value of -Wstrict_aliasing=level, currently 3. */
1741 void
1742 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
1744 gcc_assert (onoff == 0 || onoff == 1);
1745 if (onoff != 0)
1746 opts->x_warn_strict_aliasing = 3;
1747 else
1748 opts->x_warn_strict_aliasing = 0;
1751 /* The following routines are useful in setting all the flags that
1752 -ffast-math and -fno-fast-math imply. */
1753 static void
1754 set_fast_math_flags (struct gcc_options *opts, int set)
1756 if (!opts->frontend_set_flag_unsafe_math_optimizations)
1758 opts->x_flag_unsafe_math_optimizations = set;
1759 set_unsafe_math_optimizations_flags (opts, set);
1761 if (!opts->frontend_set_flag_finite_math_only)
1762 opts->x_flag_finite_math_only = set;
1763 if (!opts->frontend_set_flag_errno_math)
1764 opts->x_flag_errno_math = !set;
1765 if (set)
1767 if (!opts->frontend_set_flag_signaling_nans)
1768 opts->x_flag_signaling_nans = 0;
1769 if (!opts->frontend_set_flag_rounding_math)
1770 opts->x_flag_rounding_math = 0;
1771 if (!opts->frontend_set_flag_cx_limited_range)
1772 opts->x_flag_cx_limited_range = 1;
1776 /* When -funsafe-math-optimizations is set the following
1777 flags are set as well. */
1778 static void
1779 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
1781 if (!opts->frontend_set_flag_trapping_math)
1782 opts->x_flag_trapping_math = !set;
1783 if (!opts->frontend_set_flag_signed_zeros)
1784 opts->x_flag_signed_zeros = !set;
1785 if (!opts->frontend_set_flag_associative_math)
1786 opts->x_flag_associative_math = set;
1787 if (!opts->frontend_set_flag_reciprocal_math)
1788 opts->x_flag_reciprocal_math = set;
1791 /* Return true iff flags in OPTS are set as if -ffast-math. */
1792 bool
1793 fast_math_flags_set_p (const struct gcc_options *opts)
1795 return (!opts->x_flag_trapping_math
1796 && opts->x_flag_unsafe_math_optimizations
1797 && opts->x_flag_finite_math_only
1798 && !opts->x_flag_signed_zeros
1799 && !opts->x_flag_errno_math);
1802 /* Return true iff flags are set as if -ffast-math but using the flags stored
1803 in the struct cl_optimization structure. */
1804 bool
1805 fast_math_flags_struct_set_p (struct cl_optimization *opt)
1807 return (!opt->x_flag_trapping_math
1808 && opt->x_flag_unsafe_math_optimizations
1809 && opt->x_flag_finite_math_only
1810 && !opt->x_flag_signed_zeros
1811 && !opt->x_flag_errno_math);
1814 /* Handle a debug output -g switch for options OPTS
1815 (OPTS_SET->x_write_symbols storing whether a debug type was passed
1816 explicitly), location LOC. EXTENDED is true or false to support
1817 extended output (2 is special and means "-ggdb" was given). */
1818 static void
1819 set_debug_level (enum debug_info_type type, int extended, const char *arg,
1820 struct gcc_options *opts, struct gcc_options *opts_set,
1821 location_t loc)
1823 opts->x_use_gnu_debug_info_extensions = extended;
1825 if (type == NO_DEBUG)
1827 if (opts->x_write_symbols == NO_DEBUG)
1829 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
1831 if (extended == 2)
1833 #ifdef DWARF2_DEBUGGING_INFO
1834 opts->x_write_symbols = DWARF2_DEBUG;
1835 #elif defined DBX_DEBUGGING_INFO
1836 opts->x_write_symbols = DBX_DEBUG;
1837 #endif
1840 if (opts->x_write_symbols == NO_DEBUG)
1841 warning_at (loc, 0, "target system does not support debug output");
1844 else
1846 /* Does it conflict with an already selected type? */
1847 if (opts_set->x_write_symbols != NO_DEBUG
1848 && opts->x_write_symbols != NO_DEBUG
1849 && type != opts->x_write_symbols)
1850 error_at (loc, "debug format \"%s\" conflicts with prior selection",
1851 debug_type_names[type]);
1852 opts->x_write_symbols = type;
1853 opts_set->x_write_symbols = type;
1856 /* A debug flag without a level defaults to level 2. */
1857 if (*arg == '\0')
1859 if (!opts->x_debug_info_level)
1860 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
1862 else
1864 int argval = integral_argument (arg);
1865 if (argval == -1)
1866 error_at (loc, "unrecognised debug output level \"%s\"", arg);
1867 else if (argval > 3)
1868 error_at (loc, "debug output level %s is too high", arg);
1869 else
1870 opts->x_debug_info_level = (enum debug_info_levels) argval;
1874 /* Arrange to dump core on error for diagnostic context DC. (The
1875 regular error message is still printed first, except in the case of
1876 abort ().) */
1878 static void
1879 setup_core_dumping (diagnostic_context *dc)
1881 #ifdef SIGABRT
1882 signal (SIGABRT, SIG_DFL);
1883 #endif
1884 #if defined(HAVE_SETRLIMIT)
1886 struct rlimit rlim;
1887 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
1888 fatal_error ("getting core file size maximum limit: %m");
1889 rlim.rlim_cur = rlim.rlim_max;
1890 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
1891 fatal_error ("setting core file size limit to maximum: %m");
1893 #endif
1894 diagnostic_abort_on_error (dc);
1897 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
1898 diagnostic context DC. */
1900 static void
1901 decode_d_option (const char *arg, struct gcc_options *opts,
1902 location_t loc, diagnostic_context *dc)
1904 int c;
1906 while (*arg)
1907 switch (c = *arg++)
1909 case 'A':
1910 opts->x_flag_debug_asm = 1;
1911 break;
1912 case 'p':
1913 opts->x_flag_print_asm_name = 1;
1914 break;
1915 case 'P':
1916 opts->x_flag_dump_rtl_in_asm = 1;
1917 opts->x_flag_print_asm_name = 1;
1918 break;
1919 case 'v':
1920 opts->x_graph_dump_format = vcg;
1921 break;
1922 case 'x':
1923 opts->x_rtl_dump_and_exit = 1;
1924 break;
1925 case 'D': /* These are handled by the preprocessor. */
1926 case 'I':
1927 case 'M':
1928 case 'N':
1929 case 'U':
1930 break;
1931 case 'H':
1932 setup_core_dumping (dc);
1933 break;
1934 case 'a':
1935 opts->x_flag_dump_all_passed = true;
1936 break;
1938 default:
1939 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
1940 break;
1944 /* Enable (or disable if VALUE is 0) a warning option ARG (language
1945 mask LANG_MASK, option handlers HANDLERS) as an error for option
1946 structures OPTS and OPTS_SET, diagnostic context DC (possibly
1947 NULL), location LOC. This is used by -Werror=. */
1949 static void
1950 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
1951 const struct cl_option_handlers *handlers,
1952 struct gcc_options *opts,
1953 struct gcc_options *opts_set,
1954 location_t loc, diagnostic_context *dc)
1956 char *new_option;
1957 int option_index;
1959 new_option = XNEWVEC (char, strlen (arg) + 2);
1960 new_option[0] = 'W';
1961 strcpy (new_option + 1, arg);
1962 option_index = find_opt (new_option, lang_mask);
1963 if (option_index == OPT_SPECIAL_unknown)
1965 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
1967 else
1969 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
1971 control_warning_option (option_index, (int) kind, value,
1972 loc, lang_mask,
1973 handlers, opts, opts_set, dc);
1975 free (new_option);
1978 /* Return malloced memory for the name of the option OPTION_INDEX
1979 which enabled a diagnostic (context CONTEXT), originally of type
1980 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
1981 as -Werror. */
1983 char *
1984 option_name (diagnostic_context *context, int option_index,
1985 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
1987 if (option_index)
1989 /* A warning classified as an error. */
1990 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
1991 && diag_kind == DK_ERROR)
1992 return concat (cl_options[OPT_Werror_].opt_text,
1993 /* Skip over "-W". */
1994 cl_options[option_index].opt_text + 2,
1995 NULL);
1996 /* A warning with option. */
1997 else
1998 return xstrdup (cl_options[option_index].opt_text);
2000 /* A warning without option classified as an error. */
2001 else if (orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2002 || diag_kind == DK_WARNING)
2004 if (context->warning_as_error_requested)
2005 return xstrdup (cl_options[OPT_Werror].opt_text);
2006 else
2007 return xstrdup (_("enabled by default"));
2009 else
2010 return NULL;