flags.h (flag_really_no_inline): Remove.
[gcc.git] / gcc / opts.c
1 /* Command line option handling.
2 Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007, 2008
3 Free Software Foundation, Inc.
4 Contributed by Neil Booth.
5
6 This file is part of GCC.
7
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
11 version.
12
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
16 for more details.
17
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/>. */
21
22 #include "config.h"
23 #include "system.h"
24 #include "intl.h"
25 #include "coretypes.h"
26 #include "tm.h"
27 #include "tree.h"
28 #include "rtl.h"
29 #include "ggc.h"
30 #include "output.h"
31 #include "langhooks.h"
32 #include "opts.h"
33 #include "options.h"
34 #include "flags.h"
35 #include "toplev.h"
36 #include "params.h"
37 #include "diagnostic.h"
38 #include "tm_p.h" /* For OPTIMIZATION_OPTIONS. */
39 #include "insn-attr.h" /* For INSN_SCHEDULING. */
40 #include "target.h"
41 #include "tree-pass.h"
42 #include "dbgcnt.h"
43 #include "debug.h"
44
45 /* Value of the -G xx switch, and whether it was passed or not. */
46 unsigned HOST_WIDE_INT g_switch_value;
47 bool g_switch_set;
48
49 /* True if we should exit after parsing options. */
50 bool exit_after_options;
51
52 /* Print various extra warnings. -W/-Wextra. */
53 bool extra_warnings;
54
55 /* True to warn about any objects definitions whose size is larger
56 than N bytes. Also want about function definitions whose returned
57 values are larger than N bytes, where N is `larger_than_size'. */
58 bool warn_larger_than;
59 HOST_WIDE_INT larger_than_size;
60
61 /* True to warn about any function whose frame size is larger
62 * than N bytes. */
63 bool warn_frame_larger_than;
64 HOST_WIDE_INT frame_larger_than_size;
65
66 /* Hack for cooperation between set_Wunused and set_Wextra. */
67 static bool maybe_warn_unused_parameter;
68
69 /* Type(s) of debugging information we are producing (if any). See
70 flags.h for the definitions of the different possible types of
71 debugging information. */
72 enum debug_info_type write_symbols = NO_DEBUG;
73
74 /* Level of debugging information we are producing. See flags.h for
75 the definitions of the different possible levels. */
76 enum debug_info_level debug_info_level = DINFO_LEVEL_NONE;
77
78 /* A major contribution to object and executable size is debug
79 information size. A major contribution to debug information size
80 is struct descriptions replicated in several object files. The
81 following flags attempt to reduce this information. The basic
82 idea is to not emit struct debugging information in the current
83 compilation unit when that information will be generated by
84 another compilation unit.
85
86 Debug information for a struct defined in the current source
87 file should be generated in the object file. Likewise the
88 debug information for a struct defined in a header should be
89 generated in the object file of the corresponding source file.
90 Both of these case are handled when the base name of the file of
91 the struct definition matches the base name of the source file
92 of the current compilation unit. This matching emits minimal
93 struct debugging information.
94
95 The base file name matching rule above will fail to emit debug
96 information for structs defined in system headers. So a second
97 category of files includes system headers in addition to files
98 with matching bases.
99
100 The remaining types of files are library headers and application
101 headers. We cannot currently distinguish these two types. */
102
103 enum debug_struct_file
104 {
105 DINFO_STRUCT_FILE_NONE, /* Debug no structs. */
106 DINFO_STRUCT_FILE_BASE, /* Debug structs defined in files with the
107 same base name as the compilation unit. */
108 DINFO_STRUCT_FILE_SYS, /* Also debug structs defined in system
109 header files. */
110 DINFO_STRUCT_FILE_ANY /* Debug structs defined in all files. */
111 };
112
113 /* Generic structs (e.g. templates not explicitly specialized)
114 may not have a compilation unit associated with them, and so
115 may need to be treated differently from ordinary structs.
116
117 Structs only handled by reference (indirectly), will also usually
118 not need as much debugging information. */
119
120 static enum debug_struct_file debug_struct_ordinary[DINFO_USAGE_NUM_ENUMS]
121 = { DINFO_STRUCT_FILE_ANY, DINFO_STRUCT_FILE_ANY, DINFO_STRUCT_FILE_ANY };
122 static enum debug_struct_file debug_struct_generic[DINFO_USAGE_NUM_ENUMS]
123 = { DINFO_STRUCT_FILE_ANY, DINFO_STRUCT_FILE_ANY, DINFO_STRUCT_FILE_ANY };
124
125 /* Parse the -femit-struct-debug-detailed option value
126 and set the flag variables. */
127
128 #define MATCH( prefix, string ) \
129 ((strncmp (prefix, string, sizeof prefix - 1) == 0) \
130 ? ((string += sizeof prefix - 1), 1) : 0)
131
132 void
133 set_struct_debug_option (const char *spec)
134 {
135 /* various labels for comparison */
136 static char dfn_lbl[] = "dfn:", dir_lbl[] = "dir:", ind_lbl[] = "ind:";
137 static char ord_lbl[] = "ord:", gen_lbl[] = "gen:";
138 static char none_lbl[] = "none", any_lbl[] = "any";
139 static char base_lbl[] = "base", sys_lbl[] = "sys";
140
141 enum debug_struct_file files = DINFO_STRUCT_FILE_ANY;
142 /* Default is to apply to as much as possible. */
143 enum debug_info_usage usage = DINFO_USAGE_NUM_ENUMS;
144 int ord = 1, gen = 1;
145
146 /* What usage? */
147 if (MATCH (dfn_lbl, spec))
148 usage = DINFO_USAGE_DFN;
149 else if (MATCH (dir_lbl, spec))
150 usage = DINFO_USAGE_DIR_USE;
151 else if (MATCH (ind_lbl, spec))
152 usage = DINFO_USAGE_IND_USE;
153
154 /* Generics or not? */
155 if (MATCH (ord_lbl, spec))
156 gen = 0;
157 else if (MATCH (gen_lbl, spec))
158 ord = 0;
159
160 /* What allowable environment? */
161 if (MATCH (none_lbl, spec))
162 files = DINFO_STRUCT_FILE_NONE;
163 else if (MATCH (any_lbl, spec))
164 files = DINFO_STRUCT_FILE_ANY;
165 else if (MATCH (sys_lbl, spec))
166 files = DINFO_STRUCT_FILE_SYS;
167 else if (MATCH (base_lbl, spec))
168 files = DINFO_STRUCT_FILE_BASE;
169 else
170 error ("argument %qs to %<-femit-struct-debug-detailed%> not recognized",
171 spec);
172
173 /* Effect the specification. */
174 if (usage == DINFO_USAGE_NUM_ENUMS)
175 {
176 if (ord)
177 {
178 debug_struct_ordinary[DINFO_USAGE_DFN] = files;
179 debug_struct_ordinary[DINFO_USAGE_DIR_USE] = files;
180 debug_struct_ordinary[DINFO_USAGE_IND_USE] = files;
181 }
182 if (gen)
183 {
184 debug_struct_generic[DINFO_USAGE_DFN] = files;
185 debug_struct_generic[DINFO_USAGE_DIR_USE] = files;
186 debug_struct_generic[DINFO_USAGE_IND_USE] = files;
187 }
188 }
189 else
190 {
191 if (ord)
192 debug_struct_ordinary[usage] = files;
193 if (gen)
194 debug_struct_generic[usage] = files;
195 }
196
197 if (*spec == ',')
198 set_struct_debug_option (spec+1);
199 else
200 {
201 /* No more -femit-struct-debug-detailed specifications.
202 Do final checks. */
203 if (*spec != '\0')
204 error ("argument %qs to %<-femit-struct-debug-detailed%> unknown",
205 spec);
206 if (debug_struct_ordinary[DINFO_USAGE_DIR_USE]
207 < debug_struct_ordinary[DINFO_USAGE_IND_USE]
208 || debug_struct_generic[DINFO_USAGE_DIR_USE]
209 < debug_struct_generic[DINFO_USAGE_IND_USE])
210 error ("%<-femit-struct-debug-detailed=dir:...%> must allow at least"
211 " as much as %<-femit-struct-debug-detailed=ind:...%>");
212 }
213 }
214
215 /* Find the base name of a path, stripping off both directories and
216 a single final extension. */
217 static int
218 base_of_path (const char *path, const char **base_out)
219 {
220 const char *base = path;
221 const char *dot = 0;
222 const char *p = path;
223 char c = *p;
224 while (c)
225 {
226 if (IS_DIR_SEPARATOR(c))
227 {
228 base = p + 1;
229 dot = 0;
230 }
231 else if (c == '.')
232 dot = p;
233 c = *++p;
234 }
235 if (!dot)
236 dot = p;
237 *base_out = base;
238 return dot - base;
239 }
240
241 /* Match the base name of a file to the base name of a compilation unit. */
242
243 static const char *main_input_basename;
244 static int main_input_baselength;
245
246 static int
247 matches_main_base (const char *path)
248 {
249 /* Cache the last query. */
250 static const char *last_path = NULL;
251 static int last_match = 0;
252 if (path != last_path)
253 {
254 const char *base;
255 int length = base_of_path (path, &base);
256 last_path = path;
257 last_match = (length == main_input_baselength
258 && memcmp (base, main_input_basename, length) == 0);
259 }
260 return last_match;
261 }
262
263 #ifdef DEBUG_DEBUG_STRUCT
264
265 static int
266 dump_struct_debug (tree type, enum debug_info_usage usage,
267 enum debug_struct_file criterion, int generic,
268 int matches, int result)
269 {
270 /* Find the type name. */
271 tree type_decl = TYPE_STUB_DECL (type);
272 tree t = type_decl;
273 const char *name = 0;
274 if (TREE_CODE (t) == TYPE_DECL)
275 t = DECL_NAME (t);
276 if (t)
277 name = IDENTIFIER_POINTER (t);
278
279 fprintf (stderr, " struct %d %s %s %s %s %d %p %s\n",
280 criterion,
281 DECL_IN_SYSTEM_HEADER (type_decl) ? "sys" : "usr",
282 matches ? "bas" : "hdr",
283 generic ? "gen" : "ord",
284 usage == DINFO_USAGE_DFN ? ";" :
285 usage == DINFO_USAGE_DIR_USE ? "." : "*",
286 result,
287 (void*) type_decl, name);
288 return result;
289 }
290 #define DUMP_GSTRUCT(type, usage, criterion, generic, matches, result) \
291 dump_struct_debug (type, usage, criterion, generic, matches, result)
292
293 #else
294
295 #define DUMP_GSTRUCT(type, usage, criterion, generic, matches, result) \
296 (result)
297
298 #endif
299
300
301 bool
302 should_emit_struct_debug (tree type, enum debug_info_usage usage)
303 {
304 enum debug_struct_file criterion;
305 tree type_decl;
306 bool generic = lang_hooks.types.generic_p (type);
307
308 if (generic)
309 criterion = debug_struct_generic[usage];
310 else
311 criterion = debug_struct_ordinary[usage];
312
313 if (criterion == DINFO_STRUCT_FILE_NONE)
314 return DUMP_GSTRUCT (type, usage, criterion, generic, false, false);
315 if (criterion == DINFO_STRUCT_FILE_ANY)
316 return DUMP_GSTRUCT (type, usage, criterion, generic, false, true);
317
318 type_decl = TYPE_STUB_DECL (type);
319
320 if (criterion == DINFO_STRUCT_FILE_SYS && DECL_IN_SYSTEM_HEADER (type_decl))
321 return DUMP_GSTRUCT (type, usage, criterion, generic, false, true);
322
323 if (matches_main_base (DECL_SOURCE_FILE (type_decl)))
324 return DUMP_GSTRUCT (type, usage, criterion, generic, true, true);
325 return DUMP_GSTRUCT (type, usage, criterion, generic, false, false);
326 }
327
328 /* Nonzero means use GNU-only extensions in the generated symbolic
329 debugging information. Currently, this only has an effect when
330 write_symbols is set to DBX_DEBUG, XCOFF_DEBUG, or DWARF_DEBUG. */
331 bool use_gnu_debug_info_extensions;
332
333 /* The default visibility for all symbols (unless overridden) */
334 enum symbol_visibility default_visibility = VISIBILITY_DEFAULT;
335
336 /* Global visibility options. */
337 struct visibility_flags visibility_options;
338
339 /* What to print when a switch has no documentation. */
340 #ifdef ENABLE_CHECKING
341 static const char undocumented_msg[] = N_("This switch lacks documentation");
342 #else
343 static const char undocumented_msg[] = "";
344 #endif
345
346 /* Used for bookkeeping on whether user set these flags so
347 -fprofile-use/-fprofile-generate does not use them. */
348 static bool profile_arc_flag_set, flag_profile_values_set;
349 static bool flag_unroll_loops_set, flag_tracer_set;
350 static bool flag_value_profile_transformations_set;
351 static bool flag_peel_loops_set, flag_branch_probabilities_set;
352 static bool flag_inline_functions_set;
353
354 /* Functions excluded from profiling. */
355
356 typedef char *char_p; /* For DEF_VEC_P. */
357 DEF_VEC_P(char_p);
358 DEF_VEC_ALLOC_P(char_p,heap);
359
360 static VEC(char_p,heap) *flag_instrument_functions_exclude_functions;
361 static VEC(char_p,heap) *flag_instrument_functions_exclude_files;
362
363 typedef const char *const_char_p; /* For DEF_VEC_P. */
364 DEF_VEC_P(const_char_p);
365 DEF_VEC_ALLOC_P(const_char_p,heap);
366
367 static VEC(const_char_p,heap) *ignored_options;
368
369 /* Function calls disallowed under -Wdisallowed-function-list=... */
370 static VEC(char_p,heap) *warning_disallowed_functions;
371
372 /* If -Wdisallowed-function-list=... */
373 bool warn_disallowed_functions = false;
374
375 /* Input file names. */
376 const char **in_fnames;
377 unsigned num_in_fnames;
378
379 static int common_handle_option (size_t scode, const char *arg, int value,
380 unsigned int lang_mask);
381 static void handle_param (const char *);
382 static void set_Wextra (int);
383 static unsigned int handle_option (const char **argv, unsigned int lang_mask);
384 static char *write_langs (unsigned int lang_mask);
385 static void complain_wrong_lang (const char *, const struct cl_option *,
386 unsigned int lang_mask);
387 static void handle_options (unsigned int, const char **, unsigned int);
388 static void set_debug_level (enum debug_info_type type, int extended,
389 const char *arg);
390
391 /* If ARG is a non-negative integer made up solely of digits, return its
392 value, otherwise return -1. */
393 static int
394 integral_argument (const char *arg)
395 {
396 const char *p = arg;
397
398 while (*p && ISDIGIT (*p))
399 p++;
400
401 if (*p == '\0')
402 return atoi (arg);
403
404 return -1;
405 }
406
407 /* Return a malloced slash-separated list of languages in MASK. */
408 static char *
409 write_langs (unsigned int mask)
410 {
411 unsigned int n = 0, len = 0;
412 const char *lang_name;
413 char *result;
414
415 for (n = 0; (lang_name = lang_names[n]) != 0; n++)
416 if (mask & (1U << n))
417 len += strlen (lang_name) + 1;
418
419 result = XNEWVEC (char, len);
420 len = 0;
421 for (n = 0; (lang_name = lang_names[n]) != 0; n++)
422 if (mask & (1U << n))
423 {
424 if (len)
425 result[len++] = '/';
426 strcpy (result + len, lang_name);
427 len += strlen (lang_name);
428 }
429
430 result[len] = 0;
431
432 return result;
433 }
434
435 /* Complain that switch OPT_INDEX does not apply to this front end. */
436 static void
437 complain_wrong_lang (const char *text, const struct cl_option *option,
438 unsigned int lang_mask)
439 {
440 char *ok_langs, *bad_lang;
441
442 ok_langs = write_langs (option->flags);
443 bad_lang = write_langs (lang_mask);
444
445 /* Eventually this should become a hard error IMO. */
446 warning (0, "command line option \"%s\" is valid for %s but not for %s",
447 text, ok_langs, bad_lang);
448
449 free (ok_langs);
450 free (bad_lang);
451 }
452
453 /* Buffer the unknown option described by the string OPT. Currently,
454 we only complain about unknown -Wno-* options if they may have
455 prevented a diagnostic. Otherwise, we just ignore them.
456 Note that if we do complain, it is only as a warning, not an error;
457 passing the compiler an unrecognised -Wno-* option should never
458 change whether the compilation succeeds or fails. */
459
460 static void postpone_unknown_option_warning(const char *opt)
461 {
462 VEC_safe_push (const_char_p, heap, ignored_options, opt);
463 }
464
465 /* Produce a warning for each option previously buffered. */
466
467 void print_ignored_options (void)
468 {
469 location_t saved_loc = input_location;
470
471 input_location = 0;
472
473 while (!VEC_empty (const_char_p, ignored_options))
474 {
475 const char *opt;
476 opt = VEC_pop (const_char_p, ignored_options);
477 warning (0, "unrecognized command line option \"%s\"", opt);
478 }
479
480 input_location = saved_loc;
481 }
482
483 /* Handle the switch beginning at ARGV for the language indicated by
484 LANG_MASK. Returns the number of switches consumed. */
485 static unsigned int
486 handle_option (const char **argv, unsigned int lang_mask)
487 {
488 size_t opt_index;
489 const char *opt, *arg = 0;
490 char *dup = 0;
491 int value = 1;
492 unsigned int result = 0;
493 const struct cl_option *option;
494
495 opt = argv[0];
496
497 opt_index = find_opt (opt + 1, lang_mask | CL_COMMON | CL_TARGET);
498 if (opt_index == cl_options_count
499 && (opt[1] == 'W' || opt[1] == 'f' || opt[1] == 'm')
500 && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-')
501 {
502 /* Drop the "no-" from negative switches. */
503 size_t len = strlen (opt) - 3;
504
505 dup = XNEWVEC (char, len + 1);
506 dup[0] = '-';
507 dup[1] = opt[1];
508 memcpy (dup + 2, opt + 5, len - 2 + 1);
509 opt = dup;
510 value = 0;
511 opt_index = find_opt (opt + 1, lang_mask | CL_COMMON | CL_TARGET);
512 if (opt_index == cl_options_count && opt[1] == 'W')
513 {
514 /* We don't generate warnings for unknown -Wno-* options
515 unless we issue diagnostics. */
516 postpone_unknown_option_warning (argv[0]);
517 result = 1;
518 goto done;
519 }
520 }
521
522 if (opt_index == cl_options_count)
523 goto done;
524
525 option = &cl_options[opt_index];
526
527 /* Reject negative form of switches that don't take negatives as
528 unrecognized. */
529 if (!value && (option->flags & CL_REJECT_NEGATIVE))
530 goto done;
531
532 /* We've recognized this switch. */
533 result = 1;
534
535 /* Check to see if the option is disabled for this configuration. */
536 if (option->flags & CL_DISABLED)
537 {
538 error ("command line option %qs"
539 " is not supported by this configuration", opt);
540 goto done;
541 }
542
543 /* Sort out any argument the switch takes. */
544 if (option->flags & CL_JOINED)
545 {
546 /* Have arg point to the original switch. This is because
547 some code, such as disable_builtin_function, expects its
548 argument to be persistent until the program exits. */
549 arg = argv[0] + cl_options[opt_index].opt_len + 1;
550 if (!value)
551 arg += strlen ("no-");
552
553 if (*arg == '\0' && !(option->flags & CL_MISSING_OK))
554 {
555 if (option->flags & CL_SEPARATE)
556 {
557 arg = argv[1];
558 result = 2;
559 }
560 else
561 /* Missing argument. */
562 arg = NULL;
563 }
564 }
565 else if (option->flags & CL_SEPARATE)
566 {
567 arg = argv[1];
568 result = 2;
569 }
570
571 /* Now we've swallowed any potential argument, complain if this
572 is a switch for a different front end. */
573 if (!(option->flags & (lang_mask | CL_COMMON | CL_TARGET)))
574 {
575 complain_wrong_lang (argv[0], option, lang_mask);
576 goto done;
577 }
578 else if ((option->flags & CL_TARGET)
579 && (option->flags & CL_LANG_ALL)
580 && !(option->flags & lang_mask))
581 {
582 /* Complain for target flag language mismatches if any languages
583 are specified. */
584 complain_wrong_lang (argv[0], option, lang_mask);
585 goto done;
586 }
587
588 if (arg == NULL && (option->flags & (CL_JOINED | CL_SEPARATE)))
589 {
590 if (!lang_hooks.missing_argument (opt, opt_index))
591 error ("missing argument to \"%s\"", opt);
592 goto done;
593 }
594
595 /* If the switch takes an integer, convert it. */
596 if (arg && (option->flags & CL_UINTEGER))
597 {
598 value = integral_argument (arg);
599 if (value == -1)
600 {
601 error ("argument to \"%s\" should be a non-negative integer",
602 option->opt_text);
603 goto done;
604 }
605 }
606
607 if (option->flag_var)
608 switch (option->var_type)
609 {
610 case CLVC_BOOLEAN:
611 *(int *) option->flag_var = value;
612 break;
613
614 case CLVC_EQUAL:
615 *(int *) option->flag_var = (value
616 ? option->var_value
617 : !option->var_value);
618 break;
619
620 case CLVC_BIT_CLEAR:
621 case CLVC_BIT_SET:
622 if ((value != 0) == (option->var_type == CLVC_BIT_SET))
623 *(int *) option->flag_var |= option->var_value;
624 else
625 *(int *) option->flag_var &= ~option->var_value;
626 if (option->flag_var == &target_flags)
627 target_flags_explicit |= option->var_value;
628 break;
629
630 case CLVC_STRING:
631 *(const char **) option->flag_var = arg;
632 break;
633 }
634
635 if (option->flags & lang_mask)
636 if (lang_hooks.handle_option (opt_index, arg, value) == 0)
637 result = 0;
638
639 if (result && (option->flags & CL_COMMON))
640 if (common_handle_option (opt_index, arg, value, lang_mask) == 0)
641 result = 0;
642
643 if (result && (option->flags & CL_TARGET))
644 if (!targetm.handle_option (opt_index, arg, value))
645 result = 0;
646
647 done:
648 if (dup)
649 free (dup);
650 return result;
651 }
652
653 /* Handle FILENAME from the command line. */
654 static void
655 add_input_filename (const char *filename)
656 {
657 num_in_fnames++;
658 in_fnames = XRESIZEVEC (const char *, in_fnames, num_in_fnames);
659 in_fnames[num_in_fnames - 1] = filename;
660 }
661
662 /* Add comma-separated strings to a char_p vector. */
663
664 static void
665 add_comma_separated_to_vector (VEC(char_p,heap) **pvec, const char* arg)
666 {
667 char *tmp;
668 char *r;
669 char *w;
670 char *token_start;
671
672 /* We never free this string. */
673 tmp = xstrdup (arg);
674
675 r = tmp;
676 w = tmp;
677 token_start = tmp;
678
679 while (*r != '\0')
680 {
681 if (*r == ',')
682 {
683 *w++ = '\0';
684 ++r;
685 VEC_safe_push (char_p, heap, *pvec, token_start);
686 token_start = w;
687 }
688 if (*r == '\\' && r[1] == ',')
689 {
690 *w++ = ',';
691 r += 2;
692 }
693 else
694 *w++ = *r++;
695 }
696 if (*token_start != '\0')
697 VEC_safe_push (char_p, heap, *pvec, token_start);
698 }
699
700 /* Return whether we should exclude FNDECL from instrumentation. */
701
702 bool
703 flag_instrument_functions_exclude_p (tree fndecl)
704 {
705 if (VEC_length (char_p, flag_instrument_functions_exclude_functions) > 0)
706 {
707 const char *name;
708 int i;
709 char *s;
710
711 name = lang_hooks.decl_printable_name (fndecl, 0);
712 for (i = 0;
713 VEC_iterate (char_p, flag_instrument_functions_exclude_functions,
714 i, s);
715 ++i)
716 {
717 if (strstr (name, s) != NULL)
718 return true;
719 }
720 }
721
722 if (VEC_length (char_p, flag_instrument_functions_exclude_files) > 0)
723 {
724 const char *name;
725 int i;
726 char *s;
727
728 name = DECL_SOURCE_FILE (fndecl);
729 for (i = 0;
730 VEC_iterate (char_p, flag_instrument_functions_exclude_files, i, s);
731 ++i)
732 {
733 if (strstr (name, s) != NULL)
734 return true;
735 }
736 }
737
738 return false;
739 }
740
741
742 /* Return whether this function call is disallowed. */
743 void
744 warn_if_disallowed_function_p (const_tree exp)
745 {
746 if (TREE_CODE(exp) == CALL_EXPR
747 && VEC_length (char_p, warning_disallowed_functions) > 0)
748 {
749 int i;
750 char *s;
751 const char *fnname =
752 IDENTIFIER_POINTER (DECL_NAME (get_callee_fndecl (exp)));
753 for (i = 0; VEC_iterate (char_p, warning_disallowed_functions, i, s);
754 ++i)
755 {
756 if (strcmp (fnname, s) == 0)
757 {
758 warning (OPT_Wdisallowed_function_list_,
759 "disallowed call to %qs", fnname);
760 break;
761 }
762 }
763 }
764 }
765
766 /* Decode and handle the vector of command line options. LANG_MASK
767 contains has a single bit set representing the current
768 language. */
769 static void
770 handle_options (unsigned int argc, const char **argv, unsigned int lang_mask)
771 {
772 unsigned int n, i;
773
774 for (i = 1; i < argc; i += n)
775 {
776 const char *opt = argv[i];
777
778 /* Interpret "-" or a non-switch as a file name. */
779 if (opt[0] != '-' || opt[1] == '\0')
780 {
781 if (main_input_filename == NULL)
782 {
783 main_input_filename = opt;
784 main_input_baselength
785 = base_of_path (main_input_filename, &main_input_basename);
786 }
787 add_input_filename (opt);
788 n = 1;
789 continue;
790 }
791
792 n = handle_option (argv + i, lang_mask);
793
794 if (!n)
795 {
796 n = 1;
797 error ("unrecognized command line option \"%s\"", opt);
798 }
799 }
800 }
801
802 /* Parse command line options and set default flag values. Do minimal
803 options processing. */
804 void
805 decode_options (unsigned int argc, const char **argv)
806 {
807 static bool first_time_p = true;
808 static int initial_max_aliased_vops;
809 static int initial_avg_aliased_vops;
810 static int initial_min_crossjump_insns;
811 static int initial_max_fields_for_field_sensitive;
812 static unsigned int initial_lang_mask;
813
814 unsigned int i, lang_mask;
815 int opt1;
816 int opt2;
817 int opt3;
818 int opt1_max;
819
820 if (first_time_p)
821 {
822 /* Perform language-specific options initialization. */
823 initial_lang_mask = lang_mask = lang_hooks.init_options (argc, argv);
824
825 lang_hooks.initialize_diagnostics (global_dc);
826
827 /* Save initial values of parameters we reset. */
828 initial_max_aliased_vops = MAX_ALIASED_VOPS;
829 initial_avg_aliased_vops = AVG_ALIASED_VOPS;
830 initial_min_crossjump_insns
831 = compiler_params[PARAM_MIN_CROSSJUMP_INSNS].value;
832 initial_max_fields_for_field_sensitive
833 = compiler_params[PARAM_MAX_FIELDS_FOR_FIELD_SENSITIVE].value;
834 }
835 else
836 lang_mask = initial_lang_mask;
837
838 /* Scan to see what optimization level has been specified. That will
839 determine the default value of many flags. */
840 for (i = 1; i < argc; i++)
841 {
842 if (!strcmp (argv[i], "-O"))
843 {
844 optimize = 1;
845 optimize_size = 0;
846 }
847 else if (argv[i][0] == '-' && argv[i][1] == 'O')
848 {
849 /* Handle -Os, -O2, -O3, -O69, ... */
850 const char *p = &argv[i][2];
851
852 if ((p[0] == 's') && (p[1] == 0))
853 {
854 optimize_size = 1;
855
856 /* Optimizing for size forces optimize to be 2. */
857 optimize = 2;
858 }
859 else
860 {
861 const int optimize_val = read_integral_parameter (p, p - 2, -1);
862 if (optimize_val != -1)
863 {
864 optimize = optimize_val;
865 optimize_size = 0;
866 }
867 }
868 }
869 }
870
871 if (!flag_unit_at_a_time)
872 {
873 flag_section_anchors = 0;
874 flag_toplevel_reorder = 0;
875 }
876 if (!flag_toplevel_reorder)
877 {
878 if (flag_section_anchors == 1)
879 error ("Section anchors must be disabled when toplevel reorder is disabled.");
880 flag_section_anchors = 0;
881 }
882
883 /* Originally we just set the variables if a particular optimization level,
884 but with the advent of being able to change the optimization level for a
885 function, we need to reset optimizations. */
886 if (!optimize)
887 {
888 flag_merge_constants = 0;
889
890 /* We disable toplevel reordering at -O0 to disable transformations that
891 might be surprising to end users and to get -fno-toplevel-reorder
892 tested, but we keep section anchors. */
893 if (flag_toplevel_reorder == 2)
894 flag_toplevel_reorder = 0;
895 }
896 else
897 flag_merge_constants = 1;
898
899 /* -O1 optimizations. */
900 opt1 = (optimize >= 1);
901 flag_defer_pop = opt1;
902 #ifdef DELAY_SLOTS
903 flag_delayed_branch = opt1;
904 #endif
905 #ifdef CAN_DEBUG_WITHOUT_FP
906 flag_omit_frame_pointer = opt1;
907 #endif
908 flag_guess_branch_prob = opt1;
909 flag_cprop_registers = opt1;
910 flag_if_conversion = opt1;
911 flag_if_conversion2 = opt1;
912 flag_ipa_pure_const = opt1;
913 flag_ipa_reference = opt1;
914 flag_split_wide_types = opt1;
915 flag_tree_ccp = opt1;
916 flag_tree_dce = opt1;
917 flag_tree_dom = opt1;
918 flag_tree_dse = opt1;
919 flag_tree_ter = opt1;
920 flag_tree_sra = opt1;
921 flag_tree_copyrename = opt1;
922 flag_tree_fre = opt1;
923 flag_tree_copy_prop = opt1;
924 flag_tree_sink = opt1;
925 flag_tree_ch = opt1;
926
927 /* -O2 optimizations. */
928 opt2 = (optimize >= 2);
929 flag_inline_small_functions = opt2;
930 flag_indirect_inlining = opt2;
931 flag_thread_jumps = opt2;
932 flag_crossjumping = opt2;
933 flag_optimize_sibling_calls = opt2;
934 flag_forward_propagate = opt2;
935 flag_cse_follow_jumps = opt2;
936 flag_gcse = opt2;
937 flag_expensive_optimizations = opt2;
938 flag_rerun_cse_after_loop = opt2;
939 flag_caller_saves = opt2;
940 flag_peephole2 = opt2;
941 #ifdef INSN_SCHEDULING
942 flag_schedule_insns = opt2;
943 flag_schedule_insns_after_reload = opt2;
944 #endif
945 flag_regmove = opt2;
946 flag_strict_aliasing = opt2;
947 flag_strict_overflow = opt2;
948 flag_delete_null_pointer_checks = opt2;
949 flag_reorder_blocks = opt2;
950 flag_reorder_functions = opt2;
951 flag_tree_store_ccp = opt2;
952 flag_tree_vrp = opt2;
953 flag_tree_builtin_call_dce = opt2;
954 flag_tree_pre = opt2;
955 flag_tree_switch_conversion = 1;
956
957 /* Allow more virtual operators to increase alias precision. */
958
959 set_param_value ("max-aliased-vops",
960 (opt2) ? 500 : initial_max_aliased_vops);
961
962 /* Track fields in field-sensitive alias analysis. */
963 set_param_value ("max-fields-for-field-sensitive",
964 (opt2) ? 100 : initial_max_fields_for_field_sensitive);
965
966 /* -O3 optimizations. */
967 opt3 = (optimize >= 3);
968 flag_predictive_commoning = opt3;
969 flag_inline_functions = opt3;
970 flag_unswitch_loops = opt3;
971 flag_gcse_after_reload = opt3;
972 flag_tree_vectorize = opt3;
973
974 /* Allow even more virtual operators. Max-aliased-vops was set above for
975 -O2, so don't reset it unless we are at -O3. */
976 if (opt3)
977 set_param_value ("max-aliased-vops", 1000);
978
979 set_param_value ("avg-aliased-vops", (opt3) ? 3 : initial_avg_aliased_vops);
980
981 /* Just -O1/-O0 optimizations. */
982 opt1_max = (optimize <= 1);
983 align_loops = opt1_max;
984 align_jumps = opt1_max;
985 align_labels = opt1_max;
986 align_functions = opt1_max;
987
988 if (optimize_size)
989 {
990 /* Loop header copying usually increases size of the code. This used not to
991 be true, since quite often it is possible to verify that the condition is
992 satisfied in the first iteration and therefore to eliminate it. Jump
993 threading handles these cases now. */
994 flag_tree_ch = 0;
995
996 /* Conditional DCE generates bigger code. */
997 flag_tree_builtin_call_dce = 0;
998
999 /* PRE tends to generate bigger code. */
1000 flag_tree_pre = 0;
1001
1002 /* These options are set with -O3, so reset for -Os */
1003 flag_predictive_commoning = 0;
1004 flag_inline_functions = 0;
1005 flag_unswitch_loops = 0;
1006 flag_gcse_after_reload = 0;
1007 flag_tree_vectorize = 0;
1008
1009 /* Don't reorder blocks when optimizing for size because extra jump insns may
1010 be created; also barrier may create extra padding.
1011
1012 More correctly we should have a block reordering mode that tried to
1013 minimize the combined size of all the jumps. This would more or less
1014 automatically remove extra jumps, but would also try to use more short
1015 jumps instead of long jumps. */
1016 flag_reorder_blocks = 0;
1017 flag_reorder_blocks_and_partition = 0;
1018
1019 /* Inlining of functions reducing size is a good idea regardless of them
1020 being declared inline. */
1021 flag_inline_functions = 1;
1022
1023 /* Don't align code. */
1024 align_loops = 1;
1025 align_jumps = 1;
1026 align_labels = 1;
1027 align_functions = 1;
1028
1029 /* Unroll/prefetch switches that may be set on the command line, and tend to
1030 generate bigger code. */
1031 flag_unroll_loops = 0;
1032 flag_unroll_all_loops = 0;
1033 flag_prefetch_loop_arrays = 0;
1034
1035 /* Basic optimization options. */
1036 optimize_size = 1;
1037 if (optimize > 2)
1038 optimize = 2;
1039
1040 /* We want to crossjump as much as possible. */
1041 set_param_value ("min-crossjump-insns", 1);
1042 }
1043 else
1044 set_param_value ("min-crossjump-insns", initial_min_crossjump_insns);
1045
1046 if (first_time_p)
1047 {
1048 /* Initialize whether `char' is signed. */
1049 flag_signed_char = DEFAULT_SIGNED_CHAR;
1050 /* Set this to a special "uninitialized" value. The actual default is
1051 set after target options have been processed. */
1052 flag_short_enums = 2;
1053
1054 /* Initialize target_flags before OPTIMIZATION_OPTIONS so the latter can
1055 modify it. */
1056 target_flags = targetm.default_target_flags;
1057
1058 /* Some targets have ABI-specified unwind tables. */
1059 flag_unwind_tables = targetm.unwind_tables_default;
1060 }
1061
1062 #ifdef OPTIMIZATION_OPTIONS
1063 /* Allow default optimizations to be specified on a per-machine basis. */
1064 OPTIMIZATION_OPTIONS (optimize, optimize_size);
1065 #endif
1066
1067 handle_options (argc, argv, lang_mask);
1068
1069 if (first_time_p)
1070 {
1071 if (flag_pie)
1072 flag_pic = flag_pie;
1073 if (flag_pic && !flag_pie)
1074 flag_shlib = 1;
1075 }
1076
1077 if (optimize == 0)
1078 {
1079 /* Inlining does not work if not optimizing,
1080 so force it not to be done. */
1081 warn_inline = 0;
1082 flag_no_inline = 1;
1083
1084 /* The c_decode_option function and decode_option hook set
1085 this to `2' if -Wall is used, so we can avoid giving out
1086 lots of errors for people who don't realize what -Wall does. */
1087 if (warn_uninitialized == 1)
1088 warning (OPT_Wuninitialized,
1089 "-Wuninitialized is not supported without -O");
1090 }
1091
1092 /* The optimization to partition hot and cold basic blocks into separate
1093 sections of the .o and executable files does not work (currently)
1094 with exception handling. This is because there is no support for
1095 generating unwind info. If flag_exceptions is turned on we need to
1096 turn off the partitioning optimization. */
1097
1098 if (flag_exceptions && flag_reorder_blocks_and_partition)
1099 {
1100 inform
1101 ("-freorder-blocks-and-partition does not work with exceptions");
1102 flag_reorder_blocks_and_partition = 0;
1103 flag_reorder_blocks = 1;
1104 }
1105
1106 /* If user requested unwind info, then turn off the partitioning
1107 optimization. */
1108
1109 if (flag_unwind_tables && ! targetm.unwind_tables_default
1110 && flag_reorder_blocks_and_partition)
1111 {
1112 inform ("-freorder-blocks-and-partition does not support unwind info");
1113 flag_reorder_blocks_and_partition = 0;
1114 flag_reorder_blocks = 1;
1115 }
1116
1117 /* If the target requested unwind info, then turn off the partitioning
1118 optimization with a different message. Likewise, if the target does not
1119 support named sections. */
1120
1121 if (flag_reorder_blocks_and_partition
1122 && (!targetm.have_named_sections
1123 || (flag_unwind_tables && targetm.unwind_tables_default)))
1124 {
1125 inform
1126 ("-freorder-blocks-and-partition does not work on this architecture");
1127 flag_reorder_blocks_and_partition = 0;
1128 flag_reorder_blocks = 1;
1129 }
1130
1131 /* Save the current optimization options if this is the first call. */
1132 if (first_time_p)
1133 {
1134 optimization_default_node = build_optimization_node ();
1135 optimization_current_node = optimization_default_node;
1136 first_time_p = false;
1137 }
1138 }
1139
1140 #define LEFT_COLUMN 27
1141
1142 /* Output ITEM, of length ITEM_WIDTH, in the left column,
1143 followed by word-wrapped HELP in a second column. */
1144 static void
1145 wrap_help (const char *help,
1146 const char *item,
1147 unsigned int item_width,
1148 unsigned int columns)
1149 {
1150 unsigned int col_width = LEFT_COLUMN;
1151 unsigned int remaining, room, len;
1152
1153 remaining = strlen (help);
1154
1155 do
1156 {
1157 room = columns - 3 - MAX (col_width, item_width);
1158 if (room > columns)
1159 room = 0;
1160 len = remaining;
1161
1162 if (room < len)
1163 {
1164 unsigned int i;
1165
1166 for (i = 0; help[i]; i++)
1167 {
1168 if (i >= room && len != remaining)
1169 break;
1170 if (help[i] == ' ')
1171 len = i;
1172 else if ((help[i] == '-' || help[i] == '/')
1173 && help[i + 1] != ' '
1174 && i > 0 && ISALPHA (help[i - 1]))
1175 len = i + 1;
1176 }
1177 }
1178
1179 printf( " %-*.*s %.*s\n", col_width, item_width, item, len, help);
1180 item_width = 0;
1181 while (help[len] == ' ')
1182 len++;
1183 help += len;
1184 remaining -= len;
1185 }
1186 while (remaining);
1187 }
1188
1189 /* Print help for a specific front-end, etc. */
1190 static void
1191 print_filtered_help (unsigned int include_flags,
1192 unsigned int exclude_flags,
1193 unsigned int any_flags,
1194 unsigned int columns)
1195 {
1196 unsigned int i;
1197 const char *help;
1198 static char *printed = NULL;
1199 bool found = false;
1200 bool displayed = false;
1201
1202 if (include_flags == CL_PARAMS)
1203 {
1204 for (i = 0; i < LAST_PARAM; i++)
1205 {
1206 const char *param = compiler_params[i].option;
1207
1208 help = compiler_params[i].help;
1209 if (help == NULL || *help == '\0')
1210 {
1211 if (exclude_flags & CL_UNDOCUMENTED)
1212 continue;
1213 help = undocumented_msg;
1214 }
1215
1216 /* Get the translation. */
1217 help = _(help);
1218
1219 wrap_help (help, param, strlen (param), columns);
1220 }
1221 putchar ('\n');
1222 return;
1223 }
1224
1225 if (!printed)
1226 printed = XCNEWVAR (char, cl_options_count);
1227
1228 for (i = 0; i < cl_options_count; i++)
1229 {
1230 static char new_help[128];
1231 const struct cl_option *option = cl_options + i;
1232 unsigned int len;
1233 const char *opt;
1234 const char *tab;
1235
1236 if (include_flags == 0
1237 || ((option->flags & include_flags) != include_flags))
1238 {
1239 if ((option->flags & any_flags) == 0)
1240 continue;
1241 }
1242
1243 /* Skip unwanted switches. */
1244 if ((option->flags & exclude_flags) != 0)
1245 continue;
1246
1247 found = true;
1248 /* Skip switches that have already been printed. */
1249 if (printed[i])
1250 continue;
1251
1252 printed[i] = true;
1253
1254 help = option->help;
1255 if (help == NULL)
1256 {
1257 if (exclude_flags & CL_UNDOCUMENTED)
1258 continue;
1259 help = undocumented_msg;
1260 }
1261
1262 /* Get the translation. */
1263 help = _(help);
1264
1265 /* Find the gap between the name of the
1266 option and its descriptive text. */
1267 tab = strchr (help, '\t');
1268 if (tab)
1269 {
1270 len = tab - help;
1271 opt = help;
1272 help = tab + 1;
1273 }
1274 else
1275 {
1276 opt = option->opt_text;
1277 len = strlen (opt);
1278 }
1279
1280 /* With the -Q option enabled we change the descriptive text associated
1281 with an option to be an indication of its current setting. */
1282 if (!quiet_flag)
1283 {
1284 if (len < (LEFT_COLUMN + 2))
1285 strcpy (new_help, "\t\t");
1286 else
1287 strcpy (new_help, "\t");
1288
1289 if (option->flag_var != NULL)
1290 {
1291 if (option->flags & CL_JOINED)
1292 {
1293 if (option->var_type == CLVC_STRING)
1294 {
1295 if (* (const char **) option->flag_var != NULL)
1296 snprintf (new_help + strlen (new_help),
1297 sizeof (new_help) - strlen (new_help),
1298 * (const char **) option->flag_var);
1299 }
1300 else
1301 sprintf (new_help + strlen (new_help),
1302 "%#x", * (int *) option->flag_var);
1303 }
1304 else
1305 strcat (new_help, option_enabled (i)
1306 ? _("[enabled]") : _("[disabled]"));
1307 }
1308
1309 help = new_help;
1310 }
1311
1312 wrap_help (help, opt, len, columns);
1313 displayed = true;
1314 }
1315
1316 if (! found)
1317 {
1318 unsigned int langs = include_flags & CL_LANG_ALL;
1319
1320 if (langs == 0)
1321 printf (_(" No options with the desired characteristics were found\n"));
1322 else
1323 {
1324 unsigned int i;
1325
1326 /* PR 31349: Tell the user how to see all of the
1327 options supported by a specific front end. */
1328 for (i = 0; (1U << i) < CL_LANG_ALL; i ++)
1329 if ((1U << i) & langs)
1330 printf (_(" None found. Use --help=%s to show *all* the options supported by the %s front-end\n"),
1331 lang_names[i], lang_names[i]);
1332 }
1333
1334 }
1335 else if (! displayed)
1336 printf (_(" All options with the desired characteristics have already been displayed\n"));
1337
1338 putchar ('\n');
1339 }
1340
1341 /* Display help for a specified type of option.
1342 The options must have ALL of the INCLUDE_FLAGS set
1343 ANY of the flags in the ANY_FLAGS set
1344 and NONE of the EXCLUDE_FLAGS set. */
1345 static void
1346 print_specific_help (unsigned int include_flags,
1347 unsigned int exclude_flags,
1348 unsigned int any_flags)
1349 {
1350 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1351 const char * description = NULL;
1352 const char * descrip_extra = "";
1353 size_t i;
1354 unsigned int flag;
1355 static unsigned int columns = 0;
1356
1357 /* Sanity check: Make sure that we do not have more
1358 languages than we have bits available to enumerate them. */
1359 gcc_assert ((1U << cl_lang_count) < CL_MIN_OPTION_CLASS);
1360
1361 /* If we have not done so already, obtain
1362 the desired maximum width of the output. */
1363 if (columns == 0)
1364 {
1365 const char *p;
1366
1367 GET_ENVIRONMENT (p, "COLUMNS");
1368 if (p != NULL)
1369 {
1370 int value = atoi (p);
1371
1372 if (value > 0)
1373 columns = value;
1374 }
1375
1376 if (columns == 0)
1377 /* Use a reasonable default. */
1378 columns = 80;
1379 }
1380
1381 /* Decide upon the title for the options that we are going to display. */
1382 for (i = 0, flag = 1; flag <= CL_MAX_OPTION_CLASS; flag <<= 1, i ++)
1383 {
1384 switch (flag & include_flags)
1385 {
1386 case 0:
1387 break;
1388
1389 case CL_TARGET:
1390 description = _("The following options are target specific");
1391 break;
1392 case CL_WARNING:
1393 description = _("The following options control compiler warning messages");
1394 break;
1395 case CL_OPTIMIZATION:
1396 description = _("The following options control optimizations");
1397 break;
1398 case CL_COMMON:
1399 description = _("The following options are language-independent");
1400 break;
1401 case CL_PARAMS:
1402 description = _("The --param option recognizes the following as parameters");
1403 break;
1404 default:
1405 if (i >= cl_lang_count)
1406 break;
1407 if ((exclude_flags & ((1U << cl_lang_count) - 1)) != 0)
1408 description = _("The following options are specific to just the language ");
1409 else
1410 description = _("The following options are supported by the language ");
1411 descrip_extra = lang_names [i];
1412 break;
1413 }
1414 }
1415
1416 if (description == NULL)
1417 {
1418 if (any_flags == 0)
1419 {
1420 if (include_flags == CL_UNDOCUMENTED)
1421 description = _("The following options are not documented");
1422 else
1423 {
1424 internal_error ("unrecognized include_flags 0x%x passed to print_specific_help",
1425 include_flags);
1426 return;
1427 }
1428 }
1429 else
1430 {
1431 if (any_flags & all_langs_mask)
1432 description = _("The following options are language-related");
1433 else
1434 description = _("The following options are language-independent");
1435 }
1436 }
1437
1438 printf ("%s%s:\n", description, descrip_extra);
1439 print_filtered_help (include_flags, exclude_flags, any_flags, columns);
1440 }
1441
1442 /* Handle target- and language-independent options. Return zero to
1443 generate an "unknown option" message. Only options that need
1444 extra handling need to be listed here; if you simply want
1445 VALUE assigned to a variable, it happens automatically. */
1446
1447 static int
1448 common_handle_option (size_t scode, const char *arg, int value,
1449 unsigned int lang_mask)
1450 {
1451 static bool verbose = false;
1452 enum opt_code code = (enum opt_code) scode;
1453
1454 switch (code)
1455 {
1456 case OPT__param:
1457 handle_param (arg);
1458 break;
1459
1460 case OPT_v:
1461 verbose = true;
1462 break;
1463
1464 case OPT_fhelp:
1465 case OPT__help:
1466 {
1467 unsigned int all_langs_mask = (1U << cl_lang_count) - 1;
1468 unsigned int undoc_mask;
1469 unsigned int i;
1470
1471 undoc_mask = (verbose | extra_warnings) ? 0 : CL_UNDOCUMENTED;
1472 /* First display any single language specific options. */
1473 for (i = 0; i < cl_lang_count; i++)
1474 print_specific_help
1475 (1U << i, (all_langs_mask & (~ (1U << i))) | undoc_mask, 0);
1476 /* Next display any multi language specific options. */
1477 print_specific_help (0, undoc_mask, all_langs_mask);
1478 /* Then display any remaining, non-language options. */
1479 for (i = CL_MIN_OPTION_CLASS; i <= CL_MAX_OPTION_CLASS; i <<= 1)
1480 print_specific_help (i, undoc_mask, 0);
1481 exit_after_options = true;
1482 break;
1483 }
1484
1485 case OPT_ftarget_help:
1486 case OPT__target_help:
1487 print_specific_help (CL_TARGET, CL_UNDOCUMENTED, 0);
1488 exit_after_options = true;
1489
1490 /* Allow the target a chance to give the user some additional information. */
1491 if (targetm.target_help)
1492 targetm.target_help ();
1493 break;
1494
1495 case OPT_fhelp_:
1496 case OPT__help_:
1497 {
1498 const char * a = arg;
1499 unsigned int include_flags = 0;
1500 /* Note - by default we include undocumented options when listing
1501 specific classes. If you only want to see documented options
1502 then add ",^undocumented" to the --help= option. E.g.:
1503
1504 --help=target,^undocumented */
1505 unsigned int exclude_flags = 0;
1506
1507 /* Walk along the argument string, parsing each word in turn.
1508 The format is:
1509 arg = [^]{word}[,{arg}]
1510 word = {optimizers|target|warnings|undocumented|
1511 params|common|<language>} */
1512 while (* a != 0)
1513 {
1514 static struct
1515 {
1516 const char * string;
1517 unsigned int flag;
1518 }
1519 specifics[] =
1520 {
1521 { "optimizers", CL_OPTIMIZATION },
1522 { "target", CL_TARGET },
1523 { "warnings", CL_WARNING },
1524 { "undocumented", CL_UNDOCUMENTED },
1525 { "params", CL_PARAMS },
1526 { "joined", CL_JOINED },
1527 { "separate", CL_SEPARATE },
1528 { "common", CL_COMMON },
1529 { NULL, 0 }
1530 };
1531 unsigned int * pflags;
1532 char * comma;
1533 unsigned int lang_flag, specific_flag;
1534 unsigned int len;
1535 unsigned int i;
1536
1537 if (* a == '^')
1538 {
1539 ++ a;
1540 pflags = & exclude_flags;
1541 }
1542 else
1543 pflags = & include_flags;
1544
1545 comma = strchr (a, ',');
1546 if (comma == NULL)
1547 len = strlen (a);
1548 else
1549 len = comma - a;
1550
1551 /* Check to see if the string matches an option class name. */
1552 for (i = 0, specific_flag = 0; specifics[i].string != NULL; i++)
1553 if (strncasecmp (a, specifics[i].string, len) == 0)
1554 {
1555 specific_flag = specifics[i].flag;
1556 break;
1557 }
1558
1559 /* Check to see if the string matches a language name.
1560 Note - we rely upon the alpha-sorted nature of the entries in
1561 the lang_names array, specifically that shorter names appear
1562 before their longer variants. (i.e. C before C++). That way
1563 when we are attempting to match --help=c for example we will
1564 match with C first and not C++. */
1565 for (i = 0, lang_flag = 0; i < cl_lang_count; i++)
1566 if (strncasecmp (a, lang_names[i], len) == 0)
1567 {
1568 lang_flag = 1U << i;
1569 break;
1570 }
1571
1572 if (specific_flag != 0)
1573 {
1574 if (lang_flag == 0)
1575 * pflags |= specific_flag;
1576 else
1577 {
1578 /* The option's argument matches both the start of a
1579 language name and the start of an option class name.
1580 We have a special case for when the user has
1581 specified "--help=c", but otherwise we have to issue
1582 a warning. */
1583 if (strncasecmp (a, "c", len) == 0)
1584 * pflags |= lang_flag;
1585 else
1586 fnotice (stderr,
1587 "warning: --help argument %.*s is ambiguous, please be more specific\n",
1588 len, a);
1589 }
1590 }
1591 else if (lang_flag != 0)
1592 * pflags |= lang_flag;
1593 else
1594 fnotice (stderr,
1595 "warning: unrecognized argument to --help= option: %.*s\n",
1596 len, a);
1597
1598 if (comma == NULL)
1599 break;
1600 a = comma + 1;
1601 }
1602
1603 if (include_flags)
1604 print_specific_help (include_flags, exclude_flags, 0);
1605 exit_after_options = true;
1606 break;
1607 }
1608
1609 case OPT__version:
1610 print_version (stderr, "");
1611 exit_after_options = true;
1612 break;
1613
1614 case OPT_G:
1615 g_switch_value = value;
1616 g_switch_set = true;
1617 break;
1618
1619 case OPT_O:
1620 case OPT_Os:
1621 /* Currently handled in a prescan. */
1622 break;
1623
1624 case OPT_W:
1625 /* For backward compatibility, -W is the same as -Wextra. */
1626 set_Wextra (value);
1627 break;
1628
1629 case OPT_Wdisallowed_function_list_:
1630 warn_disallowed_functions = true;
1631 add_comma_separated_to_vector
1632 (&warning_disallowed_functions, arg);
1633 break;
1634
1635 case OPT_Werror_:
1636 enable_warning_as_error (arg, value, lang_mask);
1637 break;
1638
1639 case OPT_Wextra:
1640 set_Wextra (value);
1641 break;
1642
1643 case OPT_Wlarger_than_:
1644 /* This form corresponds to -Wlarger-than-.
1645 Kept for backward compatibility.
1646 Don't use it as the first argument of warning(). */
1647
1648 case OPT_Wlarger_than_eq:
1649 larger_than_size = value;
1650 warn_larger_than = value != -1;
1651 break;
1652
1653 case OPT_Wframe_larger_than_:
1654 frame_larger_than_size = value;
1655 warn_frame_larger_than = value != -1;
1656 break;
1657
1658 case OPT_Wstrict_aliasing:
1659 set_Wstrict_aliasing (value);
1660 break;
1661
1662 case OPT_Wstrict_aliasing_:
1663 warn_strict_aliasing = value;
1664 break;
1665
1666 case OPT_Wstrict_overflow:
1667 warn_strict_overflow = (value
1668 ? (int) WARN_STRICT_OVERFLOW_CONDITIONAL
1669 : 0);
1670 break;
1671
1672 case OPT_Wstrict_overflow_:
1673 warn_strict_overflow = value;
1674 break;
1675
1676 case OPT_Wunused:
1677 set_Wunused (value);
1678 break;
1679
1680 case OPT_aux_info:
1681 case OPT_aux_info_:
1682 aux_info_file_name = arg;
1683 flag_gen_aux_info = 1;
1684 break;
1685
1686 case OPT_auxbase:
1687 aux_base_name = arg;
1688 break;
1689
1690 case OPT_auxbase_strip:
1691 {
1692 char *tmp = xstrdup (arg);
1693 strip_off_ending (tmp, strlen (tmp));
1694 if (tmp[0])
1695 aux_base_name = tmp;
1696 }
1697 break;
1698
1699 case OPT_d:
1700 decode_d_option (arg);
1701 break;
1702
1703 case OPT_dumpbase:
1704 dump_base_name = arg;
1705 break;
1706
1707 case OPT_falign_functions_:
1708 align_functions = value;
1709 break;
1710
1711 case OPT_falign_jumps_:
1712 align_jumps = value;
1713 break;
1714
1715 case OPT_falign_labels_:
1716 align_labels = value;
1717 break;
1718
1719 case OPT_falign_loops_:
1720 align_loops = value;
1721 break;
1722
1723 case OPT_fbranch_probabilities:
1724 flag_branch_probabilities_set = true;
1725 break;
1726
1727 case OPT_fcall_used_:
1728 fix_register (arg, 0, 1);
1729 break;
1730
1731 case OPT_fcall_saved_:
1732 fix_register (arg, 0, 0);
1733 break;
1734
1735 case OPT_fdbg_cnt_:
1736 dbg_cnt_process_opt (arg);
1737 break;
1738
1739 case OPT_fdbg_cnt_list:
1740 dbg_cnt_list_all_counters ();
1741 break;
1742
1743 case OPT_fdebug_prefix_map_:
1744 add_debug_prefix_map (arg);
1745 break;
1746
1747 case OPT_fdiagnostics_show_location_:
1748 if (!strcmp (arg, "once"))
1749 diagnostic_prefixing_rule (global_dc) = DIAGNOSTICS_SHOW_PREFIX_ONCE;
1750 else if (!strcmp (arg, "every-line"))
1751 diagnostic_prefixing_rule (global_dc)
1752 = DIAGNOSTICS_SHOW_PREFIX_EVERY_LINE;
1753 else
1754 return 0;
1755 break;
1756
1757 case OPT_fdiagnostics_show_option:
1758 global_dc->show_option_requested = true;
1759 break;
1760
1761 case OPT_fdump_:
1762 if (!dump_switch_p (arg))
1763 return 0;
1764 break;
1765
1766 case OPT_ffast_math:
1767 set_fast_math_flags (value);
1768 break;
1769
1770 case OPT_funsafe_math_optimizations:
1771 set_unsafe_math_optimizations_flags (value);
1772 break;
1773
1774 case OPT_ffixed_:
1775 fix_register (arg, 1, 1);
1776 break;
1777
1778 case OPT_finline_limit_:
1779 case OPT_finline_limit_eq:
1780 set_param_value ("max-inline-insns-single", value / 2);
1781 set_param_value ("max-inline-insns-auto", value / 2);
1782 break;
1783
1784 case OPT_finstrument_functions_exclude_function_list_:
1785 add_comma_separated_to_vector
1786 (&flag_instrument_functions_exclude_functions, arg);
1787 break;
1788
1789 case OPT_finstrument_functions_exclude_file_list_:
1790 add_comma_separated_to_vector
1791 (&flag_instrument_functions_exclude_files, arg);
1792 break;
1793
1794 case OPT_fmessage_length_:
1795 pp_set_line_maximum_length (global_dc->printer, value);
1796 break;
1797
1798 case OPT_fpack_struct_:
1799 if (value <= 0 || (value & (value - 1)) || value > 16)
1800 error ("structure alignment must be a small power of two, not %d", value);
1801 else
1802 {
1803 initial_max_fld_align = value;
1804 maximum_field_alignment = value * BITS_PER_UNIT;
1805 }
1806 break;
1807
1808 case OPT_fpeel_loops:
1809 flag_peel_loops_set = true;
1810 break;
1811
1812 case OPT_fprofile_arcs:
1813 profile_arc_flag_set = true;
1814 break;
1815
1816 case OPT_finline_functions:
1817 flag_inline_functions_set = true;
1818 break;
1819
1820 case OPT_fprofile_dir_:
1821 profile_data_prefix = xstrdup (arg);
1822 break;
1823
1824 case OPT_fprofile_use_:
1825 profile_data_prefix = xstrdup (arg);
1826 flag_profile_use = true;
1827 value = true;
1828 /* No break here - do -fprofile-use processing. */
1829 case OPT_fprofile_use:
1830 if (!flag_branch_probabilities_set)
1831 flag_branch_probabilities = value;
1832 if (!flag_profile_values_set)
1833 flag_profile_values = value;
1834 if (!flag_unroll_loops_set)
1835 flag_unroll_loops = value;
1836 if (!flag_peel_loops_set)
1837 flag_peel_loops = value;
1838 if (!flag_tracer_set)
1839 flag_tracer = value;
1840 if (!flag_value_profile_transformations_set)
1841 flag_value_profile_transformations = value;
1842 if (!flag_inline_functions_set)
1843 flag_inline_functions = value;
1844 break;
1845
1846 case OPT_fprofile_generate_:
1847 profile_data_prefix = xstrdup (arg);
1848 value = true;
1849 /* No break here - do -fprofile-generate processing. */
1850 case OPT_fprofile_generate:
1851 if (!profile_arc_flag_set)
1852 profile_arc_flag = value;
1853 if (!flag_profile_values_set)
1854 flag_profile_values = value;
1855 if (!flag_value_profile_transformations_set)
1856 flag_value_profile_transformations = value;
1857 if (!flag_inline_functions_set)
1858 flag_inline_functions = value;
1859 break;
1860
1861 case OPT_fprofile_values:
1862 flag_profile_values_set = true;
1863 break;
1864
1865 case OPT_fvisibility_:
1866 {
1867 if (!strcmp(arg, "default"))
1868 default_visibility = VISIBILITY_DEFAULT;
1869 else if (!strcmp(arg, "internal"))
1870 default_visibility = VISIBILITY_INTERNAL;
1871 else if (!strcmp(arg, "hidden"))
1872 default_visibility = VISIBILITY_HIDDEN;
1873 else if (!strcmp(arg, "protected"))
1874 default_visibility = VISIBILITY_PROTECTED;
1875 else
1876 error ("unrecognized visibility value \"%s\"", arg);
1877 }
1878 break;
1879
1880 case OPT_fvpt:
1881 flag_value_profile_transformations_set = true;
1882 break;
1883
1884 case OPT_frandom_seed:
1885 /* The real switch is -fno-random-seed. */
1886 if (value)
1887 return 0;
1888 set_random_seed (NULL);
1889 break;
1890
1891 case OPT_frandom_seed_:
1892 set_random_seed (arg);
1893 break;
1894
1895 case OPT_fsched_verbose_:
1896 #ifdef INSN_SCHEDULING
1897 fix_sched_param ("verbose", arg);
1898 break;
1899 #else
1900 return 0;
1901 #endif
1902
1903 case OPT_fsched_stalled_insns_:
1904 flag_sched_stalled_insns = value;
1905 if (flag_sched_stalled_insns == 0)
1906 flag_sched_stalled_insns = -1;
1907 break;
1908
1909 case OPT_fsched_stalled_insns_dep_:
1910 flag_sched_stalled_insns_dep = value;
1911 break;
1912
1913 case OPT_fstack_limit:
1914 /* The real switch is -fno-stack-limit. */
1915 if (value)
1916 return 0;
1917 stack_limit_rtx = NULL_RTX;
1918 break;
1919
1920 case OPT_fstack_limit_register_:
1921 {
1922 int reg = decode_reg_name (arg);
1923 if (reg < 0)
1924 error ("unrecognized register name \"%s\"", arg);
1925 else
1926 stack_limit_rtx = gen_rtx_REG (Pmode, reg);
1927 }
1928 break;
1929
1930 case OPT_fstack_limit_symbol_:
1931 stack_limit_rtx = gen_rtx_SYMBOL_REF (Pmode, ggc_strdup (arg));
1932 break;
1933
1934 case OPT_ftree_vectorizer_verbose_:
1935 vect_set_verbosity_level (arg);
1936 break;
1937
1938 case OPT_ftls_model_:
1939 if (!strcmp (arg, "global-dynamic"))
1940 flag_tls_default = TLS_MODEL_GLOBAL_DYNAMIC;
1941 else if (!strcmp (arg, "local-dynamic"))
1942 flag_tls_default = TLS_MODEL_LOCAL_DYNAMIC;
1943 else if (!strcmp (arg, "initial-exec"))
1944 flag_tls_default = TLS_MODEL_INITIAL_EXEC;
1945 else if (!strcmp (arg, "local-exec"))
1946 flag_tls_default = TLS_MODEL_LOCAL_EXEC;
1947 else
1948 warning (0, "unknown tls-model \"%s\"", arg);
1949 break;
1950
1951 case OPT_ftracer:
1952 flag_tracer_set = true;
1953 break;
1954
1955 case OPT_funroll_loops:
1956 flag_unroll_loops_set = true;
1957 break;
1958
1959 case OPT_g:
1960 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg);
1961 break;
1962
1963 case OPT_gcoff:
1964 set_debug_level (SDB_DEBUG, false, arg);
1965 break;
1966
1967 case OPT_gdwarf_2:
1968 set_debug_level (DWARF2_DEBUG, false, arg);
1969 break;
1970
1971 case OPT_ggdb:
1972 set_debug_level (NO_DEBUG, 2, arg);
1973 break;
1974
1975 case OPT_gstabs:
1976 case OPT_gstabs_:
1977 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg);
1978 break;
1979
1980 case OPT_gvms:
1981 set_debug_level (VMS_DEBUG, false, arg);
1982 break;
1983
1984 case OPT_gxcoff:
1985 case OPT_gxcoff_:
1986 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg);
1987 break;
1988
1989 case OPT_o:
1990 asm_file_name = arg;
1991 break;
1992
1993 case OPT_pedantic_errors:
1994 flag_pedantic_errors = pedantic = 1;
1995 break;
1996
1997 case OPT_floop_optimize:
1998 case OPT_frerun_loop_opt:
1999 case OPT_fstrength_reduce:
2000 case OPT_ftree_store_copy_prop:
2001 case OPT_fforce_addr:
2002 case OPT_ftree_salias:
2003 /* These are no-ops, preserved for backward compatibility. */
2004 break;
2005
2006 default:
2007 /* If the flag was handled in a standard way, assume the lack of
2008 processing here is intentional. */
2009 gcc_assert (cl_options[scode].flag_var);
2010 break;
2011 }
2012
2013 return 1;
2014 }
2015
2016 /* Handle --param NAME=VALUE. */
2017 static void
2018 handle_param (const char *carg)
2019 {
2020 char *equal, *arg;
2021 int value;
2022
2023 arg = xstrdup (carg);
2024 equal = strchr (arg, '=');
2025 if (!equal)
2026 error ("%s: --param arguments should be of the form NAME=VALUE", arg);
2027 else
2028 {
2029 value = integral_argument (equal + 1);
2030 if (value == -1)
2031 error ("invalid --param value %qs", equal + 1);
2032 else
2033 {
2034 *equal = '\0';
2035 set_param_value (arg, value);
2036 }
2037 }
2038
2039 free (arg);
2040 }
2041
2042 /* Handle -W and -Wextra. */
2043 static void
2044 set_Wextra (int setting)
2045 {
2046 extra_warnings = setting;
2047 warn_unused_parameter = (setting && maybe_warn_unused_parameter);
2048
2049 /* We save the value of warn_uninitialized, since if they put
2050 -Wuninitialized on the command line, we need to generate a
2051 warning about not using it without also specifying -O. */
2052 if (setting == 0)
2053 warn_uninitialized = 0;
2054 else if (warn_uninitialized != 1)
2055 warn_uninitialized = 2;
2056 }
2057
2058 /* Initialize unused warning flags. */
2059 void
2060 set_Wunused (int setting)
2061 {
2062 warn_unused_function = setting;
2063 warn_unused_label = setting;
2064 /* Unused function parameter warnings are reported when either
2065 ``-Wextra -Wunused'' or ``-Wunused-parameter'' is specified.
2066 Thus, if -Wextra has already been seen, set warn_unused_parameter;
2067 otherwise set maybe_warn_extra_parameter, which will be picked up
2068 by set_Wextra. */
2069 maybe_warn_unused_parameter = setting;
2070 warn_unused_parameter = (setting && extra_warnings);
2071 warn_unused_variable = setting;
2072 warn_unused_value = setting;
2073 }
2074
2075 /* Used to set the level of strict aliasing warnings,
2076 when no level is specified (i.e., when -Wstrict-aliasing, and not
2077 -Wstrict-aliasing=level was given).
2078 ONOFF is assumed to take value 1 when -Wstrict-aliasing is specified,
2079 and 0 otherwise. After calling this function, wstrict_aliasing will be
2080 set to the default value of -Wstrict_aliasing=level, currently 3. */
2081 void
2082 set_Wstrict_aliasing (int onoff)
2083 {
2084 gcc_assert (onoff == 0 || onoff == 1);
2085 if (onoff != 0)
2086 warn_strict_aliasing = 3;
2087 else
2088 warn_strict_aliasing = 0;
2089 }
2090
2091 /* The following routines are useful in setting all the flags that
2092 -ffast-math and -fno-fast-math imply. */
2093 void
2094 set_fast_math_flags (int set)
2095 {
2096 flag_unsafe_math_optimizations = set;
2097 set_unsafe_math_optimizations_flags (set);
2098 flag_finite_math_only = set;
2099 flag_errno_math = !set;
2100 if (set)
2101 {
2102 flag_signaling_nans = 0;
2103 flag_rounding_math = 0;
2104 flag_cx_limited_range = 1;
2105 }
2106 }
2107
2108 /* When -funsafe-math-optimizations is set the following
2109 flags are set as well. */
2110 void
2111 set_unsafe_math_optimizations_flags (int set)
2112 {
2113 flag_trapping_math = !set;
2114 flag_signed_zeros = !set;
2115 flag_associative_math = set;
2116 flag_reciprocal_math = set;
2117 }
2118
2119 /* Return true iff flags are set as if -ffast-math. */
2120 bool
2121 fast_math_flags_set_p (void)
2122 {
2123 return (!flag_trapping_math
2124 && flag_unsafe_math_optimizations
2125 && flag_finite_math_only
2126 && !flag_signed_zeros
2127 && !flag_errno_math);
2128 }
2129
2130 /* Return true iff flags are set as if -ffast-math but using the flags stored
2131 in the struct cl_optimization structure. */
2132 bool
2133 fast_math_flags_struct_set_p (struct cl_optimization *opt)
2134 {
2135 return (!opt->flag_trapping_math
2136 && opt->flag_unsafe_math_optimizations
2137 && opt->flag_finite_math_only
2138 && !opt->flag_signed_zeros
2139 && !opt->flag_errno_math);
2140 }
2141
2142 /* Handle a debug output -g switch. EXTENDED is true or false to support
2143 extended output (2 is special and means "-ggdb" was given). */
2144 static void
2145 set_debug_level (enum debug_info_type type, int extended, const char *arg)
2146 {
2147 static bool type_explicit;
2148
2149 use_gnu_debug_info_extensions = extended;
2150
2151 if (type == NO_DEBUG)
2152 {
2153 if (write_symbols == NO_DEBUG)
2154 {
2155 write_symbols = PREFERRED_DEBUGGING_TYPE;
2156
2157 if (extended == 2)
2158 {
2159 #ifdef DWARF2_DEBUGGING_INFO
2160 write_symbols = DWARF2_DEBUG;
2161 #elif defined DBX_DEBUGGING_INFO
2162 write_symbols = DBX_DEBUG;
2163 #endif
2164 }
2165
2166 if (write_symbols == NO_DEBUG)
2167 warning (0, "target system does not support debug output");
2168 }
2169 }
2170 else
2171 {
2172 /* Does it conflict with an already selected type? */
2173 if (type_explicit && write_symbols != NO_DEBUG && type != write_symbols)
2174 error ("debug format \"%s\" conflicts with prior selection",
2175 debug_type_names[type]);
2176 write_symbols = type;
2177 type_explicit = true;
2178 }
2179
2180 /* A debug flag without a level defaults to level 2. */
2181 if (*arg == '\0')
2182 {
2183 if (!debug_info_level)
2184 debug_info_level = 2;
2185 }
2186 else
2187 {
2188 debug_info_level = integral_argument (arg);
2189 if (debug_info_level == (unsigned int) -1)
2190 error ("unrecognised debug output level \"%s\"", arg);
2191 else if (debug_info_level > 3)
2192 error ("debug output level %s is too high", arg);
2193 }
2194 }
2195
2196 /* Return 1 if OPTION is enabled, 0 if it is disabled, or -1 if it isn't
2197 a simple on-off switch. */
2198
2199 int
2200 option_enabled (int opt_idx)
2201 {
2202 const struct cl_option *option = &(cl_options[opt_idx]);
2203
2204 if (option->flag_var)
2205 switch (option->var_type)
2206 {
2207 case CLVC_BOOLEAN:
2208 return *(int *) option->flag_var != 0;
2209
2210 case CLVC_EQUAL:
2211 return *(int *) option->flag_var == option->var_value;
2212
2213 case CLVC_BIT_CLEAR:
2214 return (*(int *) option->flag_var & option->var_value) == 0;
2215
2216 case CLVC_BIT_SET:
2217 return (*(int *) option->flag_var & option->var_value) != 0;
2218
2219 case CLVC_STRING:
2220 break;
2221 }
2222 return -1;
2223 }
2224
2225 /* Fill STATE with the current state of option OPTION. Return true if
2226 there is some state to store. */
2227
2228 bool
2229 get_option_state (int option, struct cl_option_state *state)
2230 {
2231 if (cl_options[option].flag_var == 0)
2232 return false;
2233
2234 switch (cl_options[option].var_type)
2235 {
2236 case CLVC_BOOLEAN:
2237 case CLVC_EQUAL:
2238 state->data = cl_options[option].flag_var;
2239 state->size = sizeof (int);
2240 break;
2241
2242 case CLVC_BIT_CLEAR:
2243 case CLVC_BIT_SET:
2244 state->ch = option_enabled (option);
2245 state->data = &state->ch;
2246 state->size = 1;
2247 break;
2248
2249 case CLVC_STRING:
2250 state->data = *(const char **) cl_options[option].flag_var;
2251 if (state->data == 0)
2252 state->data = "";
2253 state->size = strlen ((const char *) state->data) + 1;
2254 break;
2255 }
2256 return true;
2257 }
2258
2259 /* Enable a warning option as an error. This is used by -Werror= and
2260 also by legacy Werror-implicit-function-declaration. */
2261
2262 void
2263 enable_warning_as_error (const char *arg, int value, unsigned int lang_mask)
2264 {
2265 char *new_option;
2266 int option_index;
2267
2268 new_option = XNEWVEC (char, strlen (arg) + 2);
2269 new_option[0] = 'W';
2270 strcpy (new_option + 1, arg);
2271 option_index = find_opt (new_option, lang_mask);
2272 if (option_index == N_OPTS)
2273 {
2274 error ("-Werror=%s: No option -%s", arg, new_option);
2275 }
2276 else
2277 {
2278 int kind = value ? DK_ERROR : DK_WARNING;
2279 diagnostic_classify_diagnostic (global_dc, option_index, kind);
2280
2281 /* -Werror=foo implies -Wfoo. */
2282 if (cl_options[option_index].var_type == CLVC_BOOLEAN
2283 && cl_options[option_index].flag_var
2284 && kind == DK_ERROR)
2285 *(int *) cl_options[option_index].flag_var = 1;
2286 }
2287 free (new_option);
2288 }