874c84fec5b07b3c09515a9e33b10226aeeb2b48
[gcc.git] / gcc / opts.c
1 /* Command line option handling.
2 Copyright (C) 2002-2015 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 "tm.h"
27 #include "flags.h"
28 #include "params.h"
29 #include "diagnostic.h"
30 #include "opts-diagnostic.h"
31 #include "insn-attr-common.h"
32 #include "common/common-target.h"
33
34 static void set_Wstrict_aliasing (struct gcc_options *opts, int onoff);
35
36 /* Indexed by enum debug_info_type. */
37 const char *const debug_type_names[] =
38 {
39 "none", "stabs", "coff", "dwarf-2", "xcoff", "vms"
40 };
41
42 /* Parse the -femit-struct-debug-detailed option value
43 and set the flag variables. */
44
45 #define MATCH( prefix, string ) \
46 ((strncmp (prefix, string, sizeof prefix - 1) == 0) \
47 ? ((string += sizeof prefix - 1), 1) : 0)
48
49 void
50 set_struct_debug_option (struct gcc_options *opts, location_t loc,
51 const char *spec)
52 {
53 /* various labels for comparison */
54 static const char dfn_lbl[] = "dfn:", dir_lbl[] = "dir:", ind_lbl[] = "ind:";
55 static const char ord_lbl[] = "ord:", gen_lbl[] = "gen:";
56 static const char none_lbl[] = "none", any_lbl[] = "any";
57 static const char base_lbl[] = "base", sys_lbl[] = "sys";
58
59 enum debug_struct_file files = DINFO_STRUCT_FILE_ANY;
60 /* Default is to apply to as much as possible. */
61 enum debug_info_usage usage = DINFO_USAGE_NUM_ENUMS;
62 int ord = 1, gen = 1;
63
64 /* What usage? */
65 if (MATCH (dfn_lbl, spec))
66 usage = DINFO_USAGE_DFN;
67 else if (MATCH (dir_lbl, spec))
68 usage = DINFO_USAGE_DIR_USE;
69 else if (MATCH (ind_lbl, spec))
70 usage = DINFO_USAGE_IND_USE;
71
72 /* Generics or not? */
73 if (MATCH (ord_lbl, spec))
74 gen = 0;
75 else if (MATCH (gen_lbl, spec))
76 ord = 0;
77
78 /* What allowable environment? */
79 if (MATCH (none_lbl, spec))
80 files = DINFO_STRUCT_FILE_NONE;
81 else if (MATCH (any_lbl, spec))
82 files = DINFO_STRUCT_FILE_ANY;
83 else if (MATCH (sys_lbl, spec))
84 files = DINFO_STRUCT_FILE_SYS;
85 else if (MATCH (base_lbl, spec))
86 files = DINFO_STRUCT_FILE_BASE;
87 else
88 error_at (loc,
89 "argument %qs to %<-femit-struct-debug-detailed%> "
90 "not recognized",
91 spec);
92
93 /* Effect the specification. */
94 if (usage == DINFO_USAGE_NUM_ENUMS)
95 {
96 if (ord)
97 {
98 opts->x_debug_struct_ordinary[DINFO_USAGE_DFN] = files;
99 opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE] = files;
100 opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE] = files;
101 }
102 if (gen)
103 {
104 opts->x_debug_struct_generic[DINFO_USAGE_DFN] = files;
105 opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE] = files;
106 opts->x_debug_struct_generic[DINFO_USAGE_IND_USE] = files;
107 }
108 }
109 else
110 {
111 if (ord)
112 opts->x_debug_struct_ordinary[usage] = files;
113 if (gen)
114 opts->x_debug_struct_generic[usage] = files;
115 }
116
117 if (*spec == ',')
118 set_struct_debug_option (opts, loc, spec+1);
119 else
120 {
121 /* No more -femit-struct-debug-detailed specifications.
122 Do final checks. */
123 if (*spec != '\0')
124 error_at (loc,
125 "argument %qs to %<-femit-struct-debug-detailed%> unknown",
126 spec);
127 if (opts->x_debug_struct_ordinary[DINFO_USAGE_DIR_USE]
128 < opts->x_debug_struct_ordinary[DINFO_USAGE_IND_USE]
129 || opts->x_debug_struct_generic[DINFO_USAGE_DIR_USE]
130 < opts->x_debug_struct_generic[DINFO_USAGE_IND_USE])
131 error_at (loc,
132 "%<-femit-struct-debug-detailed=dir:...%> must allow "
133 "at least as much as "
134 "%<-femit-struct-debug-detailed=ind:...%>");
135 }
136 }
137
138 /* Strip off a legitimate source ending from the input string NAME of
139 length LEN. Rather than having to know the names used by all of
140 our front ends, we strip off an ending of a period followed by
141 up to five characters. (Java uses ".class".) */
142
143 void
144 strip_off_ending (char *name, int len)
145 {
146 int i;
147 for (i = 2; i < 6 && len > i; i++)
148 {
149 if (name[len - i] == '.')
150 {
151 name[len - i] = '\0';
152 break;
153 }
154 }
155 }
156
157 /* Find the base name of a path, stripping off both directories and
158 a single final extension. */
159 int
160 base_of_path (const char *path, const char **base_out)
161 {
162 const char *base = path;
163 const char *dot = 0;
164 const char *p = path;
165 char c = *p;
166 while (c)
167 {
168 if (IS_DIR_SEPARATOR (c))
169 {
170 base = p + 1;
171 dot = 0;
172 }
173 else if (c == '.')
174 dot = p;
175 c = *++p;
176 }
177 if (!dot)
178 dot = p;
179 *base_out = base;
180 return dot - base;
181 }
182
183 /* What to print when a switch has no documentation. */
184 static const char undocumented_msg[] = N_("This option lacks documentation.");
185 static const char use_diagnosed_msg[] = N_("Uses of this option are diagnosed.");
186
187 typedef char *char_p; /* For DEF_VEC_P. */
188
189 static void handle_param (struct gcc_options *opts,
190 struct gcc_options *opts_set, location_t loc,
191 const char *carg);
192 static void set_debug_level (enum debug_info_type type, int extended,
193 const char *arg, struct gcc_options *opts,
194 struct gcc_options *opts_set,
195 location_t loc);
196 static void set_fast_math_flags (struct gcc_options *opts, int set);
197 static void decode_d_option (const char *arg, struct gcc_options *opts,
198 location_t loc, diagnostic_context *dc);
199 static void set_unsafe_math_optimizations_flags (struct gcc_options *opts,
200 int set);
201 static void enable_warning_as_error (const char *arg, int value,
202 unsigned int lang_mask,
203 const struct cl_option_handlers *handlers,
204 struct gcc_options *opts,
205 struct gcc_options *opts_set,
206 location_t loc,
207 diagnostic_context *dc);
208
209 /* Handle a back-end option; arguments and return value as for
210 handle_option. */
211
212 bool
213 target_handle_option (struct gcc_options *opts,
214 struct gcc_options *opts_set,
215 const struct cl_decoded_option *decoded,
216 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
217 location_t loc,
218 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
219 diagnostic_context *dc)
220 {
221 gcc_assert (dc == global_dc);
222 gcc_assert (kind == DK_UNSPECIFIED);
223 return targetm_common.handle_option (opts, opts_set, decoded, loc);
224 }
225
226 /* Add comma-separated strings to a char_p vector. */
227
228 static void
229 add_comma_separated_to_vector (void **pvec, const char *arg)
230 {
231 char *tmp;
232 char *r;
233 char *w;
234 char *token_start;
235 vec<char_p> *v = (vec<char_p> *) *pvec;
236
237 vec_check_alloc (v, 1);
238
239 /* We never free this string. */
240 tmp = xstrdup (arg);
241
242 r = tmp;
243 w = tmp;
244 token_start = tmp;
245
246 while (*r != '\0')
247 {
248 if (*r == ',')
249 {
250 *w++ = '\0';
251 ++r;
252 v->safe_push (token_start);
253 token_start = w;
254 }
255 if (*r == '\\' && r[1] == ',')
256 {
257 *w++ = ',';
258 r += 2;
259 }
260 else
261 *w++ = *r++;
262 }
263 if (*token_start != '\0')
264 v->safe_push (token_start);
265
266 *pvec = v;
267 }
268
269 /* Initialize opts_obstack if not initialized. */
270
271 void
272 init_opts_obstack (void)
273 {
274 static bool opts_obstack_initialized = false;
275
276 if (!opts_obstack_initialized)
277 {
278 opts_obstack_initialized = true;
279 gcc_obstack_init (&opts_obstack);
280 }
281 }
282
283 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
284
285 void
286 init_options_struct (struct gcc_options *opts, struct gcc_options *opts_set)
287 {
288 size_t num_params = get_num_compiler_params ();
289
290 init_opts_obstack ();
291
292 *opts = global_options_init;
293
294 if (opts_set)
295 memset (opts_set, 0, sizeof (*opts_set));
296
297 opts->x_param_values = XNEWVEC (int, num_params);
298
299 if (opts_set)
300 opts_set->x_param_values = XCNEWVEC (int, num_params);
301
302 init_param_values (opts->x_param_values);
303
304 /* Initialize whether `char' is signed. */
305 opts->x_flag_signed_char = DEFAULT_SIGNED_CHAR;
306 /* Set this to a special "uninitialized" value. The actual default
307 is set after target options have been processed. */
308 opts->x_flag_short_enums = 2;
309
310 /* Initialize target_flags before default_options_optimization
311 so the latter can modify it. */
312 opts->x_target_flags = targetm_common.default_target_flags;
313
314 /* Some targets have ABI-specified unwind tables. */
315 opts->x_flag_unwind_tables = targetm_common.unwind_tables_default;
316
317 /* Some targets have other target-specific initialization. */
318 targetm_common.option_init_struct (opts);
319 }
320
321 /* Release any allocations owned by OPTS. */
322
323 void
324 finalize_options_struct (struct gcc_options *opts)
325 {
326 XDELETEVEC (opts->x_param_values);
327 }
328
329 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
330 -Ofast if FAST is set, -Og if DEBUG is set), apply the option DEFAULT_OPT
331 to OPTS and OPTS_SET, diagnostic context DC, location LOC, with language
332 mask LANG_MASK and option handlers HANDLERS. */
333
334 static void
335 maybe_default_option (struct gcc_options *opts,
336 struct gcc_options *opts_set,
337 const struct default_options *default_opt,
338 int level, bool size, bool fast, bool debug,
339 unsigned int lang_mask,
340 const struct cl_option_handlers *handlers,
341 location_t loc,
342 diagnostic_context *dc)
343 {
344 const struct cl_option *option = &cl_options[default_opt->opt_index];
345 bool enabled;
346
347 if (size)
348 gcc_assert (level == 2);
349 if (fast)
350 gcc_assert (level == 3);
351 if (debug)
352 gcc_assert (level == 1);
353
354 switch (default_opt->levels)
355 {
356 case OPT_LEVELS_ALL:
357 enabled = true;
358 break;
359
360 case OPT_LEVELS_0_ONLY:
361 enabled = (level == 0);
362 break;
363
364 case OPT_LEVELS_1_PLUS:
365 enabled = (level >= 1);
366 break;
367
368 case OPT_LEVELS_1_PLUS_SPEED_ONLY:
369 enabled = (level >= 1 && !size && !debug);
370 break;
371
372 case OPT_LEVELS_1_PLUS_NOT_DEBUG:
373 enabled = (level >= 1 && !debug);
374 break;
375
376 case OPT_LEVELS_2_PLUS:
377 enabled = (level >= 2);
378 break;
379
380 case OPT_LEVELS_2_PLUS_SPEED_ONLY:
381 enabled = (level >= 2 && !size && !debug);
382 break;
383
384 case OPT_LEVELS_3_PLUS:
385 enabled = (level >= 3);
386 break;
387
388 case OPT_LEVELS_3_PLUS_AND_SIZE:
389 enabled = (level >= 3 || size);
390 break;
391
392 case OPT_LEVELS_SIZE:
393 enabled = size;
394 break;
395
396 case OPT_LEVELS_FAST:
397 enabled = fast;
398 break;
399
400 case OPT_LEVELS_NONE:
401 default:
402 gcc_unreachable ();
403 }
404
405 if (enabled)
406 handle_generated_option (opts, opts_set, default_opt->opt_index,
407 default_opt->arg, default_opt->value,
408 lang_mask, DK_UNSPECIFIED, loc,
409 handlers, dc);
410 else if (default_opt->arg == NULL
411 && !option->cl_reject_negative)
412 handle_generated_option (opts, opts_set, default_opt->opt_index,
413 default_opt->arg, !default_opt->value,
414 lang_mask, DK_UNSPECIFIED, loc,
415 handlers, dc);
416 }
417
418 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
419 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
420 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
421 language mask LANG_MASK and option handlers HANDLERS. */
422
423 static void
424 maybe_default_options (struct gcc_options *opts,
425 struct gcc_options *opts_set,
426 const struct default_options *default_opts,
427 int level, bool size, bool fast, bool debug,
428 unsigned int lang_mask,
429 const struct cl_option_handlers *handlers,
430 location_t loc,
431 diagnostic_context *dc)
432 {
433 size_t i;
434
435 for (i = 0; default_opts[i].levels != OPT_LEVELS_NONE; i++)
436 maybe_default_option (opts, opts_set, &default_opts[i],
437 level, size, fast, debug,
438 lang_mask, handlers, loc, dc);
439 }
440
441 /* Table of options enabled by default at different levels. */
442
443 static const struct default_options default_options_table[] =
444 {
445 /* -O1 optimizations. */
446 { OPT_LEVELS_1_PLUS, OPT_fdefer_pop, NULL, 1 },
447 #if DELAY_SLOTS
448 { OPT_LEVELS_1_PLUS, OPT_fdelayed_branch, NULL, 1 },
449 #endif
450 { OPT_LEVELS_1_PLUS, OPT_fguess_branch_probability, NULL, 1 },
451 { OPT_LEVELS_1_PLUS, OPT_fcprop_registers, NULL, 1 },
452 { OPT_LEVELS_1_PLUS, OPT_fforward_propagate, NULL, 1 },
453 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion, NULL, 1 },
454 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fif_conversion2, NULL, 1 },
455 { OPT_LEVELS_1_PLUS, OPT_fipa_pure_const, NULL, 1 },
456 { OPT_LEVELS_1_PLUS, OPT_fipa_reference, NULL, 1 },
457 { OPT_LEVELS_1_PLUS, OPT_fipa_profile, NULL, 1 },
458 { OPT_LEVELS_1_PLUS, OPT_fmerge_constants, NULL, 1 },
459 { OPT_LEVELS_1_PLUS, OPT_freorder_blocks, NULL, 1 },
460 { OPT_LEVELS_1_PLUS, OPT_fshrink_wrap, NULL, 1 },
461 { OPT_LEVELS_1_PLUS, OPT_fsplit_wide_types, NULL, 1 },
462 { OPT_LEVELS_1_PLUS, OPT_ftree_ccp, NULL, 1 },
463 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_bit_ccp, NULL, 1 },
464 { OPT_LEVELS_1_PLUS, OPT_ftree_coalesce_vars, NULL, 1 },
465 { OPT_LEVELS_1_PLUS, OPT_ftree_dce, NULL, 1 },
466 { OPT_LEVELS_1_PLUS, OPT_ftree_dominator_opts, NULL, 1 },
467 { OPT_LEVELS_1_PLUS, OPT_ftree_dse, NULL, 1 },
468 { OPT_LEVELS_1_PLUS, OPT_ftree_ter, NULL, 1 },
469 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_sra, NULL, 1 },
470 { OPT_LEVELS_1_PLUS, OPT_ftree_fre, NULL, 1 },
471 { OPT_LEVELS_1_PLUS, OPT_ftree_copy_prop, NULL, 1 },
472 { OPT_LEVELS_1_PLUS, OPT_ftree_sink, NULL, 1 },
473 { OPT_LEVELS_1_PLUS, OPT_ftree_ch, NULL, 1 },
474 { OPT_LEVELS_1_PLUS, OPT_fcombine_stack_adjustments, NULL, 1 },
475 { OPT_LEVELS_1_PLUS, OPT_fcompare_elim, NULL, 1 },
476 { OPT_LEVELS_1_PLUS, OPT_ftree_slsr, NULL, 1 },
477 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fbranch_count_reg, NULL, 1 },
478 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fmove_loop_invariants, NULL, 1 },
479 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_ftree_pta, NULL, 1 },
480 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_fssa_phiopt, NULL, 1 },
481 { OPT_LEVELS_1_PLUS, OPT_ftree_builtin_call_dce, NULL, 1 },
482
483 /* -O2 optimizations. */
484 { OPT_LEVELS_2_PLUS, OPT_finline_small_functions, NULL, 1 },
485 { OPT_LEVELS_2_PLUS, OPT_findirect_inlining, NULL, 1 },
486 { OPT_LEVELS_2_PLUS, OPT_fpartial_inlining, NULL, 1 },
487 { OPT_LEVELS_2_PLUS, OPT_fthread_jumps, NULL, 1 },
488 { OPT_LEVELS_2_PLUS, OPT_fcrossjumping, NULL, 1 },
489 { OPT_LEVELS_2_PLUS, OPT_foptimize_sibling_calls, NULL, 1 },
490 { OPT_LEVELS_2_PLUS, OPT_fcse_follow_jumps, NULL, 1 },
491 { OPT_LEVELS_2_PLUS, OPT_fgcse, NULL, 1 },
492 { OPT_LEVELS_2_PLUS, OPT_fexpensive_optimizations, NULL, 1 },
493 { OPT_LEVELS_2_PLUS, OPT_frerun_cse_after_loop, NULL, 1 },
494 { OPT_LEVELS_2_PLUS, OPT_fcaller_saves, NULL, 1 },
495 { OPT_LEVELS_2_PLUS, OPT_fpeephole2, NULL, 1 },
496 #ifdef INSN_SCHEDULING
497 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
498 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
499 { OPT_LEVELS_2_PLUS, OPT_fschedule_insns2, NULL, 1 },
500 #endif
501 { OPT_LEVELS_2_PLUS, OPT_fstrict_aliasing, NULL, 1 },
502 { OPT_LEVELS_2_PLUS, OPT_fstrict_overflow, NULL, 1 },
503 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
504 REORDER_BLOCKS_ALGORITHM_STC },
505 { OPT_LEVELS_2_PLUS, OPT_freorder_functions, NULL, 1 },
506 { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
507 { OPT_LEVELS_2_PLUS, OPT_ftree_pre, NULL, 1 },
508 { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
509 { OPT_LEVELS_2_PLUS, OPT_fipa_cp, NULL, 1 },
510 { OPT_LEVELS_2_PLUS, OPT_fipa_cp_alignment, NULL, 1 },
511 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize, NULL, 1 },
512 { OPT_LEVELS_2_PLUS, OPT_fdevirtualize_speculatively, NULL, 1 },
513 { OPT_LEVELS_2_PLUS, OPT_fipa_sra, NULL, 1 },
514 { OPT_LEVELS_2_PLUS, OPT_falign_loops, NULL, 1 },
515 { OPT_LEVELS_2_PLUS, OPT_falign_jumps, NULL, 1 },
516 { OPT_LEVELS_2_PLUS, OPT_falign_labels, NULL, 1 },
517 { OPT_LEVELS_2_PLUS, OPT_falign_functions, NULL, 1 },
518 { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
519 { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
520 { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
521 { OPT_LEVELS_2_PLUS, OPT_fhoist_adjacent_loads, NULL, 1 },
522 { OPT_LEVELS_2_PLUS, OPT_fipa_icf, NULL, 1 },
523 { OPT_LEVELS_2_PLUS, OPT_fisolate_erroneous_paths_dereference, NULL, 1 },
524 { OPT_LEVELS_2_PLUS, OPT_fipa_ra, NULL, 1 },
525 { OPT_LEVELS_2_PLUS, OPT_flra_remat, NULL, 1 },
526 { OPT_LEVELS_2_PLUS, OPT_fsplit_paths, NULL, 1 },
527
528 /* -O3 optimizations. */
529 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
530 { OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
531 /* Inlining of functions reducing size is a good idea with -Os
532 regardless of them being declared inline. */
533 { OPT_LEVELS_3_PLUS_AND_SIZE, OPT_finline_functions, NULL, 1 },
534 { OPT_LEVELS_1_PLUS_NOT_DEBUG, OPT_finline_functions_called_once, NULL, 1 },
535 { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
536 { OPT_LEVELS_3_PLUS, OPT_fgcse_after_reload, NULL, 1 },
537 { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
538 { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
539 { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
540 { OPT_LEVELS_3_PLUS, OPT_fipa_cp_clone, NULL, 1 },
541 { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
542
543 /* -Ofast adds optimizations to -O3. */
544 { OPT_LEVELS_FAST, OPT_ffast_math, NULL, 1 },
545
546 { OPT_LEVELS_NONE, 0, NULL, 0 }
547 };
548
549 /* Default the options in OPTS and OPTS_SET based on the optimization
550 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
551 void
552 default_options_optimization (struct gcc_options *opts,
553 struct gcc_options *opts_set,
554 struct cl_decoded_option *decoded_options,
555 unsigned int decoded_options_count,
556 location_t loc,
557 unsigned int lang_mask,
558 const struct cl_option_handlers *handlers,
559 diagnostic_context *dc)
560 {
561 unsigned int i;
562 int opt2;
563
564 /* Scan to see what optimization level has been specified. That will
565 determine the default value of many flags. */
566 for (i = 1; i < decoded_options_count; i++)
567 {
568 struct cl_decoded_option *opt = &decoded_options[i];
569 switch (opt->opt_index)
570 {
571 case OPT_O:
572 if (*opt->arg == '\0')
573 {
574 opts->x_optimize = 1;
575 opts->x_optimize_size = 0;
576 opts->x_optimize_fast = 0;
577 opts->x_optimize_debug = 0;
578 }
579 else
580 {
581 const int optimize_val = integral_argument (opt->arg);
582 if (optimize_val == -1)
583 error_at (loc, "argument to %<-O%> should be a non-negative "
584 "integer, %<g%>, %<s%> or %<fast%>");
585 else
586 {
587 opts->x_optimize = optimize_val;
588 if ((unsigned int) opts->x_optimize > 255)
589 opts->x_optimize = 255;
590 opts->x_optimize_size = 0;
591 opts->x_optimize_fast = 0;
592 opts->x_optimize_debug = 0;
593 }
594 }
595 break;
596
597 case OPT_Os:
598 opts->x_optimize_size = 1;
599
600 /* Optimizing for size forces optimize to be 2. */
601 opts->x_optimize = 2;
602 opts->x_optimize_fast = 0;
603 opts->x_optimize_debug = 0;
604 break;
605
606 case OPT_Ofast:
607 /* -Ofast only adds flags to -O3. */
608 opts->x_optimize_size = 0;
609 opts->x_optimize = 3;
610 opts->x_optimize_fast = 1;
611 opts->x_optimize_debug = 0;
612 break;
613
614 case OPT_Og:
615 /* -Og selects optimization level 1. */
616 opts->x_optimize_size = 0;
617 opts->x_optimize = 1;
618 opts->x_optimize_fast = 0;
619 opts->x_optimize_debug = 1;
620 break;
621
622 default:
623 /* Ignore other options in this prescan. */
624 break;
625 }
626 }
627
628 maybe_default_options (opts, opts_set, default_options_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 /* -O2 param settings. */
634 opt2 = (opts->x_optimize >= 2);
635
636 /* Track fields in field-sensitive alias analysis. */
637 maybe_set_param_value
638 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE,
639 opt2 ? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE),
640 opts->x_param_values, opts_set->x_param_values);
641
642 /* For -O1 only do loop invariant motion for very small loops. */
643 maybe_set_param_value
644 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP,
645 opt2 ? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) : 1000,
646 opts->x_param_values, opts_set->x_param_values);
647
648 /* At -Ofast, allow store motion to introduce potential race conditions. */
649 maybe_set_param_value
650 (PARAM_ALLOW_STORE_DATA_RACES,
651 opts->x_optimize_fast ? 1
652 : default_param_value (PARAM_ALLOW_STORE_DATA_RACES),
653 opts->x_param_values, opts_set->x_param_values);
654
655 if (opts->x_optimize_size)
656 /* We want to crossjump as much as possible. */
657 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS, 1,
658 opts->x_param_values, opts_set->x_param_values);
659 else
660 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS,
661 default_param_value (PARAM_MIN_CROSSJUMP_INSNS),
662 opts->x_param_values, opts_set->x_param_values);
663
664 /* Restrict the amount of work combine does at -Og while retaining
665 most of its useful transforms. */
666 if (opts->x_optimize_debug)
667 maybe_set_param_value (PARAM_MAX_COMBINE_INSNS, 2,
668 opts->x_param_values, opts_set->x_param_values);
669
670 /* Allow default optimizations to be specified on a per-machine basis. */
671 maybe_default_options (opts, opts_set,
672 targetm_common.option_optimization_table,
673 opts->x_optimize, opts->x_optimize_size,
674 opts->x_optimize_fast, opts->x_optimize_debug,
675 lang_mask, handlers, loc, dc);
676 }
677
678 /* After all options at LOC have been read into OPTS and OPTS_SET,
679 finalize settings of those options and diagnose incompatible
680 combinations. */
681 void
682 finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
683 location_t loc)
684 {
685 enum unwind_info_type ui_except;
686
687 if (opts->x_dump_base_name
688 && ! IS_ABSOLUTE_PATH (opts->x_dump_base_name)
689 && ! opts->x_dump_base_name_prefixed)
690 {
691 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
692 OPTS->X_DUMP_DIR_NAME directory. Then try to make
693 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
694 directory, typically the directory to contain the object
695 file. */
696 if (opts->x_dump_dir_name)
697 opts->x_dump_base_name = opts_concat (opts->x_dump_dir_name,
698 opts->x_dump_base_name, NULL);
699 else if (opts->x_aux_base_name
700 && strcmp (opts->x_aux_base_name, HOST_BIT_BUCKET) != 0)
701 {
702 const char *aux_base;
703
704 base_of_path (opts->x_aux_base_name, &aux_base);
705 if (opts->x_aux_base_name != aux_base)
706 {
707 int dir_len = aux_base - opts->x_aux_base_name;
708 char *new_dump_base_name
709 = XOBNEWVEC (&opts_obstack, char,
710 strlen (opts->x_dump_base_name) + dir_len + 1);
711
712 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
713 memcpy (new_dump_base_name, opts->x_aux_base_name, dir_len);
714 /* Append existing OPTS->X_DUMP_BASE_NAME. */
715 strcpy (new_dump_base_name + dir_len, opts->x_dump_base_name);
716 opts->x_dump_base_name = new_dump_base_name;
717 }
718 }
719 opts->x_dump_base_name_prefixed = true;
720 }
721
722 /* Handle related options for unit-at-a-time, toplevel-reorder, and
723 section-anchors. */
724 if (!opts->x_flag_unit_at_a_time)
725 {
726 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
727 error_at (loc, "section anchors must be disabled when unit-at-a-time "
728 "is disabled");
729 opts->x_flag_section_anchors = 0;
730 if (opts->x_flag_toplevel_reorder == 1)
731 error_at (loc, "toplevel reorder must be disabled when unit-at-a-time "
732 "is disabled");
733 opts->x_flag_toplevel_reorder = 0;
734 }
735
736 if (opts->x_flag_tm && opts->x_flag_non_call_exceptions)
737 sorry ("transactional memory is not supported with non-call exceptions");
738
739 /* Unless the user has asked for section anchors, we disable toplevel
740 reordering at -O0 to disable transformations that might be surprising
741 to end users and to get -fno-toplevel-reorder tested. */
742 if (!opts->x_optimize
743 && opts->x_flag_toplevel_reorder == 2
744 && !(opts->x_flag_section_anchors && opts_set->x_flag_section_anchors))
745 {
746 opts->x_flag_toplevel_reorder = 0;
747 opts->x_flag_section_anchors = 0;
748 }
749 if (!opts->x_flag_toplevel_reorder)
750 {
751 if (opts->x_flag_section_anchors && opts_set->x_flag_section_anchors)
752 error_at (loc, "section anchors must be disabled when toplevel reorder"
753 " is disabled");
754 opts->x_flag_section_anchors = 0;
755 }
756
757 if (!opts->x_flag_opts_finished)
758 {
759 /* We initialize opts->x_flag_pie to -1 so that targets can set a
760 default value. */
761 if (opts->x_flag_pie == -1)
762 {
763 if (opts->x_flag_pic == 0)
764 opts->x_flag_pie = DEFAULT_FLAG_PIE;
765 else
766 opts->x_flag_pie = 0;
767 }
768 if (opts->x_flag_pie)
769 opts->x_flag_pic = opts->x_flag_pie;
770 if (opts->x_flag_pic && !opts->x_flag_pie)
771 opts->x_flag_shlib = 1;
772 opts->x_flag_opts_finished = true;
773 }
774
775 /* We initialize opts->x_flag_stack_protect to -1 so that targets
776 can set a default value. */
777 if (opts->x_flag_stack_protect == -1)
778 opts->x_flag_stack_protect = DEFAULT_FLAG_SSP;
779
780 if (opts->x_optimize == 0)
781 {
782 /* Inlining does not work if not optimizing,
783 so force it not to be done. */
784 opts->x_warn_inline = 0;
785 opts->x_flag_no_inline = 1;
786 }
787
788 /* The optimization to partition hot and cold basic blocks into separate
789 sections of the .o and executable files does not work (currently)
790 with exception handling. This is because there is no support for
791 generating unwind info. If opts->x_flag_exceptions is turned on
792 we need to turn off the partitioning optimization. */
793
794 ui_except = targetm_common.except_unwind_info (opts);
795
796 if (opts->x_flag_exceptions
797 && opts->x_flag_reorder_blocks_and_partition
798 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
799 {
800 if (opts_set->x_flag_reorder_blocks_and_partition)
801 inform (loc,
802 "-freorder-blocks-and-partition does not work "
803 "with exceptions on this architecture");
804 opts->x_flag_reorder_blocks_and_partition = 0;
805 opts->x_flag_reorder_blocks = 1;
806 }
807
808 /* If user requested unwind info, then turn off the partitioning
809 optimization. */
810
811 if (opts->x_flag_unwind_tables
812 && !targetm_common.unwind_tables_default
813 && opts->x_flag_reorder_blocks_and_partition
814 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))
815 {
816 if (opts_set->x_flag_reorder_blocks_and_partition)
817 inform (loc,
818 "-freorder-blocks-and-partition does not support "
819 "unwind info on this architecture");
820 opts->x_flag_reorder_blocks_and_partition = 0;
821 opts->x_flag_reorder_blocks = 1;
822 }
823
824 /* If the target requested unwind info, then turn off the partitioning
825 optimization with a different message. Likewise, if the target does not
826 support named sections. */
827
828 if (opts->x_flag_reorder_blocks_and_partition
829 && (!targetm_common.have_named_sections
830 || (opts->x_flag_unwind_tables
831 && targetm_common.unwind_tables_default
832 && (ui_except == UI_SJLJ || ui_except >= UI_TARGET))))
833 {
834 if (opts_set->x_flag_reorder_blocks_and_partition)
835 inform (loc,
836 "-freorder-blocks-and-partition does not work "
837 "on this architecture");
838 opts->x_flag_reorder_blocks_and_partition = 0;
839 opts->x_flag_reorder_blocks = 1;
840 }
841
842 /* Disable -freorder-blocks-and-partition when -fprofile-use is not in
843 effect. Function splitting was not actually being performed in that case,
844 as probably_never_executed_bb_p does not distinguish any basic blocks as
845 being cold vs hot when there is no profile data. Leaving it enabled,
846 however, causes the assembly code generator to create (empty) cold
847 sections and labels, leading to unnecessary size overhead. */
848 if (opts->x_flag_reorder_blocks_and_partition
849 && !opts_set->x_flag_profile_use)
850 opts->x_flag_reorder_blocks_and_partition = 0;
851
852 if (opts->x_flag_reorder_blocks_and_partition
853 && !opts_set->x_flag_reorder_functions)
854 opts->x_flag_reorder_functions = 1;
855
856 /* Pipelining of outer loops is only possible when general pipelining
857 capabilities are requested. */
858 if (!opts->x_flag_sel_sched_pipelining)
859 opts->x_flag_sel_sched_pipelining_outer_loops = 0;
860
861 if (opts->x_flag_conserve_stack)
862 {
863 maybe_set_param_value (PARAM_LARGE_STACK_FRAME, 100,
864 opts->x_param_values, opts_set->x_param_values);
865 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH, 40,
866 opts->x_param_values, opts_set->x_param_values);
867 }
868
869 if (opts->x_flag_lto)
870 {
871 #ifdef ENABLE_LTO
872 opts->x_flag_generate_lto = 1;
873
874 /* When generating IL, do not operate in whole-program mode.
875 Otherwise, symbols will be privatized too early, causing link
876 errors later. */
877 opts->x_flag_whole_program = 0;
878 #else
879 error_at (loc, "LTO support has not been enabled in this configuration");
880 #endif
881 if (!opts->x_flag_fat_lto_objects
882 && (!HAVE_LTO_PLUGIN
883 || (opts_set->x_flag_use_linker_plugin
884 && !opts->x_flag_use_linker_plugin)))
885 {
886 if (opts_set->x_flag_fat_lto_objects)
887 error_at (loc, "-fno-fat-lto-objects are supported only with linker plugin");
888 opts->x_flag_fat_lto_objects = 1;
889 }
890 }
891
892 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
893 default value if they choose based on other options. */
894 if (opts->x_flag_split_stack == -1)
895 opts->x_flag_split_stack = 0;
896 else if (opts->x_flag_split_stack)
897 {
898 if (!targetm_common.supports_split_stack (true, opts))
899 {
900 error_at (loc, "%<-fsplit-stack%> is not supported by "
901 "this compiler configuration");
902 opts->x_flag_split_stack = 0;
903 }
904 }
905
906 /* Tune vectorization related parametees according to cost model. */
907 if (opts->x_flag_vect_cost_model == VECT_COST_MODEL_CHEAP)
908 {
909 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS,
910 6, opts->x_param_values, opts_set->x_param_values);
911 maybe_set_param_value (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS,
912 0, opts->x_param_values, opts_set->x_param_values);
913 maybe_set_param_value (PARAM_VECT_MAX_PEELING_FOR_ALIGNMENT,
914 0, opts->x_param_values, opts_set->x_param_values);
915 }
916
917 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
918 is disabled. */
919 if ((!opts->x_flag_tree_loop_vectorize && !opts->x_flag_tree_slp_vectorize)
920 || !opts->x_flag_tree_loop_if_convert)
921 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK, 0,
922 opts->x_param_values, opts_set->x_param_values);
923
924 /* The -gsplit-dwarf option requires -ggnu-pubnames. */
925 if (opts->x_dwarf_split_debug_info)
926 opts->x_debug_generate_pub_sections = 2;
927
928 /* Userspace and kernel ASan conflict with each other. */
929
930 if ((opts->x_flag_sanitize & SANITIZE_USER_ADDRESS)
931 && (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS))
932 error_at (loc,
933 "-fsanitize=address is incompatible with "
934 "-fsanitize=kernel-address");
935
936 /* And with TSan. */
937
938 if ((opts->x_flag_sanitize & SANITIZE_ADDRESS)
939 && (opts->x_flag_sanitize & SANITIZE_THREAD))
940 error_at (loc,
941 "-fsanitize=address and -fsanitize=kernel-address "
942 "are incompatible with -fsanitize=thread");
943
944 /* Error recovery is not allowed for LSan and TSan. */
945
946 if (opts->x_flag_sanitize_recover & SANITIZE_THREAD)
947 error_at (loc, "-fsanitize-recover=thread is not supported");
948
949 if (opts->x_flag_sanitize_recover & SANITIZE_LEAK)
950 error_at (loc, "-fsanitize-recover=leak is not supported");
951
952 /* When instrumenting the pointers, we don't want to remove
953 the null pointer checks. */
954 if (opts->x_flag_sanitize & (SANITIZE_NULL | SANITIZE_NONNULL_ATTRIBUTE
955 | SANITIZE_RETURNS_NONNULL_ATTRIBUTE))
956 opts->x_flag_delete_null_pointer_checks = 0;
957
958 /* Aggressive compiler optimizations may cause false negatives. */
959 if (opts->x_flag_sanitize)
960 {
961 opts->x_flag_aggressive_loop_optimizations = 0;
962 opts->x_flag_strict_overflow = 0;
963 }
964 }
965
966 #define LEFT_COLUMN 27
967
968 /* Output ITEM, of length ITEM_WIDTH, in the left column,
969 followed by word-wrapped HELP in a second column. */
970 static void
971 wrap_help (const char *help,
972 const char *item,
973 unsigned int item_width,
974 unsigned int columns)
975 {
976 unsigned int col_width = LEFT_COLUMN;
977 unsigned int remaining, room, len;
978
979 remaining = strlen (help);
980
981 do
982 {
983 room = columns - 3 - MAX (col_width, item_width);
984 if (room > columns)
985 room = 0;
986 len = remaining;
987
988 if (room < len)
989 {
990 unsigned int i;
991
992 for (i = 0; help[i]; i++)
993 {
994 if (i >= room && len != remaining)
995 break;
996 if (help[i] == ' ')
997 len = i;
998 else if ((help[i] == '-' || help[i] == '/')
999 && help[i + 1] != ' '
1000 && i > 0 && ISALPHA (help[i - 1]))
1001 len = i + 1;
1002 }
1003 }
1004
1005 printf (" %-*.*s %.*s\n", col_width, item_width, item, len, help);
1006 item_width = 0;
1007 while (help[len] == ' ')
1008 len++;
1009 help += len;
1010 remaining -= len;
1011 }
1012 while (remaining);
1013 }
1014
1015 /* Print help for a specific front-end, etc. */
1016 static void
1017 print_filtered_help (unsigned int include_flags,
1018 unsigned int exclude_flags,
1019 unsigned int any_flags,
1020 unsigned int columns,
1021 struct gcc_options *opts,
1022 unsigned int lang_mask)
1023 {
1024 unsigned int i;
1025 const char *help;
1026 bool found = false;
1027 bool displayed = false;
1028 char new_help[256];
1029
1030 if (include_flags == CL_PARAMS)
1031 {
1032 for (i = 0; i < LAST_PARAM; i++)
1033 {
1034 const char *param = compiler_params[i].option;
1035
1036 help = compiler_params[i].help;
1037 if (help == NULL || *help == '\0')
1038 {
1039 if (exclude_flags & CL_UNDOCUMENTED)
1040 continue;
1041 help = undocumented_msg;
1042 }
1043
1044 /* Get the translation. */
1045 help = _(help);
1046
1047 if (!opts->x_quiet_flag)
1048 {
1049 snprintf (new_help, sizeof (new_help),
1050 _("default %d minimum %d maximum %d"),
1051 compiler_params[i].default_value,
1052 compiler_params[i].min_value,
1053 compiler_params[i].max_value);
1054 help = new_help;
1055 }
1056 wrap_help (help, param, strlen (param), columns);
1057 }
1058 putchar ('\n');
1059 return;
1060 }
1061
1062 if (!opts->x_help_printed)
1063 opts->x_help_printed = XCNEWVAR (char, cl_options_count);
1064
1065 if (!opts->x_help_enum_printed)
1066 opts->x_help_enum_printed = XCNEWVAR (char, cl_enums_count);
1067
1068 for (i = 0; i < cl_options_count; i++)
1069 {
1070 const struct cl_option *option = cl_options + i;
1071 unsigned int len;
1072 const char *opt;
1073 const char *tab;
1074
1075 if (include_flags == 0
1076 || ((option->flags & include_flags) != include_flags))
1077 {
1078 if ((option->flags & any_flags) == 0)
1079 continue;
1080 }
1081
1082 /* Skip unwanted switches. */
1083 if ((option->flags & exclude_flags) != 0)
1084 continue;
1085
1086 /* The driver currently prints its own help text. */
1087 if ((option->flags & CL_DRIVER) != 0
1088 && (option->flags & (((1U << cl_lang_count) - 1)
1089 | CL_COMMON | CL_TARGET)) == 0)
1090 continue;
1091
1092 found = true;
1093 /* Skip switches that have already been printed. */
1094 if (opts->x_help_printed[i])
1095 continue;
1096
1097 opts->x_help_printed[i] = true;
1098
1099 help = option->help;
1100 if (help == NULL)
1101 {
1102 if (exclude_flags & CL_UNDOCUMENTED)
1103 continue;
1104
1105 help = undocumented_msg;
1106 }
1107
1108 if (option->alias_target < N_OPTS
1109 && cl_options [option->alias_target].help)
1110 {
1111 if (help == undocumented_msg)
1112 {
1113 /* For undocumented options that are aliases for other options
1114 that are documented, point the reader to the other option in
1115 preference of the former. */
1116 snprintf (new_help, sizeof new_help,
1117 _("Same as %s. Use the latter option instead."),
1118 cl_options [option->alias_target].opt_text);
1119 }
1120 else
1121 {
1122 /* For documented options with aliases, mention the aliased
1123 option's name for reference. */
1124 snprintf (new_help, sizeof new_help,
1125 _("%s Same as %s."),
1126 help, cl_options [option->alias_target].opt_text);
1127 }
1128
1129 help = new_help;
1130 }
1131
1132 if (option->warn_message)
1133 {
1134 /* Mention that the use of the option will trigger a warning. */
1135 if (help == new_help)
1136 snprintf (new_help + strlen (new_help),
1137 sizeof new_help - strlen (new_help),
1138 " %s", _(use_diagnosed_msg));
1139 else
1140 snprintf (new_help, sizeof new_help,
1141 "%s %s", help, _(use_diagnosed_msg));
1142
1143 help = new_help;
1144 }
1145
1146 /* Get the translation. */
1147 help = _(help);
1148
1149 /* Find the gap between the name of the
1150 option and its descriptive text. */
1151 tab = strchr (help, '\t');
1152 if (tab)
1153 {
1154 len = tab - help;
1155 opt = help;
1156 help = tab + 1;
1157 }
1158 else
1159 {
1160 opt = option->opt_text;
1161 len = strlen (opt);
1162 }
1163
1164 /* With the -Q option enabled we change the descriptive text associated
1165 with an option to be an indication of its current setting. */
1166 if (!opts->x_quiet_flag)
1167 {
1168 void *flag_var = option_flag_var (i, opts);
1169
1170 if (len < (LEFT_COLUMN + 2))
1171 strcpy (new_help, "\t\t");
1172 else
1173 strcpy (new_help, "\t");
1174
1175 if (flag_var != NULL
1176 && option->var_type != CLVC_DEFER)
1177 {
1178 if (option->flags & CL_JOINED)
1179 {
1180 if (option->var_type == CLVC_STRING)
1181 {
1182 if (* (const char **) flag_var != NULL)
1183 snprintf (new_help + strlen (new_help),
1184 sizeof (new_help) - strlen (new_help),
1185 "%s", * (const char **) flag_var);
1186 }
1187 else if (option->var_type == CLVC_ENUM)
1188 {
1189 const struct cl_enum *e = &cl_enums[option->var_enum];
1190 int value;
1191 const char *arg = NULL;
1192
1193 value = e->get (flag_var);
1194 enum_value_to_arg (e->values, &arg, value, lang_mask);
1195 if (arg == NULL)
1196 arg = _("[default]");
1197 snprintf (new_help + strlen (new_help),
1198 sizeof (new_help) - strlen (new_help),
1199 "%s", arg);
1200 }
1201 else
1202 sprintf (new_help + strlen (new_help),
1203 "%#x", * (int *) flag_var);
1204 }
1205 else
1206 strcat (new_help, option_enabled (i, opts)
1207 ? _("[enabled]") : _("[disabled]"));
1208 }
1209
1210 help = new_help;
1211 }
1212
1213 wrap_help (help, opt, len, columns);
1214 displayed = true;
1215
1216 if (option->var_type == CLVC_ENUM
1217 && opts->x_help_enum_printed[option->var_enum] != 2)
1218 opts->x_help_enum_printed[option->var_enum] = 1;
1219 }
1220
1221 if (! found)
1222 {
1223 unsigned int langs = include_flags & CL_LANG_ALL;
1224
1225 if (langs == 0)
1226 printf (_(" No options with the desired characteristics were found\n"));
1227 else
1228 {
1229 unsigned int i;
1230
1231 /* PR 31349: Tell the user how to see all of the
1232 options supported by a specific front end. */
1233 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1234 if ((1U << i) & langs)
1235 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end.\n"),
1236 lang_names[i], lang_names[i]);
1237 }
1238
1239 }
1240 else if (! displayed)
1241 printf (_(" All options with the desired characteristics have already been displayed\n"));
1242
1243 putchar ('\n');
1244
1245 /* Print details of enumerated option arguments, if those
1246 enumerations have help text headings provided. If no help text
1247 is provided, presume that the possible values are listed in the
1248 help text for the relevant options. */
1249 for (i = 0; i < cl_enums_count; i++)
1250 {
1251 unsigned int j, pos;
1252
1253 if (opts->x_help_enum_printed[i] != 1)
1254 continue;
1255 if (cl_enums[i].help == NULL)
1256 continue;
1257 printf (" %s\n ", _(cl_enums[i].help));
1258 pos = 4;
1259 for (j = 0; cl_enums[i].values[j].arg != NULL; j++)
1260 {
1261 unsigned int len = strlen (cl_enums[i].values[j].arg);
1262
1263 if (pos > 4 && pos + 1 + len <= columns)
1264 {
1265 printf (" %s", cl_enums[i].values[j].arg);
1266 pos += 1 + len;
1267 }
1268 else
1269 {
1270 if (pos > 4)
1271 {
1272 printf ("\n ");
1273 pos = 4;
1274 }
1275 printf ("%s", cl_enums[i].values[j].arg);
1276 pos += len;
1277 }
1278 }
1279 printf ("\n\n");
1280 opts->x_help_enum_printed[i] = 2;
1281 }
1282 }
1283
1284 /* Display help for a specified type of option.
1285 The options must have ALL of the INCLUDE_FLAGS set
1286 ANY of the flags in the ANY_FLAGS set
1287 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1288 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1289 static void
1290 print_specific_help (unsigned int include_flags,
1291 unsigned int exclude_flags,
1292 unsigned int any_flags,
1293 struct gcc_options *opts,
1294 unsigned int lang_mask)
1295 {
1296 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1297 const char * description = NULL;
1298 const char * descrip_extra = "";
1299 size_t i;
1300 unsigned int flag;
1301
1302 /* Sanity check: Make sure that we do not have more
1303 languages than we have bits available to enumerate them. */
1304 gcc_assert ((1U << cl_lang_count) <= CL_MIN_OPTION_CLASS);
1305
1306 /* If we have not done so already, obtain
1307 the desired maximum width of the output. */
1308 if (opts->x_help_columns == 0)
1309 {
1310 opts->x_help_columns = get_terminal_width ();
1311 if (opts->x_help_columns == INT_MAX)
1312 /* Use a reasonable default. */
1313 opts->x_help_columns = 80;
1314 }
1315
1316 /* Decide upon the title for the options that we are going to display. */
1317 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1318 {
1319 switch (flag & include_flags)
1320 {
1321 case 0:
1322 case CL_DRIVER:
1323 break;
1324
1325 case CL_TARGET:
1326 description = _("The following options are target specific");
1327 break;
1328 case CL_WARNING:
1329 description = _("The following options control compiler warning messages");
1330 break;
1331 case CL_OPTIMIZATION:
1332 description = _("The following options control optimizations");
1333 break;
1334 case CL_COMMON:
1335 description = _("The following options are language-independent");
1336 break;
1337 case CL_PARAMS:
1338 description = _("The --param option recognizes the following as parameters");
1339 break;
1340 default:
1341 if (i >= cl_lang_count)
1342 break;
1343 if (exclude_flags & all_langs_mask)
1344 description = _("The following options are specific to just the language ");
1345 else
1346 description = _("The following options are supported by the language ");
1347 descrip_extra = lang_names [i];
1348 break;
1349 }
1350 }
1351
1352 if (description == NULL)
1353 {
1354 if (any_flags == 0)
1355 {
1356 if (include_flags & CL_UNDOCUMENTED)
1357 description = _("The following options are not documented");
1358 else if (include_flags & CL_SEPARATE)
1359 description = _("The following options take separate arguments");
1360 else if (include_flags & CL_JOINED)
1361 description = _("The following options take joined arguments");
1362 else
1363 {
1364 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1365 include_flags);
1366 return;
1367 }
1368 }
1369 else
1370 {
1371 if (any_flags & all_langs_mask)
1372 description = _("The following options are language-related");
1373 else
1374 description = _("The following options are language-independent");
1375 }
1376 }
1377
1378 printf ("%s%s:\n", description, descrip_extra);
1379 print_filtered_help (include_flags, exclude_flags, any_flags,
1380 opts->x_help_columns, opts, lang_mask);
1381 }
1382
1383 /* Enable FDO-related flags. */
1384
1385 static void
1386 enable_fdo_optimizations (struct gcc_options *opts,
1387 struct gcc_options *opts_set,
1388 int value)
1389 {
1390 if (!opts_set->x_flag_branch_probabilities)
1391 opts->x_flag_branch_probabilities = value;
1392 if (!opts_set->x_flag_profile_values)
1393 opts->x_flag_profile_values = value;
1394 if (!opts_set->x_flag_unroll_loops)
1395 opts->x_flag_unroll_loops = value;
1396 if (!opts_set->x_flag_peel_loops)
1397 opts->x_flag_peel_loops = value;
1398 if (!opts_set->x_flag_tracer)
1399 opts->x_flag_tracer = value;
1400 if (!opts_set->x_flag_value_profile_transformations)
1401 opts->x_flag_value_profile_transformations = value;
1402 if (!opts_set->x_flag_inline_functions)
1403 opts->x_flag_inline_functions = value;
1404 if (!opts_set->x_flag_ipa_cp)
1405 opts->x_flag_ipa_cp = value;
1406 if (!opts_set->x_flag_ipa_cp_clone
1407 && value && opts->x_flag_ipa_cp)
1408 opts->x_flag_ipa_cp_clone = value;
1409 if (!opts_set->x_flag_ipa_cp_alignment
1410 && value && opts->x_flag_ipa_cp)
1411 opts->x_flag_ipa_cp_alignment = value;
1412 if (!opts_set->x_flag_predictive_commoning)
1413 opts->x_flag_predictive_commoning = value;
1414 if (!opts_set->x_flag_unswitch_loops)
1415 opts->x_flag_unswitch_loops = value;
1416 if (!opts_set->x_flag_gcse_after_reload)
1417 opts->x_flag_gcse_after_reload = value;
1418 if (!opts_set->x_flag_tree_loop_vectorize
1419 && !opts_set->x_flag_tree_vectorize)
1420 opts->x_flag_tree_loop_vectorize = value;
1421 if (!opts_set->x_flag_tree_slp_vectorize
1422 && !opts_set->x_flag_tree_vectorize)
1423 opts->x_flag_tree_slp_vectorize = value;
1424 if (!opts_set->x_flag_vect_cost_model)
1425 opts->x_flag_vect_cost_model = VECT_COST_MODEL_DYNAMIC;
1426 if (!opts_set->x_flag_tree_loop_distribute_patterns)
1427 opts->x_flag_tree_loop_distribute_patterns = value;
1428 }
1429
1430 /* Handle target- and language-independent options. Return zero to
1431 generate an "unknown option" message. Only options that need
1432 extra handling need to be listed here; if you simply want
1433 DECODED->value assigned to a variable, it happens automatically. */
1434
1435 bool
1436 common_handle_option (struct gcc_options *opts,
1437 struct gcc_options *opts_set,
1438 const struct cl_decoded_option *decoded,
1439 unsigned int lang_mask, int kind ATTRIBUTE_UNUSED,
1440 location_t loc,
1441 const struct cl_option_handlers *handlers,
1442 diagnostic_context *dc)
1443 {
1444 size_t scode = decoded->opt_index;
1445 const char *arg = decoded->arg;
1446 int value = decoded->value;
1447 enum opt_code code = (enum opt_code) scode;
1448
1449 gcc_assert (decoded->canonical_option_num_elements <= 2);
1450
1451 switch (code)
1452 {
1453 case OPT__param:
1454 handle_param (opts, opts_set, loc, arg);
1455 break;
1456
1457 case OPT__help:
1458 {
1459 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1460 unsigned int undoc_mask;
1461 unsigned int i;
1462
1463 if (lang_mask == CL_DRIVER)
1464 break;
1465
1466 undoc_mask = ((opts->x_verbose_flag | opts->x_extra_warnings)
1467 ? 0
1468 : CL_UNDOCUMENTED);
1469 /* First display any single language specific options. */
1470 for (i = 0; i < cl_lang_count; i++)
1471 print_specific_help
1472 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0, opts,
1473 lang_mask);
1474 /* Next display any multi language specific options. */
1475 print_specific_help (0, undoc_mask, all_langs_mask, opts, lang_mask);
1476 /* Then display any remaining, non-language options. */
1477 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1478 if (i != CL_DRIVER)
1479 print_specific_help (i, undoc_mask, 0, opts, lang_mask);
1480 opts->x_exit_after_options = true;
1481 break;
1482 }
1483
1484 case OPT__target_help:
1485 if (lang_mask == CL_DRIVER)
1486 break;
1487
1488 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0, opts, lang_mask);
1489 opts->x_exit_after_options = true;
1490 break;
1491
1492 case OPT__help_:
1493 {
1494 const char * a = arg;
1495 unsigned int include_flags = 0;
1496 /* Note - by default we include undocumented options when listing
1497 specific classes. If you only want to see documented options
1498 then add ",^undocumented" to the --help= option. E.g.:
1499
1500 --help=target,^undocumented */
1501 unsigned int exclude_flags = 0;
1502
1503 if (lang_mask == CL_DRIVER)
1504 break;
1505
1506 /* Walk along the argument string, parsing each word in turn.
1507 The format is:
1508 arg = [^]{word}[,{arg}]
1509 word = {optimizers|target|warnings|undocumented|
1510 params|common|<language>} */
1511 while (* a != 0)
1512 {
1513 static const struct
1514 {
1515 const char * string;
1516 unsigned int flag;
1517 }
1518 specifics[] =
1519 {
1520 { "optimizers", CL_OPTIMIZATION },
1521 { "target", CL_TARGET },
1522 { "warnings", CL_WARNING },
1523 { "undocumented", CL_UNDOCUMENTED },
1524 { "params", CL_PARAMS },
1525 { "joined", CL_JOINED },
1526 { "separate", CL_SEPARATE },
1527 { "common", CL_COMMON },
1528 { NULL, 0 }
1529 };
1530 unsigned int * pflags;
1531 const char * comma;
1532 unsigned int lang_flag, specific_flag;
1533 unsigned int len;
1534 unsigned int i;
1535
1536 if (* a == '^')
1537 {
1538 ++ a;
1539 pflags = & exclude_flags;
1540 }
1541 else
1542 pflags = & include_flags;
1543
1544 comma = strchr (a, ',');
1545 if (comma == NULL)
1546 len = strlen (a);
1547 else
1548 len = comma - a;
1549 if (len == 0)
1550 {
1551 a = comma + 1;
1552 continue;
1553 }
1554
1555 /* Check to see if the string matches an option class name. */
1556 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1557 if (strncasecmp (a, specifics[i].string, len) == 0)
1558 {
1559 specific_flag = specifics[i].flag;
1560 break;
1561 }
1562
1563 /* Check to see if the string matches a language name.
1564 Note - we rely upon the alpha-sorted nature of the entries in
1565 the lang_names array, specifically that shorter names appear
1566 before their longer variants. (i.e. C before C++). That way
1567 when we are attempting to match --help=c for example we will
1568 match with C first and not C++. */
1569 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1570 if (strncasecmp (a, lang_names[i], len) == 0)
1571 {
1572 lang_flag = 1U << i;
1573 break;
1574 }
1575
1576 if (specific_flag != 0)
1577 {
1578 if (lang_flag == 0)
1579 * pflags |= specific_flag;
1580 else
1581 {
1582 /* The option's argument matches both the start of a
1583 language name and the start of an option class name.
1584 We have a special case for when the user has
1585 specified "--help=c", but otherwise we have to issue
1586 a warning. */
1587 if (strncasecmp (a, "c", len) == 0)
1588 * pflags |= lang_flag;
1589 else
1590 warning_at (loc, 0,
1591 "--help argument %q.*s is ambiguous, "
1592 "please be more specific",
1593 len, a);
1594 }
1595 }
1596 else if (lang_flag != 0)
1597 * pflags |= lang_flag;
1598 else
1599 warning_at (loc, 0,
1600 "unrecognized argument to --help= option: %q.*s",
1601 len, a);
1602
1603 if (comma == NULL)
1604 break;
1605 a = comma + 1;
1606 }
1607
1608 if (include_flags)
1609 print_specific_help (include_flags, exclude_flags, 0, opts,
1610 lang_mask);
1611 opts->x_exit_after_options = true;
1612 break;
1613 }
1614
1615 case OPT__version:
1616 if (lang_mask == CL_DRIVER)
1617 break;
1618
1619 opts->x_exit_after_options = true;
1620 break;
1621
1622 case OPT_fsanitize_:
1623 case OPT_fsanitize_recover_:
1624 {
1625 const char *p = arg;
1626 unsigned int *flag
1627 = code == OPT_fsanitize_ ? &opts->x_flag_sanitize
1628 : &opts->x_flag_sanitize_recover;
1629 while (*p != 0)
1630 {
1631 static const struct
1632 {
1633 const char *const name;
1634 unsigned int flag;
1635 size_t len;
1636 } spec[] =
1637 {
1638 { "address", SANITIZE_ADDRESS | SANITIZE_USER_ADDRESS,
1639 sizeof "address" - 1 },
1640 { "kernel-address", SANITIZE_ADDRESS | SANITIZE_KERNEL_ADDRESS,
1641 sizeof "kernel-address" - 1 },
1642 { "thread", SANITIZE_THREAD, sizeof "thread" - 1 },
1643 { "leak", SANITIZE_LEAK, sizeof "leak" - 1 },
1644 { "shift", SANITIZE_SHIFT, sizeof "shift" - 1 },
1645 { "integer-divide-by-zero", SANITIZE_DIVIDE,
1646 sizeof "integer-divide-by-zero" - 1 },
1647 { "undefined", SANITIZE_UNDEFINED, sizeof "undefined" - 1 },
1648 { "unreachable", SANITIZE_UNREACHABLE,
1649 sizeof "unreachable" - 1 },
1650 { "vla-bound", SANITIZE_VLA, sizeof "vla-bound" - 1 },
1651 { "return", SANITIZE_RETURN, sizeof "return" - 1 },
1652 { "null", SANITIZE_NULL, sizeof "null" - 1 },
1653 { "signed-integer-overflow", SANITIZE_SI_OVERFLOW,
1654 sizeof "signed-integer-overflow" -1 },
1655 { "bool", SANITIZE_BOOL, sizeof "bool" - 1 },
1656 { "enum", SANITIZE_ENUM, sizeof "enum" - 1 },
1657 { "float-divide-by-zero", SANITIZE_FLOAT_DIVIDE,
1658 sizeof "float-divide-by-zero" - 1 },
1659 { "float-cast-overflow", SANITIZE_FLOAT_CAST,
1660 sizeof "float-cast-overflow" - 1 },
1661 { "bounds", SANITIZE_BOUNDS, sizeof "bounds" - 1 },
1662 { "bounds-strict", SANITIZE_BOUNDS | SANITIZE_BOUNDS_STRICT,
1663 sizeof "bounds-strict" - 1 },
1664 { "alignment", SANITIZE_ALIGNMENT, sizeof "alignment" - 1 },
1665 { "nonnull-attribute", SANITIZE_NONNULL_ATTRIBUTE,
1666 sizeof "nonnull-attribute" - 1 },
1667 { "returns-nonnull-attribute",
1668 SANITIZE_RETURNS_NONNULL_ATTRIBUTE,
1669 sizeof "returns-nonnull-attribute" - 1 },
1670 { "object-size", SANITIZE_OBJECT_SIZE,
1671 sizeof "object-size" - 1 },
1672 { "vptr", SANITIZE_VPTR, sizeof "vptr" - 1 },
1673 { "all", ~0, sizeof "all" - 1 },
1674 { NULL, 0, 0 }
1675 };
1676 const char *comma;
1677 size_t len, i;
1678 bool found = false;
1679
1680 comma = strchr (p, ',');
1681 if (comma == NULL)
1682 len = strlen (p);
1683 else
1684 len = comma - p;
1685 if (len == 0)
1686 {
1687 p = comma + 1;
1688 continue;
1689 }
1690
1691 /* Check to see if the string matches an option class name. */
1692 for (i = 0; spec[i].name != NULL; ++i)
1693 if (len == spec[i].len
1694 && memcmp (p, spec[i].name, len) == 0)
1695 {
1696 /* Handle both -fsanitize and -fno-sanitize cases. */
1697 if (value && spec[i].flag == ~0U)
1698 {
1699 if (code == OPT_fsanitize_)
1700 error_at (loc, "-fsanitize=all option is not valid");
1701 else
1702 *flag |= ~(SANITIZE_USER_ADDRESS | SANITIZE_THREAD
1703 | SANITIZE_LEAK);
1704 }
1705 else if (value)
1706 *flag |= spec[i].flag;
1707 else
1708 *flag &= ~spec[i].flag;
1709 found = true;
1710 break;
1711 }
1712
1713 if (! found)
1714 error_at (loc,
1715 "unrecognized argument to -fsanitize%s= option: %q.*s",
1716 code == OPT_fsanitize_ ? "" : "-recover", (int) len, p);
1717
1718 if (comma == NULL)
1719 break;
1720 p = comma + 1;
1721 }
1722
1723 if (code != OPT_fsanitize_)
1724 break;
1725
1726 /* Kernel ASan implies normal ASan but does not yet support
1727 all features. */
1728 if (opts->x_flag_sanitize & SANITIZE_KERNEL_ADDRESS)
1729 {
1730 maybe_set_param_value (PARAM_ASAN_INSTRUMENTATION_WITH_CALL_THRESHOLD, 0,
1731 opts->x_param_values,
1732 opts_set->x_param_values);
1733 maybe_set_param_value (PARAM_ASAN_GLOBALS, 0,
1734 opts->x_param_values,
1735 opts_set->x_param_values);
1736 maybe_set_param_value (PARAM_ASAN_STACK, 0,
1737 opts->x_param_values,
1738 opts_set->x_param_values);
1739 maybe_set_param_value (PARAM_ASAN_USE_AFTER_RETURN, 0,
1740 opts->x_param_values,
1741 opts_set->x_param_values);
1742 }
1743
1744 break;
1745 }
1746
1747 case OPT_fasan_shadow_offset_:
1748 /* Deferred. */
1749 break;
1750
1751 case OPT_fsanitize_recover:
1752 if (value)
1753 opts->x_flag_sanitize_recover
1754 |= SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT;
1755 else
1756 opts->x_flag_sanitize_recover
1757 &= ~(SANITIZE_UNDEFINED | SANITIZE_NONDEFAULT);
1758 break;
1759
1760 case OPT_O:
1761 case OPT_Os:
1762 case OPT_Ofast:
1763 case OPT_Og:
1764 /* Currently handled in a prescan. */
1765 break;
1766
1767 case OPT_Werror:
1768 dc->warning_as_error_requested = value;
1769 break;
1770
1771 case OPT_Werror_:
1772 if (lang_mask == CL_DRIVER)
1773 break;
1774
1775 enable_warning_as_error (arg, value, lang_mask, handlers,
1776 opts, opts_set, loc, dc);
1777 break;
1778
1779 case OPT_Wlarger_than_:
1780 opts->x_larger_than_size = value;
1781 opts->x_warn_larger_than = value != -1;
1782 break;
1783
1784 case OPT_Wfatal_errors:
1785 dc->fatal_errors = value;
1786 break;
1787
1788 case OPT_Wframe_larger_than_:
1789 opts->x_frame_larger_than_size = value;
1790 opts->x_warn_frame_larger_than = value != -1;
1791 break;
1792
1793 case OPT_Wstack_usage_:
1794 opts->x_warn_stack_usage = value;
1795 opts->x_flag_stack_usage_info = value != -1;
1796 break;
1797
1798 case OPT_Wstrict_aliasing:
1799 set_Wstrict_aliasing (opts, value);
1800 break;
1801
1802 case OPT_Wstrict_overflow:
1803 opts->x_warn_strict_overflow = (value
1804 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1805 : 0);
1806 break;
1807
1808 case OPT_Wsystem_headers:
1809 dc->dc_warn_system_headers = value;
1810 break;
1811
1812 case OPT_aux_info:
1813 opts->x_flag_gen_aux_info = 1;
1814 break;
1815
1816 case OPT_auxbase_strip:
1817 {
1818 char *tmp = xstrdup (arg);
1819 strip_off_ending (tmp, strlen (tmp));
1820 if (tmp[0])
1821 opts->x_aux_base_name = tmp;
1822 else
1823 free (tmp);
1824 }
1825 break;
1826
1827 case OPT_d:
1828 decode_d_option (arg, opts, loc, dc);
1829 break;
1830
1831 case OPT_fcall_used_:
1832 case OPT_fcall_saved_:
1833 /* Deferred. */
1834 break;
1835
1836 case OPT_fdbg_cnt_:
1837 /* Deferred. */
1838 break;
1839
1840 case OPT_fdbg_cnt_list:
1841 /* Deferred. */
1842 opts->x_exit_after_options = true;
1843 break;
1844
1845 case OPT_fdebug_prefix_map_:
1846 /* Deferred. */
1847 break;
1848
1849 case OPT_fdiagnostics_show_location_:
1850 diagnostic_prefixing_rule (dc) = (diagnostic_prefixing_rule_t) value;
1851 break;
1852
1853 case OPT_fdiagnostics_show_caret:
1854 dc->show_caret = value;
1855 break;
1856
1857 case OPT_fdiagnostics_color_:
1858 diagnostic_color_init (dc, value);
1859 break;
1860
1861 case OPT_fdiagnostics_show_option:
1862 dc->show_option_requested = value;
1863 break;
1864
1865 case OPT_fdump_:
1866 /* Deferred. */
1867 break;
1868
1869 case OPT_ffast_math:
1870 set_fast_math_flags (opts, value);
1871 break;
1872
1873 case OPT_funsafe_math_optimizations:
1874 set_unsafe_math_optimizations_flags (opts, value);
1875 break;
1876
1877 case OPT_ffixed_:
1878 /* Deferred. */
1879 break;
1880
1881 case OPT_finline_limit_:
1882 set_param_value ("max-inline-insns-single", value / 2,
1883 opts->x_param_values, opts_set->x_param_values);
1884 set_param_value ("max-inline-insns-auto", value / 2,
1885 opts->x_param_values, opts_set->x_param_values);
1886 break;
1887
1888 case OPT_finstrument_functions_exclude_function_list_:
1889 add_comma_separated_to_vector
1890 (&opts->x_flag_instrument_functions_exclude_functions, arg);
1891 break;
1892
1893 case OPT_finstrument_functions_exclude_file_list_:
1894 add_comma_separated_to_vector
1895 (&opts->x_flag_instrument_functions_exclude_files, arg);
1896 break;
1897
1898 case OPT_fmessage_length_:
1899 pp_set_line_maximum_length (dc->printer, value);
1900 diagnostic_set_caret_max_width (dc, value);
1901 break;
1902
1903 case OPT_fopt_info:
1904 case OPT_fopt_info_:
1905 /* Deferred. */
1906 break;
1907
1908 case OPT_foffload_:
1909 /* Deferred. */
1910 break;
1911
1912 #ifndef ACCEL_COMPILER
1913 case OPT_foffload_abi_:
1914 error_at (loc, "-foffload-abi option can be specified only for "
1915 "offload compiler");
1916 break;
1917 #endif
1918
1919 case OPT_fpack_struct_:
1920 if (value <= 0 || (value & (value - 1)) || value > 16)
1921 error_at (loc,
1922 "structure alignment must be a small power of two, not %d",
1923 value);
1924 else
1925 opts->x_initial_max_fld_align = value;
1926 break;
1927
1928 case OPT_fplugin_:
1929 case OPT_fplugin_arg_:
1930 /* Deferred. */
1931 break;
1932
1933 case OPT_fprofile_use_:
1934 opts->x_profile_data_prefix = xstrdup (arg);
1935 opts->x_flag_profile_use = true;
1936 value = true;
1937 /* No break here - do -fprofile-use processing. */
1938 case OPT_fprofile_use:
1939 enable_fdo_optimizations (opts, opts_set, value);
1940 if (!opts_set->x_flag_profile_reorder_functions)
1941 opts->x_flag_profile_reorder_functions = value;
1942 /* Indirect call profiling should do all useful transformations
1943 speculative devirtualization does. */
1944 if (!opts_set->x_flag_devirtualize_speculatively
1945 && opts->x_flag_value_profile_transformations)
1946 opts->x_flag_devirtualize_speculatively = false;
1947 break;
1948
1949 case OPT_fauto_profile_:
1950 opts->x_auto_profile_file = xstrdup (arg);
1951 opts->x_flag_auto_profile = true;
1952 value = true;
1953 /* No break here - do -fauto-profile processing. */
1954 case OPT_fauto_profile:
1955 enable_fdo_optimizations (opts, opts_set, value);
1956 if (!opts_set->x_flag_profile_correction)
1957 opts->x_flag_profile_correction = value;
1958 maybe_set_param_value (
1959 PARAM_EARLY_INLINER_MAX_ITERATIONS, 10,
1960 opts->x_param_values, opts_set->x_param_values);
1961 break;
1962
1963 case OPT_fprofile_generate_:
1964 opts->x_profile_data_prefix = xstrdup (arg);
1965 value = true;
1966 /* No break here - do -fprofile-generate processing. */
1967 case OPT_fprofile_generate:
1968 if (!opts_set->x_profile_arc_flag)
1969 opts->x_profile_arc_flag = value;
1970 if (!opts_set->x_flag_profile_values)
1971 opts->x_flag_profile_values = value;
1972 if (!opts_set->x_flag_inline_functions)
1973 opts->x_flag_inline_functions = value;
1974 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1975 quadratic. Disable the pass until better memory representation
1976 is done. */
1977 if (!opts_set->x_flag_ipa_reference)
1978 opts->x_flag_ipa_reference = false;
1979 break;
1980
1981 case OPT_ftree_vectorize:
1982 if (!opts_set->x_flag_tree_loop_vectorize)
1983 opts->x_flag_tree_loop_vectorize = value;
1984 if (!opts_set->x_flag_tree_slp_vectorize)
1985 opts->x_flag_tree_slp_vectorize = value;
1986 break;
1987 case OPT_fshow_column:
1988 dc->show_column = value;
1989 break;
1990
1991 case OPT_frandom_seed:
1992 /* The real switch is -fno-random-seed. */
1993 if (value)
1994 return false;
1995 /* Deferred. */
1996 break;
1997
1998 case OPT_frandom_seed_:
1999 /* Deferred. */
2000 break;
2001
2002 case OPT_fsched_verbose_:
2003 #ifdef INSN_SCHEDULING
2004 /* Handled with Var in common.opt. */
2005 break;
2006 #else
2007 return false;
2008 #endif
2009
2010 case OPT_fsched_stalled_insns_:
2011 opts->x_flag_sched_stalled_insns = value;
2012 if (opts->x_flag_sched_stalled_insns == 0)
2013 opts->x_flag_sched_stalled_insns = -1;
2014 break;
2015
2016 case OPT_fsched_stalled_insns_dep_:
2017 opts->x_flag_sched_stalled_insns_dep = value;
2018 break;
2019
2020 case OPT_fstack_check_:
2021 if (!strcmp (arg, "no"))
2022 opts->x_flag_stack_check = NO_STACK_CHECK;
2023 else if (!strcmp (arg, "generic"))
2024 /* This is the old stack checking method. */
2025 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2026 ? FULL_BUILTIN_STACK_CHECK
2027 : GENERIC_STACK_CHECK;
2028 else if (!strcmp (arg, "specific"))
2029 /* This is the new stack checking method. */
2030 opts->x_flag_stack_check = STACK_CHECK_BUILTIN
2031 ? FULL_BUILTIN_STACK_CHECK
2032 : STACK_CHECK_STATIC_BUILTIN
2033 ? STATIC_BUILTIN_STACK_CHECK
2034 : GENERIC_STACK_CHECK;
2035 else
2036 warning_at (loc, 0, "unknown stack check parameter %qs", arg);
2037 break;
2038
2039 case OPT_fstack_limit:
2040 /* The real switch is -fno-stack-limit. */
2041 if (value)
2042 return false;
2043 /* Deferred. */
2044 break;
2045
2046 case OPT_fstack_limit_register_:
2047 case OPT_fstack_limit_symbol_:
2048 /* Deferred. */
2049 break;
2050
2051 case OPT_fstack_usage:
2052 opts->x_flag_stack_usage = value;
2053 opts->x_flag_stack_usage_info = value != 0;
2054 break;
2055
2056 case OPT_g:
2057 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg, opts, opts_set,
2058 loc);
2059 break;
2060
2061 case OPT_gcoff:
2062 set_debug_level (SDB_DEBUG, false, arg, opts, opts_set, loc);
2063 break;
2064
2065 case OPT_gdwarf:
2066 if (arg && strlen (arg) != 0)
2067 {
2068 error_at (loc, "%<-gdwarf%s%> is ambiguous; "
2069 "use %<-gdwarf-%s%> for DWARF version "
2070 "or %<-gdwarf -g%s%> for debug level", arg, arg, arg);
2071 break;
2072 }
2073 else
2074 value = opts->x_dwarf_version;
2075
2076 /* FALLTHRU */
2077 case OPT_gdwarf_:
2078 if (value < 2 || value > 5)
2079 error_at (loc, "dwarf version %d is not supported", value);
2080 else
2081 opts->x_dwarf_version = value;
2082 set_debug_level (DWARF2_DEBUG, false, "", opts, opts_set, loc);
2083 break;
2084
2085 case OPT_gsplit_dwarf:
2086 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, "", opts, opts_set,
2087 loc);
2088 break;
2089
2090 case OPT_ggdb:
2091 set_debug_level (NO_DEBUG, 2, arg, opts, opts_set, loc);
2092 break;
2093
2094 case OPT_gstabs:
2095 case OPT_gstabs_:
2096 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg, opts, opts_set,
2097 loc);
2098 break;
2099
2100 case OPT_gvms:
2101 set_debug_level (VMS_DEBUG, false, arg, opts, opts_set, loc);
2102 break;
2103
2104 case OPT_gxcoff:
2105 case OPT_gxcoff_:
2106 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg, opts, opts_set,
2107 loc);
2108 break;
2109
2110 case OPT_gz:
2111 case OPT_gz_:
2112 /* Handled completely via specs. */
2113 break;
2114
2115 case OPT_pedantic_errors:
2116 dc->pedantic_errors = 1;
2117 control_warning_option (OPT_Wpedantic, DK_ERROR, value,
2118 loc, lang_mask,
2119 handlers, opts, opts_set,
2120 dc);
2121 break;
2122
2123 case OPT_flto:
2124 opts->x_flag_lto = value ? "" : NULL;
2125 break;
2126
2127 case OPT_w:
2128 dc->dc_inhibit_warnings = true;
2129 break;
2130
2131 case OPT_fmax_errors_:
2132 dc->max_errors = value;
2133 break;
2134
2135 case OPT_fuse_ld_bfd:
2136 case OPT_fuse_ld_gold:
2137 case OPT_fuse_linker_plugin:
2138 /* No-op. Used by the driver and passed to us because it starts with f.*/
2139 break;
2140
2141 case OPT_fwrapv:
2142 if (value)
2143 opts->x_flag_trapv = 0;
2144 break;
2145
2146 case OPT_ftrapv:
2147 if (value)
2148 opts->x_flag_wrapv = 0;
2149 break;
2150
2151 case OPT_fipa_icf:
2152 opts->x_flag_ipa_icf_functions = value;
2153 opts->x_flag_ipa_icf_variables = value;
2154 break;
2155
2156 default:
2157 /* If the flag was handled in a standard way, assume the lack of
2158 processing here is intentional. */
2159 gcc_assert (option_flag_var (scode, opts));
2160 break;
2161 }
2162
2163 common_handle_option_auto (opts, opts_set, decoded, lang_mask, kind,
2164 loc, handlers, dc);
2165 return true;
2166 }
2167
2168 /* Handle --param NAME=VALUE. */
2169 static void
2170 handle_param (struct gcc_options *opts, struct gcc_options *opts_set,
2171 location_t loc, const char *carg)
2172 {
2173 char *equal, *arg;
2174 int value;
2175
2176 arg = xstrdup (carg);
2177 equal = strchr (arg, '=');
2178 if (!equal)
2179 error_at (loc, "%s: --param arguments should be of the form NAME=VALUE",
2180 arg);
2181 else
2182 {
2183 *equal = '\0';
2184
2185 enum compiler_param index;
2186 if (!find_param (arg, &index))
2187 error_at (loc, "invalid --param name %qs", arg);
2188 else
2189 {
2190 if (!param_string_value_p (index, equal + 1, &value))
2191 value = integral_argument (equal + 1);
2192
2193 if (value == -1)
2194 error_at (loc, "invalid --param value %qs", equal + 1);
2195 else
2196 set_param_value (arg, value,
2197 opts->x_param_values, opts_set->x_param_values);
2198 }
2199 }
2200
2201 free (arg);
2202 }
2203
2204 /* Used to set the level of strict aliasing warnings in OPTS,
2205 when no level is specified (i.e., when -Wstrict-aliasing, and not
2206 -Wstrict-aliasing=level was given).
2207 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
2208 and 0 otherwise. After calling this function, wstrict_aliasing will be
2209 set to the default value of -Wstrict_aliasing=level, currently 3. */
2210 static void
2211 set_Wstrict_aliasing (struct gcc_options *opts, int onoff)
2212 {
2213 gcc_assert (onoff == 0 || onoff == 1);
2214 if (onoff != 0)
2215 opts->x_warn_strict_aliasing = 3;
2216 else
2217 opts->x_warn_strict_aliasing = 0;
2218 }
2219
2220 /* The following routines are useful in setting all the flags that
2221 -ffast-math and -fno-fast-math imply. */
2222 static void
2223 set_fast_math_flags (struct gcc_options *opts, int set)
2224 {
2225 if (!opts->frontend_set_flag_unsafe_math_optimizations)
2226 {
2227 opts->x_flag_unsafe_math_optimizations = set;
2228 set_unsafe_math_optimizations_flags (opts, set);
2229 }
2230 if (!opts->frontend_set_flag_finite_math_only)
2231 opts->x_flag_finite_math_only = set;
2232 if (!opts->frontend_set_flag_errno_math)
2233 opts->x_flag_errno_math = !set;
2234 if (set)
2235 {
2236 if (!opts->frontend_set_flag_signaling_nans)
2237 opts->x_flag_signaling_nans = 0;
2238 if (!opts->frontend_set_flag_rounding_math)
2239 opts->x_flag_rounding_math = 0;
2240 if (!opts->frontend_set_flag_cx_limited_range)
2241 opts->x_flag_cx_limited_range = 1;
2242 }
2243 }
2244
2245 /* When -funsafe-math-optimizations is set the following
2246 flags are set as well. */
2247 static void
2248 set_unsafe_math_optimizations_flags (struct gcc_options *opts, int set)
2249 {
2250 if (!opts->frontend_set_flag_trapping_math)
2251 opts->x_flag_trapping_math = !set;
2252 if (!opts->frontend_set_flag_signed_zeros)
2253 opts->x_flag_signed_zeros = !set;
2254 if (!opts->frontend_set_flag_associative_math)
2255 opts->x_flag_associative_math = set;
2256 if (!opts->frontend_set_flag_reciprocal_math)
2257 opts->x_flag_reciprocal_math = set;
2258 }
2259
2260 /* Return true iff flags in OPTS are set as if -ffast-math. */
2261 bool
2262 fast_math_flags_set_p (const struct gcc_options *opts)
2263 {
2264 return (!opts->x_flag_trapping_math
2265 && opts->x_flag_unsafe_math_optimizations
2266 && opts->x_flag_finite_math_only
2267 && !opts->x_flag_signed_zeros
2268 && !opts->x_flag_errno_math);
2269 }
2270
2271 /* Return true iff flags are set as if -ffast-math but using the flags stored
2272 in the struct cl_optimization structure. */
2273 bool
2274 fast_math_flags_struct_set_p (struct cl_optimization *opt)
2275 {
2276 return (!opt->x_flag_trapping_math
2277 && opt->x_flag_unsafe_math_optimizations
2278 && opt->x_flag_finite_math_only
2279 && !opt->x_flag_signed_zeros
2280 && !opt->x_flag_errno_math);
2281 }
2282
2283 /* Handle a debug output -g switch for options OPTS
2284 (OPTS_SET->x_write_symbols storing whether a debug type was passed
2285 explicitly), location LOC. EXTENDED is true or false to support
2286 extended output (2 is special and means "-ggdb" was given). */
2287 static void
2288 set_debug_level (enum debug_info_type type, int extended, const char *arg,
2289 struct gcc_options *opts, struct gcc_options *opts_set,
2290 location_t loc)
2291 {
2292 opts->x_use_gnu_debug_info_extensions = extended;
2293
2294 if (type == NO_DEBUG)
2295 {
2296 if (opts->x_write_symbols == NO_DEBUG)
2297 {
2298 opts->x_write_symbols = PREFERRED_DEBUGGING_TYPE;
2299
2300 if (extended == 2)
2301 {
2302 #if defined DWARF2_DEBUGGING_INFO || defined DWARF2_LINENO_DEBUGGING_INFO
2303 opts->x_write_symbols = DWARF2_DEBUG;
2304 #elif defined DBX_DEBUGGING_INFO
2305 opts->x_write_symbols = DBX_DEBUG;
2306 #endif
2307 }
2308
2309 if (opts->x_write_symbols == NO_DEBUG)
2310 warning_at (loc, 0, "target system does not support debug output");
2311 }
2312 }
2313 else
2314 {
2315 /* Does it conflict with an already selected type? */
2316 if (opts_set->x_write_symbols != NO_DEBUG
2317 && opts->x_write_symbols != NO_DEBUG
2318 && type != opts->x_write_symbols)
2319 error_at (loc, "debug format %qs conflicts with prior selection",
2320 debug_type_names[type]);
2321 opts->x_write_symbols = type;
2322 opts_set->x_write_symbols = type;
2323 }
2324
2325 /* A debug flag without a level defaults to level 2.
2326 If off or at level 1, set it to level 2, but if already
2327 at level 3, don't lower it. */
2328 if (*arg == '\0')
2329 {
2330 if (opts->x_debug_info_level < DINFO_LEVEL_NORMAL)
2331 opts->x_debug_info_level = DINFO_LEVEL_NORMAL;
2332 }
2333 else
2334 {
2335 int argval = integral_argument (arg);
2336 if (argval == -1)
2337 error_at (loc, "unrecognised debug output level %qs", arg);
2338 else if (argval > 3)
2339 error_at (loc, "debug output level %qs is too high", arg);
2340 else
2341 opts->x_debug_info_level = (enum debug_info_levels) argval;
2342 }
2343 }
2344
2345 /* Arrange to dump core on error for diagnostic context DC. (The
2346 regular error message is still printed first, except in the case of
2347 abort ().) */
2348
2349 static void
2350 setup_core_dumping (diagnostic_context *dc)
2351 {
2352 #ifdef SIGABRT
2353 signal (SIGABRT, SIG_DFL);
2354 #endif
2355 #if defined(HAVE_SETRLIMIT)
2356 {
2357 struct rlimit rlim;
2358 if (getrlimit (RLIMIT_CORE, &rlim) != 0)
2359 fatal_error (input_location, "getting core file size maximum limit: %m");
2360 rlim.rlim_cur = rlim.rlim_max;
2361 if (setrlimit (RLIMIT_CORE, &rlim) != 0)
2362 fatal_error (input_location,
2363 "setting core file size limit to maximum: %m");
2364 }
2365 #endif
2366 diagnostic_abort_on_error (dc);
2367 }
2368
2369 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
2370 diagnostic context DC. */
2371
2372 static void
2373 decode_d_option (const char *arg, struct gcc_options *opts,
2374 location_t loc, diagnostic_context *dc)
2375 {
2376 int c;
2377
2378 while (*arg)
2379 switch (c = *arg++)
2380 {
2381 case 'A':
2382 opts->x_flag_debug_asm = 1;
2383 break;
2384 case 'p':
2385 opts->x_flag_print_asm_name = 1;
2386 break;
2387 case 'P':
2388 opts->x_flag_dump_rtl_in_asm = 1;
2389 opts->x_flag_print_asm_name = 1;
2390 break;
2391 case 'x':
2392 opts->x_rtl_dump_and_exit = 1;
2393 break;
2394 case 'D': /* These are handled by the preprocessor. */
2395 case 'I':
2396 case 'M':
2397 case 'N':
2398 case 'U':
2399 break;
2400 case 'H':
2401 setup_core_dumping (dc);
2402 break;
2403 case 'a':
2404 opts->x_flag_dump_all_passed = true;
2405 break;
2406
2407 default:
2408 warning_at (loc, 0, "unrecognized gcc debugging option: %c", c);
2409 break;
2410 }
2411 }
2412
2413 /* Enable (or disable if VALUE is 0) a warning option ARG (language
2414 mask LANG_MASK, option handlers HANDLERS) as an error for option
2415 structures OPTS and OPTS_SET, diagnostic context DC (possibly
2416 NULL), location LOC. This is used by -Werror=. */
2417
2418 static void
2419 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask,
2420 const struct cl_option_handlers *handlers,
2421 struct gcc_options *opts,
2422 struct gcc_options *opts_set,
2423 location_t loc, diagnostic_context *dc)
2424 {
2425 char *new_option;
2426 int option_index;
2427
2428 new_option = XNEWVEC (char, strlen (arg) + 2);
2429 new_option[0] = 'W';
2430 strcpy (new_option + 1, arg);
2431 option_index = find_opt (new_option, lang_mask);
2432 if (option_index == OPT_SPECIAL_unknown)
2433 error_at (loc, "-Werror=%s: no option -%s", arg, new_option);
2434 else if (!(cl_options[option_index].flags & CL_WARNING))
2435 error_at (loc, "-Werror=%s: -%s is not an option that controls warnings",
2436 arg, new_option);
2437 else
2438 {
2439 const diagnostic_t kind = value ? DK_ERROR : DK_WARNING;
2440
2441 control_warning_option (option_index, (int) kind, value,
2442 loc, lang_mask,
2443 handlers, opts, opts_set, dc);
2444 }
2445 free (new_option);
2446 }
2447
2448 /* Return malloced memory for the name of the option OPTION_INDEX
2449 which enabled a diagnostic (context CONTEXT), originally of type
2450 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2451 as -Werror. */
2452
2453 char *
2454 option_name (diagnostic_context *context, int option_index,
2455 diagnostic_t orig_diag_kind, diagnostic_t diag_kind)
2456 {
2457 if (option_index)
2458 {
2459 /* A warning classified as an error. */
2460 if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN)
2461 && diag_kind == DK_ERROR)
2462 return concat (cl_options[OPT_Werror_].opt_text,
2463 /* Skip over "-W". */
2464 cl_options[option_index].opt_text + 2,
2465 NULL);
2466 /* A warning with option. */
2467 else
2468 return xstrdup (cl_options[option_index].opt_text);
2469 }
2470 /* A warning without option classified as an error. */
2471 else if ((orig_diag_kind == DK_WARNING || orig_diag_kind == DK_PEDWARN
2472 || diag_kind == DK_WARNING)
2473 && context->warning_as_error_requested)
2474 return xstrdup (cl_options[OPT_Werror].opt_text);
2475 else
2476 return NULL;
2477 }