2012-10-16 Manuel López-Ibáñez <manu@gcc.gnu.org>
[official-gcc.git] / gcc / opts.c
blob98bbd302c8e0a987f9b7fbce665e721df0465c4a
1 /* Command line option handling.
2 Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011,
3 2012
5 Free Software Foundation, Inc.
6 Contributed by Neil Booth.
8 This file is part of GCC.
10 GCC is free software; you can redistribute it and/or modify it under
11 the terms of the GNU General Public License as published by the Free
12 Software Foundation; either version 3, or (at your option) any later
13 version.
15 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
16 WARRANTY; without even the implied warranty of MERCHANTABILITY or
17 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
18 for more details.
20 You should have received a copy of the GNU General Public License
21 along with GCC; see the file COPYING3. If not see
22 <http://www.gnu.org/licenses/>. */
24 #include "config.h"
25 #include "system.h"
26 #include "intl.h"
27 #include "coretypes.h"
28 #include "opts.h"
29 #include "options.h"
30 #include "tm.h" /* For STACK_CHECK_BUILTIN,
31 STACK_CHECK_STATIC_BUILTIN, DEFAULT_GDB_EXTENSIONS,
32 DWARF2_DEBUGGING_INFO and DBX_DEBUGGING_INFO. */
33 #include "flags.h"
34 #include "params.h"
35 #include "diagnostic.h"
36 #include "opts-diagnostic.h"
37 #include "insn-attr-common.h"
38 #include "common/common-target.h"
40 static void set_Wstrict_aliasing (struct gcc_options *opts, int onoff);
42 /* Indexed by enum debug_info_type. */
43 const char *const debug_type_names[] =
45 "none", "stabs", "coff", "dwarf-2", "xcoff", "vms"
48 /* Parse the -femit-struct-debug-detailed option value
49 and set the flag variables. */
51 #define MATCH( prefix, string ) \
52 ((strncmp (prefix, string, sizeof prefix - 1) == 0) \
53 ? ((string += sizeof prefix - 1), 1) : 0)
55 void
56 set_struct_debug_option (struct gcc_options *opts, location_t loc,
57 const char *spec)
59 /* various labels for comparison */
60 static const char dfn_lbl[] = "dfn:", dir_lbl[] = "dir:", ind_lbl[] = "ind:";
61 static const char ord_lbl[] = "ord:", gen_lbl[] = "gen:";
62 static const char none_lbl[] = "none", any_lbl[] = "any";
63 static const char base_lbl[] = "base", sys_lbl[] = "sys";
65 enum debug_struct_file files = DINFO_STRUCT_FILE_ANY;
66 /* Default is to apply to as much as possible. */
67 enum debug_info_usage usage = DINFO_USAGE_NUM_ENUMS;
68 int ord = 1, gen = 1;
70 /* What usage? */
71 if (MATCH (dfn_lbl, spec))
72 usage = DINFO_USAGE_DFN;
73 else if (MATCH (dir_lbl, spec))
74 usage = DINFO_USAGE_DIR_USE;
75 else if (MATCH (ind_lbl, spec))
76 usage = DINFO_USAGE_IND_USE;
78 /* Generics or not? */
79 if (MATCH (ord_lbl, spec))
80 gen = 0;
81 else if (MATCH (gen_lbl, spec))
82 ord = 0;
84 /* What allowable environment? */
85 if (MATCH (none_lbl, spec))
86 files = DINFO_STRUCT_FILE_NONE;
87 else if (MATCH (any_lbl, spec))
88 files = DINFO_STRUCT_FILE_ANY;
89 else if (MATCH (sys_lbl, spec))
90 files = DINFO_STRUCT_FILE_SYS;
91 else if (MATCH (base_lbl, spec))
92 files = DINFO_STRUCT_FILE_BASE;
93 else
94 error_at (loc,
95 "argument %qs to %<-femit-struct-debug-detailed%> "
96 "not recognized",
97 spec);
99 /* Effect the specification. */
100 if (usage == DINFO_USAGE_NUM_ENUMS)
102 if (ord)
104 opts->x_debug_struct_ordinary[DINFO_USAGE_DFN] = files;
105 opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE] = files;
106 opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE] = files;
108 if (gen)
110 opts->x_debug_struct_generic[DINFO_USAGE_DFN] = files;
111 opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE] = files;
112 opts->x_debug_struct_generic[DINFO_USAGE_IND_USE] = files;
115 else
117 if (ord)
118 opts->x_debug_struct_ordinary[usage] = files;
119 if (gen)
120 opts->x_debug_struct_generic[usage] = files;
123 if (*spec == ',')
124 set_struct_debug_option (opts, loc, spec+1);
125 else
127 /* No more -femit-struct-debug-detailed specifications.
128 Do final checks. */
129 if (*spec != '\0')
130 error_at (loc,
131 "argument %qs to %<-femit-struct-debug-detailed%> unknown",
132 spec);
133 if (opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE]
134 < opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE]
135 || opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE]
136 < opts->x_debug_struct_generic[DINFO_USAGE_IND_USE])
137 error_at (loc,
138 "%<-femit-struct-debug-detailed=dir:...%> must allow "
139 "at least as much as "
140 "%<-femit-struct-debug-detailed=ind:...%>");
144 /* Strip off a legitimate source ending from the input string NAME of
145 length LEN. Rather than having to know the names used by all of
146 our front ends, we strip off an ending of a period followed by
147 up to five characters. (Java uses ".class".) */
149 void
150 strip_off_ending (char *name, int len)
152 int i;
153 for (i = 2; i < 6 && len > i; i++)
155 if (name[len - i] == '.')
157 name[len - i] = '\0';
158 break;
163 /* Find the base name of a path, stripping off both directories and
164 a single final extension. */
166 base_of_path (const char *path, const char **base_out)
168 const char *base = path;
169 const char *dot = 0;
170 const char *p = path;
171 char c = *p;
172 while (c)
174 if (IS_DIR_SEPARATOR(c))
176 base = p + 1;
177 dot = 0;
179 else if (c == '.')
180 dot = p;
181 c = *++p;
183 if (!dot)
184 dot = p;
185 *base_out = base;
186 return dot - base;
189 /* What to print when a switch has no documentation. */
190 static const char undocumented_msg[] = N_("This switch lacks documentation");
192 typedef char *char_p; /* For DEF_VEC_P. */
193 DEF_VEC_P(char_p);
194 DEF_VEC_ALLOC_P(char_p,heap);
196 static void handle_param (struct gcc_options *opts,
197 struct gcc_options *opts_set, location_t loc,
198 const char *carg);
199 static void set_debug_level (enum debug_info_type type, int extended,
200 const char *arg, struct gcc_options *opts,
201 struct gcc_options *opts_set,
202 location_t loc);
203 static void set_fast_math_flags (struct gcc_options *opts, int set);
204 static void decode_d_option (const char *arg, struct gcc_options *opts,
205 location_t loc, diagnostic_context *dc);
206 static void set_unsafe_math_optimizations_flags (struct gcc_options *opts,
207 int set);
208 static void enable_warning_as_error (const char *arg, int value,
209 unsigned int lang_mask,
210 const struct cl_option_handlers *handlers,
211 struct gcc_options *opts,
212 struct gcc_options *opts_set,
213 location_t loc,
214 diagnostic_context *dc);
216 /* Handle a back-end option; arguments and return value as for
217 handle_option. */
219 bool
220 target_handle_option (struct gcc_options *opts,
221 struct gcc_options *opts_set,
222 const struct cl_decoded_option *decoded,
223 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
224 location_t loc,
225 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
226 diagnostic_context *dc)
228 gcc_assert (dc == global_dc);
229 gcc_assert (kind == DK_UNSPECIFIED);
230 return targetm_common.handle_option (opts, opts_set, decoded, loc);
233 /* Add comma-separated strings to a char_p vector. */
235 static void
236 add_comma_separated_to_vector (void **pvec, const char *arg)
238 char *tmp;
239 char *r;
240 char *w;
241 char *token_start;
242 VEC(char_p,heap) *vec = (VEC(char_p,heap) *) *pvec;
244 /* We never free this string. */
245 tmp = xstrdup (arg);
247 r = tmp;
248 w = tmp;
249 token_start = tmp;
251 while (*r != '\0')
253 if (*r == ',')
255 *w++ = '\0';
256 ++r;
257 VEC_safe_push (char_p, heap, vec, token_start);
258 token_start = w;
260 if (*r == '\\' && r[1] == ',')
262 *w++ = ',';
263 r += 2;
265 else
266 *w++ = *r++;
268 if (*token_start != '\0')
269 VEC_safe_push (char_p, heap, vec, token_start);
271 *pvec = vec;
274 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
276 void
277 init_options_struct (struct gcc_options *opts, struct gcc_options *opts_set)
279 size_t num_params = get_num_compiler_params ();
281 *opts = global_options_init;
282 memset (opts_set, 0, sizeof (*opts_set));
284 opts->x_param_values = XNEWVEC (int, num_params);
285 opts_set->x_param_values = XCNEWVEC (int, num_params);
286 init_param_values (opts->x_param_values);
288 /* Initialize whether `char' is signed. */
289 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
290 /* Set this to a special "uninitialized" value. The actual default
291 is set after target options have been processed. */
292 opts->x_flag_short_enums = 2;
294 /* Initialize target_flags before default_options_optimization
295 so the latter can modify it. */
296 opts->x_target_flags = targetm_common.default_target_flags;
298 /* Some targets have ABI-specified unwind tables. */
299 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
301 /* Some targets have other target-specific initialization. */
302 targetm_common.option_init_struct (opts);
305 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
306 -Ofast if FAST is set, -Og if DEBUG is set), apply the option DEFAULT_OPT
307 to OPTS and OPTS_SET, diagnostic context DC, location LOC, with language
308 mask LANG_MASK and option handlers HANDLERS. */
310 static void
311 maybe_default_option (struct gcc_options *opts,
312 struct gcc_options *opts_set,
313 const struct default_options *default_opt,
314 int level, bool size, bool fast, bool debug,
315 unsigned int lang_mask,
316 const struct cl_option_handlers *handlers,
317 location_t loc,
318 diagnostic_context *dc)
320 const struct cl_option *option = &cl_options[default_opt->opt_index];
321 bool enabled;
323 if (size)
324 gcc_assert (level == 2);
325 if (fast)
326 gcc_assert (level == 3);
327 if (debug)
328 gcc_assert (level == 1);
330 switch (default_opt->levels)
332 case OPT_LEVELS_ALL:
333 enabled = true;
334 break;
336 case OPT_LEVELS_0_ONLY:
337 enabled = (level == 0);
338 break;
340 case OPT_LEVELS_1_PLUS:
341 enabled = (level >= 1);
342 break;
344 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
345 enabled = (level >= 1 && !size && !debug);
346 break;
348 case OPT_LEVELS_1_PLUS_NOT_DEBUG:
349 enabled = (level >= 1 && !debug);
350 break;
352 case OPT_LEVELS_2_PLUS:
353 enabled = (level >= 2);
354 break;
356 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
357 enabled = (level >= 2 && !size && !debug);
358 break;
360 case OPT_LEVELS_3_PLUS:
361 enabled = (level >= 3);
362 break;
364 case OPT_LEVELS_3_PLUS_AND_SIZE:
365 enabled = (level >= 3 || size);
366 break;
368 case OPT_LEVELS_SIZE:
369 enabled = size;
370 break;
372 case OPT_LEVELS_FAST:
373 enabled = fast;
374 break;
376 case OPT_LEVELS_NONE:
377 default:
378 gcc_unreachable ();
381 if (enabled)
382 handle_generated_option (opts, opts_set, default_opt->opt_index,
383 default_opt->arg, default_opt->value,
384 lang_mask, DK_UNSPECIFIED, loc,
385 handlers, dc);
386 else if (default_opt->arg == NULL
387 && !option->cl_reject_negative)
388 handle_generated_option (opts, opts_set, default_opt->opt_index,
389 default_opt->arg, !default_opt->value,
390 lang_mask, DK_UNSPECIFIED, loc,
391 handlers, dc);
394 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
395 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
396 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
397 language mask LANG_MASK and option handlers HANDLERS. */
399 static void
400 maybe_default_options (struct gcc_options *opts,
401 struct gcc_options *opts_set,
402 const struct default_options *default_opts,
403 int level, bool size, bool fast, bool debug,
404 unsigned int lang_mask,
405 const struct cl_option_handlers *handlers,
406 location_t loc,
407 diagnostic_context *dc)
409 size_t i;
411 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
412 maybe_default_option (opts, opts_set, &default_opts[i],
413 level, size, fast, debug,
414 lang_mask, handlers, loc, dc);
417 /* Table of options enabled by default at different levels. */
419 static const struct default_options default_options_table[] =
421 /* -O1 optimizations. */
422 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
423 #ifdef DELAY_SLOTS
424 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
425 #endif
426 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
427 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
428 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
429 { OPT_LEVELS_1_PLUS, OPT_fif_conversion, NULL, 1 },
430 { OPT_LEVELS_1_PLUS, OPT_fif_conversion2, NULL, 1 },
431 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
432 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
433 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
434 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
435 { OPT_LEVELS_1_PLUS, OPT_fshrink_wrap, NULL, 1 },
436 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
437 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
438 { OPT_LEVELS_1_PLUS, OPT_ftree_bit_ccp, NULL, 1 },
439 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
440 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
441 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
442 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
443 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_sra, NULL, 1 },
444 { OPT_LEVELS_1_PLUS, OPT_ftree_copyrename, NULL, 1 },
445 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
446 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
447 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
448 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
449 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
450 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
451 { OPT_LEVELS_1_PLUS, OPT_ftree_slsr, NULL, 1 },
453 /* -O2 optimizations. */
454 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
455 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
456 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
457 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
458 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
459 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
460 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
461 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
462 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
463 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
464 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
465 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
466 #ifdef INSN_SCHEDULING
467 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
468 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
469 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
470 #endif
471 { OPT_LEVELS_2_PLUS, OPT_fregmove, NULL, 1 },
472 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
473 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
474 { OPT_LEVELS_2_PLUS, OPT_freorder_blocks, NULL, 1 },
475 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
476 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
477 { OPT_LEVELS_2_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
478 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
479 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
480 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
481 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
482 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
483 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
484 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
488 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
489 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
491 /* -O3 optimizations. */
492 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
493 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
494 /* Inlining of functions reducing size is a good idea with -Os
495 regardless of them being declared inline. */
496 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
497 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
498 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
499 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
500 { OPT_LEVELS_3_PLUS, OPT_ftree_vectorize, NULL, 1 },
501 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model, NULL, 1 },
502 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
503 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
505 /* -Ofast adds optimizations to -O3. */
506 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
508 { OPT_LEVELS_NONE, 0, NULL, 0 }
511 /* Default the options in OPTS and OPTS_SET based on the optimization
512 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
513 void
514 default_options_optimization (struct gcc_options *opts,
515 struct gcc_options *opts_set,
516 struct cl_decoded_option *decoded_options,
517 unsigned int decoded_options_count,
518 location_t loc,
519 unsigned int lang_mask,
520 const struct cl_option_handlers *handlers,
521 diagnostic_context *dc)
523 unsigned int i;
524 int opt2;
526 /* Scan to see what optimization level has been specified. That will
527 determine the default value of many flags. */
528 for (i = 1; i < decoded_options_count; i++)
530 struct cl_decoded_option *opt = &decoded_options[i];
531 switch (opt->opt_index)
533 case OPT_O:
534 if (*opt->arg == '\0')
536 opts->x_optimize = 1;
537 opts->x_optimize_size = 0;
538 opts->x_optimize_fast = 0;
539 opts->x_optimize_debug = 0;
541 else
543 const int optimize_val = integral_argument (opt->arg);
544 if (optimize_val == -1)
545 error_at (loc,
546 "argument to %qs should be a non-negative integer",
547 "-O");
548 else
550 opts->x_optimize = optimize_val;
551 if ((unsigned int) opts->x_optimize > 255)
552 opts->x_optimize = 255;
553 opts->x_optimize_size = 0;
554 opts->x_optimize_fast = 0;
555 opts->x_optimize_debug = 0;
558 break;
560 case OPT_Os:
561 opts->x_optimize_size = 1;
563 /* Optimizing for size forces optimize to be 2. */
564 opts->x_optimize = 2;
565 opts->x_optimize_fast = 0;
566 opts->x_optimize_debug = 0;
567 break;
569 case OPT_Ofast:
570 /* -Ofast only adds flags to -O3. */
571 opts->x_optimize_size = 0;
572 opts->x_optimize = 3;
573 opts->x_optimize_fast = 1;
574 opts->x_optimize_debug = 0;
575 break;
577 case OPT_Og:
578 /* -Og selects optimization level 1. */
579 opts->x_optimize_size = 0;
580 opts->x_optimize = 1;
581 opts->x_optimize_fast = 0;
582 opts->x_optimize_debug = 1;
583 break;
585 default:
586 /* Ignore other options in this prescan. */
587 break;
591 maybe_default_options (opts, opts_set, default_options_table,
592 opts->x_optimize, opts->x_optimize_size,
593 opts->x_optimize_fast, opts->x_optimize_debug,
594 lang_mask, handlers, loc, dc);
596 /* -O2 param settings. */
597 opt2 = (opts->x_optimize >= 2);
599 /* Track fields in field-sensitive alias analysis. */
600 maybe_set_param_value
601 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
602 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
603 opts->x_param_values, opts_set->x_param_values);
605 /* For -O1 only do loop invariant motion for very small loops. */
606 maybe_set_param_value
607 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
608 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
609 opts->x_param_values, opts_set->x_param_values);
611 if (opts->x_optimize_size)
612 /* We want to crossjump as much as possible. */
613 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
614 opts->x_param_values, opts_set->x_param_values);
615 else
616 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
617 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
618 opts->x_param_values, opts_set->x_param_values);
620 /* Allow default optimizations to be specified on a per-machine basis. */
621 maybe_default_options (opts, opts_set,
622 targetm_common.option_optimization_table,
623 opts->x_optimize, opts->x_optimize_size,
624 opts->x_optimize_fast, opts->x_optimize_debug,
625 lang_mask, handlers, loc, dc);
628 /* After all options at LOC have been read into OPTS and OPTS_SET,
629 finalize settings of those options and diagnose incompatible
630 combinations. */
631 void
632 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
633 location_t loc)
635 enum unwind_info_type ui_except;
637 if (opts->x_dump_base_name && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name))
639 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
640 OPTS->X_DUMP_DIR_NAME directory. Then try to make
641 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
642 directory, typically the directory to contain the object
643 file. */
644 if (opts->x_dump_dir_name)
645 opts->x_dump_base_name = concat (opts->x_dump_dir_name,
646 opts->x_dump_base_name, NULL);
647 else if (opts->x_aux_base_name
648 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
650 const char *aux_base;
652 base_of_path (opts->x_aux_base_name, &aux_base);
653 if (opts->x_aux_base_name != aux_base)
655 int dir_len = aux_base - opts->x_aux_base_name;
656 char *new_dump_base_name =
657 XNEWVEC (char, strlen (opts->x_dump_base_name) + dir_len + 1);
659 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
660 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
661 /* Append existing OPTS->X_DUMP_BASE_NAME. */
662 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
663 opts->x_dump_base_name = new_dump_base_name;
668 /* Handle related options for unit-at-a-time, toplevel-reorder, and
669 section-anchors. */
670 if (!opts->x_flag_unit_at_a_time)
672 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
673 error_at (loc, "section anchors must be disabled when unit-at-a-time "
674 "is disabled");
675 opts->x_flag_section_anchors = 0;
676 if (opts->x_flag_toplevel_reorder == 1)
677 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
678 "is disabled");
679 opts->x_flag_toplevel_reorder = 0;
682 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
683 sorry ("transactional memory is not supported with non-call exceptions");
685 /* Unless the user has asked for section anchors, we disable toplevel
686 reordering at -O0 to disable transformations that might be surprising
687 to end users and to get -fno-toplevel-reorder tested. */
688 if (!opts->x_optimize
689 && opts->x_flag_toplevel_reorder == 2
690 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
692 opts->x_flag_toplevel_reorder = 0;
693 opts->x_flag_section_anchors = 0;
695 if (!opts->x_flag_toplevel_reorder)
697 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
698 error_at (loc, "section anchors must be disabled when toplevel reorder"
699 " is disabled");
700 opts->x_flag_section_anchors = 0;
703 if (!opts->x_flag_opts_finished)
705 if (opts->x_flag_pie)
706 opts->x_flag_pic = opts->x_flag_pie;
707 if (opts->x_flag_pic && !opts->x_flag_pie)
708 opts->x_flag_shlib = 1;
709 opts->x_flag_opts_finished = true;
712 if (opts->x_optimize == 0)
714 /* Inlining does not work if not optimizing,
715 so force it not to be done. */
716 opts->x_warn_inline = 0;
717 opts->x_flag_no_inline = 1;
720 /* The optimization to partition hot and cold basic blocks into separate
721 sections of the .o and executable files does not work (currently)
722 with exception handling. This is because there is no support for
723 generating unwind info. If opts->x_flag_exceptions is turned on
724 we need to turn off the partitioning optimization. */
726 ui_except = targetm_common.except_unwind_info (opts);
728 if (opts->x_flag_exceptions
729 && opts->x_flag_reorder_blocks_and_partition
730 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
732 inform (loc,
733 "-freorder-blocks-and-partition does not work "
734 "with exceptions on this architecture");
735 opts->x_flag_reorder_blocks_and_partition = 0;
736 opts->x_flag_reorder_blocks = 1;
739 /* If user requested unwind info, then turn off the partitioning
740 optimization. */
742 if (opts->x_flag_unwind_tables
743 && !targetm_common.unwind_tables_default
744 && opts->x_flag_reorder_blocks_and_partition
745 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
747 inform (loc,
748 "-freorder-blocks-and-partition does not support "
749 "unwind info on this architecture");
750 opts->x_flag_reorder_blocks_and_partition = 0;
751 opts->x_flag_reorder_blocks = 1;
754 /* If the target requested unwind info, then turn off the partitioning
755 optimization with a different message. Likewise, if the target does not
756 support named sections. */
758 if (opts->x_flag_reorder_blocks_and_partition
759 && (!targetm_common.have_named_sections
760 || (opts->x_flag_unwind_tables
761 && targetm_common.unwind_tables_default
762 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
764 inform (loc,
765 "-freorder-blocks-and-partition does not work "
766 "on this architecture");
767 opts->x_flag_reorder_blocks_and_partition = 0;
768 opts->x_flag_reorder_blocks = 1;
771 if (opts->x_flag_reorder_blocks_and_partition
772 && !opts_set->x_flag_reorder_functions)
773 opts->x_flag_reorder_functions = 1;
775 /* Pipelining of outer loops is only possible when general pipelining
776 capabilities are requested. */
777 if (!opts->x_flag_sel_sched_pipelining)
778 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
780 if (opts->x_flag_conserve_stack)
782 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
783 opts->x_param_values, opts_set->x_param_values);
784 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
785 opts->x_param_values, opts_set->x_param_values);
788 if (opts->x_flag_lto)
790 #ifdef ENABLE_LTO
791 opts->x_flag_generate_lto = 1;
793 /* When generating IL, do not operate in whole-program mode.
794 Otherwise, symbols will be privatized too early, causing link
795 errors later. */
796 opts->x_flag_whole_program = 0;
797 #else
798 error_at (loc, "LTO support has not been enabled in this configuration");
799 #endif
800 if (!opts->x_flag_fat_lto_objects && !HAVE_LTO_PLUGIN)
801 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin.");
803 if ((opts->x_flag_lto_partition_balanced != 0) + (opts->x_flag_lto_partition_1to1 != 0)
804 + (opts->x_flag_lto_partition_none != 0) >= 1)
806 if ((opts->x_flag_lto_partition_balanced != 0)
807 + (opts->x_flag_lto_partition_1to1 != 0)
808 + (opts->x_flag_lto_partition_none != 0) > 1)
809 error_at (loc, "only one -flto-partition value can be specified");
812 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
813 default value if they choose based on other options. */
814 if (opts->x_flag_split_stack == -1)
815 opts->x_flag_split_stack = 0;
816 else if (opts->x_flag_split_stack)
818 if (!targetm_common.supports_split_stack (true, opts))
820 error_at (loc, "%<-fsplit-stack%> is not supported by "
821 "this compiler configuration");
822 opts->x_flag_split_stack = 0;
826 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
827 is disabled. */
828 if (!opts->x_flag_tree_vectorize || !opts->x_flag_tree_loop_if_convert)
829 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
830 opts->x_param_values, opts_set->x_param_values);
832 /* This replaces set_Wunused. */
833 /* Wunused-local-typedefs is enabled by -Wunused or -Wall. */
834 if (opts->x_warn_unused_local_typedefs == -1)
835 opts->x_warn_unused_local_typedefs = opts->x_warn_unused;
838 #define LEFT_COLUMN 27
840 /* Output ITEM, of length ITEM_WIDTH, in the left column,
841 followed by word-wrapped HELP in a second column. */
842 static void
843 wrap_help (const char *help,
844 const char *item,
845 unsigned int item_width,
846 unsigned int columns)
848 unsigned int col_width = LEFT_COLUMN;
849 unsigned int remaining, room, len;
851 remaining = strlen (help);
855 room = columns - 3 - MAX (col_width, item_width);
856 if (room > columns)
857 room = 0;
858 len = remaining;
860 if (room < len)
862 unsigned int i;
864 for (i = 0; help[i]; i++)
866 if (i >= room && len != remaining)
867 break;
868 if (help[i] == ' ')
869 len = i;
870 else if ((help[i] == '-' || help[i] == '/')
871 && help[i + 1] != ' '
872 && i > 0 && ISALPHA (help[i - 1]))
873 len = i + 1;
877 printf( " %-*.*s %.*s\n", col_width, item_width, item, len, help);
878 item_width = 0;
879 while (help[len] == ' ')
880 len++;
881 help += len;
882 remaining -= len;
884 while (remaining);
887 /* Print help for a specific front-end, etc. */
888 static void
889 print_filtered_help (unsigned int include_flags,
890 unsigned int exclude_flags,
891 unsigned int any_flags,
892 unsigned int columns,
893 struct gcc_options *opts,
894 unsigned int lang_mask)
896 unsigned int i;
897 const char *help;
898 bool found = false;
899 bool displayed = false;
901 if (include_flags == CL_PARAMS)
903 for (i = 0; i < LAST_PARAM; i++)
905 const char *param = compiler_params[i].option;
907 help = compiler_params[i].help;
908 if (help == NULL || *help == '\0')
910 if (exclude_flags & CL_UNDOCUMENTED)
911 continue;
912 help = undocumented_msg;
915 /* Get the translation. */
916 help = _(help);
918 wrap_help (help, param, strlen (param), columns);
920 putchar ('\n');
921 return;
924 if (!opts->x_help_printed)
925 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
927 if (!opts->x_help_enum_printed)
928 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
930 for (i = 0; i < cl_options_count; i++)
932 char new_help[128];
933 const struct cl_option *option = cl_options + i;
934 unsigned int len;
935 const char *opt;
936 const char *tab;
938 if (include_flags == 0
939 || ((option->flags & include_flags) != include_flags))
941 if ((option->flags & any_flags) == 0)
942 continue;
945 /* Skip unwanted switches. */
946 if ((option->flags & exclude_flags) != 0)
947 continue;
949 /* The driver currently prints its own help text. */
950 if ((option->flags & CL_DRIVER) != 0
951 && (option->flags & (((1U << cl_lang_count) - 1)
952 | CL_COMMON | CL_TARGET)) == 0)
953 continue;
955 found = true;
956 /* Skip switches that have already been printed. */
957 if (opts->x_help_printed[i])
958 continue;
960 opts->x_help_printed[i] = true;
962 help = option->help;
963 if (help == NULL)
965 if (exclude_flags & CL_UNDOCUMENTED)
966 continue;
967 help = undocumented_msg;
970 /* Get the translation. */
971 help = _(help);
973 /* Find the gap between the name of the
974 option and its descriptive text. */
975 tab = strchr (help, '\t');
976 if (tab)
978 len = tab - help;
979 opt = help;
980 help = tab + 1;
982 else
984 opt = option->opt_text;
985 len = strlen (opt);
988 /* With the -Q option enabled we change the descriptive text associated
989 with an option to be an indication of its current setting. */
990 if (!opts->x_quiet_flag)
992 void *flag_var = option_flag_var (i, opts);
994 if (len < (LEFT_COLUMN + 2))
995 strcpy (new_help, "\t\t");
996 else
997 strcpy (new_help, "\t");
999 if (flag_var != NULL
1000 && option->var_type != CLVC_DEFER)
1002 if (option->flags & CL_JOINED)
1004 if (option->var_type == CLVC_STRING)
1006 if (* (const char **) flag_var != NULL)
1007 snprintf (new_help + strlen (new_help),
1008 sizeof (new_help) - strlen (new_help),
1009 * (const char **) flag_var);
1011 else if (option->var_type == CLVC_ENUM)
1013 const struct cl_enum *e = &cl_enums[option->var_enum];
1014 int value;
1015 const char *arg = NULL;
1017 value = e->get (flag_var);
1018 enum_value_to_arg (e->values, &arg, value, lang_mask);
1019 if (arg == NULL)
1020 arg = _("[default]");
1021 snprintf (new_help + strlen (new_help),
1022 sizeof (new_help) - strlen (new_help),
1023 arg);
1025 else
1026 sprintf (new_help + strlen (new_help),
1027 "%#x", * (int *) flag_var);
1029 else
1030 strcat (new_help, option_enabled (i, opts)
1031 ? _("[enabled]") : _("[disabled]"));
1034 help = new_help;
1037 wrap_help (help, opt, len, columns);
1038 displayed = true;
1040 if (option->var_type == CLVC_ENUM
1041 && opts->x_help_enum_printed[option->var_enum] != 2)
1042 opts->x_help_enum_printed[option->var_enum] = 1;
1045 if (! found)
1047 unsigned int langs = include_flags & CL_LANG_ALL;
1049 if (langs == 0)
1050 printf (_(" No options with the desired characteristics were found\n"));
1051 else
1053 unsigned int i;
1055 /* PR 31349: Tell the user how to see all of the
1056 options supported by a specific front end. */
1057 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1058 if ((1U << i) & langs)
1059 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end\n"),
1060 lang_names[i], lang_names[i]);
1064 else if (! displayed)
1065 printf (_(" All options with the desired characteristics have already been displayed\n"));
1067 putchar ('\n');
1069 /* Print details of enumerated option arguments, if those
1070 enumerations have help text headings provided. If no help text
1071 is provided, presume that the possible values are listed in the
1072 help text for the relevant options. */
1073 for (i = 0; i < cl_enums_count; i++)
1075 unsigned int j, pos;
1077 if (opts->x_help_enum_printed[i] != 1)
1078 continue;
1079 if (cl_enums[i].help == NULL)
1080 continue;
1081 printf (" %s\n ", _(cl_enums[i].help));
1082 pos = 4;
1083 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1085 unsigned int len = strlen (cl_enums[i].values[j].arg);
1087 if (pos > 4 && pos + 1 + len <= columns)
1089 printf (" %s", cl_enums[i].values[j].arg);
1090 pos += 1 + len;
1092 else
1094 if (pos > 4)
1096 printf ("\n ");
1097 pos = 4;
1099 printf ("%s", cl_enums[i].values[j].arg);
1100 pos += len;
1103 printf ("\n\n");
1104 opts->x_help_enum_printed[i] = 2;
1108 /* Display help for a specified type of option.
1109 The options must have ALL of the INCLUDE_FLAGS set
1110 ANY of the flags in the ANY_FLAGS set
1111 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1112 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1113 static void
1114 print_specific_help (unsigned int include_flags,
1115 unsigned int exclude_flags,
1116 unsigned int any_flags,
1117 struct gcc_options *opts,
1118 unsigned int lang_mask)
1120 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1121 const char * description = NULL;
1122 const char * descrip_extra = "";
1123 size_t i;
1124 unsigned int flag;
1126 /* Sanity check: Make sure that we do not have more
1127 languages than we have bits available to enumerate them. */
1128 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1130 /* If we have not done so already, obtain
1131 the desired maximum width of the output. */
1132 if (opts->x_help_columns == 0)
1134 const char *p;
1136 p = getenv ("COLUMNS");
1137 if (p != NULL)
1139 int value = atoi (p);
1141 if (value > 0)
1142 opts->x_help_columns = value;
1145 if (opts->x_help_columns == 0)
1146 /* Use a reasonable default. */
1147 opts->x_help_columns = 80;
1150 /* Decide upon the title for the options that we are going to display. */
1151 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1153 switch (flag & include_flags)
1155 case 0:
1156 case CL_DRIVER:
1157 break;
1159 case CL_TARGET:
1160 description = _("The following options are target specific");
1161 break;
1162 case CL_WARNING:
1163 description = _("The following options control compiler warning messages");
1164 break;
1165 case CL_OPTIMIZATION:
1166 description = _("The following options control optimizations");
1167 break;
1168 case CL_COMMON:
1169 description = _("The following options are language-independent");
1170 break;
1171 case CL_PARAMS:
1172 description = _("The --param option recognizes the following as parameters");
1173 break;
1174 default:
1175 if (i >= cl_lang_count)
1176 break;
1177 if (exclude_flags & all_langs_mask)
1178 description = _("The following options are specific to just the language ");
1179 else
1180 description = _("The following options are supported by the language ");
1181 descrip_extra = lang_names [i];
1182 break;
1186 if (description == NULL)
1188 if (any_flags == 0)
1190 if (include_flags & CL_UNDOCUMENTED)
1191 description = _("The following options are not documented");
1192 else if (include_flags & CL_SEPARATE)
1193 description = _("The following options take separate arguments");
1194 else if (include_flags & CL_JOINED)
1195 description = _("The following options take joined arguments");
1196 else
1198 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1199 include_flags);
1200 return;
1203 else
1205 if (any_flags & all_langs_mask)
1206 description = _("The following options are language-related");
1207 else
1208 description = _("The following options are language-independent");
1212 printf ("%s%s:\n", description, descrip_extra);
1213 print_filtered_help (include_flags, exclude_flags, any_flags,
1214 opts->x_help_columns, opts, lang_mask);
1217 /* Handle target- and language-independent options. Return zero to
1218 generate an "unknown option" message. Only options that need
1219 extra handling need to be listed here; if you simply want
1220 DECODED->value assigned to a variable, it happens automatically. */
1222 bool
1223 common_handle_option (struct gcc_options *opts,
1224 struct gcc_options *opts_set,
1225 const struct cl_decoded_option *decoded,
1226 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1227 location_t loc,
1228 const struct cl_option_handlers *handlers,
1229 diagnostic_context *dc)
1231 size_t scode = decoded->opt_index;
1232 const char *arg = decoded->arg;
1233 int value = decoded->value;
1234 enum opt_code code = (enum opt_code) scode;
1236 gcc_assert (decoded->canonical_option_num_elements <= 2);
1238 switch (code)
1240 case OPT__param:
1241 handle_param (opts, opts_set, loc, arg);
1242 break;
1244 case OPT__help:
1246 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1247 unsigned int undoc_mask;
1248 unsigned int i;
1250 if (lang_mask == CL_DRIVER)
1251 break;;
1253 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1255 : CL_UNDOCUMENTED);
1256 /* First display any single language specific options. */
1257 for (i = 0; i < cl_lang_count; i++)
1258 print_specific_help
1259 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1260 lang_mask);
1261 /* Next display any multi language specific options. */
1262 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1263 /* Then display any remaining, non-language options. */
1264 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1265 if (i != CL_DRIVER)
1266 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1267 opts->x_exit_after_options = true;
1268 break;
1271 case OPT__target_help:
1272 if (lang_mask == CL_DRIVER)
1273 break;
1275 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1276 opts->x_exit_after_options = true;
1277 break;
1279 case OPT__help_:
1281 const char * a = arg;
1282 unsigned int include_flags = 0;
1283 /* Note - by default we include undocumented options when listing
1284 specific classes. If you only want to see documented options
1285 then add ",^undocumented" to the --help= option. E.g.:
1287 --help=target,^undocumented */
1288 unsigned int exclude_flags = 0;
1290 if (lang_mask == CL_DRIVER)
1291 break;
1293 /* Walk along the argument string, parsing each word in turn.
1294 The format is:
1295 arg = [^]{word}[,{arg}]
1296 word = {optimizers|target|warnings|undocumented|
1297 params|common|<language>} */
1298 while (* a != 0)
1300 static const struct
1302 const char * string;
1303 unsigned int flag;
1305 specifics[] =
1307 { "optimizers", CL_OPTIMIZATION },
1308 { "target", CL_TARGET },
1309 { "warnings", CL_WARNING },
1310 { "undocumented", CL_UNDOCUMENTED },
1311 { "params", CL_PARAMS },
1312 { "joined", CL_JOINED },
1313 { "separate", CL_SEPARATE },
1314 { "common", CL_COMMON },
1315 { NULL, 0 }
1317 unsigned int * pflags;
1318 const char * comma;
1319 unsigned int lang_flag, specific_flag;
1320 unsigned int len;
1321 unsigned int i;
1323 if (* a == '^')
1325 ++ a;
1326 pflags = & exclude_flags;
1328 else
1329 pflags = & include_flags;
1331 comma = strchr (a, ',');
1332 if (comma == NULL)
1333 len = strlen (a);
1334 else
1335 len = comma - a;
1336 if (len == 0)
1338 a = comma + 1;
1339 continue;
1342 /* Check to see if the string matches an option class name. */
1343 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1344 if (strncasecmp (a, specifics[i].string, len) == 0)
1346 specific_flag = specifics[i].flag;
1347 break;
1350 /* Check to see if the string matches a language name.
1351 Note - we rely upon the alpha-sorted nature of the entries in
1352 the lang_names array, specifically that shorter names appear
1353 before their longer variants. (i.e. C before C++). That way
1354 when we are attempting to match --help=c for example we will
1355 match with C first and not C++. */
1356 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1357 if (strncasecmp (a, lang_names[i], len) == 0)
1359 lang_flag = 1U << i;
1360 break;
1363 if (specific_flag != 0)
1365 if (lang_flag == 0)
1366 * pflags |= specific_flag;
1367 else
1369 /* The option's argument matches both the start of a
1370 language name and the start of an option class name.
1371 We have a special case for when the user has
1372 specified "--help=c", but otherwise we have to issue
1373 a warning. */
1374 if (strncasecmp (a, "c", len) == 0)
1375 * pflags |= lang_flag;
1376 else
1377 warning_at (loc, 0,
1378 "--help argument %q.*s is ambiguous, "
1379 "please be more specific",
1380 len, a);
1383 else if (lang_flag != 0)
1384 * pflags |= lang_flag;
1385 else
1386 warning_at (loc, 0,
1387 "unrecognized argument to --help= option: %q.*s",
1388 len, a);
1390 if (comma == NULL)
1391 break;
1392 a = comma + 1;
1395 if (include_flags)
1396 print_specific_help (include_flags, exclude_flags, 0, opts,
1397 lang_mask);
1398 opts->x_exit_after_options = true;
1399 break;
1402 case OPT__version:
1403 if (lang_mask == CL_DRIVER)
1404 break;
1406 opts->x_exit_after_options = true;
1407 break;
1409 case OPT_O:
1410 case OPT_Os:
1411 case OPT_Ofast:
1412 case OPT_Og:
1413 /* Currently handled in a prescan. */
1414 break;
1416 case OPT_Werror:
1417 dc->warning_as_error_requested = value;
1418 break;
1420 case OPT_Werror_:
1421 if (lang_mask == CL_DRIVER)
1422 break;
1424 enable_warning_as_error (arg, value, lang_mask, handlers,
1425 opts, opts_set, loc, dc);
1426 break;
1428 case OPT_Wlarger_than_:
1429 opts->x_larger_than_size = value;
1430 opts->x_warn_larger_than = value != -1;
1431 break;
1433 case OPT_Wfatal_errors:
1434 dc->fatal_errors = value;
1435 break;
1437 case OPT_Wframe_larger_than_:
1438 opts->x_frame_larger_than_size = value;
1439 opts->x_warn_frame_larger_than = value != -1;
1440 break;
1442 case OPT_Wstack_usage_:
1443 opts->x_warn_stack_usage = value;
1444 opts->x_flag_stack_usage_info = value != -1;
1445 break;
1447 case OPT_Wstrict_aliasing:
1448 set_Wstrict_aliasing (opts, value);
1449 break;
1451 case OPT_Wstrict_overflow:
1452 opts->x_warn_strict_overflow = (value
1453 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1454 : 0);
1455 break;
1457 case OPT_Wsystem_headers:
1458 dc->dc_warn_system_headers = value;
1459 break;
1461 case OPT_aux_info:
1462 opts->x_flag_gen_aux_info = 1;
1463 break;
1465 case OPT_auxbase_strip:
1467 char *tmp = xstrdup (arg);
1468 strip_off_ending (tmp, strlen (tmp));
1469 if (tmp[0])
1470 opts->x_aux_base_name = tmp;
1471 else
1472 free (tmp);
1474 break;
1476 case OPT_d:
1477 decode_d_option (arg, opts, loc, dc);
1478 break;
1480 case OPT_fcall_used_:
1481 case OPT_fcall_saved_:
1482 /* Deferred. */
1483 break;
1485 case OPT_fdbg_cnt_:
1486 case OPT_fdbg_cnt_list:
1487 /* Deferred. */
1488 break;
1490 case OPT_fdebug_prefix_map_:
1491 /* Deferred. */
1492 break;
1494 case OPT_fdiagnostics_show_location_:
1495 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1496 break;
1498 case OPT_fdiagnostics_show_caret:
1499 dc->show_caret = value;
1500 break;
1502 case OPT_fdiagnostics_show_option:
1503 dc->show_option_requested = value;
1504 break;
1506 case OPT_fdump_:
1507 /* Deferred. */
1508 break;
1510 case OPT_ffast_math:
1511 set_fast_math_flags (opts, value);
1512 break;
1514 case OPT_funsafe_math_optimizations:
1515 set_unsafe_math_optimizations_flags (opts, value);
1516 break;
1518 case OPT_ffixed_:
1519 /* Deferred. */
1520 break;
1522 case OPT_finline_limit_:
1523 set_param_value ("max-inline-insns-single", value / 2,
1524 opts->x_param_values, opts_set->x_param_values);
1525 set_param_value ("max-inline-insns-auto", value / 2,
1526 opts->x_param_values, opts_set->x_param_values);
1527 break;
1529 case OPT_finstrument_functions_exclude_function_list_:
1530 add_comma_separated_to_vector
1531 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1532 break;
1534 case OPT_finstrument_functions_exclude_file_list_:
1535 add_comma_separated_to_vector
1536 (&opts->x_flag_instrument_functions_exclude_files, arg);
1537 break;
1539 case OPT_fmessage_length_:
1540 pp_set_line_maximum_length (dc->printer, value);
1541 diagnostic_set_caret_max_width (dc, value);
1542 break;
1544 case OPT_fopt_info:
1545 case OPT_fopt_info_:
1546 /* Deferred. */
1547 break;
1549 case OPT_fpack_struct_:
1550 if (value <= 0 || (value & (value - 1)) || value > 16)
1551 error_at (loc,
1552 "structure alignment must be a small power of two, not %d",
1553 value);
1554 else
1555 opts->x_initial_max_fld_align = value;
1556 break;
1558 case OPT_fplugin_:
1559 case OPT_fplugin_arg_:
1560 /* Deferred. */
1561 break;
1563 case OPT_fprofile_use_:
1564 opts->x_profile_data_prefix = xstrdup (arg);
1565 opts->x_flag_profile_use = true;
1566 value = true;
1567 /* No break here - do -fprofile-use processing. */
1568 case OPT_fprofile_use:
1569 if (!opts_set->x_flag_branch_probabilities)
1570 opts->x_flag_branch_probabilities = value;
1571 if (!opts_set->x_flag_profile_values)
1572 opts->x_flag_profile_values = value;
1573 if (!opts_set->x_flag_unroll_loops)
1574 opts->x_flag_unroll_loops = value;
1575 if (!opts_set->x_flag_peel_loops)
1576 opts->x_flag_peel_loops = value;
1577 if (!opts_set->x_flag_tracer)
1578 opts->x_flag_tracer = value;
1579 if (!opts_set->x_flag_value_profile_transformations)
1580 opts->x_flag_value_profile_transformations = value;
1581 if (!opts_set->x_flag_inline_functions)
1582 opts->x_flag_inline_functions = value;
1583 if (!opts_set->x_flag_ipa_cp)
1584 opts->x_flag_ipa_cp = value;
1585 if (!opts_set->x_flag_ipa_cp_clone
1586 && value && opts->x_flag_ipa_cp)
1587 opts->x_flag_ipa_cp_clone = value;
1588 if (!opts_set->x_flag_predictive_commoning)
1589 opts->x_flag_predictive_commoning = value;
1590 if (!opts_set->x_flag_unswitch_loops)
1591 opts->x_flag_unswitch_loops = value;
1592 if (!opts_set->x_flag_gcse_after_reload)
1593 opts->x_flag_gcse_after_reload = value;
1594 break;
1596 case OPT_fprofile_generate_:
1597 opts->x_profile_data_prefix = xstrdup (arg);
1598 value = true;
1599 /* No break here - do -fprofile-generate processing. */
1600 case OPT_fprofile_generate:
1601 if (!opts_set->x_profile_arc_flag)
1602 opts->x_profile_arc_flag = value;
1603 if (!opts_set->x_flag_profile_values)
1604 opts->x_flag_profile_values = value;
1605 if (!opts_set->x_flag_inline_functions)
1606 opts->x_flag_inline_functions = value;
1607 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1608 quadratic. Disable the pass until better memory representation
1609 is done. */
1610 if (!opts_set->x_flag_ipa_reference && opts->x_in_lto_p)
1611 opts->x_flag_ipa_reference = false;
1612 break;
1614 case OPT_fshow_column:
1615 dc->show_column = value;
1616 break;
1618 case OPT_frandom_seed:
1619 /* The real switch is -fno-random-seed. */
1620 if (value)
1621 return false;
1622 /* Deferred. */
1623 break;
1625 case OPT_frandom_seed_:
1626 /* Deferred. */
1627 break;
1629 case OPT_fsched_verbose_:
1630 #ifdef INSN_SCHEDULING
1631 /* Handled with Var in common.opt. */
1632 break;
1633 #else
1634 return false;
1635 #endif
1637 case OPT_fsched_stalled_insns_:
1638 opts->x_flag_sched_stalled_insns = value;
1639 if (opts->x_flag_sched_stalled_insns == 0)
1640 opts->x_flag_sched_stalled_insns = -1;
1641 break;
1643 case OPT_fsched_stalled_insns_dep_:
1644 opts->x_flag_sched_stalled_insns_dep = value;
1645 break;
1647 case OPT_fstack_check_:
1648 if (!strcmp (arg, "no"))
1649 opts->x_flag_stack_check = NO_STACK_CHECK;
1650 else if (!strcmp (arg, "generic"))
1651 /* This is the old stack checking method. */
1652 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1653 ? FULL_BUILTIN_STACK_CHECK
1654 : GENERIC_STACK_CHECK;
1655 else if (!strcmp (arg, "specific"))
1656 /* This is the new stack checking method. */
1657 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1658 ? FULL_BUILTIN_STACK_CHECK
1659 : STACK_CHECK_STATIC_BUILTIN
1660 ? STATIC_BUILTIN_STACK_CHECK
1661 : GENERIC_STACK_CHECK;
1662 else
1663 warning_at (loc, 0, "unknown stack check parameter \"%s\"", arg);
1664 break;
1666 case OPT_fstack_limit:
1667 /* The real switch is -fno-stack-limit. */
1668 if (value)
1669 return false;
1670 /* Deferred. */
1671 break;
1673 case OPT_fstack_limit_register_:
1674 case OPT_fstack_limit_symbol_:
1675 /* Deferred. */
1676 break;
1678 case OPT_fstack_usage:
1679 opts->x_flag_stack_usage = value;
1680 opts->x_flag_stack_usage_info = value != 0;
1681 break;
1683 case OPT_ftree_vectorizer_verbose_:
1684 /* -ftree-vectorizer-verbose is deprecated. It is defined in
1685 -terms of fopt-info=N. */
1686 /* Deferred. */
1687 break;
1689 case OPT_g:
1690 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
1691 loc);
1692 break;
1694 case OPT_gcoff:
1695 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
1696 break;
1698 case OPT_gdwarf_:
1699 if (value < 2 || value > 4)
1700 error_at (loc, "dwarf version %d is not supported", value);
1701 else
1702 opts->x_dwarf_version = value;
1703 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
1704 break;
1706 case OPT_ggdb:
1707 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
1708 break;
1710 case OPT_gstabs:
1711 case OPT_gstabs_:
1712 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
1713 loc);
1714 break;
1716 case OPT_gvms:
1717 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
1718 break;
1720 case OPT_gxcoff:
1721 case OPT_gxcoff_:
1722 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
1723 loc);
1724 break;
1726 case OPT_pedantic_errors:
1727 dc->pedantic_errors = 1;
1728 control_warning_option (OPT_Wpedantic, DK_ERROR, value,
1729 loc, lang_mask,
1730 handlers, opts, opts_set,
1731 dc);
1732 break;
1734 case OPT_flto:
1735 opts->x_flag_lto = value ? "" : NULL;
1736 break;
1738 case OPT_w:
1739 dc->dc_inhibit_warnings = true;
1740 break;
1742 case OPT_fmax_errors_:
1743 dc->max_errors = value;
1744 break;
1746 case OPT_fuse_linker_plugin:
1747 /* No-op. Used by the driver and passed to us because it starts with f.*/
1748 break;
1750 default:
1751 /* If the flag was handled in a standard way, assume the lack of
1752 processing here is intentional. */
1753 gcc_assert (option_flag_var (scode, opts));
1754 break;
1757 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
1758 loc, handlers, dc);
1759 return true;
1762 /* Handle --param NAME=VALUE. */
1763 static void
1764 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
1765 location_t loc, const char *carg)
1767 char *equal, *arg;
1768 int value;
1770 arg = xstrdup (carg);
1771 equal = strchr (arg, '=');
1772 if (!equal)
1773 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
1774 arg);
1775 else
1777 value = integral_argument (equal + 1);
1778 if (value == -1)
1779 error_at (loc, "invalid --param value %qs", equal + 1);
1780 else
1782 *equal = '\0';
1783 set_param_value (arg, value,
1784 opts->x_param_values, opts_set->x_param_values);
1788 free (arg);
1791 /* Used to set the level of strict aliasing warnings in OPTS,
1792 when no level is specified (i.e., when -Wstrict-aliasing, and not
1793 -Wstrict-aliasing=level was given).
1794 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
1795 and 0 otherwise. After calling this function, wstrict_aliasing will be
1796 set to the default value of -Wstrict_aliasing=level, currently 3. */
1797 static void
1798 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
1800 gcc_assert (onoff == 0 || onoff == 1);
1801 if (onoff != 0)
1802 opts->x_warn_strict_aliasing = 3;
1803 else
1804 opts->x_warn_strict_aliasing = 0;
1807 /* The following routines are useful in setting all the flags that
1808 -ffast-math and -fno-fast-math imply. */
1809 static void
1810 set_fast_math_flags (struct gcc_options *opts, int set)
1812 if (!opts->frontend_set_flag_unsafe_math_optimizations)
1814 opts->x_flag_unsafe_math_optimizations = set;
1815 set_unsafe_math_optimizations_flags (opts, set);
1817 if (!opts->frontend_set_flag_finite_math_only)
1818 opts->x_flag_finite_math_only = set;
1819 if (!opts->frontend_set_flag_errno_math)
1820 opts->x_flag_errno_math = !set;
1821 if (set)
1823 if (!opts->frontend_set_flag_signaling_nans)
1824 opts->x_flag_signaling_nans = 0;
1825 if (!opts->frontend_set_flag_rounding_math)
1826 opts->x_flag_rounding_math = 0;
1827 if (!opts->frontend_set_flag_cx_limited_range)
1828 opts->x_flag_cx_limited_range = 1;
1832 /* When -funsafe-math-optimizations is set the following
1833 flags are set as well. */
1834 static void
1835 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
1837 if (!opts->frontend_set_flag_trapping_math)
1838 opts->x_flag_trapping_math = !set;
1839 if (!opts->frontend_set_flag_signed_zeros)
1840 opts->x_flag_signed_zeros = !set;
1841 if (!opts->frontend_set_flag_associative_math)
1842 opts->x_flag_associative_math = set;
1843 if (!opts->frontend_set_flag_reciprocal_math)
1844 opts->x_flag_reciprocal_math = set;
1847 /* Return true iff flags in OPTS are set as if -ffast-math. */
1848 bool
1849 fast_math_flags_set_p (const struct gcc_options *opts)
1851 return (!opts->x_flag_trapping_math
1852 && opts->x_flag_unsafe_math_optimizations
1853 && opts->x_flag_finite_math_only
1854 && !opts->x_flag_signed_zeros
1855 && !opts->x_flag_errno_math);
1858 /* Return true iff flags are set as if -ffast-math but using the flags stored
1859 in the struct cl_optimization structure. */
1860 bool
1861 fast_math_flags_struct_set_p (struct cl_optimization *opt)
1863 return (!opt->x_flag_trapping_math
1864 && opt->x_flag_unsafe_math_optimizations
1865 && opt->x_flag_finite_math_only
1866 && !opt->x_flag_signed_zeros
1867 && !opt->x_flag_errno_math);
1870 /* Handle a debug output -g switch for options OPTS
1871 (OPTS_SET->x_write_symbols storing whether a debug type was passed
1872 explicitly), location LOC. EXTENDED is true or false to support
1873 extended output (2 is special and means "-ggdb" was given). */
1874 static void
1875 set_debug_level (enum debug_info_type type, int extended, const char *arg,
1876 struct gcc_options *opts, struct gcc_options *opts_set,
1877 location_t loc)
1879 opts->x_use_gnu_debug_info_extensions = extended;
1881 if (type == NO_DEBUG)
1883 if (opts->x_write_symbols == NO_DEBUG)
1885 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
1887 if (extended == 2)
1889 #ifdef DWARF2_DEBUGGING_INFO
1890 opts->x_write_symbols = DWARF2_DEBUG;
1891 #elif defined DBX_DEBUGGING_INFO
1892 opts->x_write_symbols = DBX_DEBUG;
1893 #endif
1896 if (opts->x_write_symbols == NO_DEBUG)
1897 warning_at (loc, 0, "target system does not support debug output");
1900 else
1902 /* Does it conflict with an already selected type? */
1903 if (opts_set->x_write_symbols != NO_DEBUG
1904 && opts->x_write_symbols != NO_DEBUG
1905 && type != opts->x_write_symbols)
1906 error_at (loc, "debug format \"%s\" conflicts with prior selection",
1907 debug_type_names[type]);
1908 opts->x_write_symbols = type;
1909 opts_set->x_write_symbols = type;
1912 /* A debug flag without a level defaults to level 2. */
1913 if (*arg == '\0')
1915 if (!opts->x_debug_info_level)
1916 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
1918 else
1920 int argval = integral_argument (arg);
1921 if (argval == -1)
1922 error_at (loc, "unrecognised debug output level \"%s\"", arg);
1923 else if (argval > 3)
1924 error_at (loc, "debug output level %s is too high", arg);
1925 else
1926 opts->x_debug_info_level = (enum debug_info_levels) argval;
1930 /* Arrange to dump core on error for diagnostic context DC. (The
1931 regular error message is still printed first, except in the case of
1932 abort ().) */
1934 static void
1935 setup_core_dumping (diagnostic_context *dc)
1937 #ifdef SIGABRT
1938 signal (SIGABRT, SIG_DFL);
1939 #endif
1940 #if defined(HAVE_SETRLIMIT)
1942 struct rlimit rlim;
1943 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
1944 fatal_error ("getting core file size maximum limit: %m");
1945 rlim.rlim_cur = rlim.rlim_max;
1946 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
1947 fatal_error ("setting core file size limit to maximum: %m");
1949 #endif
1950 diagnostic_abort_on_error (dc);
1953 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
1954 diagnostic context DC. */
1956 static void
1957 decode_d_option (const char *arg, struct gcc_options *opts,
1958 location_t loc, diagnostic_context *dc)
1960 int c;
1962 while (*arg)
1963 switch (c = *arg++)
1965 case 'A':
1966 opts->x_flag_debug_asm = 1;
1967 break;
1968 case 'p':
1969 opts->x_flag_print_asm_name = 1;
1970 break;
1971 case 'P':
1972 opts->x_flag_dump_rtl_in_asm = 1;
1973 opts->x_flag_print_asm_name = 1;
1974 break;
1975 case 'v':
1976 opts->x_graph_dump_format = vcg;
1977 break;
1978 case 'x':
1979 opts->x_rtl_dump_and_exit = 1;
1980 break;
1981 case 'D': /* These are handled by the preprocessor. */
1982 case 'I':
1983 case 'M':
1984 case 'N':
1985 case 'U':
1986 break;
1987 case 'H':
1988 setup_core_dumping (dc);
1989 break;
1990 case 'a':
1991 opts->x_flag_dump_all_passed = true;
1992 break;
1994 default:
1995 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
1996 break;
2000 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2001 mask LANG_MASK, option handlers HANDLERS) as an error for option
2002 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2003 NULL), location LOC. This is used by -Werror=. */
2005 static void
2006 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2007 const struct cl_option_handlers *handlers,
2008 struct gcc_options *opts,
2009 struct gcc_options *opts_set,
2010 location_t loc, diagnostic_context *dc)
2012 char *new_option;
2013 int option_index;
2015 new_option = XNEWVEC (char, strlen (arg) + 2);
2016 new_option[0] = 'W';
2017 strcpy (new_option + 1, arg);
2018 option_index = find_opt (new_option, lang_mask);
2019 if (option_index == OPT_SPECIAL_unknown)
2021 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2023 else
2025 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2027 control_warning_option (option_index, (int) kind, value,
2028 loc, lang_mask,
2029 handlers, opts, opts_set, dc);
2031 free (new_option);
2034 /* Return malloced memory for the name of the option OPTION_INDEX
2035 which enabled a diagnostic (context CONTEXT), originally of type
2036 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2037 as -Werror. */
2039 char *
2040 option_name (diagnostic_context *context, int option_index,
2041 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2043 if (option_index)
2045 /* A warning classified as an error. */
2046 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2047 && diag_kind == DK_ERROR)
2048 return concat (cl_options[OPT_Werror_].opt_text,
2049 /* Skip over "-W". */
2050 cl_options[option_index].opt_text + 2,
2051 NULL);
2052 /* A warning with option. */
2053 else
2054 return xstrdup (cl_options[option_index].opt_text);
2056 /* A warning without option classified as an error. */
2057 else if (orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2058 || diag_kind == DK_WARNING)
2060 if (context->warning_as_error_requested)
2061 return xstrdup (cl_options[OPT_Werror].opt_text);
2062 else
2063 return xstrdup (_("enabled by default"));
2065 else
2066 return NULL;