* config/rl78/mulsi3.S: Remove a few unneeded moves and branches.
[official-gcc.git] / gcc / opts.c
blob6b6652d89ca4997ef536193355e56da6d45fd5b2
1 /* Command line option handling.
2 Copyright (C) 2002-2013 Free Software Foundation, Inc.
3 Contributed by Neil Booth.
5 This file is part of GCC.
7 GCC is free software; you can redistribute it and/or modify it under
8 the terms of the GNU General Public License as published by the Free
9 Software Foundation; either version 3, or (at your option) any later
10 version.
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
15 for more details.
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING3. If not see
19 <http://www.gnu.org/licenses/>. */
21 #include "config.h"
22 #include "system.h"
23 #include "intl.h"
24 #include "coretypes.h"
25 #include "opts.h"
26 #include "options.h"
27 #include "tm.h" /* For STACK_CHECK_BUILTIN,
28 STACK_CHECK_STATIC_BUILTIN, DEFAULT_GDB_EXTENSIONS,
29 DWARF2_DEBUGGING_INFO and DBX_DEBUGGING_INFO. */
30 #include "flags.h"
31 #include "params.h"
32 #include "diagnostic.h"
33 #include "diagnostic-color.h"
34 #include "opts-diagnostic.h"
35 #include "insn-attr-common.h"
36 #include "common/common-target.h"
38 static void set_Wstrict_aliasing (struct gcc_options *opts, int onoff);
40 /* Indexed by enum debug_info_type. */
41 const char *const debug_type_names[] =
43 "none", "stabs", "coff", "dwarf-2", "xcoff", "vms"
46 /* Parse the -femit-struct-debug-detailed option value
47 and set the flag variables. */
49 #define MATCH( prefix, string ) \
50 ((strncmp (prefix, string, sizeof prefix - 1) == 0) \
51 ? ((string += sizeof prefix - 1), 1) : 0)
53 void
54 set_struct_debug_option (struct gcc_options *opts, location_t loc,
55 const char *spec)
57 /* various labels for comparison */
58 static const char dfn_lbl[] = "dfn:", dir_lbl[] = "dir:", ind_lbl[] = "ind:";
59 static const char ord_lbl[] = "ord:", gen_lbl[] = "gen:";
60 static const char none_lbl[] = "none", any_lbl[] = "any";
61 static const char base_lbl[] = "base", sys_lbl[] = "sys";
63 enum debug_struct_file files = DINFO_STRUCT_FILE_ANY;
64 /* Default is to apply to as much as possible. */
65 enum debug_info_usage usage = DINFO_USAGE_NUM_ENUMS;
66 int ord = 1, gen = 1;
68 /* What usage? */
69 if (MATCH (dfn_lbl, spec))
70 usage = DINFO_USAGE_DFN;
71 else if (MATCH (dir_lbl, spec))
72 usage = DINFO_USAGE_DIR_USE;
73 else if (MATCH (ind_lbl, spec))
74 usage = DINFO_USAGE_IND_USE;
76 /* Generics or not? */
77 if (MATCH (ord_lbl, spec))
78 gen = 0;
79 else if (MATCH (gen_lbl, spec))
80 ord = 0;
82 /* What allowable environment? */
83 if (MATCH (none_lbl, spec))
84 files = DINFO_STRUCT_FILE_NONE;
85 else if (MATCH (any_lbl, spec))
86 files = DINFO_STRUCT_FILE_ANY;
87 else if (MATCH (sys_lbl, spec))
88 files = DINFO_STRUCT_FILE_SYS;
89 else if (MATCH (base_lbl, spec))
90 files = DINFO_STRUCT_FILE_BASE;
91 else
92 error_at (loc,
93 "argument %qs to %<-femit-struct-debug-detailed%> "
94 "not recognized",
95 spec);
97 /* Effect the specification. */
98 if (usage == DINFO_USAGE_NUM_ENUMS)
100 if (ord)
102 opts->x_debug_struct_ordinary[DINFO_USAGE_DFN] = files;
103 opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE] = files;
104 opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE] = files;
106 if (gen)
108 opts->x_debug_struct_generic[DINFO_USAGE_DFN] = files;
109 opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE] = files;
110 opts->x_debug_struct_generic[DINFO_USAGE_IND_USE] = files;
113 else
115 if (ord)
116 opts->x_debug_struct_ordinary[usage] = files;
117 if (gen)
118 opts->x_debug_struct_generic[usage] = files;
121 if (*spec == ',')
122 set_struct_debug_option (opts, loc, spec+1);
123 else
125 /* No more -femit-struct-debug-detailed specifications.
126 Do final checks. */
127 if (*spec != '\0')
128 error_at (loc,
129 "argument %qs to %<-femit-struct-debug-detailed%> unknown",
130 spec);
131 if (opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE]
132 < opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE]
133 || opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE]
134 < opts->x_debug_struct_generic[DINFO_USAGE_IND_USE])
135 error_at (loc,
136 "%<-femit-struct-debug-detailed=dir:...%> must allow "
137 "at least as much as "
138 "%<-femit-struct-debug-detailed=ind:...%>");
142 /* Strip off a legitimate source ending from the input string NAME of
143 length LEN. Rather than having to know the names used by all of
144 our front ends, we strip off an ending of a period followed by
145 up to five characters. (Java uses ".class".) */
147 void
148 strip_off_ending (char *name, int len)
150 int i;
151 for (i = 2; i < 6 && len > i; i++)
153 if (name[len - i] == '.')
155 name[len - i] = '\0';
156 break;
161 /* Find the base name of a path, stripping off both directories and
162 a single final extension. */
164 base_of_path (const char *path, const char **base_out)
166 const char *base = path;
167 const char *dot = 0;
168 const char *p = path;
169 char c = *p;
170 while (c)
172 if (IS_DIR_SEPARATOR(c))
174 base = p + 1;
175 dot = 0;
177 else if (c == '.')
178 dot = p;
179 c = *++p;
181 if (!dot)
182 dot = p;
183 *base_out = base;
184 return dot - base;
187 /* What to print when a switch has no documentation. */
188 static const char undocumented_msg[] = N_("This switch lacks documentation");
190 typedef char *char_p; /* For DEF_VEC_P. */
192 static void handle_param (struct gcc_options *opts,
193 struct gcc_options *opts_set, location_t loc,
194 const char *carg);
195 static void set_debug_level (enum debug_info_type type, int extended,
196 const char *arg, struct gcc_options *opts,
197 struct gcc_options *opts_set,
198 location_t loc);
199 static void set_fast_math_flags (struct gcc_options *opts, int set);
200 static void decode_d_option (const char *arg, struct gcc_options *opts,
201 location_t loc, diagnostic_context *dc);
202 static void set_unsafe_math_optimizations_flags (struct gcc_options *opts,
203 int set);
204 static void enable_warning_as_error (const char *arg, int value,
205 unsigned int lang_mask,
206 const struct cl_option_handlers *handlers,
207 struct gcc_options *opts,
208 struct gcc_options *opts_set,
209 location_t loc,
210 diagnostic_context *dc);
212 /* Handle a back-end option; arguments and return value as for
213 handle_option. */
215 bool
216 target_handle_option (struct gcc_options *opts,
217 struct gcc_options *opts_set,
218 const struct cl_decoded_option *decoded,
219 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
220 location_t loc,
221 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
222 diagnostic_context *dc)
224 gcc_assert (dc == global_dc);
225 gcc_assert (kind == DK_UNSPECIFIED);
226 return targetm_common.handle_option (opts, opts_set, decoded, loc);
229 /* Add comma-separated strings to a char_p vector. */
231 static void
232 add_comma_separated_to_vector (void **pvec, const char *arg)
234 char *tmp;
235 char *r;
236 char *w;
237 char *token_start;
238 vec<char_p> *v = (vec<char_p> *) *pvec;
240 vec_check_alloc (v, 1);
242 /* We never free this string. */
243 tmp = xstrdup (arg);
245 r = tmp;
246 w = tmp;
247 token_start = tmp;
249 while (*r != '\0')
251 if (*r == ',')
253 *w++ = '\0';
254 ++r;
255 v->safe_push (token_start);
256 token_start = w;
258 if (*r == '\\' && r[1] == ',')
260 *w++ = ',';
261 r += 2;
263 else
264 *w++ = *r++;
266 if (*token_start != '\0')
267 v->safe_push (token_start);
269 *pvec = v;
272 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
274 void
275 init_options_struct (struct gcc_options *opts, struct gcc_options *opts_set)
277 size_t num_params = get_num_compiler_params ();
279 gcc_obstack_init (&opts_obstack);
281 *opts = global_options_init;
282 memset (opts_set, 0, sizeof (*opts_set));
284 opts->x_param_values = XNEWVEC (int, num_params);
285 opts_set->x_param_values = XCNEWVEC (int, num_params);
286 init_param_values (opts->x_param_values);
288 /* Initialize whether `char' is signed. */
289 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
290 /* Set this to a special "uninitialized" value. The actual default
291 is set after target options have been processed. */
292 opts->x_flag_short_enums = 2;
294 /* Initialize target_flags before default_options_optimization
295 so the latter can modify it. */
296 opts->x_target_flags = targetm_common.default_target_flags;
298 /* Some targets have ABI-specified unwind tables. */
299 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
301 /* Some targets have other target-specific initialization. */
302 targetm_common.option_init_struct (opts);
305 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
306 -Ofast if FAST is set, -Og if DEBUG is set), apply the option DEFAULT_OPT
307 to OPTS and OPTS_SET, diagnostic context DC, location LOC, with language
308 mask LANG_MASK and option handlers HANDLERS. */
310 static void
311 maybe_default_option (struct gcc_options *opts,
312 struct gcc_options *opts_set,
313 const struct default_options *default_opt,
314 int level, bool size, bool fast, bool debug,
315 unsigned int lang_mask,
316 const struct cl_option_handlers *handlers,
317 location_t loc,
318 diagnostic_context *dc)
320 const struct cl_option *option = &cl_options[default_opt->opt_index];
321 bool enabled;
323 if (size)
324 gcc_assert (level == 2);
325 if (fast)
326 gcc_assert (level == 3);
327 if (debug)
328 gcc_assert (level == 1);
330 switch (default_opt->levels)
332 case OPT_LEVELS_ALL:
333 enabled = true;
334 break;
336 case OPT_LEVELS_0_ONLY:
337 enabled = (level == 0);
338 break;
340 case OPT_LEVELS_1_PLUS:
341 enabled = (level >= 1);
342 break;
344 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
345 enabled = (level >= 1 && !size && !debug);
346 break;
348 case OPT_LEVELS_1_PLUS_NOT_DEBUG:
349 enabled = (level >= 1 && !debug);
350 break;
352 case OPT_LEVELS_2_PLUS:
353 enabled = (level >= 2);
354 break;
356 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
357 enabled = (level >= 2 && !size && !debug);
358 break;
360 case OPT_LEVELS_3_PLUS:
361 enabled = (level >= 3);
362 break;
364 case OPT_LEVELS_3_PLUS_AND_SIZE:
365 enabled = (level >= 3 || size);
366 break;
368 case OPT_LEVELS_SIZE:
369 enabled = size;
370 break;
372 case OPT_LEVELS_FAST:
373 enabled = fast;
374 break;
376 case OPT_LEVELS_NONE:
377 default:
378 gcc_unreachable ();
381 if (enabled)
382 handle_generated_option (opts, opts_set, default_opt->opt_index,
383 default_opt->arg, default_opt->value,
384 lang_mask, DK_UNSPECIFIED, loc,
385 handlers, dc);
386 else if (default_opt->arg == NULL
387 && !option->cl_reject_negative)
388 handle_generated_option (opts, opts_set, default_opt->opt_index,
389 default_opt->arg, !default_opt->value,
390 lang_mask, DK_UNSPECIFIED, loc,
391 handlers, dc);
394 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
395 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
396 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
397 language mask LANG_MASK and option handlers HANDLERS. */
399 static void
400 maybe_default_options (struct gcc_options *opts,
401 struct gcc_options *opts_set,
402 const struct default_options *default_opts,
403 int level, bool size, bool fast, bool debug,
404 unsigned int lang_mask,
405 const struct cl_option_handlers *handlers,
406 location_t loc,
407 diagnostic_context *dc)
409 size_t i;
411 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
412 maybe_default_option (opts, opts_set, &default_opts[i],
413 level, size, fast, debug,
414 lang_mask, handlers, loc, dc);
417 /* Table of options enabled by default at different levels. */
419 static const struct default_options default_options_table[] =
421 /* -O1 optimizations. */
422 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
423 #ifdef DELAY_SLOTS
424 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
425 #endif
426 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
427 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
428 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
429 { OPT_LEVELS_1_PLUS, OPT_fif_conversion, NULL, 1 },
430 { OPT_LEVELS_1_PLUS, OPT_fif_conversion2, NULL, 1 },
431 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
432 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
433 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
434 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
435 { OPT_LEVELS_1_PLUS, OPT_fshrink_wrap, NULL, 1 },
436 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
437 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
438 { OPT_LEVELS_1_PLUS, OPT_ftree_bit_ccp, NULL, 1 },
439 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
440 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
441 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
442 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
443 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_sra, NULL, 1 },
444 { OPT_LEVELS_1_PLUS, OPT_ftree_copyrename, NULL, 1 },
445 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
446 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
447 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
448 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
449 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
450 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
451 { OPT_LEVELS_1_PLUS, OPT_ftree_slsr, NULL, 1 },
453 /* -O2 optimizations. */
454 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
455 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
456 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
457 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
458 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
459 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
460 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
461 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
462 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
463 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
464 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
465 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
466 #ifdef INSN_SCHEDULING
467 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
468 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
469 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
470 #endif
471 { OPT_LEVELS_2_PLUS, OPT_fregmove, NULL, 1 },
472 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
473 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
474 { OPT_LEVELS_2_PLUS, OPT_freorder_blocks, NULL, 1 },
475 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
476 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
477 { OPT_LEVELS_2_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
478 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
479 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
480 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
481 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
482 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
483 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
484 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
488 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
489 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
490 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
492 /* -O3 optimizations. */
493 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
494 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
495 /* Inlining of functions reducing size is a good idea with -Os
496 regardless of them being declared inline. */
497 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
498 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
499 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
500 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
501 { OPT_LEVELS_3_PLUS, OPT_ftree_vectorize, NULL, 1 },
502 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model, NULL, 1 },
503 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
504 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
506 /* -Ofast adds optimizations to -O3. */
507 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
509 { OPT_LEVELS_NONE, 0, NULL, 0 }
512 /* Default the options in OPTS and OPTS_SET based on the optimization
513 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
514 void
515 default_options_optimization (struct gcc_options *opts,
516 struct gcc_options *opts_set,
517 struct cl_decoded_option *decoded_options,
518 unsigned int decoded_options_count,
519 location_t loc,
520 unsigned int lang_mask,
521 const struct cl_option_handlers *handlers,
522 diagnostic_context *dc)
524 unsigned int i;
525 int opt2;
527 /* Scan to see what optimization level has been specified. That will
528 determine the default value of many flags. */
529 for (i = 1; i < decoded_options_count; i++)
531 struct cl_decoded_option *opt = &decoded_options[i];
532 switch (opt->opt_index)
534 case OPT_O:
535 if (*opt->arg == '\0')
537 opts->x_optimize = 1;
538 opts->x_optimize_size = 0;
539 opts->x_optimize_fast = 0;
540 opts->x_optimize_debug = 0;
542 else
544 const int optimize_val = integral_argument (opt->arg);
545 if (optimize_val == -1)
546 error_at (loc, "argument to %<-O%> should be a non-negative "
547 "integer, %<g%>, %<s%> or %<fast%>");
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 = opts_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 = XOBNEWVEC (&opts_obstack, char,
658 strlen (opts->x_dump_base_name) + dir_len + 1);
660 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
661 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
662 /* Append existing OPTS->X_DUMP_BASE_NAME. */
663 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
664 opts->x_dump_base_name = new_dump_base_name;
669 /* Handle related options for unit-at-a-time, toplevel-reorder, and
670 section-anchors. */
671 if (!opts->x_flag_unit_at_a_time)
673 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
674 error_at (loc, "section anchors must be disabled when unit-at-a-time "
675 "is disabled");
676 opts->x_flag_section_anchors = 0;
677 if (opts->x_flag_toplevel_reorder == 1)
678 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
679 "is disabled");
680 opts->x_flag_toplevel_reorder = 0;
683 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
684 sorry ("transactional memory is not supported with non-call exceptions");
686 /* Unless the user has asked for section anchors, we disable toplevel
687 reordering at -O0 to disable transformations that might be surprising
688 to end users and to get -fno-toplevel-reorder tested. */
689 if (!opts->x_optimize
690 && opts->x_flag_toplevel_reorder == 2
691 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
693 opts->x_flag_toplevel_reorder = 0;
694 opts->x_flag_section_anchors = 0;
696 if (!opts->x_flag_toplevel_reorder)
698 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
699 error_at (loc, "section anchors must be disabled when toplevel reorder"
700 " is disabled");
701 opts->x_flag_section_anchors = 0;
704 if (!opts->x_flag_opts_finished)
706 if (opts->x_flag_pie)
707 opts->x_flag_pic = opts->x_flag_pie;
708 if (opts->x_flag_pic && !opts->x_flag_pie)
709 opts->x_flag_shlib = 1;
710 opts->x_flag_opts_finished = true;
713 if (opts->x_optimize == 0)
715 /* Inlining does not work if not optimizing,
716 so force it not to be done. */
717 opts->x_warn_inline = 0;
718 opts->x_flag_no_inline = 1;
721 /* The optimization to partition hot and cold basic blocks into separate
722 sections of the .o and executable files does not work (currently)
723 with exception handling. This is because there is no support for
724 generating unwind info. If opts->x_flag_exceptions is turned on
725 we need to turn off the partitioning optimization. */
727 ui_except = targetm_common.except_unwind_info (opts);
729 if (opts->x_flag_exceptions
730 && opts->x_flag_reorder_blocks_and_partition
731 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
733 inform (loc,
734 "-freorder-blocks-and-partition does not work "
735 "with exceptions on this architecture");
736 opts->x_flag_reorder_blocks_and_partition = 0;
737 opts->x_flag_reorder_blocks = 1;
740 /* If user requested unwind info, then turn off the partitioning
741 optimization. */
743 if (opts->x_flag_unwind_tables
744 && !targetm_common.unwind_tables_default
745 && opts->x_flag_reorder_blocks_and_partition
746 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
748 inform (loc,
749 "-freorder-blocks-and-partition does not support "
750 "unwind info on this architecture");
751 opts->x_flag_reorder_blocks_and_partition = 0;
752 opts->x_flag_reorder_blocks = 1;
755 /* If the target requested unwind info, then turn off the partitioning
756 optimization with a different message. Likewise, if the target does not
757 support named sections. */
759 if (opts->x_flag_reorder_blocks_and_partition
760 && (!targetm_common.have_named_sections
761 || (opts->x_flag_unwind_tables
762 && targetm_common.unwind_tables_default
763 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
765 inform (loc,
766 "-freorder-blocks-and-partition does not work "
767 "on this architecture");
768 opts->x_flag_reorder_blocks_and_partition = 0;
769 opts->x_flag_reorder_blocks = 1;
772 if (opts->x_flag_reorder_blocks_and_partition
773 && !opts_set->x_flag_reorder_functions)
774 opts->x_flag_reorder_functions = 1;
776 /* Pipelining of outer loops is only possible when general pipelining
777 capabilities are requested. */
778 if (!opts->x_flag_sel_sched_pipelining)
779 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
781 if (opts->x_flag_conserve_stack)
783 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
784 opts->x_param_values, opts_set->x_param_values);
785 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
786 opts->x_param_values, opts_set->x_param_values);
789 if (opts->x_flag_lto)
791 #ifdef ENABLE_LTO
792 opts->x_flag_generate_lto = 1;
794 /* When generating IL, do not operate in whole-program mode.
795 Otherwise, symbols will be privatized too early, causing link
796 errors later. */
797 opts->x_flag_whole_program = 0;
798 #else
799 error_at (loc, "LTO support has not been enabled in this configuration");
800 #endif
801 if (!opts->x_flag_fat_lto_objects && !HAVE_LTO_PLUGIN)
802 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin.");
804 if ((opts->x_flag_lto_partition_balanced != 0) + (opts->x_flag_lto_partition_1to1 != 0)
805 + (opts->x_flag_lto_partition_none != 0) >= 1)
807 if ((opts->x_flag_lto_partition_balanced != 0)
808 + (opts->x_flag_lto_partition_1to1 != 0)
809 + (opts->x_flag_lto_partition_none != 0) > 1)
810 error_at (loc, "only one -flto-partition value can be specified");
813 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
814 default value if they choose based on other options. */
815 if (opts->x_flag_split_stack == -1)
816 opts->x_flag_split_stack = 0;
817 else if (opts->x_flag_split_stack)
819 if (!targetm_common.supports_split_stack (true, opts))
821 error_at (loc, "%<-fsplit-stack%> is not supported by "
822 "this compiler configuration");
823 opts->x_flag_split_stack = 0;
827 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
828 is disabled. */
829 if (!opts->x_flag_tree_vectorize || !opts->x_flag_tree_loop_if_convert)
830 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
831 opts->x_param_values, opts_set->x_param_values);
833 /* The -gsplit-dwarf option requires -gpubnames. */
834 if (opts->x_dwarf_split_debug_info)
835 opts->x_debug_generate_pub_sections = 1;
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_fsanitize_:
1411 const char *p = arg;
1412 while (*p != 0)
1414 static const struct
1416 const char *const name;
1417 unsigned int flag;
1418 size_t len;
1419 } spec[] =
1421 { "address", SANITIZE_ADDRESS, sizeof "address" - 1 },
1422 { "thread", SANITIZE_THREAD, sizeof "thread" - 1 },
1423 { "shift", SANITIZE_SHIFT, sizeof "shift" - 1 },
1424 { "integer-divide-by-zero", SANITIZE_DIVIDE,
1425 sizeof "integer-divide-by-zero" - 1 },
1426 { "undefined", SANITIZE_UNDEFINED, sizeof "undefined" - 1 },
1427 { "unreachable", SANITIZE_UNREACHABLE,
1428 sizeof "unreachable" - 1 },
1429 { NULL, 0, 0 }
1431 const char *comma;
1432 size_t len, i;
1433 bool found = false;
1435 comma = strchr (p, ',');
1436 if (comma == NULL)
1437 len = strlen (p);
1438 else
1439 len = comma - p;
1440 if (len == 0)
1442 p = comma + 1;
1443 continue;
1446 /* Check to see if the string matches an option class name. */
1447 for (i = 0; spec[i].name != NULL; ++i)
1448 if (len == spec[i].len
1449 && memcmp (p, spec[i].name, len) == 0)
1451 /* Handle both -fsanitize and -fno-sanitize cases. */
1452 if (value)
1453 flag_sanitize |= spec[i].flag;
1454 else
1455 flag_sanitize &= ~spec[i].flag;
1456 found = true;
1457 break;
1460 if (! found)
1461 warning_at (loc, 0,
1462 "unrecognized argument to -fsanitize= option: %q.*s",
1463 (int) len, p);
1465 if (comma == NULL)
1466 break;
1467 p = comma + 1;
1470 break;
1473 case OPT_O:
1474 case OPT_Os:
1475 case OPT_Ofast:
1476 case OPT_Og:
1477 /* Currently handled in a prescan. */
1478 break;
1480 case OPT_Werror:
1481 dc->warning_as_error_requested = value;
1482 break;
1484 case OPT_Werror_:
1485 if (lang_mask == CL_DRIVER)
1486 break;
1488 enable_warning_as_error (arg, value, lang_mask, handlers,
1489 opts, opts_set, loc, dc);
1490 break;
1492 case OPT_Wlarger_than_:
1493 opts->x_larger_than_size = value;
1494 opts->x_warn_larger_than = value != -1;
1495 break;
1497 case OPT_Wfatal_errors:
1498 dc->fatal_errors = value;
1499 break;
1501 case OPT_Wframe_larger_than_:
1502 opts->x_frame_larger_than_size = value;
1503 opts->x_warn_frame_larger_than = value != -1;
1504 break;
1506 case OPT_Wstack_usage_:
1507 opts->x_warn_stack_usage = value;
1508 opts->x_flag_stack_usage_info = value != -1;
1509 break;
1511 case OPT_Wstrict_aliasing:
1512 set_Wstrict_aliasing (opts, value);
1513 break;
1515 case OPT_Wstrict_overflow:
1516 opts->x_warn_strict_overflow = (value
1517 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1518 : 0);
1519 break;
1521 case OPT_Wsystem_headers:
1522 dc->dc_warn_system_headers = value;
1523 break;
1525 case OPT_aux_info:
1526 opts->x_flag_gen_aux_info = 1;
1527 break;
1529 case OPT_auxbase_strip:
1531 char *tmp = xstrdup (arg);
1532 strip_off_ending (tmp, strlen (tmp));
1533 if (tmp[0])
1534 opts->x_aux_base_name = tmp;
1535 else
1536 free (tmp);
1538 break;
1540 case OPT_d:
1541 decode_d_option (arg, opts, loc, dc);
1542 break;
1544 case OPT_fcall_used_:
1545 case OPT_fcall_saved_:
1546 /* Deferred. */
1547 break;
1549 case OPT_fdbg_cnt_:
1550 case OPT_fdbg_cnt_list:
1551 /* Deferred. */
1552 break;
1554 case OPT_fdebug_prefix_map_:
1555 /* Deferred. */
1556 break;
1558 case OPT_fdiagnostics_show_location_:
1559 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1560 break;
1562 case OPT_fdiagnostics_show_caret:
1563 dc->show_caret = value;
1564 break;
1566 case OPT_fdiagnostics_color_:
1567 pp_show_color (dc->printer)
1568 = colorize_init ((diagnostic_color_rule_t) value);
1569 break;
1571 case OPT_fdiagnostics_show_option:
1572 dc->show_option_requested = value;
1573 break;
1575 case OPT_fdump_:
1576 /* Deferred. */
1577 break;
1579 case OPT_ffast_math:
1580 set_fast_math_flags (opts, value);
1581 break;
1583 case OPT_funsafe_math_optimizations:
1584 set_unsafe_math_optimizations_flags (opts, value);
1585 break;
1587 case OPT_ffixed_:
1588 /* Deferred. */
1589 break;
1591 case OPT_finline_limit_:
1592 set_param_value ("max-inline-insns-single", value / 2,
1593 opts->x_param_values, opts_set->x_param_values);
1594 set_param_value ("max-inline-insns-auto", value / 2,
1595 opts->x_param_values, opts_set->x_param_values);
1596 break;
1598 case OPT_finstrument_functions_exclude_function_list_:
1599 add_comma_separated_to_vector
1600 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1601 break;
1603 case OPT_finstrument_functions_exclude_file_list_:
1604 add_comma_separated_to_vector
1605 (&opts->x_flag_instrument_functions_exclude_files, arg);
1606 break;
1608 case OPT_fmessage_length_:
1609 pp_set_line_maximum_length (dc->printer, value);
1610 diagnostic_set_caret_max_width (dc, value);
1611 break;
1613 case OPT_fopt_info:
1614 case OPT_fopt_info_:
1615 /* Deferred. */
1616 break;
1618 case OPT_fpack_struct_:
1619 if (value <= 0 || (value & (value - 1)) || value > 16)
1620 error_at (loc,
1621 "structure alignment must be a small power of two, not %d",
1622 value);
1623 else
1624 opts->x_initial_max_fld_align = value;
1625 break;
1627 case OPT_fplugin_:
1628 case OPT_fplugin_arg_:
1629 /* Deferred. */
1630 break;
1632 case OPT_fprofile_use_:
1633 opts->x_profile_data_prefix = xstrdup (arg);
1634 opts->x_flag_profile_use = true;
1635 value = true;
1636 /* No break here - do -fprofile-use processing. */
1637 case OPT_fprofile_use:
1638 if (!opts_set->x_flag_branch_probabilities)
1639 opts->x_flag_branch_probabilities = value;
1640 if (!opts_set->x_flag_profile_values)
1641 opts->x_flag_profile_values = value;
1642 if (!opts_set->x_flag_unroll_loops)
1643 opts->x_flag_unroll_loops = value;
1644 if (!opts_set->x_flag_peel_loops)
1645 opts->x_flag_peel_loops = value;
1646 if (!opts_set->x_flag_tracer)
1647 opts->x_flag_tracer = value;
1648 if (!opts_set->x_flag_value_profile_transformations)
1649 opts->x_flag_value_profile_transformations = value;
1650 if (!opts_set->x_flag_inline_functions)
1651 opts->x_flag_inline_functions = value;
1652 if (!opts_set->x_flag_ipa_cp)
1653 opts->x_flag_ipa_cp = value;
1654 if (!opts_set->x_flag_ipa_cp_clone
1655 && value && opts->x_flag_ipa_cp)
1656 opts->x_flag_ipa_cp_clone = value;
1657 if (!opts_set->x_flag_predictive_commoning)
1658 opts->x_flag_predictive_commoning = value;
1659 if (!opts_set->x_flag_unswitch_loops)
1660 opts->x_flag_unswitch_loops = value;
1661 if (!opts_set->x_flag_gcse_after_reload)
1662 opts->x_flag_gcse_after_reload = value;
1663 if (!opts_set->x_flag_tree_vectorize)
1664 opts->x_flag_tree_vectorize = value;
1665 if (!opts_set->x_flag_vect_cost_model)
1666 opts->x_flag_vect_cost_model = value;
1667 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1668 opts->x_flag_tree_loop_distribute_patterns = value;
1669 /* Indirect call profiling should do all useful transformations
1670 speculative devirutalization does. */
1671 if (!opts_set->x_flag_devirtualize_speculatively
1672 && opts->x_flag_value_profile_transformations)
1673 opts->x_flag_devirtualize_speculatively = false;
1674 break;
1676 case OPT_fprofile_generate_:
1677 opts->x_profile_data_prefix = xstrdup (arg);
1678 value = true;
1679 /* No break here - do -fprofile-generate processing. */
1680 case OPT_fprofile_generate:
1681 if (!opts_set->x_profile_arc_flag)
1682 opts->x_profile_arc_flag = value;
1683 if (!opts_set->x_flag_profile_values)
1684 opts->x_flag_profile_values = value;
1685 if (!opts_set->x_flag_inline_functions)
1686 opts->x_flag_inline_functions = value;
1687 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1688 quadratic. Disable the pass until better memory representation
1689 is done. */
1690 if (!opts_set->x_flag_ipa_reference && opts->x_in_lto_p)
1691 opts->x_flag_ipa_reference = false;
1692 break;
1694 case OPT_fshow_column:
1695 dc->show_column = value;
1696 break;
1698 case OPT_frandom_seed:
1699 /* The real switch is -fno-random-seed. */
1700 if (value)
1701 return false;
1702 /* Deferred. */
1703 break;
1705 case OPT_frandom_seed_:
1706 /* Deferred. */
1707 break;
1709 case OPT_fsched_verbose_:
1710 #ifdef INSN_SCHEDULING
1711 /* Handled with Var in common.opt. */
1712 break;
1713 #else
1714 return false;
1715 #endif
1717 case OPT_fsched_stalled_insns_:
1718 opts->x_flag_sched_stalled_insns = value;
1719 if (opts->x_flag_sched_stalled_insns == 0)
1720 opts->x_flag_sched_stalled_insns = -1;
1721 break;
1723 case OPT_fsched_stalled_insns_dep_:
1724 opts->x_flag_sched_stalled_insns_dep = value;
1725 break;
1727 case OPT_fstack_check_:
1728 if (!strcmp (arg, "no"))
1729 opts->x_flag_stack_check = NO_STACK_CHECK;
1730 else if (!strcmp (arg, "generic"))
1731 /* This is the old stack checking method. */
1732 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1733 ? FULL_BUILTIN_STACK_CHECK
1734 : GENERIC_STACK_CHECK;
1735 else if (!strcmp (arg, "specific"))
1736 /* This is the new stack checking method. */
1737 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1738 ? FULL_BUILTIN_STACK_CHECK
1739 : STACK_CHECK_STATIC_BUILTIN
1740 ? STATIC_BUILTIN_STACK_CHECK
1741 : GENERIC_STACK_CHECK;
1742 else
1743 warning_at (loc, 0, "unknown stack check parameter \"%s\"", arg);
1744 break;
1746 case OPT_fstack_limit:
1747 /* The real switch is -fno-stack-limit. */
1748 if (value)
1749 return false;
1750 /* Deferred. */
1751 break;
1753 case OPT_fstack_limit_register_:
1754 case OPT_fstack_limit_symbol_:
1755 /* Deferred. */
1756 break;
1758 case OPT_fstack_usage:
1759 opts->x_flag_stack_usage = value;
1760 opts->x_flag_stack_usage_info = value != 0;
1761 break;
1763 case OPT_ftree_vectorizer_verbose_:
1764 /* -ftree-vectorizer-verbose is deprecated. It is defined in
1765 -terms of fopt-info=N. */
1766 /* Deferred. */
1767 break;
1769 case OPT_g:
1770 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
1771 loc);
1772 break;
1774 case OPT_gcoff:
1775 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
1776 break;
1778 case OPT_gdwarf:
1779 if (arg && strlen (arg) != 0)
1781 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
1782 "use %<-gdwarf-%s%> for DWARF version "
1783 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
1784 break;
1786 else
1787 value = opts->x_dwarf_version;
1789 /* FALLTHRU */
1790 case OPT_gdwarf_:
1791 if (value < 2 || value > 4)
1792 error_at (loc, "dwarf version %d is not supported", value);
1793 else
1794 opts->x_dwarf_version = value;
1795 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
1796 break;
1798 case OPT_gsplit_dwarf:
1799 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
1800 loc);
1801 break;
1803 case OPT_ggdb:
1804 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
1805 break;
1807 case OPT_gstabs:
1808 case OPT_gstabs_:
1809 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
1810 loc);
1811 break;
1813 case OPT_gvms:
1814 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
1815 break;
1817 case OPT_gxcoff:
1818 case OPT_gxcoff_:
1819 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
1820 loc);
1821 break;
1823 case OPT_pedantic_errors:
1824 dc->pedantic_errors = 1;
1825 control_warning_option (OPT_Wpedantic, DK_ERROR, value,
1826 loc, lang_mask,
1827 handlers, opts, opts_set,
1828 dc);
1829 break;
1831 case OPT_flto:
1832 opts->x_flag_lto = value ? "" : NULL;
1833 break;
1835 case OPT_w:
1836 dc->dc_inhibit_warnings = true;
1837 break;
1839 case OPT_fmax_errors_:
1840 dc->max_errors = value;
1841 break;
1843 case OPT_fuse_ld_bfd:
1844 case OPT_fuse_ld_gold:
1845 case OPT_fuse_linker_plugin:
1846 /* No-op. Used by the driver and passed to us because it starts with f.*/
1847 break;
1849 case OPT_fwrapv:
1850 if (value)
1851 opts->x_flag_trapv = 0;
1852 break;
1854 case OPT_ftrapv:
1855 if (value)
1856 opts->x_flag_wrapv = 0;
1857 break;
1859 default:
1860 /* If the flag was handled in a standard way, assume the lack of
1861 processing here is intentional. */
1862 gcc_assert (option_flag_var (scode, opts));
1863 break;
1866 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
1867 loc, handlers, dc);
1868 return true;
1871 /* Handle --param NAME=VALUE. */
1872 static void
1873 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
1874 location_t loc, const char *carg)
1876 char *equal, *arg;
1877 int value;
1879 arg = xstrdup (carg);
1880 equal = strchr (arg, '=');
1881 if (!equal)
1882 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
1883 arg);
1884 else
1886 value = integral_argument (equal + 1);
1887 if (value == -1)
1888 error_at (loc, "invalid --param value %qs", equal + 1);
1889 else
1891 *equal = '\0';
1892 set_param_value (arg, value,
1893 opts->x_param_values, opts_set->x_param_values);
1897 free (arg);
1900 /* Used to set the level of strict aliasing warnings in OPTS,
1901 when no level is specified (i.e., when -Wstrict-aliasing, and not
1902 -Wstrict-aliasing=level was given).
1903 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
1904 and 0 otherwise. After calling this function, wstrict_aliasing will be
1905 set to the default value of -Wstrict_aliasing=level, currently 3. */
1906 static void
1907 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
1909 gcc_assert (onoff == 0 || onoff == 1);
1910 if (onoff != 0)
1911 opts->x_warn_strict_aliasing = 3;
1912 else
1913 opts->x_warn_strict_aliasing = 0;
1916 /* The following routines are useful in setting all the flags that
1917 -ffast-math and -fno-fast-math imply. */
1918 static void
1919 set_fast_math_flags (struct gcc_options *opts, int set)
1921 if (!opts->frontend_set_flag_unsafe_math_optimizations)
1923 opts->x_flag_unsafe_math_optimizations = set;
1924 set_unsafe_math_optimizations_flags (opts, set);
1926 if (!opts->frontend_set_flag_finite_math_only)
1927 opts->x_flag_finite_math_only = set;
1928 if (!opts->frontend_set_flag_errno_math)
1929 opts->x_flag_errno_math = !set;
1930 if (set)
1932 if (!opts->frontend_set_flag_signaling_nans)
1933 opts->x_flag_signaling_nans = 0;
1934 if (!opts->frontend_set_flag_rounding_math)
1935 opts->x_flag_rounding_math = 0;
1936 if (!opts->frontend_set_flag_cx_limited_range)
1937 opts->x_flag_cx_limited_range = 1;
1941 /* When -funsafe-math-optimizations is set the following
1942 flags are set as well. */
1943 static void
1944 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
1946 if (!opts->frontend_set_flag_trapping_math)
1947 opts->x_flag_trapping_math = !set;
1948 if (!opts->frontend_set_flag_signed_zeros)
1949 opts->x_flag_signed_zeros = !set;
1950 if (!opts->frontend_set_flag_associative_math)
1951 opts->x_flag_associative_math = set;
1952 if (!opts->frontend_set_flag_reciprocal_math)
1953 opts->x_flag_reciprocal_math = set;
1956 /* Return true iff flags in OPTS are set as if -ffast-math. */
1957 bool
1958 fast_math_flags_set_p (const struct gcc_options *opts)
1960 return (!opts->x_flag_trapping_math
1961 && opts->x_flag_unsafe_math_optimizations
1962 && opts->x_flag_finite_math_only
1963 && !opts->x_flag_signed_zeros
1964 && !opts->x_flag_errno_math);
1967 /* Return true iff flags are set as if -ffast-math but using the flags stored
1968 in the struct cl_optimization structure. */
1969 bool
1970 fast_math_flags_struct_set_p (struct cl_optimization *opt)
1972 return (!opt->x_flag_trapping_math
1973 && opt->x_flag_unsafe_math_optimizations
1974 && opt->x_flag_finite_math_only
1975 && !opt->x_flag_signed_zeros
1976 && !opt->x_flag_errno_math);
1979 /* Handle a debug output -g switch for options OPTS
1980 (OPTS_SET->x_write_symbols storing whether a debug type was passed
1981 explicitly), location LOC. EXTENDED is true or false to support
1982 extended output (2 is special and means "-ggdb" was given). */
1983 static void
1984 set_debug_level (enum debug_info_type type, int extended, const char *arg,
1985 struct gcc_options *opts, struct gcc_options *opts_set,
1986 location_t loc)
1988 opts->x_use_gnu_debug_info_extensions = extended;
1990 if (type == NO_DEBUG)
1992 if (opts->x_write_symbols == NO_DEBUG)
1994 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
1996 if (extended == 2)
1998 #ifdef DWARF2_DEBUGGING_INFO
1999 opts->x_write_symbols = DWARF2_DEBUG;
2000 #elif defined DBX_DEBUGGING_INFO
2001 opts->x_write_symbols = DBX_DEBUG;
2002 #endif
2005 if (opts->x_write_symbols == NO_DEBUG)
2006 warning_at (loc, 0, "target system does not support debug output");
2009 else
2011 /* Does it conflict with an already selected type? */
2012 if (opts_set->x_write_symbols != NO_DEBUG
2013 && opts->x_write_symbols != NO_DEBUG
2014 && type != opts->x_write_symbols)
2015 error_at (loc, "debug format \"%s\" conflicts with prior selection",
2016 debug_type_names[type]);
2017 opts->x_write_symbols = type;
2018 opts_set->x_write_symbols = type;
2021 /* A debug flag without a level defaults to level 2. */
2022 if (*arg == '\0')
2024 if (!opts->x_debug_info_level)
2025 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2027 else
2029 int argval = integral_argument (arg);
2030 if (argval == -1)
2031 error_at (loc, "unrecognised debug output level \"%s\"", arg);
2032 else if (argval > 3)
2033 error_at (loc, "debug output level %s is too high", arg);
2034 else
2035 opts->x_debug_info_level = (enum debug_info_levels) argval;
2039 /* Arrange to dump core on error for diagnostic context DC. (The
2040 regular error message is still printed first, except in the case of
2041 abort ().) */
2043 static void
2044 setup_core_dumping (diagnostic_context *dc)
2046 #ifdef SIGABRT
2047 signal (SIGABRT, SIG_DFL);
2048 #endif
2049 #if defined(HAVE_SETRLIMIT)
2051 struct rlimit rlim;
2052 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2053 fatal_error ("getting core file size maximum limit: %m");
2054 rlim.rlim_cur = rlim.rlim_max;
2055 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2056 fatal_error ("setting core file size limit to maximum: %m");
2058 #endif
2059 diagnostic_abort_on_error (dc);
2062 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2063 diagnostic context DC. */
2065 static void
2066 decode_d_option (const char *arg, struct gcc_options *opts,
2067 location_t loc, diagnostic_context *dc)
2069 int c;
2071 while (*arg)
2072 switch (c = *arg++)
2074 case 'A':
2075 opts->x_flag_debug_asm = 1;
2076 break;
2077 case 'p':
2078 opts->x_flag_print_asm_name = 1;
2079 break;
2080 case 'P':
2081 opts->x_flag_dump_rtl_in_asm = 1;
2082 opts->x_flag_print_asm_name = 1;
2083 break;
2084 case 'x':
2085 opts->x_rtl_dump_and_exit = 1;
2086 break;
2087 case 'D': /* These are handled by the preprocessor. */
2088 case 'I':
2089 case 'M':
2090 case 'N':
2091 case 'U':
2092 break;
2093 case 'H':
2094 setup_core_dumping (dc);
2095 break;
2096 case 'a':
2097 opts->x_flag_dump_all_passed = true;
2098 break;
2100 default:
2101 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2102 break;
2106 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2107 mask LANG_MASK, option handlers HANDLERS) as an error for option
2108 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2109 NULL), location LOC. This is used by -Werror=. */
2111 static void
2112 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2113 const struct cl_option_handlers *handlers,
2114 struct gcc_options *opts,
2115 struct gcc_options *opts_set,
2116 location_t loc, diagnostic_context *dc)
2118 char *new_option;
2119 int option_index;
2121 new_option = XNEWVEC (char, strlen (arg) + 2);
2122 new_option[0] = 'W';
2123 strcpy (new_option + 1, arg);
2124 option_index = find_opt (new_option, lang_mask);
2125 if (option_index == OPT_SPECIAL_unknown)
2127 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2129 else
2131 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2133 control_warning_option (option_index, (int) kind, value,
2134 loc, lang_mask,
2135 handlers, opts, opts_set, dc);
2137 free (new_option);
2140 /* Return malloced memory for the name of the option OPTION_INDEX
2141 which enabled a diagnostic (context CONTEXT), originally of type
2142 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2143 as -Werror. */
2145 char *
2146 option_name (diagnostic_context *context, int option_index,
2147 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2149 if (option_index)
2151 /* A warning classified as an error. */
2152 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2153 && diag_kind == DK_ERROR)
2154 return concat (cl_options[OPT_Werror_].opt_text,
2155 /* Skip over "-W". */
2156 cl_options[option_index].opt_text + 2,
2157 NULL);
2158 /* A warning with option. */
2159 else
2160 return xstrdup (cl_options[option_index].opt_text);
2162 /* A warning without option classified as an error. */
2163 else if (orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2164 || diag_kind == DK_WARNING)
2166 if (context->warning_as_error_requested)
2167 return xstrdup (cl_options[OPT_Werror].opt_text);
2168 else
2169 return xstrdup (_("enabled by default"));
2171 else
2172 return NULL;