lto-cgraph.c (get_alias_symbol): Remove weakref sanity check.
[gcc.git] / gcc / opts.c
1 /* Command line option handling.
2 Copyright (C) 2002-2013 Free Software Foundation, Inc.
3 Contributed by Neil Booth.
4
5 This file is part of GCC.
6
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.
11
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.
16
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/>. */
20
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"
37
38 static void set_Wstrict_aliasing (struct gcc_options *opts, int onoff);
39
40 /* Indexed by enum debug_info_type. */
41 const char *const debug_type_names[] =
42 {
43 "none", "stabs", "coff", "dwarf-2", "xcoff", "vms"
44 };
45
46 /* Parse the -femit-struct-debug-detailed option value
47 and set the flag variables. */
48
49 #define MATCH( prefix, string ) \
50 ((strncmp (prefix, string, sizeof prefix - 1) == 0) \
51 ? ((string += sizeof prefix - 1), 1) : 0)
52
53 void
54 set_struct_debug_option (struct gcc_options *opts, location_t loc,
55 const char *spec)
56 {
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";
62
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;
67
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;
75
76 /* Generics or not? */
77 if (MATCH (ord_lbl, spec))
78 gen = 0;
79 else if (MATCH (gen_lbl, spec))
80 ord = 0;
81
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);
96
97 /* Effect the specification. */
98 if (usage == DINFO_USAGE_NUM_ENUMS)
99 {
100 if (ord)
101 {
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;
105 }
106 if (gen)
107 {
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;
111 }
112 }
113 else
114 {
115 if (ord)
116 opts->x_debug_struct_ordinary[usage] = files;
117 if (gen)
118 opts->x_debug_struct_generic[usage] = files;
119 }
120
121 if (*spec == ',')
122 set_struct_debug_option (opts, loc, spec+1);
123 else
124 {
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:...%>");
139 }
140 }
141
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".) */
146
147 void
148 strip_off_ending (char *name, int len)
149 {
150 int i;
151 for (i = 2; i < 6 && len > i; i++)
152 {
153 if (name[len - i] == '.')
154 {
155 name[len - i] = '\0';
156 break;
157 }
158 }
159 }
160
161 /* Find the base name of a path, stripping off both directories and
162 a single final extension. */
163 int
164 base_of_path (const char *path, const char **base_out)
165 {
166 const char *base = path;
167 const char *dot = 0;
168 const char *p = path;
169 char c = *p;
170 while (c)
171 {
172 if (IS_DIR_SEPARATOR(c))
173 {
174 base = p + 1;
175 dot = 0;
176 }
177 else if (c == '.')
178 dot = p;
179 c = *++p;
180 }
181 if (!dot)
182 dot = p;
183 *base_out = base;
184 return dot - base;
185 }
186
187 /* What to print when a switch has no documentation. */
188 static const char undocumented_msg[] = N_("This switch lacks documentation");
189
190 typedef char *char_p; /* For DEF_VEC_P. */
191
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);
211
212 /* Handle a back-end option; arguments and return value as for
213 handle_option. */
214
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)
223 {
224 gcc_assert (dc == global_dc);
225 gcc_assert (kind == DK_UNSPECIFIED);
226 return targetm_common.handle_option (opts, opts_set, decoded, loc);
227 }
228
229 /* Add comma-separated strings to a char_p vector. */
230
231 static void
232 add_comma_separated_to_vector (void **pvec, const char *arg)
233 {
234 char *tmp;
235 char *r;
236 char *w;
237 char *token_start;
238 vec<char_p> *v = (vec<char_p> *) *pvec;
239
240 vec_check_alloc (v, 1);
241
242 /* We never free this string. */
243 tmp = xstrdup (arg);
244
245 r = tmp;
246 w = tmp;
247 token_start = tmp;
248
249 while (*r != '\0')
250 {
251 if (*r == ',')
252 {
253 *w++ = '\0';
254 ++r;
255 v->safe_push (token_start);
256 token_start = w;
257 }
258 if (*r == '\\' && r[1] == ',')
259 {
260 *w++ = ',';
261 r += 2;
262 }
263 else
264 *w++ = *r++;
265 }
266 if (*token_start != '\0')
267 v->safe_push (token_start);
268
269 *pvec = v;
270 }
271
272 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
273
274 void
275 init_options_struct (struct gcc_options *opts, struct gcc_options *opts_set)
276 {
277 size_t num_params = get_num_compiler_params ();
278
279 gcc_obstack_init (&opts_obstack);
280
281 *opts = global_options_init;
282 memset (opts_set, 0, sizeof (*opts_set));
283
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);
287
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;
293
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;
297
298 /* Some targets have ABI-specified unwind tables. */
299 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
300
301 /* Some targets have other target-specific initialization. */
302 targetm_common.option_init_struct (opts);
303 }
304
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. */
309
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)
319 {
320 const struct cl_option *option = &cl_options[default_opt->opt_index];
321 bool enabled;
322
323 if (size)
324 gcc_assert (level == 2);
325 if (fast)
326 gcc_assert (level == 3);
327 if (debug)
328 gcc_assert (level == 1);
329
330 switch (default_opt->levels)
331 {
332 case OPT_LEVELS_ALL:
333 enabled = true;
334 break;
335
336 case OPT_LEVELS_0_ONLY:
337 enabled = (level == 0);
338 break;
339
340 case OPT_LEVELS_1_PLUS:
341 enabled = (level >= 1);
342 break;
343
344 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
345 enabled = (level >= 1 && !size && !debug);
346 break;
347
348 case OPT_LEVELS_1_PLUS_NOT_DEBUG:
349 enabled = (level >= 1 && !debug);
350 break;
351
352 case OPT_LEVELS_2_PLUS:
353 enabled = (level >= 2);
354 break;
355
356 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
357 enabled = (level >= 2 && !size && !debug);
358 break;
359
360 case OPT_LEVELS_3_PLUS:
361 enabled = (level >= 3);
362 break;
363
364 case OPT_LEVELS_3_PLUS_AND_SIZE:
365 enabled = (level >= 3 || size);
366 break;
367
368 case OPT_LEVELS_SIZE:
369 enabled = size;
370 break;
371
372 case OPT_LEVELS_FAST:
373 enabled = fast;
374 break;
375
376 case OPT_LEVELS_NONE:
377 default:
378 gcc_unreachable ();
379 }
380
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);
392 }
393
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. */
398
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)
408 {
409 size_t i;
410
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);
415 }
416
417 /* Table of options enabled by default at different levels. */
418
419 static const struct default_options default_options_table[] =
420 {
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 },
452
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 },
490
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 },
504
505 /* -Ofast adds optimizations to -O3. */
506 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
507
508 { OPT_LEVELS_NONE, 0, NULL, 0 }
509 };
510
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)
522 {
523 unsigned int i;
524 int opt2;
525
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++)
529 {
530 struct cl_decoded_option *opt = &decoded_options[i];
531 switch (opt->opt_index)
532 {
533 case OPT_O:
534 if (*opt->arg == '\0')
535 {
536 opts->x_optimize = 1;
537 opts->x_optimize_size = 0;
538 opts->x_optimize_fast = 0;
539 opts->x_optimize_debug = 0;
540 }
541 else
542 {
543 const int optimize_val = integral_argument (opt->arg);
544 if (optimize_val == -1)
545 error_at (loc, "argument to %<-O%> should be a non-negative "
546 "integer, %<g%>, %<s%> or %<fast%>");
547 else
548 {
549 opts->x_optimize = optimize_val;
550 if ((unsigned int) opts->x_optimize > 255)
551 opts->x_optimize = 255;
552 opts->x_optimize_size = 0;
553 opts->x_optimize_fast = 0;
554 opts->x_optimize_debug = 0;
555 }
556 }
557 break;
558
559 case OPT_Os:
560 opts->x_optimize_size = 1;
561
562 /* Optimizing for size forces optimize to be 2. */
563 opts->x_optimize = 2;
564 opts->x_optimize_fast = 0;
565 opts->x_optimize_debug = 0;
566 break;
567
568 case OPT_Ofast:
569 /* -Ofast only adds flags to -O3. */
570 opts->x_optimize_size = 0;
571 opts->x_optimize = 3;
572 opts->x_optimize_fast = 1;
573 opts->x_optimize_debug = 0;
574 break;
575
576 case OPT_Og:
577 /* -Og selects optimization level 1. */
578 opts->x_optimize_size = 0;
579 opts->x_optimize = 1;
580 opts->x_optimize_fast = 0;
581 opts->x_optimize_debug = 1;
582 break;
583
584 default:
585 /* Ignore other options in this prescan. */
586 break;
587 }
588 }
589
590 maybe_default_options (opts, opts_set, default_options_table,
591 opts->x_optimize, opts->x_optimize_size,
592 opts->x_optimize_fast, opts->x_optimize_debug,
593 lang_mask, handlers, loc, dc);
594
595 /* -O2 param settings. */
596 opt2 = (opts->x_optimize >= 2);
597
598 /* Track fields in field-sensitive alias analysis. */
599 maybe_set_param_value
600 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
601 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
602 opts->x_param_values, opts_set->x_param_values);
603
604 /* For -O1 only do loop invariant motion for very small loops. */
605 maybe_set_param_value
606 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
607 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
608 opts->x_param_values, opts_set->x_param_values);
609
610 if (opts->x_optimize_size)
611 /* We want to crossjump as much as possible. */
612 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
613 opts->x_param_values, opts_set->x_param_values);
614 else
615 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
616 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
617 opts->x_param_values, opts_set->x_param_values);
618
619 /* Allow default optimizations to be specified on a per-machine basis. */
620 maybe_default_options (opts, opts_set,
621 targetm_common.option_optimization_table,
622 opts->x_optimize, opts->x_optimize_size,
623 opts->x_optimize_fast, opts->x_optimize_debug,
624 lang_mask, handlers, loc, dc);
625 }
626
627 /* After all options at LOC have been read into OPTS and OPTS_SET,
628 finalize settings of those options and diagnose incompatible
629 combinations. */
630 void
631 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
632 location_t loc)
633 {
634 enum unwind_info_type ui_except;
635
636 if (opts->x_dump_base_name && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name))
637 {
638 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
639 OPTS->X_DUMP_DIR_NAME directory. Then try to make
640 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
641 directory, typically the directory to contain the object
642 file. */
643 if (opts->x_dump_dir_name)
644 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
645 opts->x_dump_base_name, NULL);
646 else if (opts->x_aux_base_name
647 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
648 {
649 const char *aux_base;
650
651 base_of_path (opts->x_aux_base_name, &aux_base);
652 if (opts->x_aux_base_name != aux_base)
653 {
654 int dir_len = aux_base - opts->x_aux_base_name;
655 char *new_dump_base_name
656 = XOBNEWVEC (&opts_obstack, char,
657 strlen (opts->x_dump_base_name) + dir_len + 1);
658
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;
664 }
665 }
666 }
667
668 /* Handle related options for unit-at-a-time, toplevel-reorder, and
669 section-anchors. */
670 if (!opts->x_flag_unit_at_a_time)
671 {
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;
680 }
681
682 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
683 sorry ("transactional memory is not supported with non-call exceptions");
684
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))
691 {
692 opts->x_flag_toplevel_reorder = 0;
693 opts->x_flag_section_anchors = 0;
694 }
695 if (!opts->x_flag_toplevel_reorder)
696 {
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;
701 }
702
703 if (!opts->x_flag_opts_finished)
704 {
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;
710 }
711
712 if (opts->x_optimize == 0)
713 {
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;
718 }
719
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. */
725
726 ui_except = targetm_common.except_unwind_info (opts);
727
728 if (opts->x_flag_exceptions
729 && opts->x_flag_reorder_blocks_and_partition
730 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
731 {
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;
737 }
738
739 /* If user requested unwind info, then turn off the partitioning
740 optimization. */
741
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))
746 {
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;
752 }
753
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. */
757
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))))
763 {
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;
769 }
770
771 if (opts->x_flag_reorder_blocks_and_partition
772 && !opts_set->x_flag_reorder_functions)
773 opts->x_flag_reorder_functions = 1;
774
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;
779
780 if (opts->x_flag_conserve_stack)
781 {
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);
786 }
787
788 if (opts->x_flag_lto)
789 {
790 #ifdef ENABLE_LTO
791 opts->x_flag_generate_lto = 1;
792
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.");
802 }
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)
805 {
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");
810 }
811
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)
817 {
818 if (!targetm_common.supports_split_stack (true, opts))
819 {
820 error_at (loc, "%<-fsplit-stack%> is not supported by "
821 "this compiler configuration");
822 opts->x_flag_split_stack = 0;
823 }
824 }
825
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);
831
832 /* The -gsplit-dwarf option requires -gpubnames. */
833 if (opts->x_dwarf_split_debug_info)
834 opts->x_debug_generate_pub_sections = 1;
835 }
836
837 #define LEFT_COLUMN 27
838
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)
846 {
847 unsigned int col_width = LEFT_COLUMN;
848 unsigned int remaining, room, len;
849
850 remaining = strlen (help);
851
852 do
853 {
854 room = columns - 3 - MAX (col_width, item_width);
855 if (room > columns)
856 room = 0;
857 len = remaining;
858
859 if (room < len)
860 {
861 unsigned int i;
862
863 for (i = 0; help[i]; i++)
864 {
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;
873 }
874 }
875
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;
882 }
883 while (remaining);
884 }
885
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)
894 {
895 unsigned int i;
896 const char *help;
897 bool found = false;
898 bool displayed = false;
899
900 if (include_flags == CL_PARAMS)
901 {
902 for (i = 0; i < LAST_PARAM; i++)
903 {
904 const char *param = compiler_params[i].option;
905
906 help = compiler_params[i].help;
907 if (help == NULL || *help == '\0')
908 {
909 if (exclude_flags & CL_UNDOCUMENTED)
910 continue;
911 help = undocumented_msg;
912 }
913
914 /* Get the translation. */
915 help = _(help);
916
917 wrap_help (help, param, strlen (param), columns);
918 }
919 putchar ('\n');
920 return;
921 }
922
923 if (!opts->x_help_printed)
924 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
925
926 if (!opts->x_help_enum_printed)
927 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
928
929 for (i = 0; i < cl_options_count; i++)
930 {
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;
936
937 if (include_flags == 0
938 || ((option->flags & include_flags) != include_flags))
939 {
940 if ((option->flags & any_flags) == 0)
941 continue;
942 }
943
944 /* Skip unwanted switches. */
945 if ((option->flags & exclude_flags) != 0)
946 continue;
947
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;
953
954 found = true;
955 /* Skip switches that have already been printed. */
956 if (opts->x_help_printed[i])
957 continue;
958
959 opts->x_help_printed[i] = true;
960
961 help = option->help;
962 if (help == NULL)
963 {
964 if (exclude_flags & CL_UNDOCUMENTED)
965 continue;
966 help = undocumented_msg;
967 }
968
969 /* Get the translation. */
970 help = _(help);
971
972 /* Find the gap between the name of the
973 option and its descriptive text. */
974 tab = strchr (help, '\t');
975 if (tab)
976 {
977 len = tab - help;
978 opt = help;
979 help = tab + 1;
980 }
981 else
982 {
983 opt = option->opt_text;
984 len = strlen (opt);
985 }
986
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)
990 {
991 void *flag_var = option_flag_var (i, opts);
992
993 if (len < (LEFT_COLUMN + 2))
994 strcpy (new_help, "\t\t");
995 else
996 strcpy (new_help, "\t");
997
998 if (flag_var != NULL
999 && option->var_type != CLVC_DEFER)
1000 {
1001 if (option->flags & CL_JOINED)
1002 {
1003 if (option->var_type == CLVC_STRING)
1004 {
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);
1009 }
1010 else if (option->var_type == CLVC_ENUM)
1011 {
1012 const struct cl_enum *e = &cl_enums[option->var_enum];
1013 int value;
1014 const char *arg = NULL;
1015
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);
1023 }
1024 else
1025 sprintf (new_help + strlen (new_help),
1026 "%#x", * (int *) flag_var);
1027 }
1028 else
1029 strcat (new_help, option_enabled (i, opts)
1030 ? _("[enabled]") : _("[disabled]"));
1031 }
1032
1033 help = new_help;
1034 }
1035
1036 wrap_help (help, opt, len, columns);
1037 displayed = true;
1038
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;
1042 }
1043
1044 if (! found)
1045 {
1046 unsigned int langs = include_flags & CL_LANG_ALL;
1047
1048 if (langs == 0)
1049 printf (_(" No options with the desired characteristics were found\n"));
1050 else
1051 {
1052 unsigned int i;
1053
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]);
1060 }
1061
1062 }
1063 else if (! displayed)
1064 printf (_(" All options with the desired characteristics have already been displayed\n"));
1065
1066 putchar ('\n');
1067
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++)
1073 {
1074 unsigned int j, pos;
1075
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++)
1083 {
1084 unsigned int len = strlen (cl_enums[i].values[j].arg);
1085
1086 if (pos > 4 && pos + 1 + len <= columns)
1087 {
1088 printf (" %s", cl_enums[i].values[j].arg);
1089 pos += 1 + len;
1090 }
1091 else
1092 {
1093 if (pos > 4)
1094 {
1095 printf ("\n ");
1096 pos = 4;
1097 }
1098 printf ("%s", cl_enums[i].values[j].arg);
1099 pos += len;
1100 }
1101 }
1102 printf ("\n\n");
1103 opts->x_help_enum_printed[i] = 2;
1104 }
1105 }
1106
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)
1118 {
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;
1124
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);
1128
1129 /* If we have not done so already, obtain
1130 the desired maximum width of the output. */
1131 if (opts->x_help_columns == 0)
1132 {
1133 const char *p;
1134
1135 p = getenv ("COLUMNS");
1136 if (p != NULL)
1137 {
1138 int value = atoi (p);
1139
1140 if (value > 0)
1141 opts->x_help_columns = value;
1142 }
1143
1144 if (opts->x_help_columns == 0)
1145 /* Use a reasonable default. */
1146 opts->x_help_columns = 80;
1147 }
1148
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 ++)
1151 {
1152 switch (flag & include_flags)
1153 {
1154 case 0:
1155 case CL_DRIVER:
1156 break;
1157
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;
1182 }
1183 }
1184
1185 if (description == NULL)
1186 {
1187 if (any_flags == 0)
1188 {
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
1196 {
1197 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1198 include_flags);
1199 return;
1200 }
1201 }
1202 else
1203 {
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");
1208 }
1209 }
1210
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);
1214 }
1215
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. */
1220
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)
1229 {
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;
1234
1235 gcc_assert (decoded->canonical_option_num_elements <= 2);
1236
1237 switch (code)
1238 {
1239 case OPT__param:
1240 handle_param (opts, opts_set, loc, arg);
1241 break;
1242
1243 case OPT__help:
1244 {
1245 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1246 unsigned int undoc_mask;
1247 unsigned int i;
1248
1249 if (lang_mask == CL_DRIVER)
1250 break;;
1251
1252 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1253 ? 0
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;
1268 }
1269
1270 case OPT__target_help:
1271 if (lang_mask == CL_DRIVER)
1272 break;
1273
1274 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1275 opts->x_exit_after_options = true;
1276 break;
1277
1278 case OPT__help_:
1279 {
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.:
1285
1286 --help=target,^undocumented */
1287 unsigned int exclude_flags = 0;
1288
1289 if (lang_mask == CL_DRIVER)
1290 break;
1291
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)
1298 {
1299 static const struct
1300 {
1301 const char * string;
1302 unsigned int flag;
1303 }
1304 specifics[] =
1305 {
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 }
1315 };
1316 unsigned int * pflags;
1317 const char * comma;
1318 unsigned int lang_flag, specific_flag;
1319 unsigned int len;
1320 unsigned int i;
1321
1322 if (* a == '^')
1323 {
1324 ++ a;
1325 pflags = & exclude_flags;
1326 }
1327 else
1328 pflags = & include_flags;
1329
1330 comma = strchr (a, ',');
1331 if (comma == NULL)
1332 len = strlen (a);
1333 else
1334 len = comma - a;
1335 if (len == 0)
1336 {
1337 a = comma + 1;
1338 continue;
1339 }
1340
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)
1344 {
1345 specific_flag = specifics[i].flag;
1346 break;
1347 }
1348
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)
1357 {
1358 lang_flag = 1U << i;
1359 break;
1360 }
1361
1362 if (specific_flag != 0)
1363 {
1364 if (lang_flag == 0)
1365 * pflags |= specific_flag;
1366 else
1367 {
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);
1380 }
1381 }
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);
1388
1389 if (comma == NULL)
1390 break;
1391 a = comma + 1;
1392 }
1393
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;
1399 }
1400
1401 case OPT__version:
1402 if (lang_mask == CL_DRIVER)
1403 break;
1404
1405 opts->x_exit_after_options = true;
1406 break;
1407
1408 case OPT_O:
1409 case OPT_Os:
1410 case OPT_Ofast:
1411 case OPT_Og:
1412 /* Currently handled in a prescan. */
1413 break;
1414
1415 case OPT_Werror:
1416 dc->warning_as_error_requested = value;
1417 break;
1418
1419 case OPT_Werror_:
1420 if (lang_mask == CL_DRIVER)
1421 break;
1422
1423 enable_warning_as_error (arg, value, lang_mask, handlers,
1424 opts, opts_set, loc, dc);
1425 break;
1426
1427 case OPT_Wlarger_than_:
1428 opts->x_larger_than_size = value;
1429 opts->x_warn_larger_than = value != -1;
1430 break;
1431
1432 case OPT_Wfatal_errors:
1433 dc->fatal_errors = value;
1434 break;
1435
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;
1440
1441 case OPT_Wstack_usage_:
1442 opts->x_warn_stack_usage = value;
1443 opts->x_flag_stack_usage_info = value != -1;
1444 break;
1445
1446 case OPT_Wstrict_aliasing:
1447 set_Wstrict_aliasing (opts, value);
1448 break;
1449
1450 case OPT_Wstrict_overflow:
1451 opts->x_warn_strict_overflow = (value
1452 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1453 : 0);
1454 break;
1455
1456 case OPT_Wsystem_headers:
1457 dc->dc_warn_system_headers = value;
1458 break;
1459
1460 case OPT_aux_info:
1461 opts->x_flag_gen_aux_info = 1;
1462 break;
1463
1464 case OPT_auxbase_strip:
1465 {
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);
1472 }
1473 break;
1474
1475 case OPT_d:
1476 decode_d_option (arg, opts, loc, dc);
1477 break;
1478
1479 case OPT_fcall_used_:
1480 case OPT_fcall_saved_:
1481 /* Deferred. */
1482 break;
1483
1484 case OPT_fdbg_cnt_:
1485 case OPT_fdbg_cnt_list:
1486 /* Deferred. */
1487 break;
1488
1489 case OPT_fdebug_prefix_map_:
1490 /* Deferred. */
1491 break;
1492
1493 case OPT_fdiagnostics_show_location_:
1494 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1495 break;
1496
1497 case OPT_fdiagnostics_show_caret:
1498 dc->show_caret = value;
1499 break;
1500
1501 case OPT_fdiagnostics_color_:
1502 pp_show_color (dc->printer)
1503 = colorize_init ((diagnostic_color_rule_t) value);
1504 break;
1505
1506 case OPT_fdiagnostics_show_option:
1507 dc->show_option_requested = value;
1508 break;
1509
1510 case OPT_fdump_:
1511 /* Deferred. */
1512 break;
1513
1514 case OPT_ffast_math:
1515 set_fast_math_flags (opts, value);
1516 break;
1517
1518 case OPT_funsafe_math_optimizations:
1519 set_unsafe_math_optimizations_flags (opts, value);
1520 break;
1521
1522 case OPT_ffixed_:
1523 /* Deferred. */
1524 break;
1525
1526 case OPT_finline_limit_:
1527 set_param_value ("max-inline-insns-single", value / 2,
1528 opts->x_param_values, opts_set->x_param_values);
1529 set_param_value ("max-inline-insns-auto", value / 2,
1530 opts->x_param_values, opts_set->x_param_values);
1531 break;
1532
1533 case OPT_finstrument_functions_exclude_function_list_:
1534 add_comma_separated_to_vector
1535 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1536 break;
1537
1538 case OPT_finstrument_functions_exclude_file_list_:
1539 add_comma_separated_to_vector
1540 (&opts->x_flag_instrument_functions_exclude_files, arg);
1541 break;
1542
1543 case OPT_fmessage_length_:
1544 pp_set_line_maximum_length (dc->printer, value);
1545 diagnostic_set_caret_max_width (dc, value);
1546 break;
1547
1548 case OPT_fopt_info:
1549 case OPT_fopt_info_:
1550 /* Deferred. */
1551 break;
1552
1553 case OPT_fpack_struct_:
1554 if (value <= 0 || (value & (value - 1)) || value > 16)
1555 error_at (loc,
1556 "structure alignment must be a small power of two, not %d",
1557 value);
1558 else
1559 opts->x_initial_max_fld_align = value;
1560 break;
1561
1562 case OPT_fplugin_:
1563 case OPT_fplugin_arg_:
1564 /* Deferred. */
1565 break;
1566
1567 case OPT_fprofile_use_:
1568 opts->x_profile_data_prefix = xstrdup (arg);
1569 opts->x_flag_profile_use = true;
1570 value = true;
1571 /* No break here - do -fprofile-use processing. */
1572 case OPT_fprofile_use:
1573 if (!opts_set->x_flag_branch_probabilities)
1574 opts->x_flag_branch_probabilities = value;
1575 if (!opts_set->x_flag_profile_values)
1576 opts->x_flag_profile_values = value;
1577 if (!opts_set->x_flag_unroll_loops)
1578 opts->x_flag_unroll_loops = value;
1579 if (!opts_set->x_flag_peel_loops)
1580 opts->x_flag_peel_loops = value;
1581 if (!opts_set->x_flag_tracer)
1582 opts->x_flag_tracer = value;
1583 if (!opts_set->x_flag_value_profile_transformations)
1584 opts->x_flag_value_profile_transformations = value;
1585 if (!opts_set->x_flag_inline_functions)
1586 opts->x_flag_inline_functions = value;
1587 if (!opts_set->x_flag_ipa_cp)
1588 opts->x_flag_ipa_cp = value;
1589 if (!opts_set->x_flag_ipa_cp_clone
1590 && value && opts->x_flag_ipa_cp)
1591 opts->x_flag_ipa_cp_clone = value;
1592 if (!opts_set->x_flag_predictive_commoning)
1593 opts->x_flag_predictive_commoning = value;
1594 if (!opts_set->x_flag_unswitch_loops)
1595 opts->x_flag_unswitch_loops = value;
1596 if (!opts_set->x_flag_gcse_after_reload)
1597 opts->x_flag_gcse_after_reload = value;
1598 if (!opts_set->x_flag_tree_vectorize)
1599 opts->x_flag_tree_vectorize = value;
1600 if (!opts_set->x_flag_vect_cost_model)
1601 opts->x_flag_vect_cost_model = value;
1602 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1603 opts->x_flag_tree_loop_distribute_patterns = value;
1604 break;
1605
1606 case OPT_fprofile_generate_:
1607 opts->x_profile_data_prefix = xstrdup (arg);
1608 value = true;
1609 /* No break here - do -fprofile-generate processing. */
1610 case OPT_fprofile_generate:
1611 if (!opts_set->x_profile_arc_flag)
1612 opts->x_profile_arc_flag = value;
1613 if (!opts_set->x_flag_profile_values)
1614 opts->x_flag_profile_values = value;
1615 if (!opts_set->x_flag_inline_functions)
1616 opts->x_flag_inline_functions = value;
1617 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1618 quadratic. Disable the pass until better memory representation
1619 is done. */
1620 if (!opts_set->x_flag_ipa_reference && opts->x_in_lto_p)
1621 opts->x_flag_ipa_reference = false;
1622 break;
1623
1624 case OPT_fshow_column:
1625 dc->show_column = value;
1626 break;
1627
1628 case OPT_frandom_seed:
1629 /* The real switch is -fno-random-seed. */
1630 if (value)
1631 return false;
1632 /* Deferred. */
1633 break;
1634
1635 case OPT_frandom_seed_:
1636 /* Deferred. */
1637 break;
1638
1639 case OPT_fsched_verbose_:
1640 #ifdef INSN_SCHEDULING
1641 /* Handled with Var in common.opt. */
1642 break;
1643 #else
1644 return false;
1645 #endif
1646
1647 case OPT_fsched_stalled_insns_:
1648 opts->x_flag_sched_stalled_insns = value;
1649 if (opts->x_flag_sched_stalled_insns == 0)
1650 opts->x_flag_sched_stalled_insns = -1;
1651 break;
1652
1653 case OPT_fsched_stalled_insns_dep_:
1654 opts->x_flag_sched_stalled_insns_dep = value;
1655 break;
1656
1657 case OPT_fstack_check_:
1658 if (!strcmp (arg, "no"))
1659 opts->x_flag_stack_check = NO_STACK_CHECK;
1660 else if (!strcmp (arg, "generic"))
1661 /* This is the old stack checking method. */
1662 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1663 ? FULL_BUILTIN_STACK_CHECK
1664 : GENERIC_STACK_CHECK;
1665 else if (!strcmp (arg, "specific"))
1666 /* This is the new stack checking method. */
1667 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1668 ? FULL_BUILTIN_STACK_CHECK
1669 : STACK_CHECK_STATIC_BUILTIN
1670 ? STATIC_BUILTIN_STACK_CHECK
1671 : GENERIC_STACK_CHECK;
1672 else
1673 warning_at (loc, 0, "unknown stack check parameter \"%s\"", arg);
1674 break;
1675
1676 case OPT_fstack_limit:
1677 /* The real switch is -fno-stack-limit. */
1678 if (value)
1679 return false;
1680 /* Deferred. */
1681 break;
1682
1683 case OPT_fstack_limit_register_:
1684 case OPT_fstack_limit_symbol_:
1685 /* Deferred. */
1686 break;
1687
1688 case OPT_fstack_usage:
1689 opts->x_flag_stack_usage = value;
1690 opts->x_flag_stack_usage_info = value != 0;
1691 break;
1692
1693 case OPT_ftree_vectorizer_verbose_:
1694 /* -ftree-vectorizer-verbose is deprecated. It is defined in
1695 -terms of fopt-info=N. */
1696 /* Deferred. */
1697 break;
1698
1699 case OPT_g:
1700 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
1701 loc);
1702 break;
1703
1704 case OPT_gcoff:
1705 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
1706 break;
1707
1708 case OPT_gdwarf:
1709 if (arg && strlen (arg) != 0)
1710 {
1711 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
1712 "use %<-gdwarf-%s%> for DWARF version "
1713 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
1714 break;
1715 }
1716 else
1717 value = opts->x_dwarf_version;
1718
1719 /* FALLTHRU */
1720 case OPT_gdwarf_:
1721 if (value < 2 || value > 4)
1722 error_at (loc, "dwarf version %d is not supported", value);
1723 else
1724 opts->x_dwarf_version = value;
1725 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
1726 break;
1727
1728 case OPT_gsplit_dwarf:
1729 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
1730 loc);
1731 break;
1732
1733 case OPT_ggdb:
1734 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
1735 break;
1736
1737 case OPT_gstabs:
1738 case OPT_gstabs_:
1739 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
1740 loc);
1741 break;
1742
1743 case OPT_gvms:
1744 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
1745 break;
1746
1747 case OPT_gxcoff:
1748 case OPT_gxcoff_:
1749 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
1750 loc);
1751 break;
1752
1753 case OPT_pedantic_errors:
1754 dc->pedantic_errors = 1;
1755 control_warning_option (OPT_Wpedantic, DK_ERROR, value,
1756 loc, lang_mask,
1757 handlers, opts, opts_set,
1758 dc);
1759 break;
1760
1761 case OPT_flto:
1762 opts->x_flag_lto = value ? "" : NULL;
1763 break;
1764
1765 case OPT_w:
1766 dc->dc_inhibit_warnings = true;
1767 break;
1768
1769 case OPT_fmax_errors_:
1770 dc->max_errors = value;
1771 break;
1772
1773 case OPT_fuse_ld_bfd:
1774 case OPT_fuse_ld_gold:
1775 case OPT_fuse_linker_plugin:
1776 /* No-op. Used by the driver and passed to us because it starts with f.*/
1777 break;
1778
1779 case OPT_fwrapv:
1780 if (value)
1781 opts->x_flag_trapv = 0;
1782 break;
1783
1784 case OPT_ftrapv:
1785 if (value)
1786 opts->x_flag_wrapv = 0;
1787 break;
1788
1789 default:
1790 /* If the flag was handled in a standard way, assume the lack of
1791 processing here is intentional. */
1792 gcc_assert (option_flag_var (scode, opts));
1793 break;
1794 }
1795
1796 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
1797 loc, handlers, dc);
1798 return true;
1799 }
1800
1801 /* Handle --param NAME=VALUE. */
1802 static void
1803 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
1804 location_t loc, const char *carg)
1805 {
1806 char *equal, *arg;
1807 int value;
1808
1809 arg = xstrdup (carg);
1810 equal = strchr (arg, '=');
1811 if (!equal)
1812 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
1813 arg);
1814 else
1815 {
1816 value = integral_argument (equal + 1);
1817 if (value == -1)
1818 error_at (loc, "invalid --param value %qs", equal + 1);
1819 else
1820 {
1821 *equal = '\0';
1822 set_param_value (arg, value,
1823 opts->x_param_values, opts_set->x_param_values);
1824 }
1825 }
1826
1827 free (arg);
1828 }
1829
1830 /* Used to set the level of strict aliasing warnings in OPTS,
1831 when no level is specified (i.e., when -Wstrict-aliasing, and not
1832 -Wstrict-aliasing=level was given).
1833 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
1834 and 0 otherwise. After calling this function, wstrict_aliasing will be
1835 set to the default value of -Wstrict_aliasing=level, currently 3. */
1836 static void
1837 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
1838 {
1839 gcc_assert (onoff == 0 || onoff == 1);
1840 if (onoff != 0)
1841 opts->x_warn_strict_aliasing = 3;
1842 else
1843 opts->x_warn_strict_aliasing = 0;
1844 }
1845
1846 /* The following routines are useful in setting all the flags that
1847 -ffast-math and -fno-fast-math imply. */
1848 static void
1849 set_fast_math_flags (struct gcc_options *opts, int set)
1850 {
1851 if (!opts->frontend_set_flag_unsafe_math_optimizations)
1852 {
1853 opts->x_flag_unsafe_math_optimizations = set;
1854 set_unsafe_math_optimizations_flags (opts, set);
1855 }
1856 if (!opts->frontend_set_flag_finite_math_only)
1857 opts->x_flag_finite_math_only = set;
1858 if (!opts->frontend_set_flag_errno_math)
1859 opts->x_flag_errno_math = !set;
1860 if (set)
1861 {
1862 if (!opts->frontend_set_flag_signaling_nans)
1863 opts->x_flag_signaling_nans = 0;
1864 if (!opts->frontend_set_flag_rounding_math)
1865 opts->x_flag_rounding_math = 0;
1866 if (!opts->frontend_set_flag_cx_limited_range)
1867 opts->x_flag_cx_limited_range = 1;
1868 }
1869 }
1870
1871 /* When -funsafe-math-optimizations is set the following
1872 flags are set as well. */
1873 static void
1874 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
1875 {
1876 if (!opts->frontend_set_flag_trapping_math)
1877 opts->x_flag_trapping_math = !set;
1878 if (!opts->frontend_set_flag_signed_zeros)
1879 opts->x_flag_signed_zeros = !set;
1880 if (!opts->frontend_set_flag_associative_math)
1881 opts->x_flag_associative_math = set;
1882 if (!opts->frontend_set_flag_reciprocal_math)
1883 opts->x_flag_reciprocal_math = set;
1884 }
1885
1886 /* Return true iff flags in OPTS are set as if -ffast-math. */
1887 bool
1888 fast_math_flags_set_p (const struct gcc_options *opts)
1889 {
1890 return (!opts->x_flag_trapping_math
1891 && opts->x_flag_unsafe_math_optimizations
1892 && opts->x_flag_finite_math_only
1893 && !opts->x_flag_signed_zeros
1894 && !opts->x_flag_errno_math);
1895 }
1896
1897 /* Return true iff flags are set as if -ffast-math but using the flags stored
1898 in the struct cl_optimization structure. */
1899 bool
1900 fast_math_flags_struct_set_p (struct cl_optimization *opt)
1901 {
1902 return (!opt->x_flag_trapping_math
1903 && opt->x_flag_unsafe_math_optimizations
1904 && opt->x_flag_finite_math_only
1905 && !opt->x_flag_signed_zeros
1906 && !opt->x_flag_errno_math);
1907 }
1908
1909 /* Handle a debug output -g switch for options OPTS
1910 (OPTS_SET->x_write_symbols storing whether a debug type was passed
1911 explicitly), location LOC. EXTENDED is true or false to support
1912 extended output (2 is special and means "-ggdb" was given). */
1913 static void
1914 set_debug_level (enum debug_info_type type, int extended, const char *arg,
1915 struct gcc_options *opts, struct gcc_options *opts_set,
1916 location_t loc)
1917 {
1918 opts->x_use_gnu_debug_info_extensions = extended;
1919
1920 if (type == NO_DEBUG)
1921 {
1922 if (opts->x_write_symbols == NO_DEBUG)
1923 {
1924 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
1925
1926 if (extended == 2)
1927 {
1928 #ifdef DWARF2_DEBUGGING_INFO
1929 opts->x_write_symbols = DWARF2_DEBUG;
1930 #elif defined DBX_DEBUGGING_INFO
1931 opts->x_write_symbols = DBX_DEBUG;
1932 #endif
1933 }
1934
1935 if (opts->x_write_symbols == NO_DEBUG)
1936 warning_at (loc, 0, "target system does not support debug output");
1937 }
1938 }
1939 else
1940 {
1941 /* Does it conflict with an already selected type? */
1942 if (opts_set->x_write_symbols != NO_DEBUG
1943 && opts->x_write_symbols != NO_DEBUG
1944 && type != opts->x_write_symbols)
1945 error_at (loc, "debug format \"%s\" conflicts with prior selection",
1946 debug_type_names[type]);
1947 opts->x_write_symbols = type;
1948 opts_set->x_write_symbols = type;
1949 }
1950
1951 /* A debug flag without a level defaults to level 2. */
1952 if (*arg == '\0')
1953 {
1954 if (!opts->x_debug_info_level)
1955 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
1956 }
1957 else
1958 {
1959 int argval = integral_argument (arg);
1960 if (argval == -1)
1961 error_at (loc, "unrecognised debug output level \"%s\"", arg);
1962 else if (argval > 3)
1963 error_at (loc, "debug output level %s is too high", arg);
1964 else
1965 opts->x_debug_info_level = (enum debug_info_levels) argval;
1966 }
1967 }
1968
1969 /* Arrange to dump core on error for diagnostic context DC. (The
1970 regular error message is still printed first, except in the case of
1971 abort ().) */
1972
1973 static void
1974 setup_core_dumping (diagnostic_context *dc)
1975 {
1976 #ifdef SIGABRT
1977 signal (SIGABRT, SIG_DFL);
1978 #endif
1979 #if defined(HAVE_SETRLIMIT)
1980 {
1981 struct rlimit rlim;
1982 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
1983 fatal_error ("getting core file size maximum limit: %m");
1984 rlim.rlim_cur = rlim.rlim_max;
1985 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
1986 fatal_error ("setting core file size limit to maximum: %m");
1987 }
1988 #endif
1989 diagnostic_abort_on_error (dc);
1990 }
1991
1992 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
1993 diagnostic context DC. */
1994
1995 static void
1996 decode_d_option (const char *arg, struct gcc_options *opts,
1997 location_t loc, diagnostic_context *dc)
1998 {
1999 int c;
2000
2001 while (*arg)
2002 switch (c = *arg++)
2003 {
2004 case 'A':
2005 opts->x_flag_debug_asm = 1;
2006 break;
2007 case 'p':
2008 opts->x_flag_print_asm_name = 1;
2009 break;
2010 case 'P':
2011 opts->x_flag_dump_rtl_in_asm = 1;
2012 opts->x_flag_print_asm_name = 1;
2013 break;
2014 case 'x':
2015 opts->x_rtl_dump_and_exit = 1;
2016 break;
2017 case 'D': /* These are handled by the preprocessor. */
2018 case 'I':
2019 case 'M':
2020 case 'N':
2021 case 'U':
2022 break;
2023 case 'H':
2024 setup_core_dumping (dc);
2025 break;
2026 case 'a':
2027 opts->x_flag_dump_all_passed = true;
2028 break;
2029
2030 default:
2031 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2032 break;
2033 }
2034 }
2035
2036 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2037 mask LANG_MASK, option handlers HANDLERS) as an error for option
2038 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2039 NULL), location LOC. This is used by -Werror=. */
2040
2041 static void
2042 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2043 const struct cl_option_handlers *handlers,
2044 struct gcc_options *opts,
2045 struct gcc_options *opts_set,
2046 location_t loc, diagnostic_context *dc)
2047 {
2048 char *new_option;
2049 int option_index;
2050
2051 new_option = XNEWVEC (char, strlen (arg) + 2);
2052 new_option[0] = 'W';
2053 strcpy (new_option + 1, arg);
2054 option_index = find_opt (new_option, lang_mask);
2055 if (option_index == OPT_SPECIAL_unknown)
2056 {
2057 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2058 }
2059 else
2060 {
2061 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2062
2063 control_warning_option (option_index, (int) kind, value,
2064 loc, lang_mask,
2065 handlers, opts, opts_set, dc);
2066 }
2067 free (new_option);
2068 }
2069
2070 /* Return malloced memory for the name of the option OPTION_INDEX
2071 which enabled a diagnostic (context CONTEXT), originally of type
2072 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2073 as -Werror. */
2074
2075 char *
2076 option_name (diagnostic_context *context, int option_index,
2077 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2078 {
2079 if (option_index)
2080 {
2081 /* A warning classified as an error. */
2082 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2083 && diag_kind == DK_ERROR)
2084 return concat (cl_options[OPT_Werror_].opt_text,
2085 /* Skip over "-W". */
2086 cl_options[option_index].opt_text + 2,
2087 NULL);
2088 /* A warning with option. */
2089 else
2090 return xstrdup (cl_options[option_index].opt_text);
2091 }
2092 /* A warning without option classified as an error. */
2093 else if (orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2094 || diag_kind == DK_WARNING)
2095 {
2096 if (context->warning_as_error_requested)
2097 return xstrdup (cl_options[OPT_Werror].opt_text);
2098 else
2099 return xstrdup (_("enabled by default"));
2100 }
2101 else
2102 return NULL;
2103 }