rs6000.c (rs6000_expand_vector_set): Adjust for little endian.
[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
283 if (opts_set)
284 memset (opts_set, 0, sizeof (*opts_set));
285
286 opts->x_param_values = XNEWVEC (int, num_params);
287
288 if (opts_set)
289 opts_set->x_param_values = XCNEWVEC (int, num_params);
290
291 init_param_values (opts->x_param_values);
292
293 /* Initialize whether `char' is signed. */
294 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
295 /* Set this to a special "uninitialized" value. The actual default
296 is set after target options have been processed. */
297 opts->x_flag_short_enums = 2;
298
299 /* Initialize target_flags before default_options_optimization
300 so the latter can modify it. */
301 opts->x_target_flags = targetm_common.default_target_flags;
302
303 /* Some targets have ABI-specified unwind tables. */
304 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
305
306 /* Some targets have other target-specific initialization. */
307 targetm_common.option_init_struct (opts);
308 }
309
310 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
311 -Ofast if FAST is set, -Og if DEBUG is set), apply the option DEFAULT_OPT
312 to OPTS and OPTS_SET, diagnostic context DC, location LOC, with language
313 mask LANG_MASK and option handlers HANDLERS. */
314
315 static void
316 maybe_default_option (struct gcc_options *opts,
317 struct gcc_options *opts_set,
318 const struct default_options *default_opt,
319 int level, bool size, bool fast, bool debug,
320 unsigned int lang_mask,
321 const struct cl_option_handlers *handlers,
322 location_t loc,
323 diagnostic_context *dc)
324 {
325 const struct cl_option *option = &cl_options[default_opt->opt_index];
326 bool enabled;
327
328 if (size)
329 gcc_assert (level == 2);
330 if (fast)
331 gcc_assert (level == 3);
332 if (debug)
333 gcc_assert (level == 1);
334
335 switch (default_opt->levels)
336 {
337 case OPT_LEVELS_ALL:
338 enabled = true;
339 break;
340
341 case OPT_LEVELS_0_ONLY:
342 enabled = (level == 0);
343 break;
344
345 case OPT_LEVELS_1_PLUS:
346 enabled = (level >= 1);
347 break;
348
349 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
350 enabled = (level >= 1 && !size && !debug);
351 break;
352
353 case OPT_LEVELS_1_PLUS_NOT_DEBUG:
354 enabled = (level >= 1 && !debug);
355 break;
356
357 case OPT_LEVELS_2_PLUS:
358 enabled = (level >= 2);
359 break;
360
361 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
362 enabled = (level >= 2 && !size && !debug);
363 break;
364
365 case OPT_LEVELS_3_PLUS:
366 enabled = (level >= 3);
367 break;
368
369 case OPT_LEVELS_3_PLUS_AND_SIZE:
370 enabled = (level >= 3 || size);
371 break;
372
373 case OPT_LEVELS_SIZE:
374 enabled = size;
375 break;
376
377 case OPT_LEVELS_FAST:
378 enabled = fast;
379 break;
380
381 case OPT_LEVELS_NONE:
382 default:
383 gcc_unreachable ();
384 }
385
386 if (enabled)
387 handle_generated_option (opts, opts_set, default_opt->opt_index,
388 default_opt->arg, default_opt->value,
389 lang_mask, DK_UNSPECIFIED, loc,
390 handlers, dc);
391 else if (default_opt->arg == NULL
392 && !option->cl_reject_negative)
393 handle_generated_option (opts, opts_set, default_opt->opt_index,
394 default_opt->arg, !default_opt->value,
395 lang_mask, DK_UNSPECIFIED, loc,
396 handlers, dc);
397 }
398
399 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
400 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
401 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
402 language mask LANG_MASK and option handlers HANDLERS. */
403
404 static void
405 maybe_default_options (struct gcc_options *opts,
406 struct gcc_options *opts_set,
407 const struct default_options *default_opts,
408 int level, bool size, bool fast, bool debug,
409 unsigned int lang_mask,
410 const struct cl_option_handlers *handlers,
411 location_t loc,
412 diagnostic_context *dc)
413 {
414 size_t i;
415
416 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
417 maybe_default_option (opts, opts_set, &default_opts[i],
418 level, size, fast, debug,
419 lang_mask, handlers, loc, dc);
420 }
421
422 /* Table of options enabled by default at different levels. */
423
424 static const struct default_options default_options_table[] =
425 {
426 /* -O1 optimizations. */
427 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
428 #ifdef DELAY_SLOTS
429 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
430 #endif
431 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
432 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
433 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
434 { OPT_LEVELS_1_PLUS, OPT_fif_conversion, NULL, 1 },
435 { OPT_LEVELS_1_PLUS, OPT_fif_conversion2, NULL, 1 },
436 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
437 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
438 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
439 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
440 { OPT_LEVELS_1_PLUS, OPT_fshrink_wrap, NULL, 1 },
441 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
442 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
443 { OPT_LEVELS_1_PLUS, OPT_ftree_bit_ccp, NULL, 1 },
444 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
445 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
446 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
447 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
448 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_sra, NULL, 1 },
449 { OPT_LEVELS_1_PLUS, OPT_ftree_copyrename, NULL, 1 },
450 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
451 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
452 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
453 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
454 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
455 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
456 { OPT_LEVELS_1_PLUS, OPT_ftree_slsr, NULL, 1 },
457
458 /* -O2 optimizations. */
459 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
460 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
461 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
462 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
463 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
464 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
465 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
466 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
467 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
468 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
469 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
470 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
471 #ifdef INSN_SCHEDULING
472 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
473 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
474 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
475 #endif
476 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
477 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
478 { OPT_LEVELS_2_PLUS, OPT_freorder_blocks, NULL, 1 },
479 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
480 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
481 { OPT_LEVELS_2_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
482 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
483 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
484 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
488 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
489 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
490 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
491 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
492 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
493 { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
494 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
495 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
496
497 /* -O3 optimizations. */
498 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
499 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
500 /* Inlining of functions reducing size is a good idea with -Os
501 regardless of them being declared inline. */
502 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
503 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
504 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
505 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
506 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
507 { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
508 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
509 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
510 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
511
512 /* -Ofast adds optimizations to -O3. */
513 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
514
515 { OPT_LEVELS_NONE, 0, NULL, 0 }
516 };
517
518 /* Default the options in OPTS and OPTS_SET based on the optimization
519 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
520 void
521 default_options_optimization (struct gcc_options *opts,
522 struct gcc_options *opts_set,
523 struct cl_decoded_option *decoded_options,
524 unsigned int decoded_options_count,
525 location_t loc,
526 unsigned int lang_mask,
527 const struct cl_option_handlers *handlers,
528 diagnostic_context *dc)
529 {
530 unsigned int i;
531 int opt2;
532
533 /* Scan to see what optimization level has been specified. That will
534 determine the default value of many flags. */
535 for (i = 1; i < decoded_options_count; i++)
536 {
537 struct cl_decoded_option *opt = &decoded_options[i];
538 switch (opt->opt_index)
539 {
540 case OPT_O:
541 if (*opt->arg == '\0')
542 {
543 opts->x_optimize = 1;
544 opts->x_optimize_size = 0;
545 opts->x_optimize_fast = 0;
546 opts->x_optimize_debug = 0;
547 }
548 else
549 {
550 const int optimize_val = integral_argument (opt->arg);
551 if (optimize_val == -1)
552 error_at (loc, "argument to %<-O%> should be a non-negative "
553 "integer, %<g%>, %<s%> or %<fast%>");
554 else
555 {
556 opts->x_optimize = optimize_val;
557 if ((unsigned int) opts->x_optimize > 255)
558 opts->x_optimize = 255;
559 opts->x_optimize_size = 0;
560 opts->x_optimize_fast = 0;
561 opts->x_optimize_debug = 0;
562 }
563 }
564 break;
565
566 case OPT_Os:
567 opts->x_optimize_size = 1;
568
569 /* Optimizing for size forces optimize to be 2. */
570 opts->x_optimize = 2;
571 opts->x_optimize_fast = 0;
572 opts->x_optimize_debug = 0;
573 break;
574
575 case OPT_Ofast:
576 /* -Ofast only adds flags to -O3. */
577 opts->x_optimize_size = 0;
578 opts->x_optimize = 3;
579 opts->x_optimize_fast = 1;
580 opts->x_optimize_debug = 0;
581 break;
582
583 case OPT_Og:
584 /* -Og selects optimization level 1. */
585 opts->x_optimize_size = 0;
586 opts->x_optimize = 1;
587 opts->x_optimize_fast = 0;
588 opts->x_optimize_debug = 1;
589 break;
590
591 default:
592 /* Ignore other options in this prescan. */
593 break;
594 }
595 }
596
597 maybe_default_options (opts, opts_set, default_options_table,
598 opts->x_optimize, opts->x_optimize_size,
599 opts->x_optimize_fast, opts->x_optimize_debug,
600 lang_mask, handlers, loc, dc);
601
602 /* -O2 param settings. */
603 opt2 = (opts->x_optimize >= 2);
604
605 /* Track fields in field-sensitive alias analysis. */
606 maybe_set_param_value
607 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
608 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
609 opts->x_param_values, opts_set->x_param_values);
610
611 /* For -O1 only do loop invariant motion for very small loops. */
612 maybe_set_param_value
613 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
614 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
615 opts->x_param_values, opts_set->x_param_values);
616
617 if (opts->x_optimize_size)
618 /* We want to crossjump as much as possible. */
619 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
620 opts->x_param_values, opts_set->x_param_values);
621 else
622 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
623 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
624 opts->x_param_values, opts_set->x_param_values);
625
626 /* Allow default optimizations to be specified on a per-machine basis. */
627 maybe_default_options (opts, opts_set,
628 targetm_common.option_optimization_table,
629 opts->x_optimize, opts->x_optimize_size,
630 opts->x_optimize_fast, opts->x_optimize_debug,
631 lang_mask, handlers, loc, dc);
632 }
633
634 /* After all options at LOC have been read into OPTS and OPTS_SET,
635 finalize settings of those options and diagnose incompatible
636 combinations. */
637 void
638 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
639 location_t loc)
640 {
641 enum unwind_info_type ui_except;
642
643 if (opts->x_dump_base_name && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name))
644 {
645 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
646 OPTS->X_DUMP_DIR_NAME directory. Then try to make
647 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
648 directory, typically the directory to contain the object
649 file. */
650 if (opts->x_dump_dir_name)
651 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
652 opts->x_dump_base_name, NULL);
653 else if (opts->x_aux_base_name
654 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
655 {
656 const char *aux_base;
657
658 base_of_path (opts->x_aux_base_name, &aux_base);
659 if (opts->x_aux_base_name != aux_base)
660 {
661 int dir_len = aux_base - opts->x_aux_base_name;
662 char *new_dump_base_name
663 = XOBNEWVEC (&opts_obstack, char,
664 strlen (opts->x_dump_base_name) + dir_len + 1);
665
666 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
667 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
668 /* Append existing OPTS->X_DUMP_BASE_NAME. */
669 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
670 opts->x_dump_base_name = new_dump_base_name;
671 }
672 }
673 }
674
675 /* Handle related options for unit-at-a-time, toplevel-reorder, and
676 section-anchors. */
677 if (!opts->x_flag_unit_at_a_time)
678 {
679 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
680 error_at (loc, "section anchors must be disabled when unit-at-a-time "
681 "is disabled");
682 opts->x_flag_section_anchors = 0;
683 if (opts->x_flag_toplevel_reorder == 1)
684 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
685 "is disabled");
686 opts->x_flag_toplevel_reorder = 0;
687 }
688
689 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
690 sorry ("transactional memory is not supported with non-call exceptions");
691
692 /* Unless the user has asked for section anchors, we disable toplevel
693 reordering at -O0 to disable transformations that might be surprising
694 to end users and to get -fno-toplevel-reorder tested. */
695 if (!opts->x_optimize
696 && opts->x_flag_toplevel_reorder == 2
697 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
698 {
699 opts->x_flag_toplevel_reorder = 0;
700 opts->x_flag_section_anchors = 0;
701 }
702 if (!opts->x_flag_toplevel_reorder)
703 {
704 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
705 error_at (loc, "section anchors must be disabled when toplevel reorder"
706 " is disabled");
707 opts->x_flag_section_anchors = 0;
708 }
709
710 if (!opts->x_flag_opts_finished)
711 {
712 if (opts->x_flag_pie)
713 opts->x_flag_pic = opts->x_flag_pie;
714 if (opts->x_flag_pic && !opts->x_flag_pie)
715 opts->x_flag_shlib = 1;
716 opts->x_flag_opts_finished = true;
717 }
718
719 if (opts->x_optimize == 0)
720 {
721 /* Inlining does not work if not optimizing,
722 so force it not to be done. */
723 opts->x_warn_inline = 0;
724 opts->x_flag_no_inline = 1;
725 }
726
727 /* The optimization to partition hot and cold basic blocks into separate
728 sections of the .o and executable files does not work (currently)
729 with exception handling. This is because there is no support for
730 generating unwind info. If opts->x_flag_exceptions is turned on
731 we need to turn off the partitioning optimization. */
732
733 ui_except = targetm_common.except_unwind_info (opts);
734
735 if (opts->x_flag_exceptions
736 && opts->x_flag_reorder_blocks_and_partition
737 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
738 {
739 inform (loc,
740 "-freorder-blocks-and-partition does not work "
741 "with exceptions on this architecture");
742 opts->x_flag_reorder_blocks_and_partition = 0;
743 opts->x_flag_reorder_blocks = 1;
744 }
745
746 /* If user requested unwind info, then turn off the partitioning
747 optimization. */
748
749 if (opts->x_flag_unwind_tables
750 && !targetm_common.unwind_tables_default
751 && opts->x_flag_reorder_blocks_and_partition
752 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
753 {
754 inform (loc,
755 "-freorder-blocks-and-partition does not support "
756 "unwind info on this architecture");
757 opts->x_flag_reorder_blocks_and_partition = 0;
758 opts->x_flag_reorder_blocks = 1;
759 }
760
761 /* If the target requested unwind info, then turn off the partitioning
762 optimization with a different message. Likewise, if the target does not
763 support named sections. */
764
765 if (opts->x_flag_reorder_blocks_and_partition
766 && (!targetm_common.have_named_sections
767 || (opts->x_flag_unwind_tables
768 && targetm_common.unwind_tables_default
769 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
770 {
771 inform (loc,
772 "-freorder-blocks-and-partition does not work "
773 "on this architecture");
774 opts->x_flag_reorder_blocks_and_partition = 0;
775 opts->x_flag_reorder_blocks = 1;
776 }
777
778 if (opts->x_flag_reorder_blocks_and_partition
779 && !opts_set->x_flag_reorder_functions)
780 opts->x_flag_reorder_functions = 1;
781
782 /* Pipelining of outer loops is only possible when general pipelining
783 capabilities are requested. */
784 if (!opts->x_flag_sel_sched_pipelining)
785 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
786
787 if (opts->x_flag_conserve_stack)
788 {
789 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
790 opts->x_param_values, opts_set->x_param_values);
791 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
792 opts->x_param_values, opts_set->x_param_values);
793 }
794
795 if (opts->x_flag_lto)
796 {
797 #ifdef ENABLE_LTO
798 opts->x_flag_generate_lto = 1;
799
800 /* When generating IL, do not operate in whole-program mode.
801 Otherwise, symbols will be privatized too early, causing link
802 errors later. */
803 opts->x_flag_whole_program = 0;
804 #else
805 error_at (loc, "LTO support has not been enabled in this configuration");
806 #endif
807 if (!opts->x_flag_fat_lto_objects && !HAVE_LTO_PLUGIN)
808 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin.");
809 }
810 if ((opts->x_flag_lto_partition_balanced != 0) + (opts->x_flag_lto_partition_1to1 != 0)
811 + (opts->x_flag_lto_partition_none != 0) >= 1)
812 {
813 if ((opts->x_flag_lto_partition_balanced != 0)
814 + (opts->x_flag_lto_partition_1to1 != 0)
815 + (opts->x_flag_lto_partition_none != 0) > 1)
816 error_at (loc, "only one -flto-partition value can be specified");
817 }
818
819 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
820 default value if they choose based on other options. */
821 if (opts->x_flag_split_stack == -1)
822 opts->x_flag_split_stack = 0;
823 else if (opts->x_flag_split_stack)
824 {
825 if (!targetm_common.supports_split_stack (true, opts))
826 {
827 error_at (loc, "%<-fsplit-stack%> is not supported by "
828 "this compiler configuration");
829 opts->x_flag_split_stack = 0;
830 }
831 }
832
833 /* Tune vectorization related parametees according to cost model. */
834 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
835 {
836 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
837 6, opts->x_param_values, opts_set->x_param_values);
838 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
839 0, opts->x_param_values, opts_set->x_param_values);
840 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
841 0, opts->x_param_values, opts_set->x_param_values);
842 }
843
844 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
845 is disabled. */
846 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
847 || !opts->x_flag_tree_loop_if_convert)
848 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
849 opts->x_param_values, opts_set->x_param_values);
850
851 /* The -gsplit-dwarf option requires -gpubnames. */
852 if (opts->x_dwarf_split_debug_info)
853 opts->x_debug_generate_pub_sections = 1;
854 }
855
856 #define LEFT_COLUMN 27
857
858 /* Output ITEM, of length ITEM_WIDTH, in the left column,
859 followed by word-wrapped HELP in a second column. */
860 static void
861 wrap_help (const char *help,
862 const char *item,
863 unsigned int item_width,
864 unsigned int columns)
865 {
866 unsigned int col_width = LEFT_COLUMN;
867 unsigned int remaining, room, len;
868
869 remaining = strlen (help);
870
871 do
872 {
873 room = columns - 3 - MAX (col_width, item_width);
874 if (room > columns)
875 room = 0;
876 len = remaining;
877
878 if (room < len)
879 {
880 unsigned int i;
881
882 for (i = 0; help[i]; i++)
883 {
884 if (i >= room && len != remaining)
885 break;
886 if (help[i] == ' ')
887 len = i;
888 else if ((help[i] == '-' || help[i] == '/')
889 && help[i + 1] != ' '
890 && i > 0 && ISALPHA (help[i - 1]))
891 len = i + 1;
892 }
893 }
894
895 printf (" %-*.*s %.*s\n", col_width, item_width, item, len, help);
896 item_width = 0;
897 while (help[len] == ' ')
898 len++;
899 help += len;
900 remaining -= len;
901 }
902 while (remaining);
903 }
904
905 /* Print help for a specific front-end, etc. */
906 static void
907 print_filtered_help (unsigned int include_flags,
908 unsigned int exclude_flags,
909 unsigned int any_flags,
910 unsigned int columns,
911 struct gcc_options *opts,
912 unsigned int lang_mask)
913 {
914 unsigned int i;
915 const char *help;
916 bool found = false;
917 bool displayed = false;
918
919 if (include_flags == CL_PARAMS)
920 {
921 for (i = 0; i < LAST_PARAM; i++)
922 {
923 const char *param = compiler_params[i].option;
924
925 help = compiler_params[i].help;
926 if (help == NULL || *help == '\0')
927 {
928 if (exclude_flags & CL_UNDOCUMENTED)
929 continue;
930 help = undocumented_msg;
931 }
932
933 /* Get the translation. */
934 help = _(help);
935
936 wrap_help (help, param, strlen (param), columns);
937 }
938 putchar ('\n');
939 return;
940 }
941
942 if (!opts->x_help_printed)
943 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
944
945 if (!opts->x_help_enum_printed)
946 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
947
948 for (i = 0; i < cl_options_count; i++)
949 {
950 char new_help[128];
951 const struct cl_option *option = cl_options + i;
952 unsigned int len;
953 const char *opt;
954 const char *tab;
955
956 if (include_flags == 0
957 || ((option->flags & include_flags) != include_flags))
958 {
959 if ((option->flags & any_flags) == 0)
960 continue;
961 }
962
963 /* Skip unwanted switches. */
964 if ((option->flags & exclude_flags) != 0)
965 continue;
966
967 /* The driver currently prints its own help text. */
968 if ((option->flags & CL_DRIVER) != 0
969 && (option->flags & (((1U << cl_lang_count) - 1)
970 | CL_COMMON | CL_TARGET)) == 0)
971 continue;
972
973 found = true;
974 /* Skip switches that have already been printed. */
975 if (opts->x_help_printed[i])
976 continue;
977
978 opts->x_help_printed[i] = true;
979
980 help = option->help;
981 if (help == NULL)
982 {
983 if (exclude_flags & CL_UNDOCUMENTED)
984 continue;
985 help = undocumented_msg;
986 }
987
988 /* Get the translation. */
989 help = _(help);
990
991 /* Find the gap between the name of the
992 option and its descriptive text. */
993 tab = strchr (help, '\t');
994 if (tab)
995 {
996 len = tab - help;
997 opt = help;
998 help = tab + 1;
999 }
1000 else
1001 {
1002 opt = option->opt_text;
1003 len = strlen (opt);
1004 }
1005
1006 /* With the -Q option enabled we change the descriptive text associated
1007 with an option to be an indication of its current setting. */
1008 if (!opts->x_quiet_flag)
1009 {
1010 void *flag_var = option_flag_var (i, opts);
1011
1012 if (len < (LEFT_COLUMN + 2))
1013 strcpy (new_help, "\t\t");
1014 else
1015 strcpy (new_help, "\t");
1016
1017 if (flag_var != NULL
1018 && option->var_type != CLVC_DEFER)
1019 {
1020 if (option->flags & CL_JOINED)
1021 {
1022 if (option->var_type == CLVC_STRING)
1023 {
1024 if (* (const char **) flag_var != NULL)
1025 snprintf (new_help + strlen (new_help),
1026 sizeof (new_help) - strlen (new_help),
1027 * (const char **) flag_var);
1028 }
1029 else if (option->var_type == CLVC_ENUM)
1030 {
1031 const struct cl_enum *e = &cl_enums[option->var_enum];
1032 int value;
1033 const char *arg = NULL;
1034
1035 value = e->get (flag_var);
1036 enum_value_to_arg (e->values, &arg, value, lang_mask);
1037 if (arg == NULL)
1038 arg = _("[default]");
1039 snprintf (new_help + strlen (new_help),
1040 sizeof (new_help) - strlen (new_help),
1041 arg);
1042 }
1043 else
1044 sprintf (new_help + strlen (new_help),
1045 "%#x", * (int *) flag_var);
1046 }
1047 else
1048 strcat (new_help, option_enabled (i, opts)
1049 ? _("[enabled]") : _("[disabled]"));
1050 }
1051
1052 help = new_help;
1053 }
1054
1055 wrap_help (help, opt, len, columns);
1056 displayed = true;
1057
1058 if (option->var_type == CLVC_ENUM
1059 && opts->x_help_enum_printed[option->var_enum] != 2)
1060 opts->x_help_enum_printed[option->var_enum] = 1;
1061 }
1062
1063 if (! found)
1064 {
1065 unsigned int langs = include_flags & CL_LANG_ALL;
1066
1067 if (langs == 0)
1068 printf (_(" No options with the desired characteristics were found\n"));
1069 else
1070 {
1071 unsigned int i;
1072
1073 /* PR 31349: Tell the user how to see all of the
1074 options supported by a specific front end. */
1075 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1076 if ((1U << i) & langs)
1077 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end\n"),
1078 lang_names[i], lang_names[i]);
1079 }
1080
1081 }
1082 else if (! displayed)
1083 printf (_(" All options with the desired characteristics have already been displayed\n"));
1084
1085 putchar ('\n');
1086
1087 /* Print details of enumerated option arguments, if those
1088 enumerations have help text headings provided. If no help text
1089 is provided, presume that the possible values are listed in the
1090 help text for the relevant options. */
1091 for (i = 0; i < cl_enums_count; i++)
1092 {
1093 unsigned int j, pos;
1094
1095 if (opts->x_help_enum_printed[i] != 1)
1096 continue;
1097 if (cl_enums[i].help == NULL)
1098 continue;
1099 printf (" %s\n ", _(cl_enums[i].help));
1100 pos = 4;
1101 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1102 {
1103 unsigned int len = strlen (cl_enums[i].values[j].arg);
1104
1105 if (pos > 4 && pos + 1 + len <= columns)
1106 {
1107 printf (" %s", cl_enums[i].values[j].arg);
1108 pos += 1 + len;
1109 }
1110 else
1111 {
1112 if (pos > 4)
1113 {
1114 printf ("\n ");
1115 pos = 4;
1116 }
1117 printf ("%s", cl_enums[i].values[j].arg);
1118 pos += len;
1119 }
1120 }
1121 printf ("\n\n");
1122 opts->x_help_enum_printed[i] = 2;
1123 }
1124 }
1125
1126 /* Display help for a specified type of option.
1127 The options must have ALL of the INCLUDE_FLAGS set
1128 ANY of the flags in the ANY_FLAGS set
1129 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1130 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1131 static void
1132 print_specific_help (unsigned int include_flags,
1133 unsigned int exclude_flags,
1134 unsigned int any_flags,
1135 struct gcc_options *opts,
1136 unsigned int lang_mask)
1137 {
1138 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1139 const char * description = NULL;
1140 const char * descrip_extra = "";
1141 size_t i;
1142 unsigned int flag;
1143
1144 /* Sanity check: Make sure that we do not have more
1145 languages than we have bits available to enumerate them. */
1146 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1147
1148 /* If we have not done so already, obtain
1149 the desired maximum width of the output. */
1150 if (opts->x_help_columns == 0)
1151 {
1152 const char *p;
1153
1154 p = getenv ("COLUMNS");
1155 if (p != NULL)
1156 {
1157 int value = atoi (p);
1158
1159 if (value > 0)
1160 opts->x_help_columns = value;
1161 }
1162
1163 if (opts->x_help_columns == 0)
1164 /* Use a reasonable default. */
1165 opts->x_help_columns = 80;
1166 }
1167
1168 /* Decide upon the title for the options that we are going to display. */
1169 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1170 {
1171 switch (flag & include_flags)
1172 {
1173 case 0:
1174 case CL_DRIVER:
1175 break;
1176
1177 case CL_TARGET:
1178 description = _("The following options are target specific");
1179 break;
1180 case CL_WARNING:
1181 description = _("The following options control compiler warning messages");
1182 break;
1183 case CL_OPTIMIZATION:
1184 description = _("The following options control optimizations");
1185 break;
1186 case CL_COMMON:
1187 description = _("The following options are language-independent");
1188 break;
1189 case CL_PARAMS:
1190 description = _("The --param option recognizes the following as parameters");
1191 break;
1192 default:
1193 if (i >= cl_lang_count)
1194 break;
1195 if (exclude_flags & all_langs_mask)
1196 description = _("The following options are specific to just the language ");
1197 else
1198 description = _("The following options are supported by the language ");
1199 descrip_extra = lang_names [i];
1200 break;
1201 }
1202 }
1203
1204 if (description == NULL)
1205 {
1206 if (any_flags == 0)
1207 {
1208 if (include_flags & CL_UNDOCUMENTED)
1209 description = _("The following options are not documented");
1210 else if (include_flags & CL_SEPARATE)
1211 description = _("The following options take separate arguments");
1212 else if (include_flags & CL_JOINED)
1213 description = _("The following options take joined arguments");
1214 else
1215 {
1216 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1217 include_flags);
1218 return;
1219 }
1220 }
1221 else
1222 {
1223 if (any_flags & all_langs_mask)
1224 description = _("The following options are language-related");
1225 else
1226 description = _("The following options are language-independent");
1227 }
1228 }
1229
1230 printf ("%s%s:\n", description, descrip_extra);
1231 print_filtered_help (include_flags, exclude_flags, any_flags,
1232 opts->x_help_columns, opts, lang_mask);
1233 }
1234
1235 /* Handle target- and language-independent options. Return zero to
1236 generate an "unknown option" message. Only options that need
1237 extra handling need to be listed here; if you simply want
1238 DECODED->value assigned to a variable, it happens automatically. */
1239
1240 bool
1241 common_handle_option (struct gcc_options *opts,
1242 struct gcc_options *opts_set,
1243 const struct cl_decoded_option *decoded,
1244 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1245 location_t loc,
1246 const struct cl_option_handlers *handlers,
1247 diagnostic_context *dc)
1248 {
1249 size_t scode = decoded->opt_index;
1250 const char *arg = decoded->arg;
1251 int value = decoded->value;
1252 enum opt_code code = (enum opt_code) scode;
1253
1254 gcc_assert (decoded->canonical_option_num_elements <= 2);
1255
1256 switch (code)
1257 {
1258 case OPT__param:
1259 handle_param (opts, opts_set, loc, arg);
1260 break;
1261
1262 case OPT__help:
1263 {
1264 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1265 unsigned int undoc_mask;
1266 unsigned int i;
1267
1268 if (lang_mask == CL_DRIVER)
1269 break;;
1270
1271 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1272 ? 0
1273 : CL_UNDOCUMENTED);
1274 /* First display any single language specific options. */
1275 for (i = 0; i < cl_lang_count; i++)
1276 print_specific_help
1277 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1278 lang_mask);
1279 /* Next display any multi language specific options. */
1280 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1281 /* Then display any remaining, non-language options. */
1282 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1283 if (i != CL_DRIVER)
1284 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1285 opts->x_exit_after_options = true;
1286 break;
1287 }
1288
1289 case OPT__target_help:
1290 if (lang_mask == CL_DRIVER)
1291 break;
1292
1293 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1294 opts->x_exit_after_options = true;
1295 break;
1296
1297 case OPT__help_:
1298 {
1299 const char * a = arg;
1300 unsigned int include_flags = 0;
1301 /* Note - by default we include undocumented options when listing
1302 specific classes. If you only want to see documented options
1303 then add ",^undocumented" to the --help= option. E.g.:
1304
1305 --help=target,^undocumented */
1306 unsigned int exclude_flags = 0;
1307
1308 if (lang_mask == CL_DRIVER)
1309 break;
1310
1311 /* Walk along the argument string, parsing each word in turn.
1312 The format is:
1313 arg = [^]{word}[,{arg}]
1314 word = {optimizers|target|warnings|undocumented|
1315 params|common|<language>} */
1316 while (* a != 0)
1317 {
1318 static const struct
1319 {
1320 const char * string;
1321 unsigned int flag;
1322 }
1323 specifics[] =
1324 {
1325 { "optimizers", CL_OPTIMIZATION },
1326 { "target", CL_TARGET },
1327 { "warnings", CL_WARNING },
1328 { "undocumented", CL_UNDOCUMENTED },
1329 { "params", CL_PARAMS },
1330 { "joined", CL_JOINED },
1331 { "separate", CL_SEPARATE },
1332 { "common", CL_COMMON },
1333 { NULL, 0 }
1334 };
1335 unsigned int * pflags;
1336 const char * comma;
1337 unsigned int lang_flag, specific_flag;
1338 unsigned int len;
1339 unsigned int i;
1340
1341 if (* a == '^')
1342 {
1343 ++ a;
1344 pflags = & exclude_flags;
1345 }
1346 else
1347 pflags = & include_flags;
1348
1349 comma = strchr (a, ',');
1350 if (comma == NULL)
1351 len = strlen (a);
1352 else
1353 len = comma - a;
1354 if (len == 0)
1355 {
1356 a = comma + 1;
1357 continue;
1358 }
1359
1360 /* Check to see if the string matches an option class name. */
1361 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1362 if (strncasecmp (a, specifics[i].string, len) == 0)
1363 {
1364 specific_flag = specifics[i].flag;
1365 break;
1366 }
1367
1368 /* Check to see if the string matches a language name.
1369 Note - we rely upon the alpha-sorted nature of the entries in
1370 the lang_names array, specifically that shorter names appear
1371 before their longer variants. (i.e. C before C++). That way
1372 when we are attempting to match --help=c for example we will
1373 match with C first and not C++. */
1374 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1375 if (strncasecmp (a, lang_names[i], len) == 0)
1376 {
1377 lang_flag = 1U << i;
1378 break;
1379 }
1380
1381 if (specific_flag != 0)
1382 {
1383 if (lang_flag == 0)
1384 * pflags |= specific_flag;
1385 else
1386 {
1387 /* The option's argument matches both the start of a
1388 language name and the start of an option class name.
1389 We have a special case for when the user has
1390 specified "--help=c", but otherwise we have to issue
1391 a warning. */
1392 if (strncasecmp (a, "c", len) == 0)
1393 * pflags |= lang_flag;
1394 else
1395 warning_at (loc, 0,
1396 "--help argument %q.*s is ambiguous, "
1397 "please be more specific",
1398 len, a);
1399 }
1400 }
1401 else if (lang_flag != 0)
1402 * pflags |= lang_flag;
1403 else
1404 warning_at (loc, 0,
1405 "unrecognized argument to --help= option: %q.*s",
1406 len, a);
1407
1408 if (comma == NULL)
1409 break;
1410 a = comma + 1;
1411 }
1412
1413 if (include_flags)
1414 print_specific_help (include_flags, exclude_flags, 0, opts,
1415 lang_mask);
1416 opts->x_exit_after_options = true;
1417 break;
1418 }
1419
1420 case OPT__version:
1421 if (lang_mask == CL_DRIVER)
1422 break;
1423
1424 opts->x_exit_after_options = true;
1425 break;
1426
1427 case OPT_fsanitize_:
1428 {
1429 const char *p = arg;
1430 while (*p != 0)
1431 {
1432 static const struct
1433 {
1434 const char *const name;
1435 unsigned int flag;
1436 size_t len;
1437 } spec[] =
1438 {
1439 { "address", SANITIZE_ADDRESS, sizeof "address" - 1 },
1440 { "thread", SANITIZE_THREAD, sizeof "thread" - 1 },
1441 { "shift", SANITIZE_SHIFT, sizeof "shift" - 1 },
1442 { "integer-divide-by-zero", SANITIZE_DIVIDE,
1443 sizeof "integer-divide-by-zero" - 1 },
1444 { "undefined", SANITIZE_UNDEFINED, sizeof "undefined" - 1 },
1445 { "unreachable", SANITIZE_UNREACHABLE,
1446 sizeof "unreachable" - 1 },
1447 { NULL, 0, 0 }
1448 };
1449 const char *comma;
1450 size_t len, i;
1451 bool found = false;
1452
1453 comma = strchr (p, ',');
1454 if (comma == NULL)
1455 len = strlen (p);
1456 else
1457 len = comma - p;
1458 if (len == 0)
1459 {
1460 p = comma + 1;
1461 continue;
1462 }
1463
1464 /* Check to see if the string matches an option class name. */
1465 for (i = 0; spec[i].name != NULL; ++i)
1466 if (len == spec[i].len
1467 && memcmp (p, spec[i].name, len) == 0)
1468 {
1469 /* Handle both -fsanitize and -fno-sanitize cases. */
1470 if (value)
1471 flag_sanitize |= spec[i].flag;
1472 else
1473 flag_sanitize &= ~spec[i].flag;
1474 found = true;
1475 break;
1476 }
1477
1478 if (! found)
1479 warning_at (loc, 0,
1480 "unrecognized argument to -fsanitize= option: %q.*s",
1481 (int) len, p);
1482
1483 if (comma == NULL)
1484 break;
1485 p = comma + 1;
1486 }
1487
1488 break;
1489 }
1490
1491 case OPT_O:
1492 case OPT_Os:
1493 case OPT_Ofast:
1494 case OPT_Og:
1495 /* Currently handled in a prescan. */
1496 break;
1497
1498 case OPT_Werror:
1499 dc->warning_as_error_requested = value;
1500 break;
1501
1502 case OPT_Werror_:
1503 if (lang_mask == CL_DRIVER)
1504 break;
1505
1506 enable_warning_as_error (arg, value, lang_mask, handlers,
1507 opts, opts_set, loc, dc);
1508 break;
1509
1510 case OPT_Wlarger_than_:
1511 opts->x_larger_than_size = value;
1512 opts->x_warn_larger_than = value != -1;
1513 break;
1514
1515 case OPT_Wfatal_errors:
1516 dc->fatal_errors = value;
1517 break;
1518
1519 case OPT_Wframe_larger_than_:
1520 opts->x_frame_larger_than_size = value;
1521 opts->x_warn_frame_larger_than = value != -1;
1522 break;
1523
1524 case OPT_Wstack_usage_:
1525 opts->x_warn_stack_usage = value;
1526 opts->x_flag_stack_usage_info = value != -1;
1527 break;
1528
1529 case OPT_Wstrict_aliasing:
1530 set_Wstrict_aliasing (opts, value);
1531 break;
1532
1533 case OPT_Wstrict_overflow:
1534 opts->x_warn_strict_overflow = (value
1535 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1536 : 0);
1537 break;
1538
1539 case OPT_Wsystem_headers:
1540 dc->dc_warn_system_headers = value;
1541 break;
1542
1543 case OPT_aux_info:
1544 opts->x_flag_gen_aux_info = 1;
1545 break;
1546
1547 case OPT_auxbase_strip:
1548 {
1549 char *tmp = xstrdup (arg);
1550 strip_off_ending (tmp, strlen (tmp));
1551 if (tmp[0])
1552 opts->x_aux_base_name = tmp;
1553 else
1554 free (tmp);
1555 }
1556 break;
1557
1558 case OPT_d:
1559 decode_d_option (arg, opts, loc, dc);
1560 break;
1561
1562 case OPT_fcall_used_:
1563 case OPT_fcall_saved_:
1564 /* Deferred. */
1565 break;
1566
1567 case OPT_fdbg_cnt_:
1568 case OPT_fdbg_cnt_list:
1569 /* Deferred. */
1570 break;
1571
1572 case OPT_fdebug_prefix_map_:
1573 /* Deferred. */
1574 break;
1575
1576 case OPT_fdiagnostics_show_location_:
1577 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1578 break;
1579
1580 case OPT_fdiagnostics_show_caret:
1581 dc->show_caret = value;
1582 break;
1583
1584 case OPT_fdiagnostics_color_:
1585 pp_show_color (dc->printer)
1586 = colorize_init ((diagnostic_color_rule_t) value);
1587 break;
1588
1589 case OPT_fdiagnostics_show_option:
1590 dc->show_option_requested = value;
1591 break;
1592
1593 case OPT_fdump_:
1594 /* Deferred. */
1595 break;
1596
1597 case OPT_ffast_math:
1598 set_fast_math_flags (opts, value);
1599 break;
1600
1601 case OPT_funsafe_math_optimizations:
1602 set_unsafe_math_optimizations_flags (opts, value);
1603 break;
1604
1605 case OPT_ffixed_:
1606 /* Deferred. */
1607 break;
1608
1609 case OPT_finline_limit_:
1610 set_param_value ("max-inline-insns-single", value / 2,
1611 opts->x_param_values, opts_set->x_param_values);
1612 set_param_value ("max-inline-insns-auto", value / 2,
1613 opts->x_param_values, opts_set->x_param_values);
1614 break;
1615
1616 case OPT_finstrument_functions_exclude_function_list_:
1617 add_comma_separated_to_vector
1618 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1619 break;
1620
1621 case OPT_finstrument_functions_exclude_file_list_:
1622 add_comma_separated_to_vector
1623 (&opts->x_flag_instrument_functions_exclude_files, arg);
1624 break;
1625
1626 case OPT_fmessage_length_:
1627 pp_set_line_maximum_length (dc->printer, value);
1628 diagnostic_set_caret_max_width (dc, value);
1629 break;
1630
1631 case OPT_fopt_info:
1632 case OPT_fopt_info_:
1633 /* Deferred. */
1634 break;
1635
1636 case OPT_fpack_struct_:
1637 if (value <= 0 || (value & (value - 1)) || value > 16)
1638 error_at (loc,
1639 "structure alignment must be a small power of two, not %d",
1640 value);
1641 else
1642 opts->x_initial_max_fld_align = value;
1643 break;
1644
1645 case OPT_fplugin_:
1646 case OPT_fplugin_arg_:
1647 /* Deferred. */
1648 break;
1649
1650 case OPT_fprofile_use_:
1651 opts->x_profile_data_prefix = xstrdup (arg);
1652 opts->x_flag_profile_use = true;
1653 value = true;
1654 /* No break here - do -fprofile-use processing. */
1655 case OPT_fprofile_use:
1656 if (!opts_set->x_flag_branch_probabilities)
1657 opts->x_flag_branch_probabilities = value;
1658 if (!opts_set->x_flag_profile_values)
1659 opts->x_flag_profile_values = value;
1660 if (!opts_set->x_flag_unroll_loops)
1661 opts->x_flag_unroll_loops = value;
1662 if (!opts_set->x_flag_peel_loops)
1663 opts->x_flag_peel_loops = value;
1664 if (!opts_set->x_flag_tracer)
1665 opts->x_flag_tracer = value;
1666 if (!opts_set->x_flag_value_profile_transformations)
1667 opts->x_flag_value_profile_transformations = value;
1668 if (!opts_set->x_flag_inline_functions)
1669 opts->x_flag_inline_functions = value;
1670 if (!opts_set->x_flag_ipa_cp)
1671 opts->x_flag_ipa_cp = value;
1672 if (!opts_set->x_flag_ipa_cp_clone
1673 && value && opts->x_flag_ipa_cp)
1674 opts->x_flag_ipa_cp_clone = value;
1675 if (!opts_set->x_flag_predictive_commoning)
1676 opts->x_flag_predictive_commoning = value;
1677 if (!opts_set->x_flag_unswitch_loops)
1678 opts->x_flag_unswitch_loops = value;
1679 if (!opts_set->x_flag_gcse_after_reload)
1680 opts->x_flag_gcse_after_reload = value;
1681 if (!opts_set->x_flag_tree_loop_vectorize
1682 && !opts_set->x_flag_tree_vectorize)
1683 opts->x_flag_tree_loop_vectorize = value;
1684 if (!opts_set->x_flag_tree_slp_vectorize
1685 && !opts_set->x_flag_tree_vectorize)
1686 opts->x_flag_tree_slp_vectorize = value;
1687 if (!opts_set->x_flag_vect_cost_model)
1688 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1689 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1690 opts->x_flag_tree_loop_distribute_patterns = value;
1691 /* Indirect call profiling should do all useful transformations
1692 speculative devirutalization does. */
1693 if (!opts_set->x_flag_devirtualize_speculatively
1694 && opts->x_flag_value_profile_transformations)
1695 opts->x_flag_devirtualize_speculatively = false;
1696 break;
1697
1698 case OPT_fprofile_generate_:
1699 opts->x_profile_data_prefix = xstrdup (arg);
1700 value = true;
1701 /* No break here - do -fprofile-generate processing. */
1702 case OPT_fprofile_generate:
1703 if (!opts_set->x_profile_arc_flag)
1704 opts->x_profile_arc_flag = value;
1705 if (!opts_set->x_flag_profile_values)
1706 opts->x_flag_profile_values = value;
1707 if (!opts_set->x_flag_inline_functions)
1708 opts->x_flag_inline_functions = value;
1709 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1710 quadratic. Disable the pass until better memory representation
1711 is done. */
1712 if (!opts_set->x_flag_ipa_reference && opts->x_in_lto_p)
1713 opts->x_flag_ipa_reference = false;
1714 break;
1715
1716 case OPT_ftree_vectorize:
1717 if (!opts_set->x_flag_tree_loop_vectorize)
1718 opts->x_flag_tree_loop_vectorize = value;
1719 if (!opts_set->x_flag_tree_slp_vectorize)
1720 opts->x_flag_tree_slp_vectorize = value;
1721 break;
1722 case OPT_fshow_column:
1723 dc->show_column = value;
1724 break;
1725
1726 case OPT_frandom_seed:
1727 /* The real switch is -fno-random-seed. */
1728 if (value)
1729 return false;
1730 /* Deferred. */
1731 break;
1732
1733 case OPT_frandom_seed_:
1734 /* Deferred. */
1735 break;
1736
1737 case OPT_fsched_verbose_:
1738 #ifdef INSN_SCHEDULING
1739 /* Handled with Var in common.opt. */
1740 break;
1741 #else
1742 return false;
1743 #endif
1744
1745 case OPT_fsched_stalled_insns_:
1746 opts->x_flag_sched_stalled_insns = value;
1747 if (opts->x_flag_sched_stalled_insns == 0)
1748 opts->x_flag_sched_stalled_insns = -1;
1749 break;
1750
1751 case OPT_fsched_stalled_insns_dep_:
1752 opts->x_flag_sched_stalled_insns_dep = value;
1753 break;
1754
1755 case OPT_fstack_check_:
1756 if (!strcmp (arg, "no"))
1757 opts->x_flag_stack_check = NO_STACK_CHECK;
1758 else if (!strcmp (arg, "generic"))
1759 /* This is the old stack checking method. */
1760 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1761 ? FULL_BUILTIN_STACK_CHECK
1762 : GENERIC_STACK_CHECK;
1763 else if (!strcmp (arg, "specific"))
1764 /* This is the new stack checking method. */
1765 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
1766 ? FULL_BUILTIN_STACK_CHECK
1767 : STACK_CHECK_STATIC_BUILTIN
1768 ? STATIC_BUILTIN_STACK_CHECK
1769 : GENERIC_STACK_CHECK;
1770 else
1771 warning_at (loc, 0, "unknown stack check parameter \"%s\"", arg);
1772 break;
1773
1774 case OPT_fstack_limit:
1775 /* The real switch is -fno-stack-limit. */
1776 if (value)
1777 return false;
1778 /* Deferred. */
1779 break;
1780
1781 case OPT_fstack_limit_register_:
1782 case OPT_fstack_limit_symbol_:
1783 /* Deferred. */
1784 break;
1785
1786 case OPT_fstack_usage:
1787 opts->x_flag_stack_usage = value;
1788 opts->x_flag_stack_usage_info = value != 0;
1789 break;
1790
1791 case OPT_g:
1792 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
1793 loc);
1794 break;
1795
1796 case OPT_gcoff:
1797 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
1798 break;
1799
1800 case OPT_gdwarf:
1801 if (arg && strlen (arg) != 0)
1802 {
1803 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
1804 "use %<-gdwarf-%s%> for DWARF version "
1805 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
1806 break;
1807 }
1808 else
1809 value = opts->x_dwarf_version;
1810
1811 /* FALLTHRU */
1812 case OPT_gdwarf_:
1813 if (value < 2 || value > 4)
1814 error_at (loc, "dwarf version %d is not supported", value);
1815 else
1816 opts->x_dwarf_version = value;
1817 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
1818 break;
1819
1820 case OPT_gsplit_dwarf:
1821 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
1822 loc);
1823 break;
1824
1825 case OPT_ggdb:
1826 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
1827 break;
1828
1829 case OPT_gstabs:
1830 case OPT_gstabs_:
1831 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
1832 loc);
1833 break;
1834
1835 case OPT_gvms:
1836 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
1837 break;
1838
1839 case OPT_gxcoff:
1840 case OPT_gxcoff_:
1841 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
1842 loc);
1843 break;
1844
1845 case OPT_pedantic_errors:
1846 dc->pedantic_errors = 1;
1847 control_warning_option (OPT_Wpedantic, DK_ERROR, value,
1848 loc, lang_mask,
1849 handlers, opts, opts_set,
1850 dc);
1851 break;
1852
1853 case OPT_flto:
1854 opts->x_flag_lto = value ? "" : NULL;
1855 break;
1856
1857 case OPT_w:
1858 dc->dc_inhibit_warnings = true;
1859 break;
1860
1861 case OPT_fmax_errors_:
1862 dc->max_errors = value;
1863 break;
1864
1865 case OPT_fuse_ld_bfd:
1866 case OPT_fuse_ld_gold:
1867 case OPT_fuse_linker_plugin:
1868 /* No-op. Used by the driver and passed to us because it starts with f.*/
1869 break;
1870
1871 case OPT_fwrapv:
1872 if (value)
1873 opts->x_flag_trapv = 0;
1874 break;
1875
1876 case OPT_ftrapv:
1877 if (value)
1878 opts->x_flag_wrapv = 0;
1879 break;
1880
1881 default:
1882 /* If the flag was handled in a standard way, assume the lack of
1883 processing here is intentional. */
1884 gcc_assert (option_flag_var (scode, opts));
1885 break;
1886 }
1887
1888 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
1889 loc, handlers, dc);
1890 return true;
1891 }
1892
1893 /* Handle --param NAME=VALUE. */
1894 static void
1895 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
1896 location_t loc, const char *carg)
1897 {
1898 char *equal, *arg;
1899 int value;
1900
1901 arg = xstrdup (carg);
1902 equal = strchr (arg, '=');
1903 if (!equal)
1904 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
1905 arg);
1906 else
1907 {
1908 value = integral_argument (equal + 1);
1909 if (value == -1)
1910 error_at (loc, "invalid --param value %qs", equal + 1);
1911 else
1912 {
1913 *equal = '\0';
1914 set_param_value (arg, value,
1915 opts->x_param_values, opts_set->x_param_values);
1916 }
1917 }
1918
1919 free (arg);
1920 }
1921
1922 /* Used to set the level of strict aliasing warnings in OPTS,
1923 when no level is specified (i.e., when -Wstrict-aliasing, and not
1924 -Wstrict-aliasing=level was given).
1925 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
1926 and 0 otherwise. After calling this function, wstrict_aliasing will be
1927 set to the default value of -Wstrict_aliasing=level, currently 3. */
1928 static void
1929 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
1930 {
1931 gcc_assert (onoff == 0 || onoff == 1);
1932 if (onoff != 0)
1933 opts->x_warn_strict_aliasing = 3;
1934 else
1935 opts->x_warn_strict_aliasing = 0;
1936 }
1937
1938 /* The following routines are useful in setting all the flags that
1939 -ffast-math and -fno-fast-math imply. */
1940 static void
1941 set_fast_math_flags (struct gcc_options *opts, int set)
1942 {
1943 if (!opts->frontend_set_flag_unsafe_math_optimizations)
1944 {
1945 opts->x_flag_unsafe_math_optimizations = set;
1946 set_unsafe_math_optimizations_flags (opts, set);
1947 }
1948 if (!opts->frontend_set_flag_finite_math_only)
1949 opts->x_flag_finite_math_only = set;
1950 if (!opts->frontend_set_flag_errno_math)
1951 opts->x_flag_errno_math = !set;
1952 if (set)
1953 {
1954 if (!opts->frontend_set_flag_signaling_nans)
1955 opts->x_flag_signaling_nans = 0;
1956 if (!opts->frontend_set_flag_rounding_math)
1957 opts->x_flag_rounding_math = 0;
1958 if (!opts->frontend_set_flag_cx_limited_range)
1959 opts->x_flag_cx_limited_range = 1;
1960 }
1961 }
1962
1963 /* When -funsafe-math-optimizations is set the following
1964 flags are set as well. */
1965 static void
1966 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
1967 {
1968 if (!opts->frontend_set_flag_trapping_math)
1969 opts->x_flag_trapping_math = !set;
1970 if (!opts->frontend_set_flag_signed_zeros)
1971 opts->x_flag_signed_zeros = !set;
1972 if (!opts->frontend_set_flag_associative_math)
1973 opts->x_flag_associative_math = set;
1974 if (!opts->frontend_set_flag_reciprocal_math)
1975 opts->x_flag_reciprocal_math = set;
1976 }
1977
1978 /* Return true iff flags in OPTS are set as if -ffast-math. */
1979 bool
1980 fast_math_flags_set_p (const struct gcc_options *opts)
1981 {
1982 return (!opts->x_flag_trapping_math
1983 && opts->x_flag_unsafe_math_optimizations
1984 && opts->x_flag_finite_math_only
1985 && !opts->x_flag_signed_zeros
1986 && !opts->x_flag_errno_math);
1987 }
1988
1989 /* Return true iff flags are set as if -ffast-math but using the flags stored
1990 in the struct cl_optimization structure. */
1991 bool
1992 fast_math_flags_struct_set_p (struct cl_optimization *opt)
1993 {
1994 return (!opt->x_flag_trapping_math
1995 && opt->x_flag_unsafe_math_optimizations
1996 && opt->x_flag_finite_math_only
1997 && !opt->x_flag_signed_zeros
1998 && !opt->x_flag_errno_math);
1999 }
2000
2001 /* Handle a debug output -g switch for options OPTS
2002 (OPTS_SET->x_write_symbols storing whether a debug type was passed
2003 explicitly), location LOC. EXTENDED is true or false to support
2004 extended output (2 is special and means "-ggdb" was given). */
2005 static void
2006 set_debug_level (enum debug_info_type type, int extended, const char *arg,
2007 struct gcc_options *opts, struct gcc_options *opts_set,
2008 location_t loc)
2009 {
2010 opts->x_use_gnu_debug_info_extensions = extended;
2011
2012 if (type == NO_DEBUG)
2013 {
2014 if (opts->x_write_symbols == NO_DEBUG)
2015 {
2016 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
2017
2018 if (extended == 2)
2019 {
2020 #ifdef DWARF2_DEBUGGING_INFO
2021 opts->x_write_symbols = DWARF2_DEBUG;
2022 #elif defined DBX_DEBUGGING_INFO
2023 opts->x_write_symbols = DBX_DEBUG;
2024 #endif
2025 }
2026
2027 if (opts->x_write_symbols == NO_DEBUG)
2028 warning_at (loc, 0, "target system does not support debug output");
2029 }
2030 }
2031 else
2032 {
2033 /* Does it conflict with an already selected type? */
2034 if (opts_set->x_write_symbols != NO_DEBUG
2035 && opts->x_write_symbols != NO_DEBUG
2036 && type != opts->x_write_symbols)
2037 error_at (loc, "debug format \"%s\" conflicts with prior selection",
2038 debug_type_names[type]);
2039 opts->x_write_symbols = type;
2040 opts_set->x_write_symbols = type;
2041 }
2042
2043 /* A debug flag without a level defaults to level 2. */
2044 if (*arg == '\0')
2045 {
2046 if (!opts->x_debug_info_level)
2047 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2048 }
2049 else
2050 {
2051 int argval = integral_argument (arg);
2052 if (argval == -1)
2053 error_at (loc, "unrecognised debug output level \"%s\"", arg);
2054 else if (argval > 3)
2055 error_at (loc, "debug output level %s is too high", arg);
2056 else
2057 opts->x_debug_info_level = (enum debug_info_levels) argval;
2058 }
2059 }
2060
2061 /* Arrange to dump core on error for diagnostic context DC. (The
2062 regular error message is still printed first, except in the case of
2063 abort ().) */
2064
2065 static void
2066 setup_core_dumping (diagnostic_context *dc)
2067 {
2068 #ifdef SIGABRT
2069 signal (SIGABRT, SIG_DFL);
2070 #endif
2071 #if defined(HAVE_SETRLIMIT)
2072 {
2073 struct rlimit rlim;
2074 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2075 fatal_error ("getting core file size maximum limit: %m");
2076 rlim.rlim_cur = rlim.rlim_max;
2077 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2078 fatal_error ("setting core file size limit to maximum: %m");
2079 }
2080 #endif
2081 diagnostic_abort_on_error (dc);
2082 }
2083
2084 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2085 diagnostic context DC. */
2086
2087 static void
2088 decode_d_option (const char *arg, struct gcc_options *opts,
2089 location_t loc, diagnostic_context *dc)
2090 {
2091 int c;
2092
2093 while (*arg)
2094 switch (c = *arg++)
2095 {
2096 case 'A':
2097 opts->x_flag_debug_asm = 1;
2098 break;
2099 case 'p':
2100 opts->x_flag_print_asm_name = 1;
2101 break;
2102 case 'P':
2103 opts->x_flag_dump_rtl_in_asm = 1;
2104 opts->x_flag_print_asm_name = 1;
2105 break;
2106 case 'x':
2107 opts->x_rtl_dump_and_exit = 1;
2108 break;
2109 case 'D': /* These are handled by the preprocessor. */
2110 case 'I':
2111 case 'M':
2112 case 'N':
2113 case 'U':
2114 break;
2115 case 'H':
2116 setup_core_dumping (dc);
2117 break;
2118 case 'a':
2119 opts->x_flag_dump_all_passed = true;
2120 break;
2121
2122 default:
2123 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2124 break;
2125 }
2126 }
2127
2128 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2129 mask LANG_MASK, option handlers HANDLERS) as an error for option
2130 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2131 NULL), location LOC. This is used by -Werror=. */
2132
2133 static void
2134 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2135 const struct cl_option_handlers *handlers,
2136 struct gcc_options *opts,
2137 struct gcc_options *opts_set,
2138 location_t loc, diagnostic_context *dc)
2139 {
2140 char *new_option;
2141 int option_index;
2142
2143 new_option = XNEWVEC (char, strlen (arg) + 2);
2144 new_option[0] = 'W';
2145 strcpy (new_option + 1, arg);
2146 option_index = find_opt (new_option, lang_mask);
2147 if (option_index == OPT_SPECIAL_unknown)
2148 {
2149 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2150 }
2151 else
2152 {
2153 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2154
2155 control_warning_option (option_index, (int) kind, value,
2156 loc, lang_mask,
2157 handlers, opts, opts_set, dc);
2158 }
2159 free (new_option);
2160 }
2161
2162 /* Return malloced memory for the name of the option OPTION_INDEX
2163 which enabled a diagnostic (context CONTEXT), originally of type
2164 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2165 as -Werror. */
2166
2167 char *
2168 option_name (diagnostic_context *context, int option_index,
2169 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2170 {
2171 if (option_index)
2172 {
2173 /* A warning classified as an error. */
2174 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2175 && diag_kind == DK_ERROR)
2176 return concat (cl_options[OPT_Werror_].opt_text,
2177 /* Skip over "-W". */
2178 cl_options[option_index].opt_text + 2,
2179 NULL);
2180 /* A warning with option. */
2181 else
2182 return xstrdup (cl_options[option_index].opt_text);
2183 }
2184 /* A warning without option classified as an error. */
2185 else if (orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2186 || diag_kind == DK_WARNING)
2187 {
2188 if (context->warning_as_error_requested)
2189 return xstrdup (cl_options[OPT_Werror].opt_text);
2190 else
2191 return xstrdup (_("enabled by default"));
2192 }
2193 else
2194 return NULL;
2195 }