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