2012-12-01 Alessandro Fanfarillo <alessandro.fanfarillo@gmail.com>
[official-gcc.git] / gcc / opts.c
blobb3a9afe8e4d8829896d05a749f9bcfc6fa69d454
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. */
194 static void handle_param (struct gcc_options *opts,
195 struct gcc_options *opts_set, location_t loc,
196 const char *carg);
197 static void set_debug_level (enum debug_info_type type, int extended,
198 const char *arg, struct gcc_options *opts,
199 struct gcc_options *opts_set,
200 location_t loc);
201 static void set_fast_math_flags (struct gcc_options *opts, int set);
202 static void decode_d_option (const char *arg, struct gcc_options *opts,
203 location_t loc, diagnostic_context *dc);
204 static void set_unsafe_math_optimizations_flags (struct gcc_options *opts,
205 int set);
206 static void enable_warning_as_error (const char *arg, int value,
207 unsigned int lang_mask,
208 const struct cl_option_handlers *handlers,
209 struct gcc_options *opts,
210 struct gcc_options *opts_set,
211 location_t loc,
212 diagnostic_context *dc);
214 /* Handle a back-end option; arguments and return value as for
215 handle_option. */
217 bool
218 target_handle_option (struct gcc_options *opts,
219 struct gcc_options *opts_set,
220 const struct cl_decoded_option *decoded,
221 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
222 location_t loc,
223 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
224 diagnostic_context *dc)
226 gcc_assert (dc == global_dc);
227 gcc_assert (kind == DK_UNSPECIFIED);
228 return targetm_common.handle_option (opts, opts_set, decoded, loc);
231 /* Add comma-separated strings to a char_p vector. */
233 static void
234 add_comma_separated_to_vector (void **pvec, const char *arg)
236 char *tmp;
237 char *r;
238 char *w;
239 char *token_start;
240 vec<char_p> *v = (vec<char_p> *) *pvec;
242 vec_check_alloc (v, 1);
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 v->safe_push (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 v->safe_push (token_start);
271 *pvec = v;
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 /* The -gsplit-dwarf option requires -gpubnames. */
833 if (opts->x_dwarf_split_debug_info)
834 opts->x_debug_generate_pub_sections = 1;
837 #define LEFT_COLUMN 27
839 /* Output ITEM, of length ITEM_WIDTH, in the left column,
840 followed by word-wrapped HELP in a second column. */
841 static void
842 wrap_help (const char *help,
843 const char *item,
844 unsigned int item_width,
845 unsigned int columns)
847 unsigned int col_width = LEFT_COLUMN;
848 unsigned int remaining, room, len;
850 remaining = strlen (help);
854 room = columns - 3 - MAX (col_width, item_width);
855 if (room > columns)
856 room = 0;
857 len = remaining;
859 if (room < len)
861 unsigned int i;
863 for (i = 0; help[i]; i++)
865 if (i >= room && len != remaining)
866 break;
867 if (help[i] == ' ')
868 len = i;
869 else if ((help[i] == '-' || help[i] == '/')
870 && help[i + 1] != ' '
871 && i > 0 && ISALPHA (help[i - 1]))
872 len = i + 1;
876 printf( " %-*.*s %.*s\n", col_width, item_width, item, len, help);
877 item_width = 0;
878 while (help[len] == ' ')
879 len++;
880 help += len;
881 remaining -= len;
883 while (remaining);
886 /* Print help for a specific front-end, etc. */
887 static void
888 print_filtered_help (unsigned int include_flags,
889 unsigned int exclude_flags,
890 unsigned int any_flags,
891 unsigned int columns,
892 struct gcc_options *opts,
893 unsigned int lang_mask)
895 unsigned int i;
896 const char *help;
897 bool found = false;
898 bool displayed = false;
900 if (include_flags == CL_PARAMS)
902 for (i = 0; i < LAST_PARAM; i++)
904 const char *param = compiler_params[i].option;
906 help = compiler_params[i].help;
907 if (help == NULL || *help == '\0')
909 if (exclude_flags & CL_UNDOCUMENTED)
910 continue;
911 help = undocumented_msg;
914 /* Get the translation. */
915 help = _(help);
917 wrap_help (help, param, strlen (param), columns);
919 putchar ('\n');
920 return;
923 if (!opts->x_help_printed)
924 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
926 if (!opts->x_help_enum_printed)
927 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
929 for (i = 0; i < cl_options_count; i++)
931 char new_help[128];
932 const struct cl_option *option = cl_options + i;
933 unsigned int len;
934 const char *opt;
935 const char *tab;
937 if (include_flags == 0
938 || ((option->flags & include_flags) != include_flags))
940 if ((option->flags & any_flags) == 0)
941 continue;
944 /* Skip unwanted switches. */
945 if ((option->flags & exclude_flags) != 0)
946 continue;
948 /* The driver currently prints its own help text. */
949 if ((option->flags & CL_DRIVER) != 0
950 && (option->flags & (((1U << cl_lang_count) - 1)
951 | CL_COMMON | CL_TARGET)) == 0)
952 continue;
954 found = true;
955 /* Skip switches that have already been printed. */
956 if (opts->x_help_printed[i])
957 continue;
959 opts->x_help_printed[i] = true;
961 help = option->help;
962 if (help == NULL)
964 if (exclude_flags & CL_UNDOCUMENTED)
965 continue;
966 help = undocumented_msg;
969 /* Get the translation. */
970 help = _(help);
972 /* Find the gap between the name of the
973 option and its descriptive text. */
974 tab = strchr (help, '\t');
975 if (tab)
977 len = tab - help;
978 opt = help;
979 help = tab + 1;
981 else
983 opt = option->opt_text;
984 len = strlen (opt);
987 /* With the -Q option enabled we change the descriptive text associated
988 with an option to be an indication of its current setting. */
989 if (!opts->x_quiet_flag)
991 void *flag_var = option_flag_var (i, opts);
993 if (len < (LEFT_COLUMN + 2))
994 strcpy (new_help, "\t\t");
995 else
996 strcpy (new_help, "\t");
998 if (flag_var != NULL
999 && option->var_type != CLVC_DEFER)
1001 if (option->flags & CL_JOINED)
1003 if (option->var_type == CLVC_STRING)
1005 if (* (const char **) flag_var != NULL)
1006 snprintf (new_help + strlen (new_help),
1007 sizeof (new_help) - strlen (new_help),
1008 * (const char **) flag_var);
1010 else if (option->var_type == CLVC_ENUM)
1012 const struct cl_enum *e = &cl_enums[option->var_enum];
1013 int value;
1014 const char *arg = NULL;
1016 value = e->get (flag_var);
1017 enum_value_to_arg (e->values, &arg, value, lang_mask);
1018 if (arg == NULL)
1019 arg = _("[default]");
1020 snprintf (new_help + strlen (new_help),
1021 sizeof (new_help) - strlen (new_help),
1022 arg);
1024 else
1025 sprintf (new_help + strlen (new_help),
1026 "%#x", * (int *) flag_var);
1028 else
1029 strcat (new_help, option_enabled (i, opts)
1030 ? _("[enabled]") : _("[disabled]"));
1033 help = new_help;
1036 wrap_help (help, opt, len, columns);
1037 displayed = true;
1039 if (option->var_type == CLVC_ENUM
1040 && opts->x_help_enum_printed[option->var_enum] != 2)
1041 opts->x_help_enum_printed[option->var_enum] = 1;
1044 if (! found)
1046 unsigned int langs = include_flags & CL_LANG_ALL;
1048 if (langs == 0)
1049 printf (_(" No options with the desired characteristics were found\n"));
1050 else
1052 unsigned int i;
1054 /* PR 31349: Tell the user how to see all of the
1055 options supported by a specific front end. */
1056 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1057 if ((1U << i) & langs)
1058 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end\n"),
1059 lang_names[i], lang_names[i]);
1063 else if (! displayed)
1064 printf (_(" All options with the desired characteristics have already been displayed\n"));
1066 putchar ('\n');
1068 /* Print details of enumerated option arguments, if those
1069 enumerations have help text headings provided. If no help text
1070 is provided, presume that the possible values are listed in the
1071 help text for the relevant options. */
1072 for (i = 0; i < cl_enums_count; i++)
1074 unsigned int j, pos;
1076 if (opts->x_help_enum_printed[i] != 1)
1077 continue;
1078 if (cl_enums[i].help == NULL)
1079 continue;
1080 printf (" %s\n ", _(cl_enums[i].help));
1081 pos = 4;
1082 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1084 unsigned int len = strlen (cl_enums[i].values[j].arg);
1086 if (pos > 4 && pos + 1 + len <= columns)
1088 printf (" %s", cl_enums[i].values[j].arg);
1089 pos += 1 + len;
1091 else
1093 if (pos > 4)
1095 printf ("\n ");
1096 pos = 4;
1098 printf ("%s", cl_enums[i].values[j].arg);
1099 pos += len;
1102 printf ("\n\n");
1103 opts->x_help_enum_printed[i] = 2;
1107 /* Display help for a specified type of option.
1108 The options must have ALL of the INCLUDE_FLAGS set
1109 ANY of the flags in the ANY_FLAGS set
1110 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1111 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1112 static void
1113 print_specific_help (unsigned int include_flags,
1114 unsigned int exclude_flags,
1115 unsigned int any_flags,
1116 struct gcc_options *opts,
1117 unsigned int lang_mask)
1119 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1120 const char * description = NULL;
1121 const char * descrip_extra = "";
1122 size_t i;
1123 unsigned int flag;
1125 /* Sanity check: Make sure that we do not have more
1126 languages than we have bits available to enumerate them. */
1127 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1129 /* If we have not done so already, obtain
1130 the desired maximum width of the output. */
1131 if (opts->x_help_columns == 0)
1133 const char *p;
1135 p = getenv ("COLUMNS");
1136 if (p != NULL)
1138 int value = atoi (p);
1140 if (value > 0)
1141 opts->x_help_columns = value;
1144 if (opts->x_help_columns == 0)
1145 /* Use a reasonable default. */
1146 opts->x_help_columns = 80;
1149 /* Decide upon the title for the options that we are going to display. */
1150 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1152 switch (flag & include_flags)
1154 case 0:
1155 case CL_DRIVER:
1156 break;
1158 case CL_TARGET:
1159 description = _("The following options are target specific");
1160 break;
1161 case CL_WARNING:
1162 description = _("The following options control compiler warning messages");
1163 break;
1164 case CL_OPTIMIZATION:
1165 description = _("The following options control optimizations");
1166 break;
1167 case CL_COMMON:
1168 description = _("The following options are language-independent");
1169 break;
1170 case CL_PARAMS:
1171 description = _("The --param option recognizes the following as parameters");
1172 break;
1173 default:
1174 if (i >= cl_lang_count)
1175 break;
1176 if (exclude_flags & all_langs_mask)
1177 description = _("The following options are specific to just the language ");
1178 else
1179 description = _("The following options are supported by the language ");
1180 descrip_extra = lang_names [i];
1181 break;
1185 if (description == NULL)
1187 if (any_flags == 0)
1189 if (include_flags & CL_UNDOCUMENTED)
1190 description = _("The following options are not documented");
1191 else if (include_flags & CL_SEPARATE)
1192 description = _("The following options take separate arguments");
1193 else if (include_flags & CL_JOINED)
1194 description = _("The following options take joined arguments");
1195 else
1197 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1198 include_flags);
1199 return;
1202 else
1204 if (any_flags & all_langs_mask)
1205 description = _("The following options are language-related");
1206 else
1207 description = _("The following options are language-independent");
1211 printf ("%s%s:\n", description, descrip_extra);
1212 print_filtered_help (include_flags, exclude_flags, any_flags,
1213 opts->x_help_columns, opts, lang_mask);
1216 /* Handle target- and language-independent options. Return zero to
1217 generate an "unknown option" message. Only options that need
1218 extra handling need to be listed here; if you simply want
1219 DECODED->value assigned to a variable, it happens automatically. */
1221 bool
1222 common_handle_option (struct gcc_options *opts,
1223 struct gcc_options *opts_set,
1224 const struct cl_decoded_option *decoded,
1225 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1226 location_t loc,
1227 const struct cl_option_handlers *handlers,
1228 diagnostic_context *dc)
1230 size_t scode = decoded->opt_index;
1231 const char *arg = decoded->arg;
1232 int value = decoded->value;
1233 enum opt_code code = (enum opt_code) scode;
1235 gcc_assert (decoded->canonical_option_num_elements <= 2);
1237 switch (code)
1239 case OPT__param:
1240 handle_param (opts, opts_set, loc, arg);
1241 break;
1243 case OPT__help:
1245 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1246 unsigned int undoc_mask;
1247 unsigned int i;
1249 if (lang_mask == CL_DRIVER)
1250 break;;
1252 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1254 : CL_UNDOCUMENTED);
1255 /* First display any single language specific options. */
1256 for (i = 0; i < cl_lang_count; i++)
1257 print_specific_help
1258 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1259 lang_mask);
1260 /* Next display any multi language specific options. */
1261 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1262 /* Then display any remaining, non-language options. */
1263 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1264 if (i != CL_DRIVER)
1265 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1266 opts->x_exit_after_options = true;
1267 break;
1270 case OPT__target_help:
1271 if (lang_mask == CL_DRIVER)
1272 break;
1274 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1275 opts->x_exit_after_options = true;
1276 break;
1278 case OPT__help_:
1280 const char * a = arg;
1281 unsigned int include_flags = 0;
1282 /* Note - by default we include undocumented options when listing
1283 specific classes. If you only want to see documented options
1284 then add ",^undocumented" to the --help= option. E.g.:
1286 --help=target,^undocumented */
1287 unsigned int exclude_flags = 0;
1289 if (lang_mask == CL_DRIVER)
1290 break;
1292 /* Walk along the argument string, parsing each word in turn.
1293 The format is:
1294 arg = [^]{word}[,{arg}]
1295 word = {optimizers|target|warnings|undocumented|
1296 params|common|<language>} */
1297 while (* a != 0)
1299 static const struct
1301 const char * string;
1302 unsigned int flag;
1304 specifics[] =
1306 { "optimizers", CL_OPTIMIZATION },
1307 { "target", CL_TARGET },
1308 { "warnings", CL_WARNING },
1309 { "undocumented", CL_UNDOCUMENTED },
1310 { "params", CL_PARAMS },
1311 { "joined", CL_JOINED },
1312 { "separate", CL_SEPARATE },
1313 { "common", CL_COMMON },
1314 { NULL, 0 }
1316 unsigned int * pflags;
1317 const char * comma;
1318 unsigned int lang_flag, specific_flag;
1319 unsigned int len;
1320 unsigned int i;
1322 if (* a == '^')
1324 ++ a;
1325 pflags = & exclude_flags;
1327 else
1328 pflags = & include_flags;
1330 comma = strchr (a, ',');
1331 if (comma == NULL)
1332 len = strlen (a);
1333 else
1334 len = comma - a;
1335 if (len == 0)
1337 a = comma + 1;
1338 continue;
1341 /* Check to see if the string matches an option class name. */
1342 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1343 if (strncasecmp (a, specifics[i].string, len) == 0)
1345 specific_flag = specifics[i].flag;
1346 break;
1349 /* Check to see if the string matches a language name.
1350 Note - we rely upon the alpha-sorted nature of the entries in
1351 the lang_names array, specifically that shorter names appear
1352 before their longer variants. (i.e. C before C++). That way
1353 when we are attempting to match --help=c for example we will
1354 match with C first and not C++. */
1355 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1356 if (strncasecmp (a, lang_names[i], len) == 0)
1358 lang_flag = 1U << i;
1359 break;
1362 if (specific_flag != 0)
1364 if (lang_flag == 0)
1365 * pflags |= specific_flag;
1366 else
1368 /* The option's argument matches both the start of a
1369 language name and the start of an option class name.
1370 We have a special case for when the user has
1371 specified "--help=c", but otherwise we have to issue
1372 a warning. */
1373 if (strncasecmp (a, "c", len) == 0)
1374 * pflags |= lang_flag;
1375 else
1376 warning_at (loc, 0,
1377 "--help argument %q.*s is ambiguous, "
1378 "please be more specific",
1379 len, a);
1382 else if (lang_flag != 0)
1383 * pflags |= lang_flag;
1384 else
1385 warning_at (loc, 0,
1386 "unrecognized argument to --help= option: %q.*s",
1387 len, a);
1389 if (comma == NULL)
1390 break;
1391 a = comma + 1;
1394 if (include_flags)
1395 print_specific_help (include_flags, exclude_flags, 0, opts,
1396 lang_mask);
1397 opts->x_exit_after_options = true;
1398 break;
1401 case OPT__version:
1402 if (lang_mask == CL_DRIVER)
1403 break;
1405 opts->x_exit_after_options = true;
1406 break;
1408 case OPT_O:
1409 case OPT_Os:
1410 case OPT_Ofast:
1411 case OPT_Og:
1412 /* Currently handled in a prescan. */
1413 break;
1415 case OPT_Werror:
1416 dc->warning_as_error_requested = value;
1417 break;
1419 case OPT_Werror_:
1420 if (lang_mask == CL_DRIVER)
1421 break;
1423 enable_warning_as_error (arg, value, lang_mask, handlers,
1424 opts, opts_set, loc, dc);
1425 break;
1427 case OPT_Wlarger_than_:
1428 opts->x_larger_than_size = value;
1429 opts->x_warn_larger_than = value != -1;
1430 break;
1432 case OPT_Wfatal_errors:
1433 dc->fatal_errors = value;
1434 break;
1436 case OPT_Wframe_larger_than_:
1437 opts->x_frame_larger_than_size = value;
1438 opts->x_warn_frame_larger_than = value != -1;
1439 break;
1441 case OPT_Wstack_usage_:
1442 opts->x_warn_stack_usage = value;
1443 opts->x_flag_stack_usage_info = value != -1;
1444 break;
1446 case OPT_Wstrict_aliasing:
1447 set_Wstrict_aliasing (opts, value);
1448 break;
1450 case OPT_Wstrict_overflow:
1451 opts->x_warn_strict_overflow = (value
1452 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1453 : 0);
1454 break;
1456 case OPT_Wsystem_headers:
1457 dc->dc_warn_system_headers = value;
1458 break;
1460 case OPT_aux_info:
1461 opts->x_flag_gen_aux_info = 1;
1462 break;
1464 case OPT_auxbase_strip:
1466 char *tmp = xstrdup (arg);
1467 strip_off_ending (tmp, strlen (tmp));
1468 if (tmp[0])
1469 opts->x_aux_base_name = tmp;
1470 else
1471 free (tmp);
1473 break;
1475 case OPT_d:
1476 decode_d_option (arg, opts, loc, dc);
1477 break;
1479 case OPT_fcall_used_:
1480 case OPT_fcall_saved_:
1481 /* Deferred. */
1482 break;
1484 case OPT_fdbg_cnt_:
1485 case OPT_fdbg_cnt_list:
1486 /* Deferred. */
1487 break;
1489 case OPT_fdebug_prefix_map_:
1490 /* Deferred. */
1491 break;
1493 case OPT_fdiagnostics_show_location_:
1494 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1495 break;
1497 case OPT_fdiagnostics_show_caret:
1498 dc->show_caret = value;
1499 break;
1501 case OPT_fdiagnostics_show_option:
1502 dc->show_option_requested = value;
1503 break;
1505 case OPT_fdump_:
1506 /* Deferred. */
1507 break;
1509 case OPT_ffast_math:
1510 set_fast_math_flags (opts, value);
1511 break;
1513 case OPT_funsafe_math_optimizations:
1514 set_unsafe_math_optimizations_flags (opts, value);
1515 break;
1517 case OPT_ffixed_:
1518 /* Deferred. */
1519 break;
1521 case OPT_finline_limit_:
1522 set_param_value ("max-inline-insns-single", value / 2,
1523 opts->x_param_values, opts_set->x_param_values);
1524 set_param_value ("max-inline-insns-auto", value / 2,
1525 opts->x_param_values, opts_set->x_param_values);
1526 break;
1528 case OPT_finstrument_functions_exclude_function_list_:
1529 add_comma_separated_to_vector
1530 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1531 break;
1533 case OPT_finstrument_functions_exclude_file_list_:
1534 add_comma_separated_to_vector
1535 (&opts->x_flag_instrument_functions_exclude_files, arg);
1536 break;
1538 case OPT_fmessage_length_:
1539 pp_set_line_maximum_length (dc->printer, value);
1540 diagnostic_set_caret_max_width (dc, value);
1541 break;
1543 case OPT_fopt_info:
1544 case OPT_fopt_info_:
1545 /* Deferred. */
1546 break;
1548 case OPT_fpack_struct_:
1549 if (value <= 0 || (value & (value - 1)) || value > 16)
1550 error_at (loc,
1551 "structure alignment must be a small power of two, not %d",
1552 value);
1553 else
1554 opts->x_initial_max_fld_align = value;
1555 break;
1557 case OPT_fplugin_:
1558 case OPT_fplugin_arg_:
1559 /* Deferred. */
1560 break;
1562 case OPT_fprofile_use_:
1563 opts->x_profile_data_prefix = xstrdup (arg);
1564 opts->x_flag_profile_use = true;
1565 value = true;
1566 /* No break here - do -fprofile-use processing. */
1567 case OPT_fprofile_use:
1568 if (!opts_set->x_flag_branch_probabilities)
1569 opts->x_flag_branch_probabilities = value;
1570 if (!opts_set->x_flag_profile_values)
1571 opts->x_flag_profile_values = value;
1572 if (!opts_set->x_flag_unroll_loops)
1573 opts->x_flag_unroll_loops = value;
1574 if (!opts_set->x_flag_peel_loops)
1575 opts->x_flag_peel_loops = value;
1576 if (!opts_set->x_flag_tracer)
1577 opts->x_flag_tracer = value;
1578 if (!opts_set->x_flag_value_profile_transformations)
1579 opts->x_flag_value_profile_transformations = value;
1580 if (!opts_set->x_flag_inline_functions)
1581 opts->x_flag_inline_functions = value;
1582 if (!opts_set->x_flag_ipa_cp)
1583 opts->x_flag_ipa_cp = value;
1584 if (!opts_set->x_flag_ipa_cp_clone
1585 && value && opts->x_flag_ipa_cp)
1586 opts->x_flag_ipa_cp_clone = value;
1587 if (!opts_set->x_flag_predictive_commoning)
1588 opts->x_flag_predictive_commoning = value;
1589 if (!opts_set->x_flag_unswitch_loops)
1590 opts->x_flag_unswitch_loops = value;
1591 if (!opts_set->x_flag_gcse_after_reload)
1592 opts->x_flag_gcse_after_reload = value;
1593 if (!opts_set->x_flag_tree_vectorize)
1594 opts->x_flag_tree_vectorize = value;
1595 if (!opts_set->x_flag_vect_cost_model)
1596 opts->x_flag_vect_cost_model = value;
1597 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1598 opts->x_flag_tree_loop_distribute_patterns = value;
1599 break;
1601 case OPT_fprofile_generate_:
1602 opts->x_profile_data_prefix = xstrdup (arg);
1603 value = true;
1604 /* No break here - do -fprofile-generate processing. */
1605 case OPT_fprofile_generate:
1606 if (!opts_set->x_profile_arc_flag)
1607 opts->x_profile_arc_flag = value;
1608 if (!opts_set->x_flag_profile_values)
1609 opts->x_flag_profile_values = value;
1610 if (!opts_set->x_flag_inline_functions)
1611 opts->x_flag_inline_functions = value;
1612 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1613 quadratic. Disable the pass until better memory representation
1614 is done. */
1615 if (!opts_set->x_flag_ipa_reference && opts->x_in_lto_p)
1616 opts->x_flag_ipa_reference = false;
1617 break;
1619 case OPT_fshow_column:
1620 dc->show_column = value;
1621 break;
1623 case OPT_frandom_seed:
1624 /* The real switch is -fno-random-seed. */
1625 if (value)
1626 return false;
1627 /* Deferred. */
1628 break;
1630 case OPT_frandom_seed_:
1631 /* Deferred. */
1632 break;
1634 case OPT_fsched_verbose_:
1635 #ifdef INSN_SCHEDULING
1636 /* Handled with Var in common.opt. */
1637 break;
1638 #else
1639 return false;
1640 #endif
1642 case OPT_fsched_stalled_insns_:
1643 opts->x_flag_sched_stalled_insns = value;
1644 if (opts->x_flag_sched_stalled_insns == 0)
1645 opts->x_flag_sched_stalled_insns = -1;
1646 break;
1648 case OPT_fsched_stalled_insns_dep_:
1649 opts->x_flag_sched_stalled_insns_dep = value;
1650 break;
1652 case OPT_fstack_check_:
1653 if (!strcmp (arg, "no"))
1654 opts->x_flag_stack_check = NO_STACK_CHECK;
1655 else if (!strcmp (arg, "generic"))
1656 /* This is the old stack checking method. */
1657 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1658 ? FULL_BUILTIN_STACK_CHECK
1659 : GENERIC_STACK_CHECK;
1660 else if (!strcmp (arg, "specific"))
1661 /* This is the new stack checking method. */
1662 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1663 ? FULL_BUILTIN_STACK_CHECK
1664 : STACK_CHECK_STATIC_BUILTIN
1665 ? STATIC_BUILTIN_STACK_CHECK
1666 : GENERIC_STACK_CHECK;
1667 else
1668 warning_at (loc, 0, "unknown stack check parameter \"%s\"", arg);
1669 break;
1671 case OPT_fstack_limit:
1672 /* The real switch is -fno-stack-limit. */
1673 if (value)
1674 return false;
1675 /* Deferred. */
1676 break;
1678 case OPT_fstack_limit_register_:
1679 case OPT_fstack_limit_symbol_:
1680 /* Deferred. */
1681 break;
1683 case OPT_fstack_usage:
1684 opts->x_flag_stack_usage = value;
1685 opts->x_flag_stack_usage_info = value != 0;
1686 break;
1688 case OPT_ftree_vectorizer_verbose_:
1689 /* -ftree-vectorizer-verbose is deprecated. It is defined in
1690 -terms of fopt-info=N. */
1691 /* Deferred. */
1692 break;
1694 case OPT_g:
1695 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
1696 loc);
1697 break;
1699 case OPT_gcoff:
1700 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
1701 break;
1703 case OPT_gdwarf_:
1704 if (value < 2 || value > 4)
1705 error_at (loc, "dwarf version %d is not supported", value);
1706 else
1707 opts->x_dwarf_version = value;
1708 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
1709 break;
1711 case OPT_gsplit_dwarf:
1712 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
1713 loc);
1714 break;
1716 case OPT_ggdb:
1717 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
1718 break;
1720 case OPT_gstabs:
1721 case OPT_gstabs_:
1722 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
1723 loc);
1724 break;
1726 case OPT_gvms:
1727 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
1728 break;
1730 case OPT_gxcoff:
1731 case OPT_gxcoff_:
1732 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
1733 loc);
1734 break;
1736 case OPT_pedantic_errors:
1737 dc->pedantic_errors = 1;
1738 control_warning_option (OPT_Wpedantic, DK_ERROR, value,
1739 loc, lang_mask,
1740 handlers, opts, opts_set,
1741 dc);
1742 break;
1744 case OPT_flto:
1745 opts->x_flag_lto = value ? "" : NULL;
1746 break;
1748 case OPT_w:
1749 dc->dc_inhibit_warnings = true;
1750 break;
1752 case OPT_fmax_errors_:
1753 dc->max_errors = value;
1754 break;
1756 case OPT_fuse_linker_plugin:
1757 /* No-op. Used by the driver and passed to us because it starts with f.*/
1758 break;
1760 default:
1761 /* If the flag was handled in a standard way, assume the lack of
1762 processing here is intentional. */
1763 gcc_assert (option_flag_var (scode, opts));
1764 break;
1767 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
1768 loc, handlers, dc);
1769 return true;
1772 /* Handle --param NAME=VALUE. */
1773 static void
1774 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
1775 location_t loc, const char *carg)
1777 char *equal, *arg;
1778 int value;
1780 arg = xstrdup (carg);
1781 equal = strchr (arg, '=');
1782 if (!equal)
1783 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
1784 arg);
1785 else
1787 value = integral_argument (equal + 1);
1788 if (value == -1)
1789 error_at (loc, "invalid --param value %qs", equal + 1);
1790 else
1792 *equal = '\0';
1793 set_param_value (arg, value,
1794 opts->x_param_values, opts_set->x_param_values);
1798 free (arg);
1801 /* Used to set the level of strict aliasing warnings in OPTS,
1802 when no level is specified (i.e., when -Wstrict-aliasing, and not
1803 -Wstrict-aliasing=level was given).
1804 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
1805 and 0 otherwise. After calling this function, wstrict_aliasing will be
1806 set to the default value of -Wstrict_aliasing=level, currently 3. */
1807 static void
1808 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
1810 gcc_assert (onoff == 0 || onoff == 1);
1811 if (onoff != 0)
1812 opts->x_warn_strict_aliasing = 3;
1813 else
1814 opts->x_warn_strict_aliasing = 0;
1817 /* The following routines are useful in setting all the flags that
1818 -ffast-math and -fno-fast-math imply. */
1819 static void
1820 set_fast_math_flags (struct gcc_options *opts, int set)
1822 if (!opts->frontend_set_flag_unsafe_math_optimizations)
1824 opts->x_flag_unsafe_math_optimizations = set;
1825 set_unsafe_math_optimizations_flags (opts, set);
1827 if (!opts->frontend_set_flag_finite_math_only)
1828 opts->x_flag_finite_math_only = set;
1829 if (!opts->frontend_set_flag_errno_math)
1830 opts->x_flag_errno_math = !set;
1831 if (set)
1833 if (!opts->frontend_set_flag_signaling_nans)
1834 opts->x_flag_signaling_nans = 0;
1835 if (!opts->frontend_set_flag_rounding_math)
1836 opts->x_flag_rounding_math = 0;
1837 if (!opts->frontend_set_flag_cx_limited_range)
1838 opts->x_flag_cx_limited_range = 1;
1842 /* When -funsafe-math-optimizations is set the following
1843 flags are set as well. */
1844 static void
1845 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
1847 if (!opts->frontend_set_flag_trapping_math)
1848 opts->x_flag_trapping_math = !set;
1849 if (!opts->frontend_set_flag_signed_zeros)
1850 opts->x_flag_signed_zeros = !set;
1851 if (!opts->frontend_set_flag_associative_math)
1852 opts->x_flag_associative_math = set;
1853 if (!opts->frontend_set_flag_reciprocal_math)
1854 opts->x_flag_reciprocal_math = set;
1857 /* Return true iff flags in OPTS are set as if -ffast-math. */
1858 bool
1859 fast_math_flags_set_p (const struct gcc_options *opts)
1861 return (!opts->x_flag_trapping_math
1862 && opts->x_flag_unsafe_math_optimizations
1863 && opts->x_flag_finite_math_only
1864 && !opts->x_flag_signed_zeros
1865 && !opts->x_flag_errno_math);
1868 /* Return true iff flags are set as if -ffast-math but using the flags stored
1869 in the struct cl_optimization structure. */
1870 bool
1871 fast_math_flags_struct_set_p (struct cl_optimization *opt)
1873 return (!opt->x_flag_trapping_math
1874 && opt->x_flag_unsafe_math_optimizations
1875 && opt->x_flag_finite_math_only
1876 && !opt->x_flag_signed_zeros
1877 && !opt->x_flag_errno_math);
1880 /* Handle a debug output -g switch for options OPTS
1881 (OPTS_SET->x_write_symbols storing whether a debug type was passed
1882 explicitly), location LOC. EXTENDED is true or false to support
1883 extended output (2 is special and means "-ggdb" was given). */
1884 static void
1885 set_debug_level (enum debug_info_type type, int extended, const char *arg,
1886 struct gcc_options *opts, struct gcc_options *opts_set,
1887 location_t loc)
1889 opts->x_use_gnu_debug_info_extensions = extended;
1891 if (type == NO_DEBUG)
1893 if (opts->x_write_symbols == NO_DEBUG)
1895 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
1897 if (extended == 2)
1899 #ifdef DWARF2_DEBUGGING_INFO
1900 opts->x_write_symbols = DWARF2_DEBUG;
1901 #elif defined DBX_DEBUGGING_INFO
1902 opts->x_write_symbols = DBX_DEBUG;
1903 #endif
1906 if (opts->x_write_symbols == NO_DEBUG)
1907 warning_at (loc, 0, "target system does not support debug output");
1910 else
1912 /* Does it conflict with an already selected type? */
1913 if (opts_set->x_write_symbols != NO_DEBUG
1914 && opts->x_write_symbols != NO_DEBUG
1915 && type != opts->x_write_symbols)
1916 error_at (loc, "debug format \"%s\" conflicts with prior selection",
1917 debug_type_names[type]);
1918 opts->x_write_symbols = type;
1919 opts_set->x_write_symbols = type;
1922 /* A debug flag without a level defaults to level 2. */
1923 if (*arg == '\0')
1925 if (!opts->x_debug_info_level)
1926 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
1928 else
1930 int argval = integral_argument (arg);
1931 if (argval == -1)
1932 error_at (loc, "unrecognised debug output level \"%s\"", arg);
1933 else if (argval > 3)
1934 error_at (loc, "debug output level %s is too high", arg);
1935 else
1936 opts->x_debug_info_level = (enum debug_info_levels) argval;
1940 /* Arrange to dump core on error for diagnostic context DC. (The
1941 regular error message is still printed first, except in the case of
1942 abort ().) */
1944 static void
1945 setup_core_dumping (diagnostic_context *dc)
1947 #ifdef SIGABRT
1948 signal (SIGABRT, SIG_DFL);
1949 #endif
1950 #if defined(HAVE_SETRLIMIT)
1952 struct rlimit rlim;
1953 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
1954 fatal_error ("getting core file size maximum limit: %m");
1955 rlim.rlim_cur = rlim.rlim_max;
1956 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
1957 fatal_error ("setting core file size limit to maximum: %m");
1959 #endif
1960 diagnostic_abort_on_error (dc);
1963 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
1964 diagnostic context DC. */
1966 static void
1967 decode_d_option (const char *arg, struct gcc_options *opts,
1968 location_t loc, diagnostic_context *dc)
1970 int c;
1972 while (*arg)
1973 switch (c = *arg++)
1975 case 'A':
1976 opts->x_flag_debug_asm = 1;
1977 break;
1978 case 'p':
1979 opts->x_flag_print_asm_name = 1;
1980 break;
1981 case 'P':
1982 opts->x_flag_dump_rtl_in_asm = 1;
1983 opts->x_flag_print_asm_name = 1;
1984 break;
1985 case 'x':
1986 opts->x_rtl_dump_and_exit = 1;
1987 break;
1988 case 'D': /* These are handled by the preprocessor. */
1989 case 'I':
1990 case 'M':
1991 case 'N':
1992 case 'U':
1993 break;
1994 case 'H':
1995 setup_core_dumping (dc);
1996 break;
1997 case 'a':
1998 opts->x_flag_dump_all_passed = true;
1999 break;
2001 default:
2002 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2003 break;
2007 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2008 mask LANG_MASK, option handlers HANDLERS) as an error for option
2009 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2010 NULL), location LOC. This is used by -Werror=. */
2012 static void
2013 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2014 const struct cl_option_handlers *handlers,
2015 struct gcc_options *opts,
2016 struct gcc_options *opts_set,
2017 location_t loc, diagnostic_context *dc)
2019 char *new_option;
2020 int option_index;
2022 new_option = XNEWVEC (char, strlen (arg) + 2);
2023 new_option[0] = 'W';
2024 strcpy (new_option + 1, arg);
2025 option_index = find_opt (new_option, lang_mask);
2026 if (option_index == OPT_SPECIAL_unknown)
2028 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2030 else
2032 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2034 control_warning_option (option_index, (int) kind, value,
2035 loc, lang_mask,
2036 handlers, opts, opts_set, dc);
2038 free (new_option);
2041 /* Return malloced memory for the name of the option OPTION_INDEX
2042 which enabled a diagnostic (context CONTEXT), originally of type
2043 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2044 as -Werror. */
2046 char *
2047 option_name (diagnostic_context *context, int option_index,
2048 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2050 if (option_index)
2052 /* A warning classified as an error. */
2053 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2054 && diag_kind == DK_ERROR)
2055 return concat (cl_options[OPT_Werror_].opt_text,
2056 /* Skip over "-W". */
2057 cl_options[option_index].opt_text + 2,
2058 NULL);
2059 /* A warning with option. */
2060 else
2061 return xstrdup (cl_options[option_index].opt_text);
2063 /* A warning without option classified as an error. */
2064 else if (orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2065 || diag_kind == DK_WARNING)
2067 if (context->warning_as_error_requested)
2068 return xstrdup (cl_options[OPT_Werror].opt_text);
2069 else
2070 return xstrdup (_("enabled by default"));
2072 else
2073 return NULL;