1 /* Command line option handling.
2 Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011
3 Free Software Foundation, Inc.
4 Contributed by Neil Booth.
6 This file is part of GCC.
8 GCC is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 3, or (at your option) any later
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING3. If not see
20 <http://www.gnu.org/licenses/>. */
25 #include "coretypes.h"
26 #include "tm.h" /* For STACK_CHECK_BUILTIN,
27 STACK_CHECK_STATIC_BUILTIN, DEFAULT_GDB_EXTENSIONS,
28 DWARF2_DEBUGGING_INFO and DBX_DEBUGGING_INFO. */
33 #include "diagnostic.h"
34 #include "opts-diagnostic.h"
35 #include "insn-attr-common.h"
36 #include "common/common-target.h"
38 /* Parse the -femit-struct-debug-detailed option value
39 and set the flag variables. */
41 #define MATCH( prefix, string ) \
42 ((strncmp (prefix, string, sizeof prefix - 1) == 0) \
43 ? ((string += sizeof prefix - 1), 1) : 0)
46 set_struct_debug_option (struct gcc_options
*opts
, location_t loc
,
49 /* various labels for comparison */
50 static const char dfn_lbl
[] = "dfn:", dir_lbl
[] = "dir:", ind_lbl
[] = "ind:";
51 static const char ord_lbl
[] = "ord:", gen_lbl
[] = "gen:";
52 static const char none_lbl
[] = "none", any_lbl
[] = "any";
53 static const char base_lbl
[] = "base", sys_lbl
[] = "sys";
55 enum debug_struct_file files
= DINFO_STRUCT_FILE_ANY
;
56 /* Default is to apply to as much as possible. */
57 enum debug_info_usage usage
= DINFO_USAGE_NUM_ENUMS
;
61 if (MATCH (dfn_lbl
, spec
))
62 usage
= DINFO_USAGE_DFN
;
63 else if (MATCH (dir_lbl
, spec
))
64 usage
= DINFO_USAGE_DIR_USE
;
65 else if (MATCH (ind_lbl
, spec
))
66 usage
= DINFO_USAGE_IND_USE
;
68 /* Generics or not? */
69 if (MATCH (ord_lbl
, spec
))
71 else if (MATCH (gen_lbl
, spec
))
74 /* What allowable environment? */
75 if (MATCH (none_lbl
, spec
))
76 files
= DINFO_STRUCT_FILE_NONE
;
77 else if (MATCH (any_lbl
, spec
))
78 files
= DINFO_STRUCT_FILE_ANY
;
79 else if (MATCH (sys_lbl
, spec
))
80 files
= DINFO_STRUCT_FILE_SYS
;
81 else if (MATCH (base_lbl
, spec
))
82 files
= DINFO_STRUCT_FILE_BASE
;
85 "argument %qs to %<-femit-struct-debug-detailed%> "
89 /* Effect the specification. */
90 if (usage
== DINFO_USAGE_NUM_ENUMS
)
94 opts
->x_debug_struct_ordinary
[DINFO_USAGE_DFN
] = files
;
95 opts
->x_debug_struct_ordinary
[DINFO_USAGE_DIR_USE
] = files
;
96 opts
->x_debug_struct_ordinary
[DINFO_USAGE_IND_USE
] = files
;
100 opts
->x_debug_struct_generic
[DINFO_USAGE_DFN
] = files
;
101 opts
->x_debug_struct_generic
[DINFO_USAGE_DIR_USE
] = files
;
102 opts
->x_debug_struct_generic
[DINFO_USAGE_IND_USE
] = files
;
108 opts
->x_debug_struct_ordinary
[usage
] = files
;
110 opts
->x_debug_struct_generic
[usage
] = files
;
114 set_struct_debug_option (opts
, loc
, spec
+1);
117 /* No more -femit-struct-debug-detailed specifications.
121 "argument %qs to %<-femit-struct-debug-detailed%> unknown",
123 if (opts
->x_debug_struct_ordinary
[DINFO_USAGE_DIR_USE
]
124 < opts
->x_debug_struct_ordinary
[DINFO_USAGE_IND_USE
]
125 || opts
->x_debug_struct_generic
[DINFO_USAGE_DIR_USE
]
126 < opts
->x_debug_struct_generic
[DINFO_USAGE_IND_USE
])
128 "%<-femit-struct-debug-detailed=dir:...%> must allow "
129 "at least as much as "
130 "%<-femit-struct-debug-detailed=ind:...%>");
134 /* Handle -ftree-vectorizer-verbose=VAL for options OPTS. */
137 vect_set_verbosity_level (struct gcc_options
*opts
, int val
)
139 if (val
< MAX_VERBOSITY_LEVEL
)
140 opts
->x_user_vect_verbosity_level
= (enum vect_verbosity_levels
) val
;
142 opts
->x_user_vect_verbosity_level
143 = (enum vect_verbosity_levels
) (MAX_VERBOSITY_LEVEL
- 1);
147 /* Strip off a legitimate source ending from the input string NAME of
148 length LEN. Rather than having to know the names used by all of
149 our front ends, we strip off an ending of a period followed by
150 up to five characters. (Java uses ".class".) */
153 strip_off_ending (char *name
, int len
)
156 for (i
= 2; i
< 6 && len
> i
; i
++)
158 if (name
[len
- i
] == '.')
160 name
[len
- i
] = '\0';
166 /* Find the base name of a path, stripping off both directories and
167 a single final extension. */
169 base_of_path (const char *path
, const char **base_out
)
171 const char *base
= path
;
173 const char *p
= path
;
177 if (IS_DIR_SEPARATOR(c
))
192 /* What to print when a switch has no documentation. */
193 static const char undocumented_msg
[] = N_("This switch lacks documentation");
195 typedef char *char_p
; /* For DEF_VEC_P. */
197 DEF_VEC_ALLOC_P(char_p
,heap
);
199 static void handle_param (struct gcc_options
*opts
,
200 struct gcc_options
*opts_set
, location_t loc
,
202 static void set_debug_level (enum debug_info_type type
, int extended
,
203 const char *arg
, struct gcc_options
*opts
,
204 struct gcc_options
*opts_set
,
206 static void set_fast_math_flags (struct gcc_options
*opts
, int set
);
207 static void decode_d_option (const char *arg
, struct gcc_options
*opts
,
208 location_t loc
, diagnostic_context
*dc
);
209 static void set_unsafe_math_optimizations_flags (struct gcc_options
*opts
,
211 static void enable_warning_as_error (const char *arg
, int value
,
212 unsigned int lang_mask
,
213 const struct cl_option_handlers
*handlers
,
214 struct gcc_options
*opts
,
215 struct gcc_options
*opts_set
,
217 diagnostic_context
*dc
);
219 /* Handle a back-end option; arguments and return value as for
223 target_handle_option (struct gcc_options
*opts
,
224 struct gcc_options
*opts_set
,
225 const struct cl_decoded_option
*decoded
,
226 unsigned int lang_mask ATTRIBUTE_UNUSED
, int kind
,
228 const struct cl_option_handlers
*handlers ATTRIBUTE_UNUSED
,
229 diagnostic_context
*dc
)
231 gcc_assert (dc
== global_dc
);
232 gcc_assert (kind
== DK_UNSPECIFIED
);
233 return targetm_common
.handle_option (opts
, opts_set
, decoded
, loc
);
236 /* Add comma-separated strings to a char_p vector. */
239 add_comma_separated_to_vector (void **pvec
, const char *arg
)
245 VEC(char_p
,heap
) *vec
= (VEC(char_p
,heap
) *) *pvec
;
247 /* We never free this string. */
260 VEC_safe_push (char_p
, heap
, vec
, token_start
);
263 if (*r
== '\\' && r
[1] == ',')
271 if (*token_start
!= '\0')
272 VEC_safe_push (char_p
, heap
, vec
, token_start
);
277 /* Initialize OPTS and OPTS_SET before using them in parsing options. */
280 init_options_struct (struct gcc_options
*opts
, struct gcc_options
*opts_set
)
282 size_t num_params
= get_num_compiler_params ();
284 *opts
= global_options_init
;
285 memset (opts_set
, 0, sizeof (*opts_set
));
287 opts
->x_param_values
= XNEWVEC (int, num_params
);
288 opts_set
->x_param_values
= XCNEWVEC (int, num_params
);
289 init_param_values (opts
->x_param_values
);
291 /* Initialize whether `char' is signed. */
292 opts
->x_flag_signed_char
= DEFAULT_SIGNED_CHAR
;
293 /* Set this to a special "uninitialized" value. The actual default
294 is set after target options have been processed. */
295 opts
->x_flag_short_enums
= 2;
297 /* Initialize target_flags before default_options_optimization
298 so the latter can modify it. */
299 opts
->x_target_flags
= targetm_common
.default_target_flags
;
301 /* Some targets have ABI-specified unwind tables. */
302 opts
->x_flag_unwind_tables
= targetm_common
.unwind_tables_default
;
304 /* Some targets have other target-specific initialization. */
305 targetm_common
.option_init_struct (opts
);
308 /* If indicated by the optimization level LEVEL (-Os if SIZE is set,
309 -Ofast if FAST is set), apply the option DEFAULT_OPT to OPTS and
310 OPTS_SET, diagnostic context DC, location LOC, with language mask
311 LANG_MASK and option handlers HANDLERS. */
314 maybe_default_option (struct gcc_options
*opts
,
315 struct gcc_options
*opts_set
,
316 const struct default_options
*default_opt
,
317 int level
, bool size
, bool fast
,
318 unsigned int lang_mask
,
319 const struct cl_option_handlers
*handlers
,
321 diagnostic_context
*dc
)
323 const struct cl_option
*option
= &cl_options
[default_opt
->opt_index
];
327 gcc_assert (level
== 2);
329 gcc_assert (level
== 3);
331 switch (default_opt
->levels
)
337 case OPT_LEVELS_0_ONLY
:
338 enabled
= (level
== 0);
341 case OPT_LEVELS_1_PLUS
:
342 enabled
= (level
>= 1);
345 case OPT_LEVELS_1_PLUS_SPEED_ONLY
:
346 enabled
= (level
>= 1 && !size
);
349 case OPT_LEVELS_2_PLUS
:
350 enabled
= (level
>= 2);
353 case OPT_LEVELS_2_PLUS_SPEED_ONLY
:
354 enabled
= (level
>= 2 && !size
);
357 case OPT_LEVELS_3_PLUS
:
358 enabled
= (level
>= 3);
361 case OPT_LEVELS_3_PLUS_AND_SIZE
:
362 enabled
= (level
>= 3 || size
);
365 case OPT_LEVELS_SIZE
:
369 case OPT_LEVELS_FAST
:
373 case OPT_LEVELS_NONE
:
379 handle_generated_option (opts
, opts_set
, default_opt
->opt_index
,
380 default_opt
->arg
, default_opt
->value
,
381 lang_mask
, DK_UNSPECIFIED
, loc
,
383 else if (default_opt
->arg
== NULL
384 && !option
->cl_reject_negative
)
385 handle_generated_option (opts
, opts_set
, default_opt
->opt_index
,
386 default_opt
->arg
, !default_opt
->value
,
387 lang_mask
, DK_UNSPECIFIED
, loc
,
391 /* As indicated by the optimization level LEVEL (-Os if SIZE is set,
392 -Ofast if FAST is set), apply the options in array DEFAULT_OPTS to
393 OPTS and OPTS_SET, diagnostic context DC, location LOC, with
394 language mask LANG_MASK and option handlers HANDLERS. */
397 maybe_default_options (struct gcc_options
*opts
,
398 struct gcc_options
*opts_set
,
399 const struct default_options
*default_opts
,
400 int level
, bool size
, bool fast
,
401 unsigned int lang_mask
,
402 const struct cl_option_handlers
*handlers
,
404 diagnostic_context
*dc
)
408 for (i
= 0; default_opts
[i
].levels
!= OPT_LEVELS_NONE
; i
++)
409 maybe_default_option (opts
, opts_set
, &default_opts
[i
],
410 level
, size
, fast
, lang_mask
, handlers
, loc
, dc
);
413 /* Table of options enabled by default at different levels. */
415 static const struct default_options default_options_table
[] =
417 /* -O1 optimizations. */
418 { OPT_LEVELS_1_PLUS
, OPT_fdefer_pop
, NULL
, 1 },
420 { OPT_LEVELS_1_PLUS
, OPT_fdelayed_branch
, NULL
, 1 },
422 { OPT_LEVELS_1_PLUS
, OPT_fguess_branch_probability
, NULL
, 1 },
423 { OPT_LEVELS_1_PLUS
, OPT_fcprop_registers
, NULL
, 1 },
424 { OPT_LEVELS_1_PLUS
, OPT_fforward_propagate
, NULL
, 1 },
425 { OPT_LEVELS_1_PLUS
, OPT_fif_conversion
, NULL
, 1 },
426 { OPT_LEVELS_1_PLUS
, OPT_fif_conversion2
, NULL
, 1 },
427 { OPT_LEVELS_1_PLUS
, OPT_fipa_pure_const
, NULL
, 1 },
428 { OPT_LEVELS_1_PLUS
, OPT_fipa_reference
, NULL
, 1 },
429 { OPT_LEVELS_1_PLUS
, OPT_fipa_profile
, NULL
, 1 },
430 { OPT_LEVELS_1_PLUS
, OPT_fmerge_constants
, NULL
, 1 },
431 { OPT_LEVELS_1_PLUS
, OPT_fsplit_wide_types
, NULL
, 1 },
432 { OPT_LEVELS_1_PLUS
, OPT_ftree_ccp
, NULL
, 1 },
433 { OPT_LEVELS_1_PLUS
, OPT_ftree_bit_ccp
, NULL
, 1 },
434 { OPT_LEVELS_1_PLUS
, OPT_ftree_dce
, NULL
, 1 },
435 { OPT_LEVELS_1_PLUS
, OPT_ftree_dominator_opts
, NULL
, 1 },
436 { OPT_LEVELS_1_PLUS
, OPT_ftree_dse
, NULL
, 1 },
437 { OPT_LEVELS_1_PLUS
, OPT_ftree_ter
, NULL
, 1 },
438 { OPT_LEVELS_1_PLUS
, OPT_ftree_sra
, NULL
, 1 },
439 { OPT_LEVELS_1_PLUS
, OPT_ftree_copyrename
, NULL
, 1 },
440 { OPT_LEVELS_1_PLUS
, OPT_ftree_fre
, NULL
, 1 },
441 { OPT_LEVELS_1_PLUS
, OPT_ftree_copy_prop
, NULL
, 1 },
442 { OPT_LEVELS_1_PLUS
, OPT_ftree_sink
, NULL
, 1 },
443 { OPT_LEVELS_1_PLUS
, OPT_ftree_ch
, NULL
, 1 },
444 { OPT_LEVELS_1_PLUS
, OPT_fcombine_stack_adjustments
, NULL
, 1 },
445 { OPT_LEVELS_1_PLUS
, OPT_fcompare_elim
, NULL
, 1 },
447 /* -O2 optimizations. */
448 { OPT_LEVELS_2_PLUS
, OPT_finline_small_functions
, NULL
, 1 },
449 { OPT_LEVELS_2_PLUS
, OPT_findirect_inlining
, NULL
, 1 },
450 { OPT_LEVELS_2_PLUS
, OPT_fpartial_inlining
, NULL
, 1 },
451 { OPT_LEVELS_2_PLUS
, OPT_fthread_jumps
, NULL
, 1 },
452 { OPT_LEVELS_2_PLUS
, OPT_fcrossjumping
, NULL
, 1 },
453 { OPT_LEVELS_2_PLUS
, OPT_foptimize_sibling_calls
, NULL
, 1 },
454 { OPT_LEVELS_2_PLUS
, OPT_fcse_follow_jumps
, NULL
, 1 },
455 { OPT_LEVELS_2_PLUS
, OPT_fgcse
, NULL
, 1 },
456 { OPT_LEVELS_2_PLUS
, OPT_fexpensive_optimizations
, NULL
, 1 },
457 { OPT_LEVELS_2_PLUS
, OPT_frerun_cse_after_loop
, NULL
, 1 },
458 { OPT_LEVELS_2_PLUS
, OPT_fcaller_saves
, NULL
, 1 },
459 { OPT_LEVELS_2_PLUS
, OPT_fpeephole2
, NULL
, 1 },
460 #ifdef INSN_SCHEDULING
461 /* Only run the pre-regalloc scheduling pass if optimizing for speed. */
462 { OPT_LEVELS_2_PLUS_SPEED_ONLY
, OPT_fschedule_insns
, NULL
, 1 },
463 { OPT_LEVELS_2_PLUS
, OPT_fschedule_insns2
, NULL
, 1 },
465 { OPT_LEVELS_2_PLUS
, OPT_fregmove
, NULL
, 1 },
466 { OPT_LEVELS_2_PLUS
, OPT_fstrict_aliasing
, NULL
, 1 },
467 { OPT_LEVELS_2_PLUS
, OPT_fstrict_overflow
, NULL
, 1 },
468 { OPT_LEVELS_2_PLUS
, OPT_freorder_blocks
, NULL
, 1 },
469 { OPT_LEVELS_2_PLUS
, OPT_freorder_functions
, NULL
, 1 },
470 { OPT_LEVELS_2_PLUS
, OPT_ftree_vrp
, NULL
, 1 },
471 { OPT_LEVELS_2_PLUS
, OPT_ftree_builtin_call_dce
, NULL
, 1 },
472 { OPT_LEVELS_2_PLUS
, OPT_ftree_pre
, NULL
, 1 },
473 { OPT_LEVELS_2_PLUS
, OPT_ftree_switch_conversion
, NULL
, 1 },
474 { OPT_LEVELS_2_PLUS
, OPT_fipa_cp
, NULL
, 1 },
475 { OPT_LEVELS_2_PLUS
, OPT_fdevirtualize
, NULL
, 1 },
476 { OPT_LEVELS_2_PLUS
, OPT_fipa_sra
, NULL
, 1 },
477 { OPT_LEVELS_2_PLUS
, OPT_falign_loops
, NULL
, 1 },
478 { OPT_LEVELS_2_PLUS
, OPT_falign_jumps
, NULL
, 1 },
479 { OPT_LEVELS_2_PLUS
, OPT_falign_labels
, NULL
, 1 },
480 { OPT_LEVELS_2_PLUS
, OPT_falign_functions
, NULL
, 1 },
482 /* -O3 optimizations. */
483 { OPT_LEVELS_3_PLUS
, OPT_ftree_loop_distribute_patterns
, NULL
, 1 },
484 { OPT_LEVELS_3_PLUS
, OPT_fpredictive_commoning
, NULL
, 1 },
485 /* Inlining of functions reducing size is a good idea with -Os
486 regardless of them being declared inline. */
487 { OPT_LEVELS_3_PLUS_AND_SIZE
, OPT_finline_functions
, NULL
, 1 },
488 { OPT_LEVELS_1_PLUS
, OPT_finline_functions_called_once
, NULL
, 1 },
489 { OPT_LEVELS_3_PLUS
, OPT_funswitch_loops
, NULL
, 1 },
490 { OPT_LEVELS_3_PLUS
, OPT_fgcse_after_reload
, NULL
, 1 },
491 { OPT_LEVELS_3_PLUS
, OPT_ftree_vectorize
, NULL
, 1 },
492 { OPT_LEVELS_3_PLUS
, OPT_fipa_cp_clone
, NULL
, 1 },
494 /* -Ofast adds optimizations to -O3. */
495 { OPT_LEVELS_FAST
, OPT_ffast_math
, NULL
, 1 },
497 { OPT_LEVELS_NONE
, 0, NULL
, 0 }
500 /* Default the options in OPTS and OPTS_SET based on the optimization
501 settings in DECODED_OPTIONS and DECODED_OPTIONS_COUNT. */
503 default_options_optimization (struct gcc_options
*opts
,
504 struct gcc_options
*opts_set
,
505 struct cl_decoded_option
*decoded_options
,
506 unsigned int decoded_options_count
,
508 unsigned int lang_mask
,
509 const struct cl_option_handlers
*handlers
,
510 diagnostic_context
*dc
)
515 /* Scan to see what optimization level has been specified. That will
516 determine the default value of many flags. */
517 for (i
= 1; i
< decoded_options_count
; i
++)
519 struct cl_decoded_option
*opt
= &decoded_options
[i
];
520 switch (opt
->opt_index
)
523 if (*opt
->arg
== '\0')
525 opts
->x_optimize
= 1;
526 opts
->x_optimize_size
= 0;
527 opts
->x_optimize_fast
= 0;
531 const int optimize_val
= integral_argument (opt
->arg
);
532 if (optimize_val
== -1)
534 "argument to %qs should be a non-negative integer",
538 opts
->x_optimize
= optimize_val
;
539 if ((unsigned int) opts
->x_optimize
> 255)
540 opts
->x_optimize
= 255;
541 opts
->x_optimize_size
= 0;
542 opts
->x_optimize_fast
= 0;
548 opts
->x_optimize_size
= 1;
550 /* Optimizing for size forces optimize to be 2. */
551 opts
->x_optimize
= 2;
552 opts
->x_optimize_fast
= 0;
556 /* -Ofast only adds flags to -O3. */
557 opts
->x_optimize_size
= 0;
558 opts
->x_optimize
= 3;
559 opts
->x_optimize_fast
= 1;
563 /* Ignore other options in this prescan. */
568 maybe_default_options (opts
, opts_set
, default_options_table
,
569 opts
->x_optimize
, opts
->x_optimize_size
,
570 opts
->x_optimize_fast
, lang_mask
, handlers
, loc
, dc
);
572 /* -O2 param settings. */
573 opt2
= (opts
->x_optimize
>= 2);
575 /* Track fields in field-sensitive alias analysis. */
576 maybe_set_param_value
577 (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE
,
578 opt2
? 100 : default_param_value (PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE
),
579 opts
->x_param_values
, opts_set
->x_param_values
);
581 /* For -O1 only do loop invariant motion for very small loops. */
582 maybe_set_param_value
583 (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP
,
584 opt2
? default_param_value (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP
) : 1000,
585 opts
->x_param_values
, opts_set
->x_param_values
);
587 if (opts
->x_optimize_size
)
588 /* We want to crossjump as much as possible. */
589 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS
, 1,
590 opts
->x_param_values
, opts_set
->x_param_values
);
592 maybe_set_param_value (PARAM_MIN_CROSSJUMP_INSNS
,
593 default_param_value (PARAM_MIN_CROSSJUMP_INSNS
),
594 opts
->x_param_values
, opts_set
->x_param_values
);
596 /* Allow default optimizations to be specified on a per-machine basis. */
597 maybe_default_options (opts
, opts_set
,
598 targetm_common
.option_optimization_table
,
599 opts
->x_optimize
, opts
->x_optimize_size
,
600 opts
->x_optimize_fast
, lang_mask
, handlers
, loc
, dc
);
603 /* After all options at LOC have been read into OPTS and OPTS_SET,
604 finalize settings of those options and diagnose incompatible
607 finish_options (struct gcc_options
*opts
, struct gcc_options
*opts_set
,
610 enum unwind_info_type ui_except
;
612 if (opts
->x_dump_base_name
&& ! IS_ABSOLUTE_PATH (opts
->x_dump_base_name
))
614 /* First try to make OPTS->X_DUMP_BASE_NAME relative to the
615 OPTS->X_DUMP_DIR_NAME directory. Then try to make
616 OPTS->X_DUMP_BASE_NAME relative to the OPTS->X_AUX_BASE_NAME
617 directory, typically the directory to contain the object
619 if (opts
->x_dump_dir_name
)
620 opts
->x_dump_base_name
= concat (opts
->x_dump_dir_name
,
621 opts
->x_dump_base_name
, NULL
);
622 else if (opts
->x_aux_base_name
623 && strcmp (opts
->x_aux_base_name
, HOST_BIT_BUCKET
) != 0)
625 const char *aux_base
;
627 base_of_path (opts
->x_aux_base_name
, &aux_base
);
628 if (opts
->x_aux_base_name
!= aux_base
)
630 int dir_len
= aux_base
- opts
->x_aux_base_name
;
631 char *new_dump_base_name
=
632 XNEWVEC (char, strlen (opts
->x_dump_base_name
) + dir_len
+ 1);
634 /* Copy directory component from OPTS->X_AUX_BASE_NAME. */
635 memcpy (new_dump_base_name
, opts
->x_aux_base_name
, dir_len
);
636 /* Append existing OPTS->X_DUMP_BASE_NAME. */
637 strcpy (new_dump_base_name
+ dir_len
, opts
->x_dump_base_name
);
638 opts
->x_dump_base_name
= new_dump_base_name
;
643 /* Handle related options for unit-at-a-time, toplevel-reorder, and
645 if (!opts
->x_flag_unit_at_a_time
)
647 if (opts
->x_flag_section_anchors
&& opts_set
->x_flag_section_anchors
)
648 error_at (loc
, "section anchors must be disabled when unit-at-a-time "
650 opts
->x_flag_section_anchors
= 0;
651 if (opts
->x_flag_toplevel_reorder
== 1)
652 error_at (loc
, "toplevel reorder must be disabled when unit-at-a-time "
654 opts
->x_flag_toplevel_reorder
= 0;
657 /* -Wmissing-noreturn is alias for -Wsuggest-attribute=noreturn. */
658 if (opts
->x_warn_missing_noreturn
)
659 opts
->x_warn_suggest_attribute_noreturn
= true;
661 /* Unless the user has asked for section anchors, we disable toplevel
662 reordering at -O0 to disable transformations that might be surprising
663 to end users and to get -fno-toplevel-reorder tested. */
664 if (!opts
->x_optimize
665 && opts
->x_flag_toplevel_reorder
== 2
666 && !(opts
->x_flag_section_anchors
&& opts_set
->x_flag_section_anchors
))
668 opts
->x_flag_toplevel_reorder
= 0;
669 opts
->x_flag_section_anchors
= 0;
671 if (!opts
->x_flag_toplevel_reorder
)
673 if (opts
->x_flag_section_anchors
&& opts_set
->x_flag_section_anchors
)
674 error_at (loc
, "section anchors must be disabled when toplevel reorder"
676 opts
->x_flag_section_anchors
= 0;
679 if (!opts
->x_flag_opts_finished
)
681 if (opts
->x_flag_pie
)
682 opts
->x_flag_pic
= opts
->x_flag_pie
;
683 if (opts
->x_flag_pic
&& !opts
->x_flag_pie
)
684 opts
->x_flag_shlib
= 1;
685 opts
->x_flag_opts_finished
= true;
688 if (opts
->x_optimize
== 0)
690 /* Inlining does not work if not optimizing,
691 so force it not to be done. */
692 opts
->x_warn_inline
= 0;
693 opts
->x_flag_no_inline
= 1;
696 /* The optimization to partition hot and cold basic blocks into separate
697 sections of the .o and executable files does not work (currently)
698 with exception handling. This is because there is no support for
699 generating unwind info. If opts->x_flag_exceptions is turned on
700 we need to turn off the partitioning optimization. */
702 ui_except
= targetm_common
.except_unwind_info (opts
);
704 if (opts
->x_flag_exceptions
705 && opts
->x_flag_reorder_blocks_and_partition
706 && (ui_except
== UI_SJLJ
|| ui_except
== UI_TARGET
))
709 "-freorder-blocks-and-partition does not work "
710 "with exceptions on this architecture");
711 opts
->x_flag_reorder_blocks_and_partition
= 0;
712 opts
->x_flag_reorder_blocks
= 1;
715 /* If user requested unwind info, then turn off the partitioning
718 if (opts
->x_flag_unwind_tables
719 && !targetm_common
.unwind_tables_default
720 && opts
->x_flag_reorder_blocks_and_partition
721 && (ui_except
== UI_SJLJ
|| ui_except
== UI_TARGET
))
724 "-freorder-blocks-and-partition does not support "
725 "unwind info on this architecture");
726 opts
->x_flag_reorder_blocks_and_partition
= 0;
727 opts
->x_flag_reorder_blocks
= 1;
730 /* If the target requested unwind info, then turn off the partitioning
731 optimization with a different message. Likewise, if the target does not
732 support named sections. */
734 if (opts
->x_flag_reorder_blocks_and_partition
735 && (!targetm_common
.have_named_sections
736 || (opts
->x_flag_unwind_tables
737 && targetm_common
.unwind_tables_default
738 && (ui_except
== UI_SJLJ
|| ui_except
== UI_TARGET
))))
741 "-freorder-blocks-and-partition does not work "
742 "on this architecture");
743 opts
->x_flag_reorder_blocks_and_partition
= 0;
744 opts
->x_flag_reorder_blocks
= 1;
747 if (opts
->x_flag_reorder_blocks_and_partition
748 && !opts_set
->x_flag_reorder_functions
)
749 opts
->x_flag_reorder_functions
= 1;
751 /* Pipelining of outer loops is only possible when general pipelining
752 capabilities are requested. */
753 if (!opts
->x_flag_sel_sched_pipelining
)
754 opts
->x_flag_sel_sched_pipelining_outer_loops
= 0;
756 if (opts
->x_flag_conserve_stack
)
758 maybe_set_param_value (PARAM_LARGE_STACK_FRAME
, 100,
759 opts
->x_param_values
, opts_set
->x_param_values
);
760 maybe_set_param_value (PARAM_STACK_FRAME_GROWTH
, 40,
761 opts
->x_param_values
, opts_set
->x_param_values
);
763 if (opts
->x_flag_wpa
|| opts
->x_flag_ltrans
)
765 /* These passes are not WHOPR compatible yet. */
766 opts
->x_flag_ipa_pta
= 0;
769 if (opts
->x_flag_lto
)
772 opts
->x_flag_generate_lto
= 1;
774 /* When generating IL, do not operate in whole-program mode.
775 Otherwise, symbols will be privatized too early, causing link
777 opts
->x_flag_whole_program
= 0;
779 error_at (loc
, "LTO support has not been enabled in this configuration");
782 if ((opts
->x_flag_lto_partition_balanced
!= 0) + (opts
->x_flag_lto_partition_1to1
!= 0)
783 + (opts
->x_flag_lto_partition_none
!= 0) >= 1)
785 if ((opts
->x_flag_lto_partition_balanced
!= 0)
786 + (opts
->x_flag_lto_partition_1to1
!= 0)
787 + (opts
->x_flag_lto_partition_none
!= 0) > 1)
788 error_at (loc
, "only one -flto-partition value can be specified");
791 /* We initialize opts->x_flag_split_stack to -1 so that targets can set a
792 default value if they choose based on other options. */
793 if (opts
->x_flag_split_stack
== -1)
794 opts
->x_flag_split_stack
= 0;
795 else if (opts
->x_flag_split_stack
)
797 if (!targetm_common
.supports_split_stack (true, opts
))
799 error_at (loc
, "%<-fsplit-stack%> is not supported by "
800 "this compiler configuration");
801 opts
->x_flag_split_stack
= 0;
805 /* Set PARAM_MAX_STORES_TO_SINK to 0 if either vectorization or if-conversion
807 if (!opts
->x_flag_tree_vectorize
|| !opts
->x_flag_tree_loop_if_convert
)
808 maybe_set_param_value (PARAM_MAX_STORES_TO_SINK
, 0,
809 opts
->x_param_values
, opts_set
->x_param_values
);
811 /* This replaces set_Wunused. */
812 if (opts
->x_warn_unused_function
== -1)
813 opts
->x_warn_unused_function
= opts
->x_warn_unused
;
814 if (opts
->x_warn_unused_label
== -1)
815 opts
->x_warn_unused_label
= opts
->x_warn_unused
;
816 /* Wunused-parameter is enabled if both -Wunused -Wextra are enabled. */
817 if (opts
->x_warn_unused_parameter
== -1)
818 opts
->x_warn_unused_parameter
= (opts
->x_warn_unused
819 && opts
->x_extra_warnings
);
820 if (opts
->x_warn_unused_variable
== -1)
821 opts
->x_warn_unused_variable
= opts
->x_warn_unused
;
822 /* Wunused-but-set-parameter is enabled if both -Wunused -Wextra are
824 if (opts
->x_warn_unused_but_set_parameter
== -1)
825 opts
->x_warn_unused_but_set_parameter
= (opts
->x_warn_unused
826 && opts
->x_extra_warnings
);
827 if (opts
->x_warn_unused_but_set_variable
== -1)
828 opts
->x_warn_unused_but_set_variable
= opts
->x_warn_unused
;
829 if (opts
->x_warn_unused_value
== -1)
830 opts
->x_warn_unused_value
= opts
->x_warn_unused
;
832 /* This replaces set_Wextra. */
833 if (opts
->x_warn_uninitialized
== -1)
834 opts
->x_warn_uninitialized
= opts
->x_extra_warnings
;
837 #define LEFT_COLUMN 27
839 /* Output ITEM, of length ITEM_WIDTH, in the left column,
840 followed by word-wrapped HELP in a second column. */
842 wrap_help (const char *help
,
844 unsigned int item_width
,
845 unsigned int columns
)
847 unsigned int col_width
= LEFT_COLUMN
;
848 unsigned int remaining
, room
, len
;
850 remaining
= strlen (help
);
854 room
= columns
- 3 - MAX (col_width
, item_width
);
863 for (i
= 0; help
[i
]; i
++)
865 if (i
>= room
&& len
!= remaining
)
869 else if ((help
[i
] == '-' || help
[i
] == '/')
870 && help
[i
+ 1] != ' '
871 && i
> 0 && ISALPHA (help
[i
- 1]))
876 printf( " %-*.*s %.*s\n", col_width
, item_width
, item
, len
, help
);
878 while (help
[len
] == ' ')
886 /* Print help for a specific front-end, etc. */
888 print_filtered_help (unsigned int include_flags
,
889 unsigned int exclude_flags
,
890 unsigned int any_flags
,
891 unsigned int columns
,
892 struct gcc_options
*opts
,
893 unsigned int lang_mask
)
898 bool displayed
= false;
900 if (include_flags
== CL_PARAMS
)
902 for (i
= 0; i
< LAST_PARAM
; i
++)
904 const char *param
= compiler_params
[i
].option
;
906 help
= compiler_params
[i
].help
;
907 if (help
== NULL
|| *help
== '\0')
909 if (exclude_flags
& CL_UNDOCUMENTED
)
911 help
= undocumented_msg
;
914 /* Get the translation. */
917 wrap_help (help
, param
, strlen (param
), columns
);
923 if (!opts
->x_help_printed
)
924 opts
->x_help_printed
= XCNEWVAR (char, cl_options_count
);
926 if (!opts
->x_help_enum_printed
)
927 opts
->x_help_enum_printed
= XCNEWVAR (char, cl_enums_count
);
929 for (i
= 0; i
< cl_options_count
; i
++)
932 const struct cl_option
*option
= cl_options
+ i
;
937 if (include_flags
== 0
938 || ((option
->flags
& include_flags
) != include_flags
))
940 if ((option
->flags
& any_flags
) == 0)
944 /* Skip unwanted switches. */
945 if ((option
->flags
& exclude_flags
) != 0)
948 /* The driver currently prints its own help text. */
949 if ((option
->flags
& CL_DRIVER
) != 0
950 && (option
->flags
& (((1U << cl_lang_count
) - 1)
951 | CL_COMMON
| CL_TARGET
)) == 0)
955 /* Skip switches that have already been printed. */
956 if (opts
->x_help_printed
[i
])
959 opts
->x_help_printed
[i
] = true;
964 if (exclude_flags
& CL_UNDOCUMENTED
)
966 help
= undocumented_msg
;
969 /* Get the translation. */
972 /* Find the gap between the name of the
973 option and its descriptive text. */
974 tab
= strchr (help
, '\t');
983 opt
= option
->opt_text
;
987 /* With the -Q option enabled we change the descriptive text associated
988 with an option to be an indication of its current setting. */
991 void *flag_var
= option_flag_var (i
, opts
);
993 if (len
< (LEFT_COLUMN
+ 2))
994 strcpy (new_help
, "\t\t");
996 strcpy (new_help
, "\t");
999 && option
->var_type
!= CLVC_DEFER
)
1001 if (option
->flags
& CL_JOINED
)
1003 if (option
->var_type
== CLVC_STRING
)
1005 if (* (const char **) flag_var
!= NULL
)
1006 snprintf (new_help
+ strlen (new_help
),
1007 sizeof (new_help
) - strlen (new_help
),
1008 * (const char **) flag_var
);
1010 else if (option
->var_type
== CLVC_ENUM
)
1012 const struct cl_enum
*e
= &cl_enums
[option
->var_enum
];
1014 const char *arg
= NULL
;
1016 value
= e
->get (flag_var
);
1017 enum_value_to_arg (e
->values
, &arg
, value
, lang_mask
);
1019 arg
= _("[default]");
1020 snprintf (new_help
+ strlen (new_help
),
1021 sizeof (new_help
) - strlen (new_help
),
1025 sprintf (new_help
+ strlen (new_help
),
1026 "%#x", * (int *) flag_var
);
1029 strcat (new_help
, option_enabled (i
, opts
)
1030 ? _("[enabled]") : _("[disabled]"));
1036 wrap_help (help
, opt
, len
, columns
);
1039 if (option
->var_type
== CLVC_ENUM
1040 && opts
->x_help_enum_printed
[option
->var_enum
] != 2)
1041 opts
->x_help_enum_printed
[option
->var_enum
] = 1;
1046 unsigned int langs
= include_flags
& CL_LANG_ALL
;
1049 printf (_(" No options with the desired characteristics were found\n"));
1054 /* PR 31349: Tell the user how to see all of the
1055 options supported by a specific front end. */
1056 for (i
= 0; (1U << i
) < CL_LANG_ALL
; i
++)
1057 if ((1U << i
) & langs
)
1058 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end\n"),
1059 lang_names
[i
], lang_names
[i
]);
1063 else if (! displayed
)
1064 printf (_(" All options with the desired characteristics have already been displayed\n"));
1068 /* Print details of enumerated option arguments, if those
1069 enumerations have help text headings provided. If no help text
1070 is provided, presume that the possible values are listed in the
1071 help text for the relevant options. */
1072 for (i
= 0; i
< cl_enums_count
; i
++)
1074 unsigned int j
, pos
;
1076 if (opts
->x_help_enum_printed
[i
] != 1)
1078 if (cl_enums
[i
].help
== NULL
)
1080 printf (" %s\n ", _(cl_enums
[i
].help
));
1082 for (j
= 0; cl_enums
[i
].values
[j
].arg
!= NULL
; j
++)
1084 unsigned int len
= strlen (cl_enums
[i
].values
[j
].arg
);
1086 if (pos
> 4 && pos
+ 1 + len
<= columns
)
1088 printf (" %s", cl_enums
[i
].values
[j
].arg
);
1098 printf ("%s", cl_enums
[i
].values
[j
].arg
);
1103 opts
->x_help_enum_printed
[i
] = 2;
1107 /* Display help for a specified type of option.
1108 The options must have ALL of the INCLUDE_FLAGS set
1109 ANY of the flags in the ANY_FLAGS set
1110 and NONE of the EXCLUDE_FLAGS set. The current option state is in
1111 OPTS; LANG_MASK is used for interpreting enumerated option state. */
1113 print_specific_help (unsigned int include_flags
,
1114 unsigned int exclude_flags
,
1115 unsigned int any_flags
,
1116 struct gcc_options
*opts
,
1117 unsigned int lang_mask
)
1119 unsigned int all_langs_mask
= (1U << cl_lang_count
) - 1;
1120 const char * description
= NULL
;
1121 const char * descrip_extra
= "";
1125 /* Sanity check: Make sure that we do not have more
1126 languages than we have bits available to enumerate them. */
1127 gcc_assert ((1U << cl_lang_count
) < CL_MIN_OPTION_CLASS
);
1129 /* If we have not done so already, obtain
1130 the desired maximum width of the output. */
1131 if (opts
->x_help_columns
== 0)
1135 p
= getenv ("COLUMNS");
1138 int value
= atoi (p
);
1141 opts
->x_help_columns
= value
;
1144 if (opts
->x_help_columns
== 0)
1145 /* Use a reasonable default. */
1146 opts
->x_help_columns
= 80;
1149 /* Decide upon the title for the options that we are going to display. */
1150 for (i
= 0, flag
= 1; flag
<= CL_MAX_OPTION_CLASS
; flag
<<= 1, i
++)
1152 switch (flag
& include_flags
)
1159 description
= _("The following options are target specific");
1162 description
= _("The following options control compiler warning messages");
1164 case CL_OPTIMIZATION
:
1165 description
= _("The following options control optimizations");
1168 description
= _("The following options are language-independent");
1171 description
= _("The --param option recognizes the following as parameters");
1174 if (i
>= cl_lang_count
)
1176 if (exclude_flags
& all_langs_mask
)
1177 description
= _("The following options are specific to just the language ");
1179 description
= _("The following options are supported by the language ");
1180 descrip_extra
= lang_names
[i
];
1185 if (description
== NULL
)
1189 if (include_flags
& CL_UNDOCUMENTED
)
1190 description
= _("The following options are not documented");
1191 else if (include_flags
& CL_SEPARATE
)
1192 description
= _("The following options take separate arguments");
1193 else if (include_flags
& CL_JOINED
)
1194 description
= _("The following options take joined arguments");
1197 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1204 if (any_flags
& all_langs_mask
)
1205 description
= _("The following options are language-related");
1207 description
= _("The following options are language-independent");
1211 printf ("%s%s:\n", description
, descrip_extra
);
1212 print_filtered_help (include_flags
, exclude_flags
, any_flags
,
1213 opts
->x_help_columns
, opts
, lang_mask
);
1216 /* Handle target- and language-independent options. Return zero to
1217 generate an "unknown option" message. Only options that need
1218 extra handling need to be listed here; if you simply want
1219 DECODED->value assigned to a variable, it happens automatically. */
1222 common_handle_option (struct gcc_options
*opts
,
1223 struct gcc_options
*opts_set
,
1224 const struct cl_decoded_option
*decoded
,
1225 unsigned int lang_mask
, int kind ATTRIBUTE_UNUSED
,
1227 const struct cl_option_handlers
*handlers
,
1228 diagnostic_context
*dc
)
1230 size_t scode
= decoded
->opt_index
;
1231 const char *arg
= decoded
->arg
;
1232 int value
= decoded
->value
;
1233 enum opt_code code
= (enum opt_code
) scode
;
1235 gcc_assert (decoded
->canonical_option_num_elements
<= 2);
1240 handle_param (opts
, opts_set
, loc
, arg
);
1245 unsigned int all_langs_mask
= (1U << cl_lang_count
) - 1;
1246 unsigned int undoc_mask
;
1249 undoc_mask
= ((opts
->x_verbose_flag
| opts
->x_extra_warnings
)
1252 /* First display any single language specific options. */
1253 for (i
= 0; i
< cl_lang_count
; i
++)
1255 (1U << i
, (all_langs_mask
& (~ (1U << i
))) | undoc_mask
, 0, opts
,
1257 /* Next display any multi language specific options. */
1258 print_specific_help (0, undoc_mask
, all_langs_mask
, opts
, lang_mask
);
1259 /* Then display any remaining, non-language options. */
1260 for (i
= CL_MIN_OPTION_CLASS
; i
<= CL_MAX_OPTION_CLASS
; i
<<= 1)
1262 print_specific_help (i
, undoc_mask
, 0, opts
, lang_mask
);
1263 opts
->x_exit_after_options
= true;
1267 case OPT__target_help
:
1268 print_specific_help (CL_TARGET
, CL_UNDOCUMENTED
, 0, opts
, lang_mask
);
1269 opts
->x_exit_after_options
= true;
1274 const char * a
= arg
;
1275 unsigned int include_flags
= 0;
1276 /* Note - by default we include undocumented options when listing
1277 specific classes. If you only want to see documented options
1278 then add ",^undocumented" to the --help= option. E.g.:
1280 --help=target,^undocumented */
1281 unsigned int exclude_flags
= 0;
1283 /* Walk along the argument string, parsing each word in turn.
1285 arg = [^]{word}[,{arg}]
1286 word = {optimizers|target|warnings|undocumented|
1287 params|common|<language>} */
1292 const char * string
;
1297 { "optimizers", CL_OPTIMIZATION
},
1298 { "target", CL_TARGET
},
1299 { "warnings", CL_WARNING
},
1300 { "undocumented", CL_UNDOCUMENTED
},
1301 { "params", CL_PARAMS
},
1302 { "joined", CL_JOINED
},
1303 { "separate", CL_SEPARATE
},
1304 { "common", CL_COMMON
},
1307 unsigned int * pflags
;
1309 unsigned int lang_flag
, specific_flag
;
1316 pflags
= & exclude_flags
;
1319 pflags
= & include_flags
;
1321 comma
= strchr (a
, ',');
1332 /* Check to see if the string matches an option class name. */
1333 for (i
= 0, specific_flag
= 0; specifics
[i
].string
!= NULL
; i
++)
1334 if (strncasecmp (a
, specifics
[i
].string
, len
) == 0)
1336 specific_flag
= specifics
[i
].flag
;
1340 /* Check to see if the string matches a language name.
1341 Note - we rely upon the alpha-sorted nature of the entries in
1342 the lang_names array, specifically that shorter names appear
1343 before their longer variants. (i.e. C before C++). That way
1344 when we are attempting to match --help=c for example we will
1345 match with C first and not C++. */
1346 for (i
= 0, lang_flag
= 0; i
< cl_lang_count
; i
++)
1347 if (strncasecmp (a
, lang_names
[i
], len
) == 0)
1349 lang_flag
= 1U << i
;
1353 if (specific_flag
!= 0)
1356 * pflags
|= specific_flag
;
1359 /* The option's argument matches both the start of a
1360 language name and the start of an option class name.
1361 We have a special case for when the user has
1362 specified "--help=c", but otherwise we have to issue
1364 if (strncasecmp (a
, "c", len
) == 0)
1365 * pflags
|= lang_flag
;
1368 "--help argument %q.*s is ambiguous, "
1369 "please be more specific",
1373 else if (lang_flag
!= 0)
1374 * pflags
|= lang_flag
;
1377 "unrecognized argument to --help= option: %q.*s",
1386 print_specific_help (include_flags
, exclude_flags
, 0, opts
,
1388 opts
->x_exit_after_options
= true;
1393 opts
->x_exit_after_options
= true;
1399 /* Currently handled in a prescan. */
1403 enable_warning_as_error (arg
, value
, lang_mask
, handlers
,
1404 opts
, opts_set
, loc
, dc
);
1407 case OPT_Wlarger_than_
:
1408 opts
->x_larger_than_size
= value
;
1409 opts
->x_warn_larger_than
= value
!= -1;
1412 case OPT_Wfatal_errors
:
1413 dc
->fatal_errors
= value
;
1416 case OPT_Wframe_larger_than_
:
1417 opts
->x_frame_larger_than_size
= value
;
1418 opts
->x_warn_frame_larger_than
= value
!= -1;
1421 case OPT_Wstack_usage_
:
1422 opts
->x_warn_stack_usage
= value
;
1423 opts
->x_flag_stack_usage_info
= value
!= -1;
1426 case OPT_Wstrict_aliasing
:
1427 set_Wstrict_aliasing (opts
, value
);
1430 case OPT_Wstrict_overflow
:
1431 opts
->x_warn_strict_overflow
= (value
1432 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1436 case OPT_Wsystem_headers
:
1437 dc
->dc_warn_system_headers
= value
;
1441 opts
->x_flag_gen_aux_info
= 1;
1444 case OPT_auxbase_strip
:
1446 char *tmp
= xstrdup (arg
);
1447 strip_off_ending (tmp
, strlen (tmp
));
1449 opts
->x_aux_base_name
= tmp
;
1454 decode_d_option (arg
, opts
, loc
, dc
);
1457 case OPT_fcall_used_
:
1458 case OPT_fcall_saved_
:
1463 case OPT_fdbg_cnt_list
:
1467 case OPT_fdebug_prefix_map_
:
1471 case OPT_fdiagnostics_show_location_
:
1472 diagnostic_prefixing_rule (dc
) = (diagnostic_prefixing_rule_t
) value
;
1475 case OPT_fdiagnostics_show_option
:
1476 dc
->show_option_requested
= value
;
1483 case OPT_ffast_math
:
1484 set_fast_math_flags (opts
, value
);
1487 case OPT_funsafe_math_optimizations
:
1488 set_unsafe_math_optimizations_flags (opts
, value
);
1495 case OPT_finline_limit_
:
1496 set_param_value ("max-inline-insns-single", value
/ 2,
1497 opts
->x_param_values
, opts_set
->x_param_values
);
1498 set_param_value ("max-inline-insns-auto", value
/ 2,
1499 opts
->x_param_values
, opts_set
->x_param_values
);
1502 case OPT_finstrument_functions_exclude_function_list_
:
1503 add_comma_separated_to_vector
1504 (&opts
->x_flag_instrument_functions_exclude_functions
, arg
);
1507 case OPT_finstrument_functions_exclude_file_list_
:
1508 add_comma_separated_to_vector
1509 (&opts
->x_flag_instrument_functions_exclude_files
, arg
);
1512 case OPT_fmessage_length_
:
1513 pp_set_line_maximum_length (dc
->printer
, value
);
1516 case OPT_fpack_struct_
:
1517 if (value
<= 0 || (value
& (value
- 1)) || value
> 16)
1519 "structure alignment must be a small power of two, not %d",
1522 opts
->x_initial_max_fld_align
= value
;
1526 case OPT_fplugin_arg_
:
1530 case OPT_fprofile_use_
:
1531 opts
->x_profile_data_prefix
= xstrdup (arg
);
1532 opts
->x_flag_profile_use
= true;
1534 /* No break here - do -fprofile-use processing. */
1535 case OPT_fprofile_use
:
1536 if (!opts_set
->x_flag_branch_probabilities
)
1537 opts
->x_flag_branch_probabilities
= value
;
1538 if (!opts_set
->x_flag_profile_values
)
1539 opts
->x_flag_profile_values
= value
;
1540 if (!opts_set
->x_flag_unroll_loops
)
1541 opts
->x_flag_unroll_loops
= value
;
1542 if (!opts_set
->x_flag_peel_loops
)
1543 opts
->x_flag_peel_loops
= value
;
1544 if (!opts_set
->x_flag_tracer
)
1545 opts
->x_flag_tracer
= value
;
1546 if (!opts_set
->x_flag_value_profile_transformations
)
1547 opts
->x_flag_value_profile_transformations
= value
;
1548 if (!opts_set
->x_flag_inline_functions
)
1549 opts
->x_flag_inline_functions
= value
;
1550 if (!opts_set
->x_flag_ipa_cp
)
1551 opts
->x_flag_ipa_cp
= value
;
1552 if (!opts_set
->x_flag_ipa_cp_clone
1553 && value
&& opts
->x_flag_ipa_cp
)
1554 opts
->x_flag_ipa_cp_clone
= value
;
1555 if (!opts_set
->x_flag_predictive_commoning
)
1556 opts
->x_flag_predictive_commoning
= value
;
1557 if (!opts_set
->x_flag_unswitch_loops
)
1558 opts
->x_flag_unswitch_loops
= value
;
1559 if (!opts_set
->x_flag_gcse_after_reload
)
1560 opts
->x_flag_gcse_after_reload
= value
;
1563 case OPT_fprofile_generate_
:
1564 opts
->x_profile_data_prefix
= xstrdup (arg
);
1566 /* No break here - do -fprofile-generate processing. */
1567 case OPT_fprofile_generate
:
1568 if (!opts_set
->x_profile_arc_flag
)
1569 opts
->x_profile_arc_flag
= value
;
1570 if (!opts_set
->x_flag_profile_values
)
1571 opts
->x_flag_profile_values
= value
;
1572 if (!opts_set
->x_flag_value_profile_transformations
)
1573 opts
->x_flag_value_profile_transformations
= value
;
1574 if (!opts_set
->x_flag_inline_functions
)
1575 opts
->x_flag_inline_functions
= value
;
1576 /* FIXME: Instrumentation we insert makes ipa-reference bitmaps
1577 quadratic. Disable the pass until better memory representation
1579 if (!opts_set
->x_flag_ipa_reference
&& in_lto_p
)
1580 opts
->x_flag_ipa_reference
= false;
1583 case OPT_fshow_column
:
1584 dc
->show_column
= value
;
1587 case OPT_frandom_seed
:
1588 /* The real switch is -fno-random-seed. */
1594 case OPT_frandom_seed_
:
1598 case OPT_fsched_verbose_
:
1599 #ifdef INSN_SCHEDULING
1600 /* Handled with Var in common.opt. */
1606 case OPT_fsched_stalled_insns_
:
1607 opts
->x_flag_sched_stalled_insns
= value
;
1608 if (opts
->x_flag_sched_stalled_insns
== 0)
1609 opts
->x_flag_sched_stalled_insns
= -1;
1612 case OPT_fsched_stalled_insns_dep_
:
1613 opts
->x_flag_sched_stalled_insns_dep
= value
;
1616 case OPT_fstack_check_
:
1617 if (!strcmp (arg
, "no"))
1618 opts
->x_flag_stack_check
= NO_STACK_CHECK
;
1619 else if (!strcmp (arg
, "generic"))
1620 /* This is the old stack checking method. */
1621 opts
->x_flag_stack_check
= STACK_CHECK_BUILTIN
1622 ? FULL_BUILTIN_STACK_CHECK
1623 : GENERIC_STACK_CHECK
;
1624 else if (!strcmp (arg
, "specific"))
1625 /* This is the new stack checking method. */
1626 opts
->x_flag_stack_check
= STACK_CHECK_BUILTIN
1627 ? FULL_BUILTIN_STACK_CHECK
1628 : STACK_CHECK_STATIC_BUILTIN
1629 ? STATIC_BUILTIN_STACK_CHECK
1630 : GENERIC_STACK_CHECK
;
1632 warning_at (loc
, 0, "unknown stack check parameter \"%s\"", arg
);
1635 case OPT_fstack_limit
:
1636 /* The real switch is -fno-stack-limit. */
1642 case OPT_fstack_limit_register_
:
1643 case OPT_fstack_limit_symbol_
:
1647 case OPT_fstack_usage
:
1648 opts
->x_flag_stack_usage
= value
;
1649 opts
->x_flag_stack_usage_info
= value
!= 0;
1652 case OPT_ftree_vectorizer_verbose_
:
1653 vect_set_verbosity_level (opts
, value
);
1657 set_debug_level (NO_DEBUG
, DEFAULT_GDB_EXTENSIONS
, arg
, opts
, opts_set
,
1662 set_debug_level (SDB_DEBUG
, false, arg
, opts
, opts_set
, loc
);
1666 if (value
< 2 || value
> 4)
1667 error_at (loc
, "dwarf version %d is not supported", value
);
1669 dwarf_version
= value
;
1670 set_debug_level (DWARF2_DEBUG
, false, "", opts
, opts_set
, loc
);
1674 set_debug_level (NO_DEBUG
, 2, arg
, opts
, opts_set
, loc
);
1679 set_debug_level (DBX_DEBUG
, code
== OPT_gstabs_
, arg
, opts
, opts_set
,
1684 set_debug_level (VMS_DEBUG
, false, arg
, opts
, opts_set
, loc
);
1689 set_debug_level (XCOFF_DEBUG
, code
== OPT_gxcoff_
, arg
, opts
, opts_set
,
1693 case OPT_pedantic_errors
:
1694 opts
->x_pedantic
= 1;
1695 dc
->pedantic_errors
= 1;
1699 opts
->x_flag_lto
= value
? "" : NULL
;
1703 dc
->dc_inhibit_warnings
= true;
1706 case OPT_fmax_errors_
:
1707 dc
->max_errors
= value
;
1710 case OPT_fuse_linker_plugin
:
1711 /* No-op. Used by the driver and passed to us because it starts with f.*/
1714 case OPT_Wuninitialized
:
1715 /* Also turn on maybe uninitialized warning. */
1716 warn_maybe_uninitialized
= value
;
1720 /* If the flag was handled in a standard way, assume the lack of
1721 processing here is intentional. */
1722 gcc_assert (option_flag_var (scode
, opts
));
1729 /* Handle --param NAME=VALUE. */
1731 handle_param (struct gcc_options
*opts
, struct gcc_options
*opts_set
,
1732 location_t loc
, const char *carg
)
1737 arg
= xstrdup (carg
);
1738 equal
= strchr (arg
, '=');
1740 error_at (loc
, "%s: --param arguments should be of the form NAME=VALUE",
1744 value
= integral_argument (equal
+ 1);
1746 error_at (loc
, "invalid --param value %qs", equal
+ 1);
1750 set_param_value (arg
, value
,
1751 opts
->x_param_values
, opts_set
->x_param_values
);
1758 /* Used to set the level of strict aliasing warnings in OPTS,
1759 when no level is specified (i.e., when -Wstrict-aliasing, and not
1760 -Wstrict-aliasing=level was given).
1761 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
1762 and 0 otherwise. After calling this function, wstrict_aliasing will be
1763 set to the default value of -Wstrict_aliasing=level, currently 3. */
1765 set_Wstrict_aliasing (struct gcc_options
*opts
, int onoff
)
1767 gcc_assert (onoff
== 0 || onoff
== 1);
1769 opts
->x_warn_strict_aliasing
= 3;
1771 opts
->x_warn_strict_aliasing
= 0;
1774 /* The following routines are useful in setting all the flags that
1775 -ffast-math and -fno-fast-math imply. */
1777 set_fast_math_flags (struct gcc_options
*opts
, int set
)
1779 if (!opts
->frontend_set_flag_unsafe_math_optimizations
)
1781 opts
->x_flag_unsafe_math_optimizations
= set
;
1782 set_unsafe_math_optimizations_flags (opts
, set
);
1784 if (!opts
->frontend_set_flag_finite_math_only
)
1785 opts
->x_flag_finite_math_only
= set
;
1786 if (!opts
->frontend_set_flag_errno_math
)
1787 opts
->x_flag_errno_math
= !set
;
1790 if (!opts
->frontend_set_flag_signaling_nans
)
1791 opts
->x_flag_signaling_nans
= 0;
1792 if (!opts
->frontend_set_flag_rounding_math
)
1793 opts
->x_flag_rounding_math
= 0;
1794 if (!opts
->frontend_set_flag_cx_limited_range
)
1795 opts
->x_flag_cx_limited_range
= 1;
1799 /* When -funsafe-math-optimizations is set the following
1800 flags are set as well. */
1802 set_unsafe_math_optimizations_flags (struct gcc_options
*opts
, int set
)
1804 if (!opts
->frontend_set_flag_trapping_math
)
1805 opts
->x_flag_trapping_math
= !set
;
1806 if (!opts
->frontend_set_flag_signed_zeros
)
1807 opts
->x_flag_signed_zeros
= !set
;
1808 if (!opts
->frontend_set_flag_associative_math
)
1809 opts
->x_flag_associative_math
= set
;
1810 if (!opts
->frontend_set_flag_reciprocal_math
)
1811 opts
->x_flag_reciprocal_math
= set
;
1814 /* Return true iff flags in OPTS are set as if -ffast-math. */
1816 fast_math_flags_set_p (const struct gcc_options
*opts
)
1818 return (!opts
->x_flag_trapping_math
1819 && opts
->x_flag_unsafe_math_optimizations
1820 && opts
->x_flag_finite_math_only
1821 && !opts
->x_flag_signed_zeros
1822 && !opts
->x_flag_errno_math
);
1825 /* Return true iff flags are set as if -ffast-math but using the flags stored
1826 in the struct cl_optimization structure. */
1828 fast_math_flags_struct_set_p (struct cl_optimization
*opt
)
1830 return (!opt
->x_flag_trapping_math
1831 && opt
->x_flag_unsafe_math_optimizations
1832 && opt
->x_flag_finite_math_only
1833 && !opt
->x_flag_signed_zeros
1834 && !opt
->x_flag_errno_math
);
1837 /* Handle a debug output -g switch for options OPTS
1838 (OPTS_SET->x_write_symbols storing whether a debug type was passed
1839 explicitly), location LOC. EXTENDED is true or false to support
1840 extended output (2 is special and means "-ggdb" was given). */
1842 set_debug_level (enum debug_info_type type
, int extended
, const char *arg
,
1843 struct gcc_options
*opts
, struct gcc_options
*opts_set
,
1846 opts
->x_use_gnu_debug_info_extensions
= extended
;
1848 if (type
== NO_DEBUG
)
1850 if (opts
->x_write_symbols
== NO_DEBUG
)
1852 opts
->x_write_symbols
= PREFERRED_DEBUGGING_TYPE
;
1856 #ifdef DWARF2_DEBUGGING_INFO
1857 opts
->x_write_symbols
= DWARF2_DEBUG
;
1858 #elif defined DBX_DEBUGGING_INFO
1859 opts
->x_write_symbols
= DBX_DEBUG
;
1863 if (opts
->x_write_symbols
== NO_DEBUG
)
1864 warning_at (loc
, 0, "target system does not support debug output");
1869 /* Does it conflict with an already selected type? */
1870 if (opts_set
->x_write_symbols
!= NO_DEBUG
1871 && opts
->x_write_symbols
!= NO_DEBUG
1872 && type
!= opts
->x_write_symbols
)
1873 error_at (loc
, "debug format \"%s\" conflicts with prior selection",
1874 debug_type_names
[type
]);
1875 opts
->x_write_symbols
= type
;
1876 opts_set
->x_write_symbols
= type
;
1879 /* A debug flag without a level defaults to level 2. */
1882 if (!opts
->x_debug_info_level
)
1883 opts
->x_debug_info_level
= DINFO_LEVEL_NORMAL
;
1887 int argval
= integral_argument (arg
);
1889 error_at (loc
, "unrecognised debug output level \"%s\"", arg
);
1890 else if (argval
> 3)
1891 error_at (loc
, "debug output level %s is too high", arg
);
1893 opts
->x_debug_info_level
= (enum debug_info_levels
) argval
;
1897 /* Arrange to dump core on error for diagnostic context DC. (The
1898 regular error message is still printed first, except in the case of
1902 setup_core_dumping (diagnostic_context
*dc
)
1905 signal (SIGABRT
, SIG_DFL
);
1907 #if defined(HAVE_SETRLIMIT)
1910 if (getrlimit (RLIMIT_CORE
, &rlim
) != 0)
1911 fatal_error ("getting core file size maximum limit: %m");
1912 rlim
.rlim_cur
= rlim
.rlim_max
;
1913 if (setrlimit (RLIMIT_CORE
, &rlim
) != 0)
1914 fatal_error ("setting core file size limit to maximum: %m");
1917 diagnostic_abort_on_error (dc
);
1920 /* Parse a -d<ARG> command line switch for OPTS, location LOC,
1921 diagnostic context DC. */
1924 decode_d_option (const char *arg
, struct gcc_options
*opts
,
1925 location_t loc
, diagnostic_context
*dc
)
1933 opts
->x_flag_debug_asm
= 1;
1936 opts
->x_flag_print_asm_name
= 1;
1939 opts
->x_flag_dump_rtl_in_asm
= 1;
1940 opts
->x_flag_print_asm_name
= 1;
1943 opts
->x_graph_dump_format
= vcg
;
1946 opts
->x_rtl_dump_and_exit
= 1;
1948 case 'D': /* These are handled by the preprocessor. */
1955 setup_core_dumping (dc
);
1958 opts
->x_flag_dump_all_passed
= true;
1962 warning_at (loc
, 0, "unrecognized gcc debugging option: %c", c
);
1967 /* Enable (or disable if VALUE is 0) a warning option ARG (language
1968 mask LANG_MASK, option handlers HANDLERS) as an error for option
1969 structures OPTS and OPTS_SET, diagnostic context DC (possibly
1970 NULL), location LOC. This is used by -Werror=. */
1973 enable_warning_as_error (const char *arg
, int value
, unsigned int lang_mask
,
1974 const struct cl_option_handlers
*handlers
,
1975 struct gcc_options
*opts
,
1976 struct gcc_options
*opts_set
,
1977 location_t loc
, diagnostic_context
*dc
)
1982 new_option
= XNEWVEC (char, strlen (arg
) + 2);
1983 new_option
[0] = 'W';
1984 strcpy (new_option
+ 1, arg
);
1985 option_index
= find_opt (new_option
, lang_mask
);
1986 if (option_index
== OPT_SPECIAL_unknown
)
1988 error_at (loc
, "-Werror=%s: no option -%s", arg
, new_option
);
1992 const diagnostic_t kind
= value
? DK_ERROR
: DK_WARNING
;
1994 control_warning_option (option_index
, (int) kind
, value
,
1996 handlers
, opts
, opts_set
, dc
);
1997 if (option_index
== OPT_Wuninitialized
)
1998 enable_warning_as_error ("maybe-uninitialized", value
, lang_mask
,
1999 handlers
, opts
, opts_set
, loc
, dc
);
2004 /* Return malloced memory for the name of the option OPTION_INDEX
2005 which enabled a diagnostic (context CONTEXT), originally of type
2006 ORIG_DIAG_KIND but possibly converted to DIAG_KIND by options such
2010 option_name (diagnostic_context
*context
, int option_index
,
2011 diagnostic_t orig_diag_kind
, diagnostic_t diag_kind
)
2015 /* A warning classified as an error. */
2016 if ((orig_diag_kind
== DK_WARNING
|| orig_diag_kind
== DK_PEDWARN
)
2017 && diag_kind
== DK_ERROR
)
2018 return concat (cl_options
[OPT_Werror_
].opt_text
,
2019 /* Skip over "-W". */
2020 cl_options
[option_index
].opt_text
+ 2,
2022 /* A warning with option. */
2024 return xstrdup (cl_options
[option_index
].opt_text
);
2026 /* A warning without option classified as an error. */
2027 else if (orig_diag_kind
== DK_WARNING
|| orig_diag_kind
== DK_PEDWARN
2028 || diag_kind
== DK_WARNING
)
2030 if (context
->warning_as_error_requested
)
2031 return xstrdup (cl_options
[OPT_Werror
].opt_text
);
2033 return xstrdup (_("enabled by default"));