lb1sf68.asm: Add __PIC__ and __ID_SHARED_LIBRARY__ support.
[official-gcc.git] / gcc / opts.c
blobdc489e19b31bdc76b03db9fd2e2999cfca2e4a05
1 /* Command line option handling.
2 Copyright (C) 2002, 2003 Free Software Foundation, Inc.
3 Contributed by Neil Booth.
5 This file is part of GCC.
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 2, or (at your option) any later
10 version.
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.
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING. If not, write to the Free
19 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
20 02111-1307, USA. */
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. */
41 /* Value of the -G xx switch, and whether it was passed or not. */
42 unsigned HOST_WIDE_INT g_switch_value;
43 bool g_switch_set;
45 /* True if we should exit after parsing options. */
46 bool exit_after_options;
48 /* If -version. */
49 bool version_flag;
51 /* Print various extra warnings. -W/-Wextra. */
52 bool extra_warnings;
54 /* Don't print warning messages. -w. */
55 bool inhibit_warnings;
57 /* Treat warnings as errors. -Werror. */
58 bool warnings_are_errors;
60 /* Warn if a function returns an aggregate, since there are often
61 incompatible calling conventions for doing this. */
62 bool warn_aggregate_return;
64 /* Nonzero means warn about pointer casts that increase the required
65 alignment of the target type (and might therefore lead to a crash
66 due to a misaligned access). */
67 bool warn_cast_align;
69 /* Nonzero means warn about uses of __attribute__((deprecated))
70 declarations. */
71 bool warn_deprecated_decl = true;
73 /* Warn when an optimization pass is disabled. */
74 bool warn_disabled_optimization;
76 /* Nonzero means warn if inline function is too large. */
77 bool warn_inline;
79 /* True to warn about any objects definitions whose size is larger
80 than N bytes. Also want about function definitions whose returned
81 values are larger than N bytes, where N is `larger_than_size'. */
82 bool warn_larger_than;
83 HOST_WIDE_INT larger_than_size;
85 /* Warn about functions which might be candidates for attribute noreturn. */
86 bool warn_missing_noreturn;
88 /* True to warn about code which is never reached. */
89 bool warn_notreached;
91 /* Warn if packed attribute on struct is unnecessary and inefficient. */
92 bool warn_packed;
94 /* Warn when gcc pads a structure to an alignment boundary. */
95 bool warn_padded;
97 /* True means warn about all declarations which shadow others. */
98 bool warn_shadow;
100 /* Nonzero means warn about constructs which might not be
101 strict-aliasing safe. */
102 bool warn_strict_aliasing;
104 /* True to warn if a switch on an enum, that does not have a default
105 case, fails to have a case for every enum value. */
106 bool warn_switch;
108 /* Warn if a switch does not have a default case. */
109 bool warn_switch_default;
111 /* Warn if a switch on an enum fails to have a case for every enum
112 value (regardless of the presence or otherwise of a default case). */
113 bool warn_switch_enum;
115 /* Don't suppress warnings from system headers. -Wsystem-headers. */
116 bool warn_system_headers;
118 /* True to warn about variables used before they are initialized. */
119 int warn_uninitialized;
121 /* True to warn about unused variables, functions et.al. */
122 bool warn_unused_function;
123 bool warn_unused_label;
124 bool warn_unused_parameter;
125 bool warn_unused_variable;
126 bool warn_unused_value;
128 /* Hack for cooperation between set_Wunused and set_Wextra. */
129 static bool maybe_warn_unused_parameter;
131 /* Type(s) of debugging information we are producing (if any). See
132 flags.h for the definitions of the different possible types of
133 debugging information. */
134 enum debug_info_type write_symbols = NO_DEBUG;
136 /* Level of debugging information we are producing. See flags.h for
137 the definitions of the different possible levels. */
138 enum debug_info_level debug_info_level = DINFO_LEVEL_NONE;
140 /* Nonzero means use GNU-only extensions in the generated symbolic
141 debugging information. Currently, this only has an effect when
142 write_symbols is set to DBX_DEBUG, XCOFF_DEBUG, or DWARF_DEBUG. */
143 bool use_gnu_debug_info_extensions;
145 /* Columns of --help display. */
146 static unsigned int columns = 80;
148 /* What to print when a switch has no documentation. */
149 static const char undocumented_msg[] = N_("This switch lacks documentation");
151 /* Input file names. */
152 const char **in_fnames;
153 unsigned num_in_fnames;
155 static size_t find_opt (const char *, int);
156 static int common_handle_option (size_t scode, const char *arg, int value);
157 static void handle_param (const char *);
158 static void set_Wextra (int);
159 static unsigned int handle_option (const char **argv, unsigned int lang_mask);
160 static char *write_langs (unsigned int lang_mask);
161 static void complain_wrong_lang (const char *, const struct cl_option *,
162 unsigned int lang_mask);
163 static void handle_options (unsigned int, const char **, unsigned int);
164 static void wrap_help (const char *help, const char *item, unsigned int);
165 static void print_help (void);
166 static void print_param_help (void);
167 static void print_filtered_help (unsigned int flag);
168 static unsigned int print_switch (const char *text, unsigned int indent);
169 static void set_debug_level (enum debug_info_type type, int extended,
170 const char *arg);
172 /* Perform a binary search to find which option the command-line INPUT
173 matches. Returns its index in the option array, and N_OPTS
174 (cl_options_count) on failure.
176 This routine is quite subtle. A normal binary search is not good
177 enough because some options can be suffixed with an argument, and
178 multiple sub-matches can occur, e.g. input of "-pedantic" matching
179 the initial substring of "-pedantic-errors".
181 A more complicated example is -gstabs. It should match "-g" with
182 an argument of "stabs". Suppose, however, that the number and list
183 of switches are such that the binary search tests "-gen-decls"
184 before having tested "-g". This doesn't match, and as "-gen-decls"
185 is less than "-gstabs", it will become the lower bound of the
186 binary search range, and "-g" will never be seen. To resolve this
187 issue, opts.sh makes "-gen-decls" point, via the back_chain member,
188 to "-g" so that failed searches that end between "-gen-decls" and
189 the lexicographically subsequent switch know to go back and see if
190 "-g" causes a match (which it does in this example).
192 This search is done in such a way that the longest match for the
193 front end in question wins. If there is no match for the current
194 front end, the longest match for a different front end is returned
195 (or N_OPTS if none) and the caller emits an error message. */
196 static size_t
197 find_opt (const char *input, int lang_mask)
199 size_t mn, mx, md, opt_len;
200 size_t match_wrong_lang;
201 int comp;
203 mn = 0;
204 mx = cl_options_count;
206 /* Find mn such this lexicographical inequality holds:
207 cl_options[mn] <= input < cl_options[mn + 1]. */
208 while (mx - mn > 1)
210 md = (mn + mx) / 2;
211 opt_len = cl_options[md].opt_len;
212 comp = strncmp (input, cl_options[md].opt_text + 1, opt_len);
214 if (comp < 0)
215 mx = md;
216 else
217 mn = md;
220 /* This is the switch that is the best match but for a different
221 front end, or cl_options_count if there is no match at all. */
222 match_wrong_lang = cl_options_count;
224 /* Backtrace the chain of possible matches, returning the longest
225 one, if any, that fits best. With current GCC switches, this
226 loop executes at most twice. */
229 const struct cl_option *opt = &cl_options[mn];
231 /* Is this switch a prefix of the input? */
232 if (!strncmp (input, opt->opt_text + 1, opt->opt_len))
234 /* If language is OK, and the match is exact or the switch
235 takes a joined argument, return it. */
236 if ((opt->flags & lang_mask)
237 && (input[opt->opt_len] == '\0' || (opt->flags & CL_JOINED)))
238 return mn;
240 /* If we haven't remembered a prior match, remember this
241 one. Any prior match is necessarily better. */
242 if (match_wrong_lang == cl_options_count)
243 match_wrong_lang = mn;
246 /* Try the next possibility. This is cl_options_count if there
247 are no more. */
248 mn = opt->back_chain;
250 while (mn != cl_options_count);
252 /* Return the best wrong match, or cl_options_count if none. */
253 return match_wrong_lang;
256 /* If ARG is a non-negative integer made up solely of digits, return its
257 value, otherwise return -1. */
258 static int
259 integral_argument (const char *arg)
261 const char *p = arg;
263 while (*p && ISDIGIT (*p))
264 p++;
266 if (*p == '\0')
267 return atoi (arg);
269 return -1;
272 /* Return a malloced slash-separated list of languages in MASK. */
273 static char *
274 write_langs (unsigned int mask)
276 unsigned int n = 0, len = 0;
277 const char *lang_name;
278 char *result;
280 for (n = 0; (lang_name = lang_names[n]) != 0; n++)
281 if (mask & (1U << n))
282 len += strlen (lang_name) + 1;
284 result = xmalloc (len);
285 len = 0;
286 for (n = 0; (lang_name = lang_names[n]) != 0; n++)
287 if (mask & (1U << n))
289 if (len)
290 result[len++] = '/';
291 strcpy (result + len, lang_name);
292 len += strlen (lang_name);
295 result[len] = 0;
297 return result;
300 /* Complain that switch OPT_INDEX does not apply to this front end. */
301 static void
302 complain_wrong_lang (const char *text, const struct cl_option *option,
303 unsigned int lang_mask)
305 char *ok_langs, *bad_lang;
307 ok_langs = write_langs (option->flags);
308 bad_lang = write_langs (lang_mask);
310 /* Eventually this should become a hard error IMO. */
311 warning ("command line option \"%s\" is valid for %s but not for %s",
312 text, ok_langs, bad_lang);
314 free (ok_langs);
315 free (bad_lang);
318 /* Handle the switch beginning at ARGV for the language indicated by
319 LANG_MASK. Returns the number of switches consumed. */
320 static unsigned int
321 handle_option (const char **argv, unsigned int lang_mask)
323 size_t opt_index;
324 const char *opt, *arg = 0;
325 char *dup = 0;
326 int value = 1;
327 unsigned int result = 0;
328 const struct cl_option *option;
330 opt = argv[0];
332 /* Drop the "no-" from negative switches. */
333 if ((opt[1] == 'W' || opt[1] == 'f')
334 && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-')
336 size_t len = strlen (opt) - 3;
338 dup = xmalloc (len + 1);
339 dup[0] = '-';
340 dup[1] = opt[1];
341 memcpy (dup + 2, opt + 5, len - 2 + 1);
342 opt = dup;
343 value = 0;
346 opt_index = find_opt (opt + 1, lang_mask | CL_COMMON);
347 if (opt_index == cl_options_count)
348 goto done;
350 option = &cl_options[opt_index];
352 /* Reject negative form of switches that don't take negatives as
353 unrecognized. */
354 if (!value && (option->flags & CL_REJECT_NEGATIVE))
355 goto done;
357 /* We've recognized this switch. */
358 result = 1;
360 /* Sort out any argument the switch takes. */
361 if (option->flags & CL_JOINED)
363 /* Have arg point to the original switch. This is because
364 some code, such as disable_builtin_function, expects its
365 argument to be persistent until the program exits. */
366 arg = argv[0] + cl_options[opt_index].opt_len + 1;
367 if (!value)
368 arg += strlen ("no-");
370 if (*arg == '\0' && !(option->flags & CL_MISSING_OK))
372 if (option->flags & CL_SEPARATE)
374 arg = argv[1];
375 result = 2;
377 else
378 /* Missing argument. */
379 arg = NULL;
382 else if (option->flags & CL_SEPARATE)
384 arg = argv[1];
385 result = 2;
388 /* Now we've swallowed any potential argument, complain if this
389 is a switch for a different front end. */
390 if (!(option->flags & (lang_mask | CL_COMMON)))
392 complain_wrong_lang (argv[0], option, lang_mask);
393 goto done;
396 if (arg == NULL && (option->flags & (CL_JOINED | CL_SEPARATE)))
398 if (!(*lang_hooks.missing_argument) (opt, opt_index))
399 error ("missing argument to \"%s\"", opt);
400 goto done;
403 /* If the switch takes an integer, convert it. */
404 if (arg && (option->flags & CL_UINTEGER))
406 value = integral_argument (arg);
407 if (value == -1)
409 error ("argument to \"%s\" should be a non-negative integer",
410 option->opt_text);
411 goto done;
415 if (option->flags & lang_mask)
416 if ((*lang_hooks.handle_option) (opt_index, arg, value) == 0)
417 result = 0;
419 if (result && (option->flags & CL_COMMON))
420 if (common_handle_option (opt_index, arg, value) == 0)
421 result = 0;
423 done:
424 if (dup)
425 free (dup);
426 return result;
429 /* Decode and handle the vector of command line options. LANG_MASK
430 contains has a single bit set representing the current
431 language. */
432 static void
433 handle_options (unsigned int argc, const char **argv, unsigned int lang_mask)
435 unsigned int n, i;
437 for (i = 1; i < argc; i += n)
439 const char *opt = argv[i];
441 /* Interpret "-" or a non-switch as a file name. */
442 if (opt[0] != '-' || opt[1] == '\0')
444 main_input_filename = opt;
445 add_input_filename (opt);
446 n = 1;
447 continue;
450 n = handle_option (argv + i, lang_mask);
452 if (!n)
454 n = 1;
455 error ("unrecognized command line option \"%s\"", opt);
460 /* Handle FILENAME from the command line. */
461 void
462 add_input_filename (const char *filename)
464 num_in_fnames++;
465 in_fnames = xrealloc (in_fnames, num_in_fnames * sizeof (in_fnames[0]));
466 in_fnames[num_in_fnames - 1] = filename;
469 /* Parse command line options and set default flag values. Do minimal
470 options processing. */
471 void
472 decode_options (unsigned int argc, const char **argv)
474 unsigned int i, lang_mask;
476 /* Perform language-specific options initialization. */
477 lang_mask = (*lang_hooks.init_options) (argc, argv);
479 lang_hooks.initialize_diagnostics (global_dc);
481 /* Scan to see what optimization level has been specified. That will
482 determine the default value of many flags. */
483 for (i = 1; i < argc; i++)
485 if (!strcmp (argv[i], "-O"))
487 optimize = 1;
488 optimize_size = 0;
490 else if (argv[i][0] == '-' && argv[i][1] == 'O')
492 /* Handle -Os, -O2, -O3, -O69, ... */
493 const char *p = &argv[i][2];
495 if ((p[0] == 's') && (p[1] == 0))
497 optimize_size = 1;
499 /* Optimizing for size forces optimize to be 2. */
500 optimize = 2;
502 else
504 const int optimize_val = read_integral_parameter (p, p - 2, -1);
505 if (optimize_val != -1)
507 optimize = optimize_val;
508 optimize_size = 0;
514 if (!optimize)
516 flag_merge_constants = 0;
519 if (optimize >= 1)
521 flag_defer_pop = 1;
522 flag_thread_jumps = 1;
523 #ifdef DELAY_SLOTS
524 flag_delayed_branch = 1;
525 #endif
526 #ifdef CAN_DEBUG_WITHOUT_FP
527 flag_omit_frame_pointer = 1;
528 #endif
529 flag_guess_branch_prob = 1;
530 flag_cprop_registers = 1;
531 flag_loop_optimize = 1;
532 flag_crossjumping = 1;
533 flag_if_conversion = 1;
534 flag_if_conversion2 = 1;
537 if (optimize >= 2)
539 flag_optimize_sibling_calls = 1;
540 flag_cse_follow_jumps = 1;
541 flag_cse_skip_blocks = 1;
542 flag_gcse = 1;
543 flag_expensive_optimizations = 1;
544 flag_strength_reduce = 1;
545 flag_rerun_cse_after_loop = 1;
546 flag_rerun_loop_opt = 1;
547 flag_caller_saves = 1;
548 flag_force_mem = 1;
549 flag_peephole2 = 1;
550 #ifdef INSN_SCHEDULING
551 flag_schedule_insns = 1;
552 flag_schedule_insns_after_reload = 1;
553 #endif
554 flag_regmove = 1;
555 flag_strict_aliasing = 1;
556 flag_delete_null_pointer_checks = 1;
557 flag_reorder_blocks = 1;
558 flag_reorder_functions = 1;
559 flag_unit_at_a_time = 1;
562 if (optimize >= 3)
564 flag_inline_functions = 1;
565 flag_rename_registers = 1;
566 flag_unswitch_loops = 1;
569 if (optimize < 2 || optimize_size)
571 align_loops = 1;
572 align_jumps = 1;
573 align_labels = 1;
574 align_functions = 1;
576 /* Don't reorder blocks when optimizing for size because extra
577 jump insns may be created; also barrier may create extra padding.
579 More correctly we should have a block reordering mode that tried
580 to minimize the combined size of all the jumps. This would more
581 or less automatically remove extra jumps, but would also try to
582 use more short jumps instead of long jumps. */
583 flag_reorder_blocks = 0;
586 /* Initialize whether `char' is signed. */
587 flag_signed_char = DEFAULT_SIGNED_CHAR;
588 #ifdef DEFAULT_SHORT_ENUMS
589 /* Initialize how much space enums occupy, by default. */
590 flag_short_enums = DEFAULT_SHORT_ENUMS;
591 #endif
593 /* Initialize target_flags before OPTIMIZATION_OPTIONS so the latter can
594 modify it. */
595 target_flags = 0;
596 set_target_switch ("");
598 /* Unwind tables are always present in an ABI-conformant IA-64
599 object file, so the default should be ON. */
600 #ifdef IA64_UNWIND_INFO
601 flag_unwind_tables = IA64_UNWIND_INFO;
602 #endif
604 #ifdef OPTIMIZATION_OPTIONS
605 /* Allow default optimizations to be specified on a per-machine basis. */
606 OPTIMIZATION_OPTIONS (optimize, optimize_size);
607 #endif
609 handle_options (argc, argv, lang_mask);
611 if (flag_pie)
612 flag_pic = flag_pie;
613 if (flag_pic && !flag_pie)
614 flag_shlib = 1;
616 if (flag_no_inline == 2)
617 flag_no_inline = 0;
618 else
619 flag_really_no_inline = flag_no_inline;
621 /* Set flag_no_inline before the post_options () hook. The C front
622 ends use it to determine tree inlining defaults. FIXME: such
623 code should be lang-independent when all front ends use tree
624 inlining, in which case it, and this condition, should be moved
625 to the top of process_options() instead. */
626 if (optimize == 0)
628 /* Inlining does not work if not optimizing,
629 so force it not to be done. */
630 flag_no_inline = 1;
631 warn_inline = 0;
633 /* The c_decode_option function and decode_option hook set
634 this to `2' if -Wall is used, so we can avoid giving out
635 lots of errors for people who don't realize what -Wall does. */
636 if (warn_uninitialized == 1)
637 warning ("-Wuninitialized is not supported without -O");
640 if (flag_really_no_inline == 2)
641 flag_really_no_inline = flag_no_inline;
644 /* Handle target- and language-independent options. Return zero to
645 generate an "unknown option" message. */
646 static int
647 common_handle_option (size_t scode, const char *arg,
648 int value ATTRIBUTE_UNUSED)
650 enum opt_code code = (enum opt_code) scode;
652 switch (code)
654 default:
655 abort ();
657 case OPT__help:
658 print_help ();
659 exit_after_options = true;
660 break;
662 case OPT__param:
663 handle_param (arg);
664 break;
666 case OPT__target_help:
667 display_target_options ();
668 exit_after_options = true;
669 break;
671 case OPT__version:
672 print_version (stderr, "");
673 exit_after_options = true;
674 break;
676 case OPT_G:
677 g_switch_value = value;
678 g_switch_set = true;
679 break;
681 case OPT_O:
682 case OPT_Os:
683 /* Currently handled in a prescan. */
684 break;
686 case OPT_W:
687 /* For backward compatibility, -W is the same as -Wextra. */
688 set_Wextra (value);
689 break;
691 case OPT_Waggregate_return:
692 warn_aggregate_return = value;
693 break;
695 case OPT_Wcast_align:
696 warn_cast_align = value;
697 break;
699 case OPT_Wdeprecated_declarations:
700 warn_deprecated_decl = value;
701 break;
703 case OPT_Wdisabled_optimization:
704 warn_disabled_optimization = value;
705 break;
707 case OPT_Werror:
708 warnings_are_errors = value;
709 break;
711 case OPT_Wextra:
712 set_Wextra (value);
713 break;
715 case OPT_Winline:
716 warn_inline = value;
717 break;
719 case OPT_Wlarger_than_:
720 larger_than_size = value;
721 warn_larger_than = value != -1;
722 break;
724 case OPT_Wmissing_noreturn:
725 warn_missing_noreturn = value;
726 break;
728 case OPT_Wpacked:
729 warn_packed = value;
730 break;
732 case OPT_Wpadded:
733 warn_padded = value;
734 break;
736 case OPT_Wshadow:
737 warn_shadow = value;
738 break;
740 case OPT_Wstrict_aliasing:
741 warn_strict_aliasing = value;
742 break;
744 case OPT_Wswitch:
745 warn_switch = value;
746 break;
748 case OPT_Wswitch_default:
749 warn_switch_default = value;
750 break;
752 case OPT_Wswitch_enum:
753 warn_switch_enum = value;
754 break;
756 case OPT_Wsystem_headers:
757 warn_system_headers = value;
758 break;
760 case OPT_Wuninitialized:
761 warn_uninitialized = value;
762 break;
764 case OPT_Wunreachable_code:
765 warn_notreached = value;
766 break;
768 case OPT_Wunused:
769 set_Wunused (value);
770 break;
772 case OPT_Wunused_function:
773 warn_unused_function = value;
774 break;
776 case OPT_Wunused_label:
777 warn_unused_label = value;
778 break;
780 case OPT_Wunused_parameter:
781 warn_unused_parameter = value;
782 break;
784 case OPT_Wunused_value:
785 warn_unused_value = value;
786 break;
788 case OPT_Wunused_variable:
789 warn_unused_variable = value;
790 break;
792 case OPT_aux_info:
793 case OPT_aux_info_:
794 aux_info_file_name = arg;
795 flag_gen_aux_info = 1;
796 break;
798 case OPT_auxbase:
799 aux_base_name = arg;
800 break;
802 case OPT_auxbase_strip:
804 char *tmp = xstrdup (arg);
805 strip_off_ending (tmp, strlen (tmp));
806 if (tmp[0])
807 aux_base_name = tmp;
809 break;
811 case OPT_d:
812 decode_d_option (arg);
813 break;
815 case OPT_dumpbase:
816 dump_base_name = arg;
817 break;
819 case OPT_fPIC:
820 flag_pic = value + value;
821 break;
823 case OPT_fPIE:
824 flag_pie = value + value;
825 break;
827 case OPT_falign_functions:
828 align_functions = !value;
829 break;
831 case OPT_falign_functions_:
832 align_functions = value;
833 break;
835 case OPT_falign_jumps:
836 align_jumps = !value;
837 break;
839 case OPT_falign_jumps_:
840 align_jumps = value;
841 break;
843 case OPT_falign_labels:
844 align_labels = !value;
845 break;
847 case OPT_falign_labels_:
848 align_labels = value;
849 break;
851 case OPT_falign_loops:
852 align_loops = !value;
853 break;
855 case OPT_falign_loops_:
856 align_loops = value;
857 break;
859 case OPT_fargument_alias:
860 flag_argument_noalias = !value;
861 break;
863 case OPT_fargument_noalias:
864 flag_argument_noalias = value;
865 break;
867 case OPT_fargument_noalias_global:
868 flag_argument_noalias = value + value;
869 break;
871 case OPT_fasynchronous_unwind_tables:
872 flag_asynchronous_unwind_tables = value;
873 break;
875 case OPT_fbounds_check:
876 flag_bounds_check = value;
877 break;
879 case OPT_fbranch_count_reg:
880 flag_branch_on_count_reg = value;
881 break;
883 case OPT_fbranch_probabilities:
884 flag_branch_probabilities = value;
885 break;
887 case OPT_fbranch_target_load_optimize:
888 flag_branch_target_load_optimize = value;
889 break;
891 case OPT_fbranch_target_load_optimize2:
892 flag_branch_target_load_optimize2 = value;
893 break;
895 case OPT_fcall_used_:
896 fix_register (arg, 0, 1);
897 break;
899 case OPT_fcall_saved_:
900 fix_register (arg, 0, 0);
901 break;
903 case OPT_fcaller_saves:
904 flag_caller_saves = value;
905 break;
907 case OPT_fcommon:
908 flag_no_common = !value;
909 break;
911 case OPT_fcprop_registers:
912 flag_cprop_registers = value;
913 break;
915 case OPT_fcrossjumping:
916 flag_crossjumping = value;
917 break;
919 case OPT_fcse_follow_jumps:
920 flag_cse_follow_jumps = value;
921 break;
923 case OPT_fcse_skip_blocks:
924 flag_cse_skip_blocks = value;
925 break;
927 case OPT_fdata_sections:
928 flag_data_sections = value;
929 break;
931 case OPT_fdefer_pop:
932 flag_defer_pop = value;
933 break;
935 case OPT_fdelayed_branch:
936 flag_delayed_branch = value;
937 break;
939 case OPT_fdelete_null_pointer_checks:
940 flag_delete_null_pointer_checks = value;
941 break;
943 case OPT_fdiagnostics_show_location_:
944 if (!strcmp (arg, "once"))
945 diagnostic_prefixing_rule (global_dc) = DIAGNOSTICS_SHOW_PREFIX_ONCE;
946 else if (!strcmp (arg, "every-line"))
947 diagnostic_prefixing_rule (global_dc)
948 = DIAGNOSTICS_SHOW_PREFIX_EVERY_LINE;
949 else
950 return 0;
951 break;
953 case OPT_fdump_unnumbered:
954 flag_dump_unnumbered = value;
955 break;
957 case OPT_feliminate_dwarf2_dups:
958 flag_eliminate_dwarf2_dups = value;
959 break;
961 case OPT_feliminate_unused_debug_types:
962 flag_eliminate_unused_debug_types = value;
963 break;
965 case OPT_feliminate_unused_debug_symbols:
966 flag_debug_only_used_symbols = value;
967 break;
969 case OPT_fexceptions:
970 flag_exceptions = value;
971 break;
973 case OPT_fexpensive_optimizations:
974 flag_expensive_optimizations = value;
975 break;
977 case OPT_ffast_math:
978 set_fast_math_flags (value);
979 break;
981 case OPT_ffinite_math_only:
982 flag_finite_math_only = value;
983 break;
985 case OPT_ffixed_:
986 fix_register (arg, 1, 1);
987 break;
989 case OPT_ffunction_cse:
990 flag_no_function_cse = !value;
991 break;
993 case OPT_ffloat_store:
994 flag_float_store = value;
995 break;
997 case OPT_fforce_addr:
998 flag_force_addr = value;
999 break;
1001 case OPT_fforce_mem:
1002 flag_force_mem = value;
1003 break;
1005 case OPT_ffunction_sections:
1006 flag_function_sections = value;
1007 break;
1009 case OPT_fgcse:
1010 flag_gcse = value;
1011 break;
1013 case OPT_fgcse_lm:
1014 flag_gcse_lm = value;
1015 break;
1017 case OPT_fgcse_sm:
1018 flag_gcse_sm = value;
1019 break;
1021 case OPT_fgnu_linker:
1022 flag_gnu_linker = value;
1023 break;
1025 case OPT_fguess_branch_probability:
1026 flag_guess_branch_prob = value;
1027 break;
1029 case OPT_fident:
1030 flag_no_ident = !value;
1031 break;
1033 case OPT_fif_conversion:
1034 flag_if_conversion = value;
1035 break;
1037 case OPT_fif_conversion2:
1038 flag_if_conversion2 = value;
1039 break;
1041 case OPT_finhibit_size_directive:
1042 flag_inhibit_size_directive = value;
1043 break;
1045 case OPT_finline:
1046 flag_no_inline = !value;
1047 break;
1049 case OPT_finline_functions:
1050 flag_inline_functions = value;
1051 break;
1053 case OPT_finline_limit_:
1054 case OPT_finline_limit_eq:
1055 set_param_value ("max-inline-insns", value);
1056 set_param_value ("max-inline-insns-single", value / 2);
1057 set_param_value ("max-inline-insns-auto", value / 2);
1058 set_param_value ("max-inline-insns-rtl", value);
1059 if (value / 4 < MIN_INLINE_INSNS)
1061 if (value / 4 > 10)
1062 set_param_value ("min-inline-insns", value / 4);
1063 else
1064 set_param_value ("min-inline-insns", 10);
1066 break;
1068 case OPT_finstrument_functions:
1069 flag_instrument_function_entry_exit = value;
1070 break;
1072 case OPT_fkeep_inline_functions:
1073 flag_keep_inline_functions =value;
1074 break;
1076 case OPT_fkeep_static_consts:
1077 flag_keep_static_consts = value;
1078 break;
1080 case OPT_fleading_underscore:
1081 flag_leading_underscore = value;
1082 break;
1084 case OPT_floop_optimize:
1085 flag_loop_optimize = value;
1086 break;
1088 case OPT_fmath_errno:
1089 flag_errno_math = value;
1090 break;
1092 case OPT_fmem_report:
1093 mem_report = value;
1094 break;
1096 case OPT_fmerge_all_constants:
1097 flag_merge_constants = value + value;
1098 break;
1100 case OPT_fmerge_constants:
1101 flag_merge_constants = value;
1102 break;
1104 case OPT_fmessage_length_:
1105 pp_set_line_maximum_length (global_dc->printer, value);
1106 break;
1108 case OPT_fmove_all_movables:
1109 flag_move_all_movables = value;
1110 break;
1112 case OPT_fnew_ra:
1113 flag_new_regalloc = value;
1114 break;
1116 case OPT_fnon_call_exceptions:
1117 flag_non_call_exceptions = value;
1118 break;
1120 case OPT_fold_unroll_all_loops:
1121 flag_old_unroll_all_loops = value;
1122 break;
1124 case OPT_fold_unroll_loops:
1125 flag_old_unroll_loops = value;
1126 break;
1128 case OPT_fomit_frame_pointer:
1129 flag_omit_frame_pointer = value;
1130 break;
1132 case OPT_foptimize_register_move:
1133 flag_regmove = value;
1134 break;
1136 case OPT_foptimize_sibling_calls:
1137 flag_optimize_sibling_calls = value;
1138 break;
1140 case OPT_fpack_struct:
1141 flag_pack_struct = value;
1142 break;
1144 case OPT_fpeel_loops:
1145 flag_peel_loops = value;
1146 break;
1148 case OPT_fpcc_struct_return:
1149 flag_pcc_struct_return = value;
1150 break;
1152 case OPT_fpeephole:
1153 flag_no_peephole = !value;
1154 break;
1156 case OPT_fpeephole2:
1157 flag_peephole2 = value;
1158 break;
1160 case OPT_fpic:
1161 flag_pic = value;
1162 break;
1164 case OPT_fpie:
1165 flag_pie = value;
1166 break;
1168 case OPT_fprefetch_loop_arrays:
1169 flag_prefetch_loop_arrays = value;
1170 break;
1172 case OPT_fprofile:
1173 profile_flag = value;
1174 break;
1176 case OPT_fprofile_arcs:
1177 profile_arc_flag = value;
1178 break;
1180 case OPT_frandom_seed:
1181 /* The real switch is -fno-random-seed. */
1182 if (value)
1183 return 0;
1184 flag_random_seed = NULL;
1185 break;
1187 case OPT_frandom_seed_:
1188 flag_random_seed = arg;
1189 break;
1191 case OPT_freduce_all_givs:
1192 flag_reduce_all_givs = value;
1193 break;
1195 case OPT_freg_struct_return:
1196 flag_pcc_struct_return = !value;
1197 break;
1199 case OPT_fregmove:
1200 flag_regmove = value;
1201 break;
1203 case OPT_frename_registers:
1204 flag_rename_registers = value;
1205 break;
1207 case OPT_freorder_blocks:
1208 flag_reorder_blocks = value;
1209 break;
1211 case OPT_freorder_functions:
1212 flag_reorder_functions = value;
1213 break;
1215 case OPT_frerun_cse_after_loop:
1216 flag_rerun_cse_after_loop = value;
1217 break;
1219 case OPT_frerun_loop_opt:
1220 flag_rerun_loop_opt = value;
1221 break;
1223 case OPT_frounding_math:
1224 flag_rounding_math = value;
1225 break;
1227 case OPT_fsched_interblock:
1228 flag_schedule_interblock = value;
1229 break;
1231 case OPT_fsched_spec:
1232 flag_schedule_speculative = value;
1233 break;
1235 case OPT_fsched_spec_load:
1236 flag_schedule_speculative_load = value;
1237 break;
1239 case OPT_fsched_spec_load_dangerous:
1240 flag_schedule_speculative_load_dangerous = value;
1241 break;
1243 case OPT_fsched_verbose_:
1244 #ifdef INSN_SCHEDULING
1245 fix_sched_param ("verbose", arg);
1246 break;
1247 #else
1248 return 0;
1249 #endif
1251 case OPT_fsched2_use_superblocks:
1252 flag_sched2_use_superblocks = value;
1253 break;
1255 case OPT_fsched2_use_traces:
1256 flag_sched2_use_traces = value;
1257 break;
1259 case OPT_fschedule_insns:
1260 flag_schedule_insns = value;
1261 break;
1263 case OPT_fschedule_insns2:
1264 flag_schedule_insns_after_reload = value;
1265 break;
1267 case OPT_fsched_stalled_insns:
1268 flag_sched_stalled_insns = value;
1269 break;
1271 case OPT_fsched_stalled_insns_:
1272 flag_sched_stalled_insns = value;
1273 if (flag_sched_stalled_insns == 0)
1274 flag_sched_stalled_insns = -1;
1275 break;
1277 case OPT_fsched_stalled_insns_dep:
1278 flag_sched_stalled_insns_dep = 1;
1279 break;
1281 case OPT_fsched_stalled_insns_dep_:
1282 flag_sched_stalled_insns_dep = value;
1283 break;
1285 case OPT_fshared_data:
1286 flag_shared_data = value;
1287 break;
1289 case OPT_fsignaling_nans:
1290 flag_signaling_nans = value;
1291 break;
1293 case OPT_fsingle_precision_constant:
1294 flag_single_precision_constant = value;
1295 break;
1297 case OPT_fssa:
1298 flag_ssa = value;
1299 break;
1301 case OPT_fssa_ccp:
1302 flag_ssa_ccp = value;
1303 break;
1305 case OPT_fssa_dce:
1306 flag_ssa_dce = value;
1307 break;
1309 case OPT_fstack_check:
1310 flag_stack_check = value;
1311 break;
1313 case OPT_fstack_limit:
1314 /* The real switch is -fno-stack-limit. */
1315 if (value)
1316 return 0;
1317 stack_limit_rtx = NULL_RTX;
1318 break;
1320 case OPT_fstack_limit_register_:
1322 int reg = decode_reg_name (arg);
1323 if (reg < 0)
1324 error ("unrecognized register name \"%s\"", arg);
1325 else
1326 stack_limit_rtx = gen_rtx_REG (Pmode, reg);
1328 break;
1330 case OPT_fstack_limit_symbol_:
1331 stack_limit_rtx = gen_rtx_SYMBOL_REF (Pmode, ggc_strdup (arg));
1332 break;
1334 case OPT_fstrength_reduce:
1335 flag_strength_reduce = value;
1336 break;
1338 case OPT_fstrict_aliasing:
1339 flag_strict_aliasing = value;
1340 break;
1342 case OPT_fsyntax_only:
1343 flag_syntax_only = value;
1344 break;
1346 case OPT_ftest_coverage:
1347 flag_test_coverage = value;
1348 break;
1350 case OPT_fthread_jumps:
1351 flag_thread_jumps = value;
1352 break;
1354 case OPT_ftime_report:
1355 time_report = value;
1356 break;
1358 case OPT_ftls_model_:
1359 if (!strcmp (arg, "global-dynamic"))
1360 flag_tls_default = TLS_MODEL_GLOBAL_DYNAMIC;
1361 else if (!strcmp (arg, "local-dynamic"))
1362 flag_tls_default = TLS_MODEL_LOCAL_DYNAMIC;
1363 else if (!strcmp (arg, "initial-exec"))
1364 flag_tls_default = TLS_MODEL_INITIAL_EXEC;
1365 else if (!strcmp (arg, "local-exec"))
1366 flag_tls_default = TLS_MODEL_LOCAL_EXEC;
1367 else
1368 warning ("unknown tls-model \"%s\"", arg);
1369 break;
1371 case OPT_ftracer:
1372 flag_tracer = value;
1373 break;
1375 case OPT_ftrapping_math:
1376 flag_trapping_math = value;
1377 break;
1379 case OPT_ftrapv:
1380 flag_trapv = value;
1381 break;
1383 case OPT_funit_at_a_time:
1384 flag_unit_at_a_time = value;
1385 break;
1387 case OPT_funroll_all_loops:
1388 flag_unroll_all_loops = value;
1389 break;
1391 case OPT_funroll_loops:
1392 flag_unroll_loops = value;
1393 break;
1395 case OPT_funsafe_math_optimizations:
1396 flag_unsafe_math_optimizations = value;
1397 break;
1399 case OPT_funswitch_loops:
1400 flag_unswitch_loops = value;
1401 break;
1403 case OPT_funwind_tables:
1404 flag_unwind_tables = value;
1405 break;
1407 case OPT_fverbose_asm:
1408 flag_verbose_asm = value;
1409 break;
1411 case OPT_fwrapv:
1412 flag_wrapv = value;
1413 break;
1415 case OPT_fwritable_strings:
1416 flag_writable_strings = value;
1417 break;
1419 case OPT_fzero_initialized_in_bss:
1420 flag_zero_initialized_in_bss = value;
1421 break;
1423 case OPT_g:
1424 set_debug_level (NO_DEBUG, DEFAULT_GDB_EXTENSIONS, arg);
1425 break;
1427 case OPT_gcoff:
1428 set_debug_level (SDB_DEBUG, false, arg);
1429 break;
1431 case OPT_gdwarf:
1432 if (*arg)
1434 error ("use -gdwarf -gN for DWARF v1 level N, "
1435 "and -gdwarf-2 for DWARF v2" );
1436 break;
1439 /* Fall through. */
1440 case OPT_gdwarf_:
1441 set_debug_level (DWARF_DEBUG, code == OPT_gdwarf_, arg);
1442 break;
1444 case OPT_gdwarf_2:
1445 set_debug_level (DWARF2_DEBUG, false, arg);
1446 break;
1448 case OPT_ggdb:
1449 set_debug_level (NO_DEBUG, 2, arg);
1450 break;
1452 case OPT_gstabs:
1453 case OPT_gstabs_:
1454 set_debug_level (DBX_DEBUG, code == OPT_gstabs_, arg);
1455 break;
1457 case OPT_gvms:
1458 set_debug_level (VMS_DEBUG, false, arg);
1459 break;
1461 case OPT_gxcoff:
1462 case OPT_gxcoff_:
1463 set_debug_level (XCOFF_DEBUG, code == OPT_gxcoff_, arg);
1464 break;
1466 case OPT_m:
1467 set_target_switch (arg);
1468 break;
1470 case OPT_o:
1471 asm_file_name = arg;
1472 break;
1474 case OPT_p:
1475 profile_flag = 1;
1476 break;
1478 case OPT_pedantic:
1479 pedantic = 1;
1480 break;
1482 case OPT_pedantic_errors:
1483 flag_pedantic_errors = pedantic = 1;
1484 break;
1486 case OPT_quiet:
1487 quiet_flag = 1;
1488 break;
1490 case OPT_version:
1491 version_flag = 1;
1492 break;
1494 case OPT_w:
1495 inhibit_warnings = true;
1496 break;
1499 return 1;
1502 /* Handle --param NAME=VALUE. */
1503 static void
1504 handle_param (const char *carg)
1506 char *equal, *arg;
1507 int value;
1509 arg = xstrdup (carg);
1510 equal = strchr (arg, '=');
1511 if (!equal)
1512 error ("%s: --param arguments should be of the form NAME=VALUE", arg);
1513 else
1515 value = integral_argument (equal + 1);
1516 if (value == -1)
1517 error ("invalid --param value `%s'", equal + 1);
1518 else
1520 *equal = '\0';
1521 set_param_value (arg, value);
1525 free (arg);
1528 /* Handle -W and -Wextra. */
1529 static void
1530 set_Wextra (int setting)
1532 extra_warnings = setting;
1533 warn_unused_value = setting;
1534 warn_unused_parameter = (setting && maybe_warn_unused_parameter);
1536 /* We save the value of warn_uninitialized, since if they put
1537 -Wuninitialized on the command line, we need to generate a
1538 warning about not using it without also specifying -O. */
1539 if (setting == 0)
1540 warn_uninitialized = 0;
1541 else if (warn_uninitialized != 1)
1542 warn_uninitialized = 2;
1545 /* Initialize unused warning flags. */
1546 void
1547 set_Wunused (int setting)
1549 warn_unused_function = setting;
1550 warn_unused_label = setting;
1551 /* Unused function parameter warnings are reported when either
1552 ``-Wextra -Wunused'' or ``-Wunused-parameter'' is specified.
1553 Thus, if -Wextra has already been seen, set warn_unused_parameter;
1554 otherwise set maybe_warn_extra_parameter, which will be picked up
1555 by set_Wextra. */
1556 maybe_warn_unused_parameter = setting;
1557 warn_unused_parameter = (setting && extra_warnings);
1558 warn_unused_variable = setting;
1559 warn_unused_value = setting;
1562 /* The following routines are useful in setting all the flags that
1563 -ffast-math and -fno-fast-math imply. */
1564 void
1565 set_fast_math_flags (int set)
1567 flag_trapping_math = !set;
1568 flag_unsafe_math_optimizations = set;
1569 flag_finite_math_only = set;
1570 flag_errno_math = !set;
1571 if (set)
1573 flag_signaling_nans = 0;
1574 flag_rounding_math = 0;
1578 /* Return true iff flags are set as if -ffast-math. */
1579 bool
1580 fast_math_flags_set_p (void)
1582 return (!flag_trapping_math
1583 && flag_unsafe_math_optimizations
1584 && flag_finite_math_only
1585 && !flag_errno_math);
1588 /* Handle a debug output -g switch. EXTENDED is true or false to support
1589 extended output (2 is special and means "-ggdb" was given). */
1590 static void
1591 set_debug_level (enum debug_info_type type, int extended, const char *arg)
1593 static bool type_explicit;
1595 use_gnu_debug_info_extensions = extended;
1597 if (type == NO_DEBUG)
1599 if (write_symbols == NO_DEBUG)
1601 write_symbols = PREFERRED_DEBUGGING_TYPE;
1603 if (extended == 2)
1605 #ifdef DWARF2_DEBUGGING_INFO
1606 write_symbols = DWARF2_DEBUG;
1607 #elif defined DBX_DEBUGGING_INFO
1608 write_symbols = DBX_DEBUG;
1609 #endif
1612 if (write_symbols == NO_DEBUG)
1613 warning ("target system does not support debug output");
1616 else
1618 /* Does it conflict with an already selected type? */
1619 if (type_explicit && write_symbols != NO_DEBUG && type != write_symbols)
1620 error ("debug format \"%s\" conflicts with prior selection",
1621 debug_type_names[type]);
1622 write_symbols = type;
1623 type_explicit = true;
1626 /* A debug flag without a level defaults to level 2. */
1627 if (*arg == '\0')
1629 if (!debug_info_level)
1630 debug_info_level = 2;
1632 else
1634 debug_info_level = integral_argument (arg);
1635 if (debug_info_level == (unsigned int) -1)
1636 error ("unrecognised debug output level \"%s\"", arg);
1637 else if (debug_info_level > 3)
1638 error ("debug output level %s is too high", arg);
1642 /* Output --help text. */
1643 static void
1644 print_help (void)
1646 size_t i;
1647 const char *p;
1649 GET_ENVIRONMENT (p, "COLUMNS");
1650 if (p)
1652 int value = atoi (p);
1653 if (value > 0)
1654 columns = value;
1657 puts (_("The following options are language-independent:\n"));
1659 print_filtered_help (CL_COMMON);
1660 print_param_help ();
1662 for (i = 0; lang_names[i]; i++)
1664 printf (_("The %s front end recognizes the following options:\n\n"),
1665 lang_names[i]);
1666 print_filtered_help (1U << i);
1669 display_target_options ();
1672 /* Print the help for --param. */
1673 static void
1674 print_param_help (void)
1676 size_t i;
1678 puts (_("The --param option recognizes the following as parameters:\n"));
1680 for (i = 0; i < LAST_PARAM; i++)
1682 const char *help = compiler_params[i].help;
1683 const char *param = compiler_params[i].option;
1685 if (help == NULL || *help == '\0')
1686 help = undocumented_msg;
1688 /* Get the translation. */
1689 help = _(help);
1691 wrap_help (help, param, strlen (param));
1694 putchar ('\n');
1697 /* Print help for a specific front-end, etc. */
1698 static void
1699 print_filtered_help (unsigned int flag)
1701 unsigned int i, len, filter, indent = 0;
1702 bool duplicates = false;
1703 const char *help, *opt, *tab;
1704 static char *printed;
1706 if (flag == CL_COMMON)
1708 filter = flag;
1709 if (!printed)
1710 printed = xmalloc (cl_options_count);
1711 memset (printed, 0, cl_options_count);
1713 else
1715 /* Don't print COMMON options twice. */
1716 filter = flag | CL_COMMON;
1718 for (i = 0; i < cl_options_count; i++)
1720 if ((cl_options[i].flags & filter) != flag)
1721 continue;
1723 /* Skip help for internal switches. */
1724 if (cl_options[i].flags & CL_UNDOCUMENTED)
1725 continue;
1727 /* Skip switches that have already been printed, mark them to be
1728 listed later. */
1729 if (printed[i])
1731 duplicates = true;
1732 indent = print_switch (cl_options[i].opt_text, indent);
1736 if (duplicates)
1738 putchar ('\n');
1739 putchar ('\n');
1743 for (i = 0; i < cl_options_count; i++)
1745 if ((cl_options[i].flags & filter) != flag)
1746 continue;
1748 /* Skip help for internal switches. */
1749 if (cl_options[i].flags & CL_UNDOCUMENTED)
1750 continue;
1752 /* Skip switches that have already been printed. */
1753 if (printed[i])
1754 continue;
1756 printed[i] = true;
1758 help = cl_options[i].help;
1759 if (!help)
1760 help = undocumented_msg;
1762 /* Get the translation. */
1763 help = _(help);
1765 tab = strchr (help, '\t');
1766 if (tab)
1768 len = tab - help;
1769 opt = help;
1770 help = tab + 1;
1772 else
1774 opt = cl_options[i].opt_text;
1775 len = strlen (opt);
1778 wrap_help (help, opt, len);
1781 putchar ('\n');
1784 /* Output ITEM, of length ITEM_WIDTH, in the left column, followed by
1785 word-wrapped HELP in a second column. */
1786 static unsigned int
1787 print_switch (const char *text, unsigned int indent)
1789 unsigned int len = strlen (text) + 1; /* trailing comma */
1791 if (indent)
1793 putchar (',');
1794 if (indent + len > columns)
1796 putchar ('\n');
1797 putchar (' ');
1798 indent = 1;
1801 else
1802 putchar (' ');
1804 putchar (' ');
1805 fputs (text, stdout);
1807 return indent + len + 1;
1810 /* Output ITEM, of length ITEM_WIDTH, in the left column, followed by
1811 word-wrapped HELP in a second column. */
1812 static void
1813 wrap_help (const char *help, const char *item, unsigned int item_width)
1815 unsigned int col_width = 27;
1816 unsigned int remaining, room, len;
1818 remaining = strlen (help);
1822 room = columns - 3 - MAX (col_width, item_width);
1823 if (room > columns)
1824 room = 0;
1825 len = remaining;
1827 if (room < len)
1829 unsigned int i;
1831 for (i = 0; help[i]; i++)
1833 if (i >= room && len != remaining)
1834 break;
1835 if (help[i] == ' ')
1836 len = i;
1837 else if ((help[i] == '-' || help[i] == '/')
1838 && help[i + 1] != ' '
1839 && ISALPHA (help[i - 1]))
1840 len = i + 1;
1844 printf( " %-*.*s %.*s\n", col_width, item_width, item, len, help);
1845 item_width = 0;
1846 while (help[len] == ' ')
1847 len++;
1848 help += len;
1849 remaining -= len;
1851 while (remaining);