builtins.def (DEF_SANITIZER_BUILTIN): Define tsan builtins.
[platform/upstream/gcc.git] / gcc / gcc.c
1 /* Compiler driver program that can handle many languages.
2    Copyright (C) 1987, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3    1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009,
4    2010, 2011, 2012
5    Free Software Foundation, Inc.
6
7 This file is part of GCC.
8
9 GCC is free software; you can redistribute it and/or modify it under
10 the terms of the GNU General Public License as published by the Free
11 Software Foundation; either version 3, or (at your option) any later
12 version.
13
14 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
15 WARRANTY; without even the implied warranty of MERCHANTABILITY or
16 FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
17 for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with GCC; see the file COPYING3.  If not see
21 <http://www.gnu.org/licenses/>.  */
22
23 /* This program is the user interface to the C compiler and possibly to
24 other compilers.  It is used because compilation is a complicated procedure
25 which involves running several programs and passing temporary files between
26 them, forwarding the users switches to those programs selectively,
27 and deleting the temporary files at the end.
28
29 CC recognizes how to compile each input file by suffixes in the file names.
30 Once it knows which kind of compilation to perform, the procedure for
31 compilation is specified by a string called a "spec".  */
32
33 #include "config.h"
34 #include "system.h"
35 #include "coretypes.h"
36 #include "multilib.h" /* before tm.h */
37 #include "tm.h"
38 #include "xregex.h"
39 #include "obstack.h"
40 #include "intl.h"
41 #include "prefix.h"
42 #include "gcc.h"
43 #include "diagnostic.h"
44 #include "flags.h"
45 #include "opts.h"
46 #include "params.h"
47 #include "vec.h"
48 #include "filenames.h"
49
50 /* By default there is no special suffix for target executables.  */
51 /* FIXME: when autoconf is fixed, remove the host check - dj */
52 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
53 #define HAVE_TARGET_EXECUTABLE_SUFFIX
54 #endif
55
56 /* By default there is no special suffix for host executables.  */
57 #ifdef HOST_EXECUTABLE_SUFFIX
58 #define HAVE_HOST_EXECUTABLE_SUFFIX
59 #else
60 #define HOST_EXECUTABLE_SUFFIX ""
61 #endif
62
63 /* By default, the suffix for target object files is ".o".  */
64 #ifdef TARGET_OBJECT_SUFFIX
65 #define HAVE_TARGET_OBJECT_SUFFIX
66 #else
67 #define TARGET_OBJECT_SUFFIX ".o"
68 #endif
69
70 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
71
72 /* Most every one is fine with LIBRARY_PATH.  For some, it conflicts.  */
73 #ifndef LIBRARY_PATH_ENV
74 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
75 #endif
76
77 /* If a stage of compilation returns an exit status >= 1,
78    compilation of that file ceases.  */
79
80 #define MIN_FATAL_STATUS 1
81
82 /* Flag set by cppspec.c to 1.  */
83 int is_cpp_driver;
84
85 /* Flag set to nonzero if an @file argument has been supplied to gcc.  */
86 static bool at_file_supplied;
87
88 /* Definition of string containing the arguments given to configure.  */
89 #include "configargs.h"
90
91 /* Flag saying to print the command line options understood by gcc and its
92    sub-processes.  */
93
94 static int print_help_list;
95
96 /* Flag saying to print the version of gcc and its sub-processes.  */
97
98 static int print_version;
99
100 /* Flag indicating whether we should ONLY print the command and
101    arguments (like verbose_flag) without executing the command.
102    Displayed arguments are quoted so that the generated command
103    line is suitable for execution.  This is intended for use in
104    shell scripts to capture the driver-generated command line.  */
105 static int verbose_only_flag;
106
107 /* Flag indicating how to print command line options of sub-processes.  */
108
109 static int print_subprocess_help;
110
111 /* Whether we should report subprocess execution times to a file.  */
112
113 FILE *report_times_to_file = NULL;
114
115 /* Nonzero means place this string before uses of /, so that include
116    and library files can be found in an alternate location.  */
117
118 #ifdef TARGET_SYSTEM_ROOT
119 static const char *target_system_root = TARGET_SYSTEM_ROOT;
120 #else
121 static const char *target_system_root = 0;
122 #endif
123
124 /* Nonzero means pass the updated target_system_root to the compiler.  */
125
126 static int target_system_root_changed;
127
128 /* Nonzero means append this string to target_system_root.  */
129
130 static const char *target_sysroot_suffix = 0;
131
132 /* Nonzero means append this string to target_system_root for headers.  */
133
134 static const char *target_sysroot_hdrs_suffix = 0;
135
136 /* Nonzero means write "temp" files in source directory
137    and use the source file's name in them, and don't delete them.  */
138
139 static enum save_temps {
140   SAVE_TEMPS_NONE,              /* no -save-temps */
141   SAVE_TEMPS_CWD,               /* -save-temps in current directory */
142   SAVE_TEMPS_OBJ                /* -save-temps in object directory */
143 } save_temps_flag;
144
145 /* Output file to use to get the object directory for -save-temps=obj  */
146 static char *save_temps_prefix = 0;
147 static size_t save_temps_length = 0;
148
149 /* The compiler version.  */
150
151 static const char *compiler_version;
152
153 /* The target version.  */
154
155 static const char *const spec_version = DEFAULT_TARGET_VERSION;
156
157 /* The target machine.  */
158
159 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
160
161 /* Nonzero if cross-compiling.
162    When -b is used, the value comes from the `specs' file.  */
163
164 #ifdef CROSS_DIRECTORY_STRUCTURE
165 static const char *cross_compile = "1";
166 #else
167 static const char *cross_compile = "0";
168 #endif
169
170 /* Greatest exit code of sub-processes that has been encountered up to
171    now.  */
172 static int greatest_status = 1;
173
174 /* This is the obstack which we use to allocate many strings.  */
175
176 static struct obstack obstack;
177
178 /* This is the obstack to build an environment variable to pass to
179    collect2 that describes all of the relevant switches of what to
180    pass the compiler in building the list of pointers to constructors
181    and destructors.  */
182
183 static struct obstack collect_obstack;
184
185 /* Forward declaration for prototypes.  */
186 struct path_prefix;
187 struct prefix_list;
188
189 static void init_spec (void);
190 static void store_arg (const char *, int, int);
191 static void insert_wrapper (const char *);
192 static char *load_specs (const char *);
193 static void read_specs (const char *, bool, bool);
194 static void set_spec (const char *, const char *, bool);
195 static struct compiler *lookup_compiler (const char *, size_t, const char *);
196 static char *build_search_list (const struct path_prefix *, const char *,
197                                 bool, bool);
198 static void xputenv (const char *);
199 static void putenv_from_prefixes (const struct path_prefix *, const char *,
200                                   bool);
201 static int access_check (const char *, int);
202 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
203 static void add_prefix (struct path_prefix *, const char *, const char *,
204                         int, int, int);
205 static void add_sysrooted_prefix (struct path_prefix *, const char *,
206                                   const char *, int, int, int);
207 static char *skip_whitespace (char *);
208 static void delete_if_ordinary (const char *);
209 static void delete_temp_files (void);
210 static void delete_failure_queue (void);
211 static void clear_failure_queue (void);
212 static int check_live_switch (int, int);
213 static const char *handle_braces (const char *);
214 static inline bool input_suffix_matches (const char *, const char *);
215 static inline bool switch_matches (const char *, const char *, int);
216 static inline void mark_matching_switches (const char *, const char *, int);
217 static inline void process_marked_switches (void);
218 static const char *process_brace_body (const char *, const char *, const char *, int, int);
219 static const struct spec_function *lookup_spec_function (const char *);
220 static const char *eval_spec_function (const char *, const char *);
221 static const char *handle_spec_function (const char *);
222 static char *save_string (const char *, int);
223 static void set_collect_gcc_options (void);
224 static int do_spec_1 (const char *, int, const char *);
225 static int do_spec_2 (const char *);
226 static void do_option_spec (const char *, const char *);
227 static void do_self_spec (const char *);
228 static const char *find_file (const char *);
229 static int is_directory (const char *, bool);
230 static const char *validate_switches (const char *, bool);
231 static void validate_all_switches (void);
232 static inline void validate_switches_from_spec (const char *, bool);
233 static void give_switch (int, int);
234 static int used_arg (const char *, int);
235 static int default_arg (const char *, int);
236 static void set_multilib_dir (void);
237 static void print_multilib_info (void);
238 static void perror_with_name (const char *);
239 static void display_help (void);
240 static void add_preprocessor_option (const char *, int);
241 static void add_assembler_option (const char *, int);
242 static void add_linker_option (const char *, int);
243 static void process_command (unsigned int, struct cl_decoded_option *);
244 static int execute (void);
245 static void alloc_args (void);
246 static void clear_args (void);
247 static void fatal_signal (int);
248 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
249 static void init_gcc_specs (struct obstack *, const char *, const char *,
250                             const char *);
251 #endif
252 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
253 static const char *convert_filename (const char *, int, int);
254 #endif
255
256 static const char *getenv_spec_function (int, const char **);
257 static const char *if_exists_spec_function (int, const char **);
258 static const char *if_exists_else_spec_function (int, const char **);
259 static const char *replace_outfile_spec_function (int, const char **);
260 static const char *remove_outfile_spec_function (int, const char **);
261 static const char *version_compare_spec_function (int, const char **);
262 static const char *include_spec_function (int, const char **);
263 static const char *find_file_spec_function (int, const char **);
264 static const char *find_plugindir_spec_function (int, const char **);
265 static const char *print_asm_header_spec_function (int, const char **);
266 static const char *compare_debug_dump_opt_spec_function (int, const char **);
267 static const char *compare_debug_self_opt_spec_function (int, const char **);
268 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
269 static const char *pass_through_libs_spec_func (int, const char **);
270 static const char *replace_extension_spec_func (int, const char **);
271 \f
272 /* The Specs Language
273
274 Specs are strings containing lines, each of which (if not blank)
275 is made up of a program name, and arguments separated by spaces.
276 The program name must be exact and start from root, since no path
277 is searched and it is unreliable to depend on the current working directory.
278 Redirection of input or output is not supported; the subprograms must
279 accept filenames saying what files to read and write.
280
281 In addition, the specs can contain %-sequences to substitute variable text
282 or for conditional text.  Here is a table of all defined %-sequences.
283 Note that spaces are not generated automatically around the results of
284 expanding these sequences; therefore, you can concatenate them together
285 or with constant text in a single argument.
286
287  %%     substitute one % into the program name or argument.
288  %i     substitute the name of the input file being processed.
289  %b     substitute the basename of the input file being processed.
290         This is the substring up to (and not including) the last period
291         and not including the directory unless -save-temps was specified
292         to put temporaries in a different location.
293  %B     same as %b, but include the file suffix (text after the last period).
294  %gSUFFIX
295         substitute a file name that has suffix SUFFIX and is chosen
296         once per compilation, and mark the argument a la %d.  To reduce
297         exposure to denial-of-service attacks, the file name is now
298         chosen in a way that is hard to predict even when previously
299         chosen file names are known.  For example, `%g.s ... %g.o ... %g.s'
300         might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'.  SUFFIX matches
301         the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
302         had been pre-processed.  Previously, %g was simply substituted
303         with a file name chosen once per compilation, without regard
304         to any appended suffix (which was therefore treated just like
305         ordinary text), making such attacks more likely to succeed.
306  %|SUFFIX
307         like %g, but if -pipe is in effect, expands simply to "-".
308  %mSUFFIX
309         like %g, but if -pipe is in effect, expands to nothing.  (We have both
310         %| and %m to accommodate differences between system assemblers; see
311         the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
312  %uSUFFIX
313         like %g, but generates a new temporary file name even if %uSUFFIX
314         was already seen.
315  %USUFFIX
316         substitutes the last file name generated with %uSUFFIX, generating a
317         new one if there is no such last file name.  In the absence of any
318         %uSUFFIX, this is just like %gSUFFIX, except they don't share
319         the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
320         would involve the generation of two distinct file names, one
321         for each `%g.s' and another for each `%U.s'.  Previously, %U was
322         simply substituted with a file name chosen for the previous %u,
323         without regard to any appended suffix.
324  %jSUFFIX
325         substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
326         writable, and if save-temps is off; otherwise, substitute the name
327         of a temporary file, just like %u.  This temporary file is not
328         meant for communication between processes, but rather as a junk
329         disposal mechanism.
330  %.SUFFIX
331         substitutes .SUFFIX for the suffixes of a matched switch's args when
332         it is subsequently output with %*. SUFFIX is terminated by the next
333         space or %.
334  %d     marks the argument containing or following the %d as a
335         temporary file name, so that that file will be deleted if GCC exits
336         successfully.  Unlike %g, this contributes no text to the argument.
337  %w     marks the argument containing or following the %w as the
338         "output file" of this compilation.  This puts the argument
339         into the sequence of arguments that %o will substitute later.
340  %V     indicates that this compilation produces no "output file".
341  %W{...}
342         like %{...} but mark last argument supplied within
343         as a file to be deleted on failure.
344  %o     substitutes the names of all the output files, with spaces
345         automatically placed around them.  You should write spaces
346         around the %o as well or the results are undefined.
347         %o is for use in the specs for running the linker.
348         Input files whose names have no recognized suffix are not compiled
349         at all, but they are included among the output files, so they will
350         be linked.
351  %O     substitutes the suffix for object files.  Note that this is
352         handled specially when it immediately follows %g, %u, or %U
353         (with or without a suffix argument) because of the need for
354         those to form complete file names.  The handling is such that
355         %O is treated exactly as if it had already been substituted,
356         except that %g, %u, and %U do not currently support additional
357         SUFFIX characters following %O as they would following, for
358         example, `.o'.
359  %I     Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
360         (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
361         and -B options) and -imultilib as necessary.
362  %s     current argument is the name of a library or startup file of some sort.
363         Search for that file in a standard list of directories
364         and substitute the full name found.
365  %eSTR  Print STR as an error message.  STR is terminated by a newline.
366         Use this when inconsistent options are detected.
367  %nSTR  Print STR as a notice.  STR is terminated by a newline.
368  %x{OPTION}     Accumulate an option for %X.
369  %X     Output the accumulated linker options specified by compilations.
370  %Y     Output the accumulated assembler options specified by compilations.
371  %Z     Output the accumulated preprocessor options specified by compilations.
372  %a     process ASM_SPEC as a spec.
373         This allows config.h to specify part of the spec for running as.
374  %A     process ASM_FINAL_SPEC as a spec.  A capital A is actually
375         used here.  This can be used to run a post-processor after the
376         assembler has done its job.
377  %D     Dump out a -L option for each directory in startfile_prefixes.
378         If multilib_dir is set, extra entries are generated with it affixed.
379  %l     process LINK_SPEC as a spec.
380  %L     process LIB_SPEC as a spec.
381  %M     Output multilib_os_dir.
382  %G     process LIBGCC_SPEC as a spec.
383  %R     Output the concatenation of target_system_root and
384         target_sysroot_suffix.
385  %S     process STARTFILE_SPEC as a spec.  A capital S is actually used here.
386  %E     process ENDFILE_SPEC as a spec.  A capital E is actually used here.
387  %C     process CPP_SPEC as a spec.
388  %1     process CC1_SPEC as a spec.
389  %2     process CC1PLUS_SPEC as a spec.
390  %*     substitute the variable part of a matched option.  (See below.)
391         Note that each comma in the substituted string is replaced by
392         a single space.
393  %<S    remove all occurrences of -S from the command line.
394         Note - this command is position dependent.  % commands in the
395         spec string before this one will see -S, % commands in the
396         spec string after this one will not.
397  %>S    Similar to "%<S", but keep it in the GCC command line.
398  %<S*   remove all occurrences of all switches beginning with -S from the
399         command line.
400  %:function(args)
401         Call the named function FUNCTION, passing it ARGS.  ARGS is
402         first processed as a nested spec string, then split into an
403         argument vector in the usual fashion.  The function returns
404         a string which is processed as if it had appeared literally
405         as part of the current spec.
406  %{S}   substitutes the -S switch, if that switch was given to GCC.
407         If that switch was not specified, this substitutes nothing.
408         Here S is a metasyntactic variable.
409  %{S*}  substitutes all the switches specified to GCC whose names start
410         with -S.  This is used for -o, -I, etc; switches that take
411         arguments.  GCC considers `-o foo' as being one switch whose
412         name starts with `o'.  %{o*} would substitute this text,
413         including the space; thus, two arguments would be generated.
414  %{S*&T*} likewise, but preserve order of S and T options (the order
415         of S and T in the spec is not significant).  Can be any number
416         of ampersand-separated variables; for each the wild card is
417         optional.  Useful for CPP as %{D*&U*&A*}.
418
419  %{S:X}   substitutes X, if the -S switch was given to GCC.
420  %{!S:X}  substitutes X, if the -S switch was NOT given to GCC.
421  %{S*:X}  substitutes X if one or more switches whose names start
422           with -S was given to GCC.  Normally X is substituted only
423           once, no matter how many such switches appeared.  However,
424           if %* appears somewhere in X, then X will be substituted
425           once for each matching switch, with the %* replaced by the
426           part of that switch that matched the '*'.
427  %{.S:X}  substitutes X, if processing a file with suffix S.
428  %{!.S:X} substitutes X, if NOT processing a file with suffix S.
429  %{,S:X}  substitutes X, if processing a file which will use spec S.
430  %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
431
432  %{S|T:X} substitutes X if either -S or -T was given to GCC.  This may be
433           combined with '!', '.', ',', and '*' as above binding stronger
434           than the OR.
435           If %* appears in X, all of the alternatives must be starred, and
436           only the first matching alternative is substituted.
437  %{S:X;   if S was given to GCC, substitutes X;
438    T:Y;   else if T was given to GCC, substitutes Y;
439     :D}   else substitutes D.  There can be as many clauses as you need.
440           This may be combined with '.', '!', ',', '|', and '*' as above.
441
442  %(Spec) processes a specification defined in a specs file as *Spec:
443
444 The conditional text X in a %{S:X} or similar construct may contain
445 other nested % constructs or spaces, or even newlines.  They are
446 processed as usual, as described above.  Trailing white space in X is
447 ignored.  White space may also appear anywhere on the left side of the
448 colon in these constructs, except between . or * and the corresponding
449 word.
450
451 The -O, -f, -g, -m, and -W switches are handled specifically in these
452 constructs.  If another value of -O or the negated form of a -f, -m, or
453 -W switch is found later in the command line, the earlier switch
454 value is ignored, except with {S*} where S is just one letter; this
455 passes all matching options.
456
457 The character | at the beginning of the predicate text is used to indicate
458 that a command should be piped to the following command, but only if -pipe
459 is specified.
460
461 Note that it is built into GCC which switches take arguments and which
462 do not.  You might think it would be useful to generalize this to
463 allow each compiler's spec to say which switches take arguments.  But
464 this cannot be done in a consistent fashion.  GCC cannot even decide
465 which input files have been specified without knowing which switches
466 take arguments, and it must know which input files to compile in order
467 to tell which compilers to run.
468
469 GCC also knows implicitly that arguments starting in `-l' are to be
470 treated as compiler output files, and passed to the linker in their
471 proper position among the other output files.  */
472 \f
473 /* Define the macros used for specs %a, %l, %L, %S, %C, %1.  */
474
475 /* config.h can define ASM_SPEC to provide extra args to the assembler
476    or extra switch-translations.  */
477 #ifndef ASM_SPEC
478 #define ASM_SPEC ""
479 #endif
480
481 /* config.h can define ASM_FINAL_SPEC to run a post processor after
482    the assembler has run.  */
483 #ifndef ASM_FINAL_SPEC
484 #define ASM_FINAL_SPEC \
485   "%{gsplit-dwarf: \n\
486        objcopy --extract-dwo \
487          %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
488          %{c:%{o*:%:replace-extension(%{o*:%*} .dwo)}%{!o*:%b.dwo}}%{!c:%b.dwo} \n\
489        objcopy --strip-dwo \
490          %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
491     }"
492 #endif
493
494 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
495    or extra switch-translations.  */
496 #ifndef CPP_SPEC
497 #define CPP_SPEC ""
498 #endif
499
500 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
501    or extra switch-translations.  */
502 #ifndef CC1_SPEC
503 #define CC1_SPEC ""
504 #endif
505
506 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
507    or extra switch-translations.  */
508 #ifndef CC1PLUS_SPEC
509 #define CC1PLUS_SPEC ""
510 #endif
511
512 /* config.h can define LINK_SPEC to provide extra args to the linker
513    or extra switch-translations.  */
514 #ifndef LINK_SPEC
515 #define LINK_SPEC ""
516 #endif
517
518 /* config.h can define LIB_SPEC to override the default libraries.  */
519 #ifndef LIB_SPEC
520 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
521 #endif
522
523 /* mudflap specs */
524 #ifndef MFWRAP_SPEC
525 /* XXX: valid only for GNU ld */
526 /* XXX: should exactly match hooks provided by libmudflap.a */
527 #define MFWRAP_SPEC " %{static: %{fmudflap|fmudflapth: \
528  --wrap=malloc --wrap=free --wrap=calloc --wrap=realloc\
529  --wrap=mmap --wrap=mmap64 --wrap=munmap --wrap=alloca\
530 } %{fmudflapth: --wrap=pthread_create\
531 }} %{fmudflap|fmudflapth: --wrap=main}"
532 #endif
533 #ifndef MFLIB_SPEC
534 #define MFLIB_SPEC "%{fmudflap|fmudflapth: -export-dynamic}"
535 #endif
536
537 /* When using -fsplit-stack we need to wrap pthread_create, in order
538    to initialize the stack guard.  We always use wrapping, rather than
539    shared library ordering, and we keep the wrapper function in
540    libgcc.  This is not yet a real spec, though it could become one;
541    it is currently just stuffed into LINK_SPEC.  FIXME: This wrapping
542    only works with GNU ld and gold.  FIXME: This is incompatible with
543    -fmudflap when linking statically, which wants to do its own
544    wrapping.  */
545 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
546
547 #ifndef LIBASAN_SPEC
548 #ifdef STATIC_LIBASAN_LIBS
549 #define ADD_STATIC_LIBASAN_LIBS \
550   " %{static-libasan:" STATIC_LIBASAN_LIBS "}"
551 #else
552 #define ADD_STATIC_LIBASAN_LIBS
553 #endif
554 #ifdef HAVE_LD_STATIC_DYNAMIC
555 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
556                      "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
557                      ADD_STATIC_LIBASAN_LIBS
558 #else
559 #define LIBASAN_SPEC "-lasan" ADD_STATIC_LIBASAN_LIBS
560 #endif
561 #endif
562
563 #ifndef LIBTSAN_SPEC
564 #ifdef HAVE_LD_STATIC_DYNAMIC
565 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
566                      "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}"
567 #else
568 #define LIBTSAN_SPEC "-ltsan"
569 #endif
570 #endif
571
572 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
573    included.  */
574 #ifndef LIBGCC_SPEC
575 #if defined(REAL_LIBGCC_SPEC)
576 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
577 #elif defined(LINK_LIBGCC_SPECIAL_1)
578 /* Have gcc do the search for libgcc.a.  */
579 #define LIBGCC_SPEC "libgcc.a%s"
580 #else
581 #define LIBGCC_SPEC "-lgcc"
582 #endif
583 #endif
584
585 /* config.h can define STARTFILE_SPEC to override the default crt0 files.  */
586 #ifndef STARTFILE_SPEC
587 #define STARTFILE_SPEC  \
588   "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
589 #endif
590
591 /* config.h can define ENDFILE_SPEC to override the default crtn files.  */
592 #ifndef ENDFILE_SPEC
593 #define ENDFILE_SPEC ""
594 #endif
595
596 #ifndef LINKER_NAME
597 #define LINKER_NAME "collect2"
598 #endif
599
600 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
601 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
602 #else
603 #define ASM_MAP ""
604 #endif
605
606 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
607    to the assembler.  */
608 #ifndef ASM_DEBUG_SPEC
609 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
610      && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
611 #  define ASM_DEBUG_SPEC                                                \
612       (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG                            \
613        ? "%{!g0:%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}}" ASM_MAP    \
614        : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
615 # else
616 #  if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
617 #   define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
618 #  endif
619 #  if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
620 #   define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
621 #  endif
622 # endif
623 #endif
624 #ifndef ASM_DEBUG_SPEC
625 # define ASM_DEBUG_SPEC ""
626 #endif
627
628 /* Here is the spec for running the linker, after compiling all files.  */
629
630 /* This is overridable by the target in case they need to specify the
631    -lgcc and -lc order specially, yet not require them to override all
632    of LINK_COMMAND_SPEC.  */
633 #ifndef LINK_GCC_C_SEQUENCE_SPEC
634 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
635 #endif
636
637 #ifndef LINK_SSP_SPEC
638 #ifdef TARGET_LIBC_PROVIDES_SSP
639 #define LINK_SSP_SPEC "%{fstack-protector:}"
640 #else
641 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all:-lssp_nonshared -lssp}"
642 #endif
643 #endif
644
645 #ifndef LINK_PIE_SPEC
646 #ifdef HAVE_LD_PIE
647 #define LINK_PIE_SPEC "%{pie:-pie} "
648 #else
649 #define LINK_PIE_SPEC "%{pie:} "
650 #endif
651 #endif
652
653 #ifndef LINK_BUILDID_SPEC
654 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
655 #  define LINK_BUILDID_SPEC "%{!r:--build-id} "
656 # endif
657 #endif
658
659 /* Conditional to test whether the LTO plugin is used or not.
660    FIXME: For slim LTO we will need to enable plugin unconditionally.  This
661    still cause problems with PLUGIN_LD != LD and when plugin is built but
662    not useable.  For GCC 4.6 we don't support slim LTO and thus we can enable
663    plugin only when LTO is enabled.  We still honor explicit
664    -fuse-linker-plugin if the linker used understands -plugin.  */
665
666 /* The linker has some plugin support.  */
667 #if HAVE_LTO_PLUGIN > 0
668 /* The linker used has full plugin support, use LTO plugin by default.  */
669 #if HAVE_LTO_PLUGIN == 2
670 #define PLUGIN_COND "!fno-use-linker-plugin:%{flto|flto=*|fuse-linker-plugin"
671 #define PLUGIN_COND_CLOSE "}"
672 #else
673 /* The linker used has limited plugin support, use LTO plugin with explicit
674    -fuse-linker-plugin.  */
675 #define PLUGIN_COND "fuse-linker-plugin"
676 #define PLUGIN_COND_CLOSE ""
677 #endif
678 #define LINK_PLUGIN_SPEC \
679     "%{"PLUGIN_COND": \
680     -plugin %(linker_plugin_file) \
681     -plugin-opt=%(lto_wrapper) \
682     -plugin-opt=-fresolution=%u.res \
683     %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
684     }"PLUGIN_COND_CLOSE
685 #else
686 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin.  */
687 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
688     %e-fuse-linker-plugin is not supported in this configuration}"
689 #endif
690
691
692 /* -u* was put back because both BSD and SysV seem to support it.  */
693 /* %{static:} simply prevents an error message if the target machine
694    doesn't handle -static.  */
695 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
696    scripts which exist in user specified directories, or in standard
697    directories.  */
698 /* We pass any -flto flags on to the linker, which is expected
699    to understand them.  In practice, this means it had better be collect2.  */
700 /* %{e*} includes -export-dynamic; see comment in common.opt.  */
701 #ifndef LINK_COMMAND_SPEC
702 #define LINK_COMMAND_SPEC "\
703 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
704     %(linker) " \
705     LINK_PLUGIN_SPEC \
706     "%{flto|flto=*:%<fcompare-debug*} \
707     %{flto} %{flto=*} %l " LINK_PIE_SPEC \
708    "%X %{o*} %{e*} %{N} %{n} %{r}\
709     %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}}\
710     %{static:} %{L*} %(mfwrap) %(link_libgcc) %o\
711     %{fopenmp|ftree-parallelize-loops=*:%:include(libgomp.spec)%(link_gomp)}\
712     %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
713     %(mflib) " STACK_SPLIT_SPEC "\
714     %{fprofile-arcs|fprofile-generate*|coverage:-lgcov}\
715     %{fsanitize=address:" LIBASAN_SPEC "%{static:%ecannot specify -static with -fsanitize=address}}\
716     %{fsanitize=thread:" LIBTSAN_SPEC "}\
717     %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
718     %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
719 #endif
720
721 #ifndef LINK_LIBGCC_SPEC
722 /* Generate -L options for startfile prefix list.  */
723 # define LINK_LIBGCC_SPEC "%D"
724 #endif
725
726 #ifndef STARTFILE_PREFIX_SPEC
727 # define STARTFILE_PREFIX_SPEC ""
728 #endif
729
730 #ifndef SYSROOT_SPEC
731 # define SYSROOT_SPEC "--sysroot=%R"
732 #endif
733
734 #ifndef SYSROOT_SUFFIX_SPEC
735 # define SYSROOT_SUFFIX_SPEC ""
736 #endif
737
738 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
739 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
740 #endif
741
742 static const char *asm_debug = ASM_DEBUG_SPEC;
743 static const char *cpp_spec = CPP_SPEC;
744 static const char *cc1_spec = CC1_SPEC;
745 static const char *cc1plus_spec = CC1PLUS_SPEC;
746 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
747 static const char *link_ssp_spec = LINK_SSP_SPEC;
748 static const char *asm_spec = ASM_SPEC;
749 static const char *asm_final_spec = ASM_FINAL_SPEC;
750 static const char *link_spec = LINK_SPEC;
751 static const char *lib_spec = LIB_SPEC;
752 static const char *mfwrap_spec = MFWRAP_SPEC;
753 static const char *mflib_spec = MFLIB_SPEC;
754 static const char *link_gomp_spec = "";
755 static const char *libgcc_spec = LIBGCC_SPEC;
756 static const char *endfile_spec = ENDFILE_SPEC;
757 static const char *startfile_spec = STARTFILE_SPEC;
758 static const char *linker_name_spec = LINKER_NAME;
759 static const char *linker_plugin_file_spec = "";
760 static const char *lto_wrapper_spec = "";
761 static const char *lto_gcc_spec = "";
762 static const char *link_command_spec = LINK_COMMAND_SPEC;
763 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
764 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
765 static const char *sysroot_spec = SYSROOT_SPEC;
766 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
767 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
768 static const char *self_spec = "";
769
770 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
771    There should be no need to override these in target dependent files,
772    but we need to copy them to the specs file so that newer versions
773    of the GCC driver can correctly drive older tool chains with the
774    appropriate -B options.  */
775
776 /* When cpplib handles traditional preprocessing, get rid of this, and
777    call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
778    that we default the front end language better.  */
779 static const char *trad_capable_cpp =
780 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
781
782 /* We don't wrap .d files in %W{} since a missing .d file, and
783    therefore no dependency entry, confuses make into thinking a .o
784    file that happens to exist is up-to-date.  */
785 static const char *cpp_unique_options =
786 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
787  %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
788  %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
789  %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
790  %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
791  %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
792  %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
793  %{H} %C %{D*&U*&A*} %{i*} %Z %i\
794  %{fmudflap:-D_MUDFLAP -include mf-runtime.h}\
795  %{fmudflapth:-D_MUDFLAP -D_MUDFLAPTH -include mf-runtime.h}\
796  %{E|M|MM:%W{o*}}";
797
798 /* This contains cpp options which are common with cc1_options and are passed
799    only when preprocessing only to avoid duplication.  We pass the cc1 spec
800    options to the preprocessor so that it the cc1 spec may manipulate
801    options used to set target flags.  Those special target flags settings may
802    in turn cause preprocessor symbols to be defined specially.  */
803 static const char *cpp_options =
804 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
805  %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
806  %{undef} %{save-temps*:-fpch-preprocess}";
807
808 /* This contains cpp options which are not passed when the preprocessor
809    output will be used by another program.  */
810 static const char *cpp_debug_options = "%{d*}";
811
812 /* NB: This is shared amongst all front-ends, except for Ada.  */
813 static const char *cc1_options =
814 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
815  %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
816  %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
817  %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
818  %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
819  %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
820  %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
821  %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
822  %{-target-help:--target-help}\
823  %{-version:--version}\
824  %{-help=*:--help=%*}\
825  %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
826  %{fsyntax-only:-o %j} %{-param*}\
827  %{fmudflap|fmudflapth:-fno-builtin -fno-merge-constants}\
828  %{coverage:-fprofile-arcs -ftest-coverage}";
829
830 static const char *asm_options =
831 "%{-target-help:%:print-asm-header()} "
832 #if HAVE_GNU_AS
833 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
834    to the assembler equivalents.  */
835 "%{v} %{w:-W} %{I*} "
836 #endif
837 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
838
839 static const char *invoke_as =
840 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
841 "%{!fwpa:\
842    %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
843    %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
844   }";
845 #else
846 "%{!fwpa:\
847    %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
848    %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
849   }";
850 #endif
851
852 /* Some compilers have limits on line lengths, and the multilib_select
853    and/or multilib_matches strings can be very long, so we build them at
854    run time.  */
855 static struct obstack multilib_obstack;
856 static const char *multilib_select;
857 static const char *multilib_matches;
858 static const char *multilib_defaults;
859 static const char *multilib_exclusions;
860
861 /* Check whether a particular argument is a default argument.  */
862
863 #ifndef MULTILIB_DEFAULTS
864 #define MULTILIB_DEFAULTS { "" }
865 #endif
866
867 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
868
869 #ifndef DRIVER_SELF_SPECS
870 #define DRIVER_SELF_SPECS ""
871 #endif
872
873 /* Adding -fopenmp should imply pthreads.  This is particularly important
874    for targets that use different start files and suchlike.  */
875 #ifndef GOMP_SELF_SPECS
876 #define GOMP_SELF_SPECS "%{fopenmp|ftree-parallelize-loops=*: -pthread}"
877 #endif
878
879 /* Likewise for -fgnu-tm.  */
880 #ifndef GTM_SELF_SPECS
881 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
882 #endif
883
884 static const char *const driver_self_specs[] = {
885   "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
886   DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS
887 };
888
889 #ifndef OPTION_DEFAULT_SPECS
890 #define OPTION_DEFAULT_SPECS { "", "" }
891 #endif
892
893 struct default_spec
894 {
895   const char *name;
896   const char *spec;
897 };
898
899 static const struct default_spec
900   option_default_specs[] = { OPTION_DEFAULT_SPECS };
901
902 struct user_specs
903 {
904   struct user_specs *next;
905   const char *filename;
906 };
907
908 static struct user_specs *user_specs_head, *user_specs_tail;
909
910 \f
911 /* Record the mapping from file suffixes for compilation specs.  */
912
913 struct compiler
914 {
915   const char *suffix;           /* Use this compiler for input files
916                                    whose names end in this suffix.  */
917
918   const char *spec;             /* To use this compiler, run this spec.  */
919
920   const char *cpp_spec;         /* If non-NULL, substitute this spec
921                                    for `%C', rather than the usual
922                                    cpp_spec.  */
923   const int combinable;          /* If nonzero, compiler can deal with
924                                     multiple source files at once (IMA).  */
925   const int needs_preprocessing; /* If nonzero, source files need to
926                                     be run through a preprocessor.  */
927 };
928
929 /* Pointer to a vector of `struct compiler' that gives the spec for
930    compiling a file, based on its suffix.
931    A file that does not end in any of these suffixes will be passed
932    unchanged to the loader and nothing else will be done to it.
933
934    An entry containing two 0s is used to terminate the vector.
935
936    If multiple entries match a file, the last matching one is used.  */
937
938 static struct compiler *compilers;
939
940 /* Number of entries in `compilers', not counting the null terminator.  */
941
942 static int n_compilers;
943
944 /* The default list of file name suffixes and their compilation specs.  */
945
946 static const struct compiler default_compilers[] =
947 {
948   /* Add lists of suffixes of known languages here.  If those languages
949      were not present when we built the driver, we will hit these copies
950      and be given a more meaningful error than "file not used since
951      linking is not done".  */
952   {".m",  "#Objective-C", 0, 0, 0}, {".mi",  "#Objective-C", 0, 0, 0},
953   {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
954   {".mii", "#Objective-C++", 0, 0, 0},
955   {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
956   {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
957   {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
958   {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
959   {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
960   {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
961   {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
962   {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
963   {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
964   {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
965   {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
966   {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
967   {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
968   {".r", "#Ratfor", 0, 0, 0},
969   {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
970   {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
971   {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
972   {".go", "#Go", 0, 1, 0},
973   /* Next come the entries for C.  */
974   {".c", "@c", 0, 0, 1},
975   {"@c",
976    /* cc1 has an integrated ISO C preprocessor.  We should invoke the
977       external preprocessor if -save-temps is given.  */
978      "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
979       %{!E:%{!M:%{!MM:\
980           %{traditional:\
981 %eGNU C no longer supports -traditional without -E}\
982       %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
983           %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
984             cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
985           %(cc1_options)}\
986       %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
987           cc1 %(cpp_unique_options) %(cc1_options)}}}\
988       %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
989   {"-",
990    "%{!E:%e-E or -x required when input is from standard input}\
991     %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
992   {".h", "@c-header", 0, 0, 0},
993   {"@c-header",
994    /* cc1 has an integrated ISO C preprocessor.  We should invoke the
995       external preprocessor if -save-temps is given.  */
996      "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
997       %{!E:%{!M:%{!MM:\
998           %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
999                 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1000                     cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1001                         %(cc1_options)\
1002                         %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1003                         %W{o*:--output-pch=%*}}%V}\
1004           %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1005                 cc1 %(cpp_unique_options) %(cc1_options)\
1006                     %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1007                     %W{o*:--output-pch=%*}}%V}}}}}}", 0, 0, 0},
1008   {".i", "@cpp-output", 0, 0, 0},
1009   {"@cpp-output",
1010    "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1011   {".s", "@assembler", 0, 0, 0},
1012   {"@assembler",
1013    "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1014   {".sx", "@assembler-with-cpp", 0, 0, 0},
1015   {".S", "@assembler-with-cpp", 0, 0, 0},
1016   {"@assembler-with-cpp",
1017 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1018    "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1019       %{E|M|MM:%(cpp_debug_options)}\
1020       %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1021        as %(asm_debug) %(asm_options) %|.s %A }}}}"
1022 #else
1023    "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1024       %{E|M|MM:%(cpp_debug_options)}\
1025       %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1026        as %(asm_debug) %(asm_options) %m.s %A }}}}"
1027 #endif
1028    , 0, 0, 0},
1029
1030 #include "specs.h"
1031   /* Mark end of table.  */
1032   {0, 0, 0, 0, 0}
1033 };
1034
1035 /* Number of elements in default_compilers, not counting the terminator.  */
1036
1037 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1038
1039 typedef char *char_p; /* For DEF_VEC_P.  */
1040
1041 /* A vector of options to give to the linker.
1042    These options are accumulated by %x,
1043    and substituted into the linker command with %X.  */
1044 static vec<char_p> linker_options;
1045
1046 /* A vector of options to give to the assembler.
1047    These options are accumulated by -Wa,
1048    and substituted into the assembler command with %Y.  */
1049 static vec<char_p> assembler_options;
1050
1051 /* A vector of options to give to the preprocessor.
1052    These options are accumulated by -Wp,
1053    and substituted into the preprocessor command with %Z.  */
1054 static vec<char_p> preprocessor_options;
1055 \f
1056 static char *
1057 skip_whitespace (char *p)
1058 {
1059   while (1)
1060     {
1061       /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1062          be considered whitespace.  */
1063       if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1064         return p + 1;
1065       else if (*p == '\n' || *p == ' ' || *p == '\t')
1066         p++;
1067       else if (*p == '#')
1068         {
1069           while (*p != '\n')
1070             p++;
1071           p++;
1072         }
1073       else
1074         break;
1075     }
1076
1077   return p;
1078 }
1079 /* Structures to keep track of prefixes to try when looking for files.  */
1080
1081 struct prefix_list
1082 {
1083   const char *prefix;         /* String to prepend to the path.  */
1084   struct prefix_list *next;   /* Next in linked list.  */
1085   int require_machine_suffix; /* Don't use without machine_suffix.  */
1086   /* 2 means try both machine_suffix and just_machine_suffix.  */
1087   int priority;               /* Sort key - priority within list.  */
1088   int os_multilib;            /* 1 if OS multilib scheme should be used,
1089                                  0 for GCC multilib scheme.  */
1090 };
1091
1092 struct path_prefix
1093 {
1094   struct prefix_list *plist;  /* List of prefixes to try */
1095   int max_len;                /* Max length of a prefix in PLIST */
1096   const char *name;           /* Name of this list (used in config stuff) */
1097 };
1098
1099 /* List of prefixes to try when looking for executables.  */
1100
1101 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1102
1103 /* List of prefixes to try when looking for startup (crt0) files.  */
1104
1105 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1106
1107 /* List of prefixes to try when looking for include files.  */
1108
1109 static struct path_prefix include_prefixes = { 0, 0, "include" };
1110
1111 /* Suffix to attach to directories searched for commands.
1112    This looks like `MACHINE/VERSION/'.  */
1113
1114 static const char *machine_suffix = 0;
1115
1116 /* Suffix to attach to directories searched for commands.
1117    This is just `MACHINE/'.  */
1118
1119 static const char *just_machine_suffix = 0;
1120
1121 /* Adjusted value of GCC_EXEC_PREFIX envvar.  */
1122
1123 static const char *gcc_exec_prefix;
1124
1125 /* Adjusted value of standard_libexec_prefix.  */
1126
1127 static const char *gcc_libexec_prefix;
1128
1129 /* Default prefixes to attach to command names.  */
1130
1131 #ifndef STANDARD_STARTFILE_PREFIX_1
1132 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1133 #endif
1134 #ifndef STANDARD_STARTFILE_PREFIX_2
1135 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1136 #endif
1137
1138 #ifdef CROSS_DIRECTORY_STRUCTURE  /* Don't use these prefixes for a cross compiler.  */
1139 #undef MD_EXEC_PREFIX
1140 #undef MD_STARTFILE_PREFIX
1141 #undef MD_STARTFILE_PREFIX_1
1142 #endif
1143
1144 /* If no prefixes defined, use the null string, which will disable them.  */
1145 #ifndef MD_EXEC_PREFIX
1146 #define MD_EXEC_PREFIX ""
1147 #endif
1148 #ifndef MD_STARTFILE_PREFIX
1149 #define MD_STARTFILE_PREFIX ""
1150 #endif
1151 #ifndef MD_STARTFILE_PREFIX_1
1152 #define MD_STARTFILE_PREFIX_1 ""
1153 #endif
1154
1155 /* These directories are locations set at configure-time based on the
1156    --prefix option provided to configure.  Their initializers are
1157    defined in Makefile.in.  These paths are not *directly* used when
1158    gcc_exec_prefix is set because, in that case, we know where the
1159    compiler has been installed, and use paths relative to that
1160    location instead.  */
1161 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1162 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1163 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1164 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1165
1166 /* For native compilers, these are well-known paths containing
1167    components that may be provided by the system.  For cross
1168    compilers, these paths are not used.  */
1169 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1170 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1171 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1172 static const char *const standard_startfile_prefix_1
1173   = STANDARD_STARTFILE_PREFIX_1;
1174 static const char *const standard_startfile_prefix_2
1175   = STANDARD_STARTFILE_PREFIX_2;
1176
1177 /* A relative path to be used in finding the location of tools
1178    relative to the driver.  */
1179 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1180
1181 /* Subdirectory to use for locating libraries.  Set by
1182    set_multilib_dir based on the compilation options.  */
1183
1184 static const char *multilib_dir;
1185
1186 /* Subdirectory to use for locating libraries in OS conventions.  Set by
1187    set_multilib_dir based on the compilation options.  */
1188
1189 static const char *multilib_os_dir;
1190
1191 /* Subdirectory to use for locating libraries in multiarch conventions.  Set by
1192    set_multilib_dir based on the compilation options.  */
1193
1194 static const char *multiarch_dir;
1195 \f
1196 /* Structure to keep track of the specs that have been defined so far.
1197    These are accessed using %(specname) in a compiler or link
1198    spec.  */
1199
1200 struct spec_list
1201 {
1202                                 /* The following 2 fields must be first */
1203                                 /* to allow EXTRA_SPECS to be initialized */
1204   const char *name;             /* name of the spec.  */
1205   const char *ptr;              /* available ptr if no static pointer */
1206
1207                                 /* The following fields are not initialized */
1208                                 /* by EXTRA_SPECS */
1209   const char **ptr_spec;        /* pointer to the spec itself.  */
1210   struct spec_list *next;       /* Next spec in linked list.  */
1211   int name_len;                 /* length of the name */
1212   bool user_p;                  /* whether string come from file spec.  */
1213   bool alloc_p;                 /* whether string was allocated */
1214 };
1215
1216 #define INIT_STATIC_SPEC(NAME,PTR) \
1217   { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false }
1218
1219 /* List of statically defined specs.  */
1220 static struct spec_list static_specs[] =
1221 {
1222   INIT_STATIC_SPEC ("asm",                      &asm_spec),
1223   INIT_STATIC_SPEC ("asm_debug",                &asm_debug),
1224   INIT_STATIC_SPEC ("asm_final",                &asm_final_spec),
1225   INIT_STATIC_SPEC ("asm_options",              &asm_options),
1226   INIT_STATIC_SPEC ("invoke_as",                &invoke_as),
1227   INIT_STATIC_SPEC ("cpp",                      &cpp_spec),
1228   INIT_STATIC_SPEC ("cpp_options",              &cpp_options),
1229   INIT_STATIC_SPEC ("cpp_debug_options",        &cpp_debug_options),
1230   INIT_STATIC_SPEC ("cpp_unique_options",       &cpp_unique_options),
1231   INIT_STATIC_SPEC ("trad_capable_cpp",         &trad_capable_cpp),
1232   INIT_STATIC_SPEC ("cc1",                      &cc1_spec),
1233   INIT_STATIC_SPEC ("cc1_options",              &cc1_options),
1234   INIT_STATIC_SPEC ("cc1plus",                  &cc1plus_spec),
1235   INIT_STATIC_SPEC ("link_gcc_c_sequence",      &link_gcc_c_sequence_spec),
1236   INIT_STATIC_SPEC ("link_ssp",                 &link_ssp_spec),
1237   INIT_STATIC_SPEC ("endfile",                  &endfile_spec),
1238   INIT_STATIC_SPEC ("link",                     &link_spec),
1239   INIT_STATIC_SPEC ("lib",                      &lib_spec),
1240   INIT_STATIC_SPEC ("mfwrap",                   &mfwrap_spec),
1241   INIT_STATIC_SPEC ("mflib",                    &mflib_spec),
1242   INIT_STATIC_SPEC ("link_gomp",                &link_gomp_spec),
1243   INIT_STATIC_SPEC ("libgcc",                   &libgcc_spec),
1244   INIT_STATIC_SPEC ("startfile",                &startfile_spec),
1245   INIT_STATIC_SPEC ("cross_compile",            &cross_compile),
1246   INIT_STATIC_SPEC ("version",                  &compiler_version),
1247   INIT_STATIC_SPEC ("multilib",                 &multilib_select),
1248   INIT_STATIC_SPEC ("multilib_defaults",        &multilib_defaults),
1249   INIT_STATIC_SPEC ("multilib_extra",           &multilib_extra),
1250   INIT_STATIC_SPEC ("multilib_matches",         &multilib_matches),
1251   INIT_STATIC_SPEC ("multilib_exclusions",      &multilib_exclusions),
1252   INIT_STATIC_SPEC ("multilib_options",         &multilib_options),
1253   INIT_STATIC_SPEC ("linker",                   &linker_name_spec),
1254   INIT_STATIC_SPEC ("linker_plugin_file",       &linker_plugin_file_spec),
1255   INIT_STATIC_SPEC ("lto_wrapper",              &lto_wrapper_spec),
1256   INIT_STATIC_SPEC ("lto_gcc",                  &lto_gcc_spec),
1257   INIT_STATIC_SPEC ("link_libgcc",              &link_libgcc_spec),
1258   INIT_STATIC_SPEC ("md_exec_prefix",           &md_exec_prefix),
1259   INIT_STATIC_SPEC ("md_startfile_prefix",      &md_startfile_prefix),
1260   INIT_STATIC_SPEC ("md_startfile_prefix_1",    &md_startfile_prefix_1),
1261   INIT_STATIC_SPEC ("startfile_prefix_spec",    &startfile_prefix_spec),
1262   INIT_STATIC_SPEC ("sysroot_spec",             &sysroot_spec),
1263   INIT_STATIC_SPEC ("sysroot_suffix_spec",      &sysroot_suffix_spec),
1264   INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1265   INIT_STATIC_SPEC ("self_spec",                &self_spec),
1266 };
1267
1268 #ifdef EXTRA_SPECS              /* additional specs needed */
1269 /* Structure to keep track of just the first two args of a spec_list.
1270    That is all that the EXTRA_SPECS macro gives us.  */
1271 struct spec_list_1
1272 {
1273   const char *const name;
1274   const char *const ptr;
1275 };
1276
1277 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1278 static struct spec_list *extra_specs = (struct spec_list *) 0;
1279 #endif
1280
1281 /* List of dynamically allocates specs that have been defined so far.  */
1282
1283 static struct spec_list *specs = (struct spec_list *) 0;
1284 \f
1285 /* List of static spec functions.  */
1286
1287 static const struct spec_function static_spec_functions[] =
1288 {
1289   { "getenv",                   getenv_spec_function },
1290   { "if-exists",                if_exists_spec_function },
1291   { "if-exists-else",           if_exists_else_spec_function },
1292   { "replace-outfile",          replace_outfile_spec_function },
1293   { "remove-outfile",           remove_outfile_spec_function },
1294   { "version-compare",          version_compare_spec_function },
1295   { "include",                  include_spec_function },
1296   { "find-file",                find_file_spec_function },
1297   { "find-plugindir",           find_plugindir_spec_function },
1298   { "print-asm-header",         print_asm_header_spec_function },
1299   { "compare-debug-dump-opt",   compare_debug_dump_opt_spec_function },
1300   { "compare-debug-self-opt",   compare_debug_self_opt_spec_function },
1301   { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1302   { "pass-through-libs",        pass_through_libs_spec_func },
1303   { "replace-extension",        replace_extension_spec_func },
1304 #ifdef EXTRA_SPEC_FUNCTIONS
1305   EXTRA_SPEC_FUNCTIONS
1306 #endif
1307   { 0, 0 }
1308 };
1309
1310 static int processing_spec_function;
1311 \f
1312 /* Add appropriate libgcc specs to OBSTACK, taking into account
1313    various permutations of -shared-libgcc, -shared, and such.  */
1314
1315 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1316
1317 #ifndef USE_LD_AS_NEEDED
1318 #define USE_LD_AS_NEEDED 0
1319 #endif
1320
1321 static void
1322 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1323                 const char *static_name, const char *eh_name)
1324 {
1325   char *buf;
1326
1327   buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1328                 "%{!static:%{!static-libgcc:"
1329 #if USE_LD_AS_NEEDED
1330                 "%{!shared-libgcc:",
1331                 static_name, " --as-needed ", shared_name, " --no-as-needed"
1332                 "}"
1333                 "%{shared-libgcc:",
1334                 shared_name, "%{!shared: ", static_name, "}"
1335                 "}"
1336 #else
1337                 "%{!shared:"
1338                 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1339                 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1340                 "}"
1341 #ifdef LINK_EH_SPEC
1342                 "%{shared:"
1343                 "%{shared-libgcc:", shared_name, "}"
1344                 "%{!shared-libgcc:", static_name, "}"
1345                 "}"
1346 #else
1347                 "%{shared:", shared_name, "}"
1348 #endif
1349 #endif
1350                 "}}", NULL);
1351
1352   obstack_grow (obstack, buf, strlen (buf));
1353   free (buf);
1354 }
1355 #endif /* ENABLE_SHARED_LIBGCC */
1356
1357 /* Initialize the specs lookup routines.  */
1358
1359 static void
1360 init_spec (void)
1361 {
1362   struct spec_list *next = (struct spec_list *) 0;
1363   struct spec_list *sl   = (struct spec_list *) 0;
1364   int i;
1365
1366   if (specs)
1367     return;                     /* Already initialized.  */
1368
1369   if (verbose_flag)
1370     fnotice (stderr, "Using built-in specs.\n");
1371
1372 #ifdef EXTRA_SPECS
1373   extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1374
1375   for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1376     {
1377       sl = &extra_specs[i];
1378       sl->name = extra_specs_1[i].name;
1379       sl->ptr = extra_specs_1[i].ptr;
1380       sl->next = next;
1381       sl->name_len = strlen (sl->name);
1382       sl->ptr_spec = &sl->ptr;
1383       next = sl;
1384     }
1385 #endif
1386
1387   for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1388     {
1389       sl = &static_specs[i];
1390       sl->next = next;
1391       next = sl;
1392     }
1393
1394 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1395   /* ??? If neither -shared-libgcc nor --static-libgcc was
1396      seen, then we should be making an educated guess.  Some proposed
1397      heuristics for ELF include:
1398
1399         (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1400             program will be doing dynamic loading, which will likely
1401             need the shared libgcc.
1402
1403         (2) If "-ldl", then it's also a fair bet that we're doing
1404             dynamic loading.
1405
1406         (3) For each ET_DYN we're linking against (either through -lfoo
1407             or /some/path/foo.so), check to see whether it or one of
1408             its dependencies depends on a shared libgcc.
1409
1410         (4) If "-shared"
1411
1412             If the runtime is fixed to look for program headers instead
1413             of calling __register_frame_info at all, for each object,
1414             use the shared libgcc if any EH symbol referenced.
1415
1416             If crtstuff is fixed to not invoke __register_frame_info
1417             automatically, for each object, use the shared libgcc if
1418             any non-empty unwind section found.
1419
1420      Doing any of this probably requires invoking an external program to
1421      do the actual object file scanning.  */
1422   {
1423     const char *p = libgcc_spec;
1424     int in_sep = 1;
1425
1426     /* Transform the extant libgcc_spec into one that uses the shared libgcc
1427        when given the proper command line arguments.  */
1428     while (*p)
1429       {
1430         if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1431           {
1432             init_gcc_specs (&obstack,
1433                             "-lgcc_s"
1434 #ifdef USE_LIBUNWIND_EXCEPTIONS
1435                             " -lunwind"
1436 #endif
1437                             ,
1438                             "-lgcc",
1439                             "-lgcc_eh"
1440 #ifdef USE_LIBUNWIND_EXCEPTIONS
1441 # ifdef HAVE_LD_STATIC_DYNAMIC
1442                             " %{!static:" LD_STATIC_OPTION "} -lunwind"
1443                             " %{!static:" LD_DYNAMIC_OPTION "}"
1444 # else
1445                             " -lunwind"
1446 # endif
1447 #endif
1448                             );
1449
1450             p += 5;
1451             in_sep = 0;
1452           }
1453         else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1454           {
1455             /* Ug.  We don't know shared library extensions.  Hope that
1456                systems that use this form don't do shared libraries.  */
1457             init_gcc_specs (&obstack,
1458                             "-lgcc_s",
1459                             "libgcc.a%s",
1460                             "libgcc_eh.a%s"
1461 #ifdef USE_LIBUNWIND_EXCEPTIONS
1462                             " -lunwind"
1463 #endif
1464                             );
1465             p += 10;
1466             in_sep = 0;
1467           }
1468         else
1469           {
1470             obstack_1grow (&obstack, *p);
1471             in_sep = (*p == ' ');
1472             p += 1;
1473           }
1474       }
1475
1476     obstack_1grow (&obstack, '\0');
1477     libgcc_spec = XOBFINISH (&obstack, const char *);
1478   }
1479 #endif
1480 #ifdef USE_AS_TRADITIONAL_FORMAT
1481   /* Prepend "--traditional-format" to whatever asm_spec we had before.  */
1482   {
1483     static const char tf[] = "--traditional-format ";
1484     obstack_grow (&obstack, tf, sizeof(tf) - 1);
1485     obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1486     asm_spec = XOBFINISH (&obstack, const char *);
1487   }
1488 #endif
1489
1490 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1491     defined LINKER_HASH_STYLE
1492 # ifdef LINK_BUILDID_SPEC
1493   /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before.  */
1494   obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof(LINK_BUILDID_SPEC) - 1);
1495 # endif
1496 # ifdef LINK_EH_SPEC
1497   /* Prepend LINK_EH_SPEC to whatever link_spec we had before.  */
1498   obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1499 # endif
1500 # ifdef LINKER_HASH_STYLE
1501   /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1502      before.  */
1503   {
1504     static const char hash_style[] = "--hash-style=";
1505     obstack_grow (&obstack, hash_style, sizeof(hash_style) - 1);
1506     obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof(LINKER_HASH_STYLE) - 1);
1507     obstack_1grow (&obstack, ' ');
1508   }
1509 # endif
1510   obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1511   link_spec = XOBFINISH (&obstack, const char *);
1512 #endif
1513
1514   specs = sl;
1515 }
1516 \f
1517 /* Change the value of spec NAME to SPEC.  If SPEC is empty, then the spec is
1518    removed; If the spec starts with a + then SPEC is added to the end of the
1519    current spec.  */
1520
1521 static void
1522 set_spec (const char *name, const char *spec, bool user_p)
1523 {
1524   struct spec_list *sl;
1525   const char *old_spec;
1526   int name_len = strlen (name);
1527   int i;
1528
1529   /* If this is the first call, initialize the statically allocated specs.  */
1530   if (!specs)
1531     {
1532       struct spec_list *next = (struct spec_list *) 0;
1533       for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1534         {
1535           sl = &static_specs[i];
1536           sl->next = next;
1537           next = sl;
1538         }
1539       specs = sl;
1540     }
1541
1542   /* See if the spec already exists.  */
1543   for (sl = specs; sl; sl = sl->next)
1544     if (name_len == sl->name_len && !strcmp (sl->name, name))
1545       break;
1546
1547   if (!sl)
1548     {
1549       /* Not found - make it.  */
1550       sl = XNEW (struct spec_list);
1551       sl->name = xstrdup (name);
1552       sl->name_len = name_len;
1553       sl->ptr_spec = &sl->ptr;
1554       sl->alloc_p = 0;
1555       *(sl->ptr_spec) = "";
1556       sl->next = specs;
1557       specs = sl;
1558     }
1559
1560   old_spec = *(sl->ptr_spec);
1561   *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1562                      ? concat (old_spec, spec + 1, NULL)
1563                      : xstrdup (spec));
1564
1565 #ifdef DEBUG_SPECS
1566   if (verbose_flag)
1567     fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1568 #endif
1569
1570   /* Free the old spec.  */
1571   if (old_spec && sl->alloc_p)
1572     free (CONST_CAST(char *, old_spec));
1573
1574   sl->user_p = user_p;
1575   sl->alloc_p = true;
1576 }
1577 \f
1578 /* Accumulate a command (program name and args), and run it.  */
1579
1580 typedef const char *const_char_p; /* For DEF_VEC_P.  */
1581
1582 /* Vector of pointers to arguments in the current line of specifications.  */
1583
1584 static vec<const_char_p> argbuf;
1585
1586 /* Position in the argbuf vector containing the name of the output file
1587    (the value associated with the "-o" flag).  */
1588
1589 static int have_o_argbuf_index = 0;
1590
1591 /* Were the options -c, -S or -E passed.  */
1592 static int have_c = 0;
1593
1594 /* Was the option -o passed.  */
1595 static int have_o = 0;
1596
1597 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1598    temp file.  If the HOST_BIT_BUCKET is used for %j, no entry is made for
1599    it here.  */
1600
1601 static struct temp_name {
1602   const char *suffix;   /* suffix associated with the code.  */
1603   int length;           /* strlen (suffix).  */
1604   int unique;           /* Indicates whether %g or %u/%U was used.  */
1605   const char *filename; /* associated filename.  */
1606   int filename_length;  /* strlen (filename).  */
1607   struct temp_name *next;
1608 } *temp_names;
1609
1610 /* Number of commands executed so far.  */
1611
1612 static int execution_count;
1613
1614 /* Number of commands that exited with a signal.  */
1615
1616 static int signal_count;
1617 \f
1618 /* Allocate the argument vector.  */
1619
1620 static void
1621 alloc_args (void)
1622 {
1623   argbuf.create (10);
1624 }
1625
1626 /* Clear out the vector of arguments (after a command is executed).  */
1627
1628 static void
1629 clear_args (void)
1630 {
1631   argbuf.truncate (0);
1632 }
1633
1634 /* Add one argument to the vector at the end.
1635    This is done when a space is seen or at the end of the line.
1636    If DELETE_ALWAYS is nonzero, the arg is a filename
1637     and the file should be deleted eventually.
1638    If DELETE_FAILURE is nonzero, the arg is a filename
1639     and the file should be deleted if this compilation fails.  */
1640
1641 static void
1642 store_arg (const char *arg, int delete_always, int delete_failure)
1643 {
1644   argbuf.safe_push (arg);
1645
1646   if (strcmp (arg, "-o") == 0)
1647     have_o_argbuf_index = argbuf.length ();
1648   if (delete_always || delete_failure)
1649     {
1650       const char *p;
1651       /* If the temporary file we should delete is specified as
1652          part of a joined argument extract the filename.  */
1653       if (arg[0] == '-'
1654           && (p = strrchr (arg, '=')))
1655         arg = p + 1;
1656       record_temp_file (arg, delete_always, delete_failure);
1657     }
1658 }
1659 \f
1660 /* Load specs from a file name named FILENAME, replacing occurrences of
1661    various different types of line-endings, \r\n, \n\r and just \r, with
1662    a single \n.  */
1663
1664 static char *
1665 load_specs (const char *filename)
1666 {
1667   int desc;
1668   int readlen;
1669   struct stat statbuf;
1670   char *buffer;
1671   char *buffer_p;
1672   char *specs;
1673   char *specs_p;
1674
1675   if (verbose_flag)
1676     fnotice (stderr, "Reading specs from %s\n", filename);
1677
1678   /* Open and stat the file.  */
1679   desc = open (filename, O_RDONLY, 0);
1680   if (desc < 0)
1681     pfatal_with_name (filename);
1682   if (stat (filename, &statbuf) < 0)
1683     pfatal_with_name (filename);
1684
1685   /* Read contents of file into BUFFER.  */
1686   buffer = XNEWVEC (char, statbuf.st_size + 1);
1687   readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1688   if (readlen < 0)
1689     pfatal_with_name (filename);
1690   buffer[readlen] = 0;
1691   close (desc);
1692
1693   specs = XNEWVEC (char, readlen + 1);
1694   specs_p = specs;
1695   for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1696     {
1697       int skip = 0;
1698       char c = *buffer_p;
1699       if (c == '\r')
1700         {
1701           if (buffer_p > buffer && *(buffer_p - 1) == '\n')     /* \n\r */
1702             skip = 1;
1703           else if (*(buffer_p + 1) == '\n')                     /* \r\n */
1704             skip = 1;
1705           else                                                  /* \r */
1706             c = '\n';
1707         }
1708       if (! skip)
1709         *specs_p++ = c;
1710     }
1711   *specs_p = '\0';
1712
1713   free (buffer);
1714   return (specs);
1715 }
1716
1717 /* Read compilation specs from a file named FILENAME,
1718    replacing the default ones.
1719
1720    A suffix which starts with `*' is a definition for
1721    one of the machine-specific sub-specs.  The "suffix" should be
1722    *asm, *cc1, *cpp, *link, *startfile, etc.
1723    The corresponding spec is stored in asm_spec, etc.,
1724    rather than in the `compilers' vector.
1725
1726    Anything invalid in the file is a fatal error.  */
1727
1728 static void
1729 read_specs (const char *filename, bool main_p, bool user_p)
1730 {
1731   char *buffer;
1732   char *p;
1733
1734   buffer = load_specs (filename);
1735
1736   /* Scan BUFFER for specs, putting them in the vector.  */
1737   p = buffer;
1738   while (1)
1739     {
1740       char *suffix;
1741       char *spec;
1742       char *in, *out, *p1, *p2, *p3;
1743
1744       /* Advance P in BUFFER to the next nonblank nocomment line.  */
1745       p = skip_whitespace (p);
1746       if (*p == 0)
1747         break;
1748
1749       /* Is this a special command that starts with '%'? */
1750       /* Don't allow this for the main specs file, since it would
1751          encourage people to overwrite it.  */
1752       if (*p == '%' && !main_p)
1753         {
1754           p1 = p;
1755           while (*p && *p != '\n')
1756             p++;
1757
1758           /* Skip '\n'.  */
1759           p++;
1760
1761           if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1762               && (p1[sizeof "%include" - 1] == ' '
1763                   || p1[sizeof "%include" - 1] == '\t'))
1764             {
1765               char *new_filename;
1766
1767               p1 += sizeof ("%include");
1768               while (*p1 == ' ' || *p1 == '\t')
1769                 p1++;
1770
1771               if (*p1++ != '<' || p[-2] != '>')
1772                 fatal_error ("specs %%include syntax malformed after "
1773                              "%ld characters",
1774                              (long) (p1 - buffer + 1));
1775
1776               p[-2] = '\0';
1777               new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1778               read_specs (new_filename ? new_filename : p1, false, user_p);
1779               continue;
1780             }
1781           else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1782                    && (p1[sizeof "%include_noerr" - 1] == ' '
1783                        || p1[sizeof "%include_noerr" - 1] == '\t'))
1784             {
1785               char *new_filename;
1786
1787               p1 += sizeof "%include_noerr";
1788               while (*p1 == ' ' || *p1 == '\t')
1789                 p1++;
1790
1791               if (*p1++ != '<' || p[-2] != '>')
1792                 fatal_error ("specs %%include syntax malformed after "
1793                              "%ld characters",
1794                              (long) (p1 - buffer + 1));
1795
1796               p[-2] = '\0';
1797               new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1798               if (new_filename)
1799                 read_specs (new_filename, false, user_p);
1800               else if (verbose_flag)
1801                 fnotice (stderr, "could not find specs file %s\n", p1);
1802               continue;
1803             }
1804           else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1805                    && (p1[sizeof "%rename" - 1] == ' '
1806                        || p1[sizeof "%rename" - 1] == '\t'))
1807             {
1808               int name_len;
1809               struct spec_list *sl;
1810               struct spec_list *newsl;
1811
1812               /* Get original name.  */
1813               p1 += sizeof "%rename";
1814               while (*p1 == ' ' || *p1 == '\t')
1815                 p1++;
1816
1817               if (! ISALPHA ((unsigned char) *p1))
1818                 fatal_error ("specs %%rename syntax malformed after "
1819                              "%ld characters",
1820                              (long) (p1 - buffer));
1821
1822               p2 = p1;
1823               while (*p2 && !ISSPACE ((unsigned char) *p2))
1824                 p2++;
1825
1826               if (*p2 != ' ' && *p2 != '\t')
1827                 fatal_error ("specs %%rename syntax malformed after "
1828                              "%ld characters",
1829                              (long) (p2 - buffer));
1830
1831               name_len = p2 - p1;
1832               *p2++ = '\0';
1833               while (*p2 == ' ' || *p2 == '\t')
1834                 p2++;
1835
1836               if (! ISALPHA ((unsigned char) *p2))
1837                 fatal_error ("specs %%rename syntax malformed after "
1838                              "%ld characters",
1839                              (long) (p2 - buffer));
1840
1841               /* Get new spec name.  */
1842               p3 = p2;
1843               while (*p3 && !ISSPACE ((unsigned char) *p3))
1844                 p3++;
1845
1846               if (p3 != p - 1)
1847                 fatal_error ("specs %%rename syntax malformed after "
1848                              "%ld characters",
1849                              (long) (p3 - buffer));
1850               *p3 = '\0';
1851
1852               for (sl = specs; sl; sl = sl->next)
1853                 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1854                   break;
1855
1856               if (!sl)
1857                 fatal_error ("specs %s spec was not found to be renamed", p1);
1858
1859               if (strcmp (p1, p2) == 0)
1860                 continue;
1861
1862               for (newsl = specs; newsl; newsl = newsl->next)
1863                 if (strcmp (newsl->name, p2) == 0)
1864                   fatal_error ("%s: attempt to rename spec %qs to "
1865                                "already defined spec %qs",
1866                     filename, p1, p2);
1867
1868               if (verbose_flag)
1869                 {
1870                   fnotice (stderr, "rename spec %s to %s\n", p1, p2);
1871 #ifdef DEBUG_SPECS
1872                   fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
1873 #endif
1874                 }
1875
1876               set_spec (p2, *(sl->ptr_spec), user_p);
1877               if (sl->alloc_p)
1878                 free (CONST_CAST (char *, *(sl->ptr_spec)));
1879
1880               *(sl->ptr_spec) = "";
1881               sl->alloc_p = 0;
1882               continue;
1883             }
1884           else
1885             fatal_error ("specs unknown %% command after %ld characters",
1886                          (long) (p1 - buffer));
1887         }
1888
1889       /* Find the colon that should end the suffix.  */
1890       p1 = p;
1891       while (*p1 && *p1 != ':' && *p1 != '\n')
1892         p1++;
1893
1894       /* The colon shouldn't be missing.  */
1895       if (*p1 != ':')
1896         fatal_error ("specs file malformed after %ld characters",
1897                      (long) (p1 - buffer));
1898
1899       /* Skip back over trailing whitespace.  */
1900       p2 = p1;
1901       while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
1902         p2--;
1903
1904       /* Copy the suffix to a string.  */
1905       suffix = save_string (p, p2 - p);
1906       /* Find the next line.  */
1907       p = skip_whitespace (p1 + 1);
1908       if (p[1] == 0)
1909         fatal_error ("specs file malformed after %ld characters",
1910                      (long) (p - buffer));
1911
1912       p1 = p;
1913       /* Find next blank line or end of string.  */
1914       while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
1915         p1++;
1916
1917       /* Specs end at the blank line and do not include the newline.  */
1918       spec = save_string (p, p1 - p);
1919       p = p1;
1920
1921       /* Delete backslash-newline sequences from the spec.  */
1922       in = spec;
1923       out = spec;
1924       while (*in != 0)
1925         {
1926           if (in[0] == '\\' && in[1] == '\n')
1927             in += 2;
1928           else if (in[0] == '#')
1929             while (*in && *in != '\n')
1930               in++;
1931
1932           else
1933             *out++ = *in++;
1934         }
1935       *out = 0;
1936
1937       if (suffix[0] == '*')
1938         {
1939           if (! strcmp (suffix, "*link_command"))
1940             link_command_spec = spec;
1941           else
1942             set_spec (suffix + 1, spec, user_p);
1943         }
1944       else
1945         {
1946           /* Add this pair to the vector.  */
1947           compilers
1948             = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
1949
1950           compilers[n_compilers].suffix = suffix;
1951           compilers[n_compilers].spec = spec;
1952           n_compilers++;
1953           memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
1954         }
1955
1956       if (*suffix == 0)
1957         link_command_spec = spec;
1958     }
1959
1960   if (link_command_spec == 0)
1961     fatal_error ("spec file has no spec for linking");
1962 }
1963 \f
1964 /* Record the names of temporary files we tell compilers to write,
1965    and delete them at the end of the run.  */
1966
1967 /* This is the common prefix we use to make temp file names.
1968    It is chosen once for each run of this program.
1969    It is substituted into a spec by %g or %j.
1970    Thus, all temp file names contain this prefix.
1971    In practice, all temp file names start with this prefix.
1972
1973    This prefix comes from the envvar TMPDIR if it is defined;
1974    otherwise, from the P_tmpdir macro if that is defined;
1975    otherwise, in /usr/tmp or /tmp;
1976    or finally the current directory if all else fails.  */
1977
1978 static const char *temp_filename;
1979
1980 /* Length of the prefix.  */
1981
1982 static int temp_filename_length;
1983
1984 /* Define the list of temporary files to delete.  */
1985
1986 struct temp_file
1987 {
1988   const char *name;
1989   struct temp_file *next;
1990 };
1991
1992 /* Queue of files to delete on success or failure of compilation.  */
1993 static struct temp_file *always_delete_queue;
1994 /* Queue of files to delete on failure of compilation.  */
1995 static struct temp_file *failure_delete_queue;
1996
1997 /* Record FILENAME as a file to be deleted automatically.
1998    ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
1999    otherwise delete it in any case.
2000    FAIL_DELETE nonzero means delete it if a compilation step fails;
2001    otherwise delete it in any case.  */
2002
2003 void
2004 record_temp_file (const char *filename, int always_delete, int fail_delete)
2005 {
2006   char *const name = xstrdup (filename);
2007
2008   if (always_delete)
2009     {
2010       struct temp_file *temp;
2011       for (temp = always_delete_queue; temp; temp = temp->next)
2012         if (! filename_cmp (name, temp->name))
2013           goto already1;
2014
2015       temp = XNEW (struct temp_file);
2016       temp->next = always_delete_queue;
2017       temp->name = name;
2018       always_delete_queue = temp;
2019
2020     already1:;
2021     }
2022
2023   if (fail_delete)
2024     {
2025       struct temp_file *temp;
2026       for (temp = failure_delete_queue; temp; temp = temp->next)
2027         if (! filename_cmp (name, temp->name))
2028           {
2029             free (name);
2030             goto already2;
2031           }
2032
2033       temp = XNEW (struct temp_file);
2034       temp->next = failure_delete_queue;
2035       temp->name = name;
2036       failure_delete_queue = temp;
2037
2038     already2:;
2039     }
2040 }
2041
2042 /* Delete all the temporary files whose names we previously recorded.  */
2043
2044 #ifndef DELETE_IF_ORDINARY
2045 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG)        \
2046 do                                                      \
2047   {                                                     \
2048     if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode))  \
2049       if (unlink (NAME) < 0)                            \
2050         if (VERBOSE_FLAG)                               \
2051           perror_with_name (NAME);                      \
2052   } while (0)
2053 #endif
2054
2055 static void
2056 delete_if_ordinary (const char *name)
2057 {
2058   struct stat st;
2059 #ifdef DEBUG
2060   int i, c;
2061
2062   printf ("Delete %s? (y or n) ", name);
2063   fflush (stdout);
2064   i = getchar ();
2065   if (i != '\n')
2066     while ((c = getchar ()) != '\n' && c != EOF)
2067       ;
2068
2069   if (i == 'y' || i == 'Y')
2070 #endif /* DEBUG */
2071   DELETE_IF_ORDINARY (name, st, verbose_flag);
2072 }
2073
2074 static void
2075 delete_temp_files (void)
2076 {
2077   struct temp_file *temp;
2078
2079   for (temp = always_delete_queue; temp; temp = temp->next)
2080     delete_if_ordinary (temp->name);
2081   always_delete_queue = 0;
2082 }
2083
2084 /* Delete all the files to be deleted on error.  */
2085
2086 static void
2087 delete_failure_queue (void)
2088 {
2089   struct temp_file *temp;
2090
2091   for (temp = failure_delete_queue; temp; temp = temp->next)
2092     delete_if_ordinary (temp->name);
2093 }
2094
2095 static void
2096 clear_failure_queue (void)
2097 {
2098   failure_delete_queue = 0;
2099 }
2100 \f
2101 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2102    returns non-NULL.
2103    If DO_MULTI is true iterate over the paths twice, first with multilib
2104    suffix then without, otherwise iterate over the paths once without
2105    adding a multilib suffix.  When DO_MULTI is true, some attempt is made
2106    to avoid visiting the same path twice, but we could do better.  For
2107    instance, /usr/lib/../lib is considered different from /usr/lib.
2108    At least EXTRA_SPACE chars past the end of the path passed to
2109    CALLBACK are available for use by the callback.
2110    CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2111
2112    Returns the value returned by CALLBACK.  */
2113
2114 static void *
2115 for_each_path (const struct path_prefix *paths,
2116                bool do_multi,
2117                size_t extra_space,
2118                void *(*callback) (char *, void *),
2119                void *callback_info)
2120 {
2121   struct prefix_list *pl;
2122   const char *multi_dir = NULL;
2123   const char *multi_os_dir = NULL;
2124   const char *multiarch_suffix = NULL;
2125   const char *multi_suffix;
2126   const char *just_multi_suffix;
2127   char *path = NULL;
2128   void *ret = NULL;
2129   bool skip_multi_dir = false;
2130   bool skip_multi_os_dir = false;
2131
2132   multi_suffix = machine_suffix;
2133   just_multi_suffix = just_machine_suffix;
2134   if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2135     {
2136       multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2137       multi_suffix = concat (multi_suffix, multi_dir, NULL);
2138       just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2139     }
2140   if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2141     multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2142   if (multiarch_dir)
2143     multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2144
2145   while (1)
2146     {
2147       size_t multi_dir_len = 0;
2148       size_t multi_os_dir_len = 0;
2149       size_t multiarch_len = 0;
2150       size_t suffix_len;
2151       size_t just_suffix_len;
2152       size_t len;
2153
2154       if (multi_dir)
2155         multi_dir_len = strlen (multi_dir);
2156       if (multi_os_dir)
2157         multi_os_dir_len = strlen (multi_os_dir);
2158       if (multiarch_suffix)
2159         multiarch_len = strlen (multiarch_suffix);
2160       suffix_len = strlen (multi_suffix);
2161       just_suffix_len = strlen (just_multi_suffix);
2162
2163       if (path == NULL)
2164         {
2165           len = paths->max_len + extra_space + 1;
2166           len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2167           path = XNEWVEC (char, len);
2168         }
2169
2170       for (pl = paths->plist; pl != 0; pl = pl->next)
2171         {
2172           len = strlen (pl->prefix);
2173           memcpy (path, pl->prefix, len);
2174
2175           /* Look first in MACHINE/VERSION subdirectory.  */
2176           if (!skip_multi_dir)
2177             {
2178               memcpy (path + len, multi_suffix, suffix_len + 1);
2179               ret = callback (path, callback_info);
2180               if (ret)
2181                 break;
2182             }
2183
2184           /* Some paths are tried with just the machine (ie. target)
2185              subdir.  This is used for finding as, ld, etc.  */
2186           if (!skip_multi_dir
2187               && pl->require_machine_suffix == 2)
2188             {
2189               memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2190               ret = callback (path, callback_info);
2191               if (ret)
2192                 break;
2193             }
2194
2195           /* Now try the multiarch path.  */
2196           if (!skip_multi_dir
2197               && !pl->require_machine_suffix && multiarch_dir)
2198             {
2199               memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2200               ret = callback (path, callback_info);
2201               if (ret)
2202                 break;
2203             }
2204
2205           /* Now try the base path.  */
2206           if (!pl->require_machine_suffix
2207               && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2208             {
2209               const char *this_multi;
2210               size_t this_multi_len;
2211
2212               if (pl->os_multilib)
2213                 {
2214                   this_multi = multi_os_dir;
2215                   this_multi_len = multi_os_dir_len;
2216                 }
2217               else
2218                 {
2219                   this_multi = multi_dir;
2220                   this_multi_len = multi_dir_len;
2221                 }
2222
2223               if (this_multi_len)
2224                 memcpy (path + len, this_multi, this_multi_len + 1);
2225               else
2226                 path[len] = '\0';
2227
2228               ret = callback (path, callback_info);
2229               if (ret)
2230                 break;
2231             }
2232         }
2233       if (pl)
2234         break;
2235
2236       if (multi_dir == NULL && multi_os_dir == NULL)
2237         break;
2238
2239       /* Run through the paths again, this time without multilibs.
2240          Don't repeat any we have already seen.  */
2241       if (multi_dir)
2242         {
2243           free (CONST_CAST (char *, multi_dir));
2244           multi_dir = NULL;
2245           free (CONST_CAST (char *, multi_suffix));
2246           multi_suffix = machine_suffix;
2247           free (CONST_CAST (char *, just_multi_suffix));
2248           just_multi_suffix = just_machine_suffix;
2249         }
2250       else
2251         skip_multi_dir = true;
2252       if (multi_os_dir)
2253         {
2254           free (CONST_CAST (char *, multi_os_dir));
2255           multi_os_dir = NULL;
2256         }
2257       else
2258         skip_multi_os_dir = true;
2259     }
2260
2261   if (multi_dir)
2262     {
2263       free (CONST_CAST (char *, multi_dir));
2264       free (CONST_CAST (char *, multi_suffix));
2265       free (CONST_CAST (char *, just_multi_suffix));
2266     }
2267   if (multi_os_dir)
2268     free (CONST_CAST (char *, multi_os_dir));
2269   if (ret != path)
2270     free (path);
2271   return ret;
2272 }
2273
2274 /* Callback for build_search_list.  Adds path to obstack being built.  */
2275
2276 struct add_to_obstack_info {
2277   struct obstack *ob;
2278   bool check_dir;
2279   bool first_time;
2280 };
2281
2282 static void *
2283 add_to_obstack (char *path, void *data)
2284 {
2285   struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2286
2287   if (info->check_dir && !is_directory (path, false))
2288     return NULL;
2289
2290   if (!info->first_time)
2291     obstack_1grow (info->ob, PATH_SEPARATOR);
2292
2293   obstack_grow (info->ob, path, strlen (path));
2294
2295   info->first_time = false;
2296   return NULL;
2297 }
2298
2299 /* Add or change the value of an environment variable, outputting the
2300    change to standard error if in verbose mode.  */
2301 static void
2302 xputenv (const char *string)
2303 {
2304   if (verbose_flag)
2305     fnotice (stderr, "%s\n", string);
2306   putenv (CONST_CAST (char *, string));
2307 }
2308
2309 /* Build a list of search directories from PATHS.
2310    PREFIX is a string to prepend to the list.
2311    If CHECK_DIR_P is true we ensure the directory exists.
2312    If DO_MULTI is true, multilib paths are output first, then
2313    non-multilib paths.
2314    This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2315    It is also used by the --print-search-dirs flag.  */
2316
2317 static char *
2318 build_search_list (const struct path_prefix *paths, const char *prefix,
2319                    bool check_dir, bool do_multi)
2320 {
2321   struct add_to_obstack_info info;
2322
2323   info.ob = &collect_obstack;
2324   info.check_dir = check_dir;
2325   info.first_time = true;
2326
2327   obstack_grow (&collect_obstack, prefix, strlen (prefix));
2328   obstack_1grow (&collect_obstack, '=');
2329
2330   for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2331
2332   obstack_1grow (&collect_obstack, '\0');
2333   return XOBFINISH (&collect_obstack, char *);
2334 }
2335
2336 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2337    for collect.  */
2338
2339 static void
2340 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2341                       bool do_multi)
2342 {
2343   xputenv (build_search_list (paths, env_var, true, do_multi));
2344 }
2345 \f
2346 /* Check whether NAME can be accessed in MODE.  This is like access,
2347    except that it never considers directories to be executable.  */
2348
2349 static int
2350 access_check (const char *name, int mode)
2351 {
2352   if (mode == X_OK)
2353     {
2354       struct stat st;
2355
2356       if (stat (name, &st) < 0
2357           || S_ISDIR (st.st_mode))
2358         return -1;
2359     }
2360
2361   return access (name, mode);
2362 }
2363
2364 /* Callback for find_a_file.  Appends the file name to the directory
2365    path.  If the resulting file exists in the right mode, return the
2366    full pathname to the file.  */
2367
2368 struct file_at_path_info {
2369   const char *name;
2370   const char *suffix;
2371   int name_len;
2372   int suffix_len;
2373   int mode;
2374 };
2375
2376 static void *
2377 file_at_path (char *path, void *data)
2378 {
2379   struct file_at_path_info *info = (struct file_at_path_info *) data;
2380   size_t len = strlen (path);
2381
2382   memcpy (path + len, info->name, info->name_len);
2383   len += info->name_len;
2384
2385   /* Some systems have a suffix for executable files.
2386      So try appending that first.  */
2387   if (info->suffix_len)
2388     {
2389       memcpy (path + len, info->suffix, info->suffix_len + 1);
2390       if (access_check (path, info->mode) == 0)
2391         return path;
2392     }
2393
2394   path[len] = '\0';
2395   if (access_check (path, info->mode) == 0)
2396     return path;
2397
2398   return NULL;
2399 }
2400
2401 /* Search for NAME using the prefix list PREFIXES.  MODE is passed to
2402    access to check permissions.  If DO_MULTI is true, search multilib
2403    paths then non-multilib paths, otherwise do not search multilib paths.
2404    Return 0 if not found, otherwise return its name, allocated with malloc.  */
2405
2406 static char *
2407 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2408              bool do_multi)
2409 {
2410   struct file_at_path_info info;
2411
2412 #ifdef DEFAULT_ASSEMBLER
2413   if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2414     return xstrdup (DEFAULT_ASSEMBLER);
2415 #endif
2416
2417 #ifdef DEFAULT_LINKER
2418   if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2419     return xstrdup (DEFAULT_LINKER);
2420 #endif
2421
2422   /* Determine the filename to execute (special case for absolute paths).  */
2423
2424   if (IS_ABSOLUTE_PATH (name))
2425     {
2426       if (access (name, mode) == 0)
2427         return xstrdup (name);
2428
2429       return NULL;
2430     }
2431
2432   info.name = name;
2433   info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2434   info.name_len = strlen (info.name);
2435   info.suffix_len = strlen (info.suffix);
2436   info.mode = mode;
2437
2438   return (char*) for_each_path (pprefix, do_multi,
2439                                 info.name_len + info.suffix_len,
2440                                 file_at_path, &info);
2441 }
2442
2443 /* Ranking of prefixes in the sort list. -B prefixes are put before
2444    all others.  */
2445
2446 enum path_prefix_priority
2447 {
2448   PREFIX_PRIORITY_B_OPT,
2449   PREFIX_PRIORITY_LAST
2450 };
2451
2452 /* Add an entry for PREFIX in PLIST.  The PLIST is kept in ascending
2453    order according to PRIORITY.  Within each PRIORITY, new entries are
2454    appended.
2455
2456    If WARN is nonzero, we will warn if no file is found
2457    through this prefix.  WARN should point to an int
2458    which will be set to 1 if this entry is used.
2459
2460    COMPONENT is the value to be passed to update_path.
2461
2462    REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2463    the complete value of machine_suffix.
2464    2 means try both machine_suffix and just_machine_suffix.  */
2465
2466 static void
2467 add_prefix (struct path_prefix *pprefix, const char *prefix,
2468             const char *component, /* enum prefix_priority */ int priority,
2469             int require_machine_suffix, int os_multilib)
2470 {
2471   struct prefix_list *pl, **prev;
2472   int len;
2473
2474   for (prev = &pprefix->plist;
2475        (*prev) != NULL && (*prev)->priority <= priority;
2476        prev = &(*prev)->next)
2477     ;
2478
2479   /* Keep track of the longest prefix.  */
2480
2481   prefix = update_path (prefix, component);
2482   len = strlen (prefix);
2483   if (len > pprefix->max_len)
2484     pprefix->max_len = len;
2485
2486   pl = XNEW (struct prefix_list);
2487   pl->prefix = prefix;
2488   pl->require_machine_suffix = require_machine_suffix;
2489   pl->priority = priority;
2490   pl->os_multilib = os_multilib;
2491
2492   /* Insert after PREV.  */
2493   pl->next = (*prev);
2494   (*prev) = pl;
2495 }
2496
2497 /* Same as add_prefix, but prepending target_system_root to prefix.  */
2498 /* The target_system_root prefix has been relocated by gcc_exec_prefix.  */
2499 static void
2500 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2501                       const char *component,
2502                       /* enum prefix_priority */ int priority,
2503                       int require_machine_suffix, int os_multilib)
2504 {
2505   if (!IS_ABSOLUTE_PATH (prefix))
2506     fatal_error ("system path %qs is not absolute", prefix);
2507
2508   if (target_system_root)
2509     {
2510       char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2511       size_t sysroot_len = strlen (target_system_root);
2512
2513       if (sysroot_len > 0
2514           && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2515         sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2516
2517       if (target_sysroot_suffix)
2518         prefix = concat (sysroot_no_trailing_dir_separator,
2519                          target_sysroot_suffix, prefix, NULL);
2520       else
2521         prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2522
2523       free (sysroot_no_trailing_dir_separator);
2524
2525       /* We have to override this because GCC's notion of sysroot
2526          moves along with GCC.  */
2527       component = "GCC";
2528     }
2529
2530   add_prefix (pprefix, prefix, component, priority,
2531               require_machine_suffix, os_multilib);
2532 }
2533 \f
2534 /* Execute the command specified by the arguments on the current line of spec.
2535    When using pipes, this includes several piped-together commands
2536    with `|' between them.
2537
2538    Return 0 if successful, -1 if failed.  */
2539
2540 static int
2541 execute (void)
2542 {
2543   int i;
2544   int n_commands;               /* # of command.  */
2545   char *string;
2546   struct pex_obj *pex;
2547   struct command
2548   {
2549     const char *prog;           /* program name.  */
2550     const char **argv;          /* vector of args.  */
2551   };
2552   const char *arg;
2553
2554   struct command *commands;     /* each command buffer with above info.  */
2555
2556   gcc_assert (!processing_spec_function);
2557
2558   if (wrapper_string)
2559     {
2560       string = find_a_file (&exec_prefixes,
2561                             argbuf[0], X_OK, false);
2562       if (string)
2563         argbuf[0] = string;
2564       insert_wrapper (wrapper_string);
2565     }
2566
2567   /* Count # of piped commands.  */
2568   for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2569     if (strcmp (arg, "|") == 0)
2570       n_commands++;
2571
2572   /* Get storage for each command.  */
2573   commands = (struct command *) alloca (n_commands * sizeof (struct command));
2574
2575   /* Split argbuf into its separate piped processes,
2576      and record info about each one.
2577      Also search for the programs that are to be run.  */
2578
2579   argbuf.safe_push (0);
2580
2581   commands[0].prog = argbuf[0]; /* first command.  */
2582   commands[0].argv = argbuf.address ();
2583
2584   if (!wrapper_string)
2585     {
2586       string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2587       commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2588     }
2589
2590   for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2591     if (arg && strcmp (arg, "|") == 0)
2592       {                         /* each command.  */
2593 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2594         fatal_error ("-pipe not supported");
2595 #endif
2596         argbuf[i] = 0; /* Termination of
2597                                                      command args.  */
2598         commands[n_commands].prog = argbuf[i + 1];
2599         commands[n_commands].argv
2600           = &(argbuf.address ())[i + 1];
2601         string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2602                               X_OK, false);
2603         if (string)
2604           commands[n_commands].argv[0] = string;
2605         n_commands++;
2606       }
2607
2608   /* If -v, print what we are about to do, and maybe query.  */
2609
2610   if (verbose_flag)
2611     {
2612       /* For help listings, put a blank line between sub-processes.  */
2613       if (print_help_list)
2614         fputc ('\n', stderr);
2615
2616       /* Print each piped command as a separate line.  */
2617       for (i = 0; i < n_commands; i++)
2618         {
2619           const char *const *j;
2620
2621           if (verbose_only_flag)
2622             {
2623               for (j = commands[i].argv; *j; j++)
2624                 {
2625                   const char *p;
2626                   for (p = *j; *p; ++p)
2627                     if (!ISALNUM ((unsigned char) *p)
2628                         && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2629                       break;
2630                   if (*p || !*j)
2631                     {
2632                       fprintf (stderr, " \"");
2633                       for (p = *j; *p; ++p)
2634                         {
2635                           if (*p == '"' || *p == '\\' || *p == '$')
2636                             fputc ('\\', stderr);
2637                           fputc (*p, stderr);
2638                         }
2639                       fputc ('"', stderr);
2640                     }
2641                   /* If it's empty, print "".  */
2642                   else if (!**j)
2643                     fprintf (stderr, " \"\"");
2644                   else
2645                     fprintf (stderr, " %s", *j);
2646                 }
2647             }
2648           else
2649             for (j = commands[i].argv; *j; j++)
2650               /* If it's empty, print "".  */
2651               if (!**j)
2652                 fprintf (stderr, " \"\"");
2653               else
2654                 fprintf (stderr, " %s", *j);
2655
2656           /* Print a pipe symbol after all but the last command.  */
2657           if (i + 1 != n_commands)
2658             fprintf (stderr, " |");
2659           fprintf (stderr, "\n");
2660         }
2661       fflush (stderr);
2662       if (verbose_only_flag != 0)
2663         {
2664           /* verbose_only_flag should act as if the spec was
2665              executed, so increment execution_count before
2666              returning.  This prevents spurious warnings about
2667              unused linker input files, etc.  */
2668           execution_count++;
2669           return 0;
2670         }
2671 #ifdef DEBUG
2672       fnotice (stderr, "\nGo ahead? (y or n) ");
2673       fflush (stderr);
2674       i = getchar ();
2675       if (i != '\n')
2676         while (getchar () != '\n')
2677           ;
2678
2679       if (i != 'y' && i != 'Y')
2680         return 0;
2681 #endif /* DEBUG */
2682     }
2683
2684 #ifdef ENABLE_VALGRIND_CHECKING
2685   /* Run the each command through valgrind.  To simplify prepending the
2686      path to valgrind and the option "-q" (for quiet operation unless
2687      something triggers), we allocate a separate argv array.  */
2688
2689   for (i = 0; i < n_commands; i++)
2690     {
2691       const char **argv;
2692       int argc;
2693       int j;
2694
2695       for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2696         ;
2697
2698       argv = XALLOCAVEC (const char *, argc + 3);
2699
2700       argv[0] = VALGRIND_PATH;
2701       argv[1] = "-q";
2702       for (j = 2; j < argc + 2; j++)
2703         argv[j] = commands[i].argv[j - 2];
2704       argv[j] = NULL;
2705
2706       commands[i].argv = argv;
2707       commands[i].prog = argv[0];
2708     }
2709 #endif
2710
2711   /* Run each piped subprocess.  */
2712
2713   pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2714                                    ? PEX_RECORD_TIMES : 0),
2715                   progname, temp_filename);
2716   if (pex == NULL)
2717     fatal_error ("pex_init failed: %m");
2718
2719   for (i = 0; i < n_commands; i++)
2720     {
2721       const char *errmsg;
2722       int err;
2723       const char *string = commands[i].argv[0];
2724
2725       errmsg = pex_run (pex,
2726                         ((i + 1 == n_commands ? PEX_LAST : 0)
2727                          | (string == commands[i].prog ? PEX_SEARCH : 0)),
2728                         string, CONST_CAST (char **, commands[i].argv),
2729                         NULL, NULL, &err);
2730       if (errmsg != NULL)
2731         {
2732           if (err == 0)
2733             fatal_error (errmsg);
2734           else
2735             {
2736               errno = err;
2737               pfatal_with_name (errmsg);
2738             }
2739         }
2740
2741       if (string != commands[i].prog)
2742         free (CONST_CAST (char *, string));
2743     }
2744
2745   execution_count++;
2746
2747   /* Wait for all the subprocesses to finish.  */
2748
2749   {
2750     int *statuses;
2751     struct pex_time *times = NULL;
2752     int ret_code = 0;
2753
2754     statuses = (int *) alloca (n_commands * sizeof (int));
2755     if (!pex_get_status (pex, n_commands, statuses))
2756       fatal_error ("failed to get exit status: %m");
2757
2758     if (report_times || report_times_to_file)
2759       {
2760         times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2761         if (!pex_get_times (pex, n_commands, times))
2762           fatal_error ("failed to get process times: %m");
2763       }
2764
2765     pex_free (pex);
2766
2767     for (i = 0; i < n_commands; ++i)
2768       {
2769         int status = statuses[i];
2770
2771         if (WIFSIGNALED (status))
2772           {
2773 #ifdef SIGPIPE
2774             /* SIGPIPE is a special case.  It happens in -pipe mode
2775                when the compiler dies before the preprocessor is done,
2776                or the assembler dies before the compiler is done.
2777                There's generally been an error already, and this is
2778                just fallout.  So don't generate another error unless
2779                we would otherwise have succeeded.  */
2780             if (WTERMSIG (status) == SIGPIPE
2781                 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2782               {
2783                 signal_count++;
2784                 ret_code = -1;
2785               }
2786             else
2787 #endif
2788               internal_error ("%s (program %s)",
2789                               strsignal (WTERMSIG (status)), commands[i].prog);
2790           }
2791         else if (WIFEXITED (status)
2792                  && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2793           {
2794             if (WEXITSTATUS (status) > greatest_status)
2795               greatest_status = WEXITSTATUS (status);
2796             ret_code = -1;
2797           }
2798
2799         if (report_times || report_times_to_file)
2800           {
2801             struct pex_time *pt = &times[i];
2802             double ut, st;
2803
2804             ut = ((double) pt->user_seconds
2805                   + (double) pt->user_microseconds / 1.0e6);
2806             st = ((double) pt->system_seconds
2807                   + (double) pt->system_microseconds / 1.0e6);
2808
2809             if (ut + st != 0)
2810               {
2811                 if (report_times)
2812                   fnotice (stderr, "# %s %.2f %.2f\n",
2813                            commands[i].prog, ut, st);
2814
2815                 if (report_times_to_file)
2816                   {
2817                     int c = 0;
2818                     const char *const *j;
2819
2820                     fprintf (report_times_to_file, "%g %g", ut, st);
2821
2822                     for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
2823                       {
2824                         const char *p;
2825                         for (p = *j; *p; ++p)
2826                           if (*p == '"' || *p == '\\' || *p == '$'
2827                               || ISSPACE (*p))
2828                             break;
2829
2830                         if (*p)
2831                           {
2832                             fprintf (report_times_to_file, " \"");
2833                             for (p = *j; *p; ++p)
2834                               {
2835                                 if (*p == '"' || *p == '\\' || *p == '$')
2836                                   fputc ('\\', report_times_to_file);
2837                                 fputc (*p, report_times_to_file);
2838                               }
2839                             fputc ('"', report_times_to_file);
2840                           }
2841                         else
2842                           fprintf (report_times_to_file, " %s", *j);
2843                       }
2844
2845                     fputc ('\n', report_times_to_file);
2846                   }
2847               }
2848           }
2849       }
2850
2851     return ret_code;
2852   }
2853 }
2854 \f
2855 /* Find all the switches given to us
2856    and make a vector describing them.
2857    The elements of the vector are strings, one per switch given.
2858    If a switch uses following arguments, then the `part1' field
2859    is the switch itself and the `args' field
2860    is a null-terminated vector containing the following arguments.
2861    Bits in the `live_cond' field are:
2862    SWITCH_LIVE to indicate this switch is true in a conditional spec.
2863    SWITCH_FALSE to indicate this switch is overridden by a later switch.
2864    SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
2865    SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
2866    in all do_spec calls afterwards.  Used for %<S from self specs.
2867    The `validated' field is nonzero if any spec has looked at this switch;
2868    if it remains zero at the end of the run, it must be meaningless.  */
2869
2870 #define SWITCH_LIVE                     (1 << 0)
2871 #define SWITCH_FALSE                    (1 << 1)
2872 #define SWITCH_IGNORE                   (1 << 2)
2873 #define SWITCH_IGNORE_PERMANENTLY       (1 << 3)
2874 #define SWITCH_KEEP_FOR_GCC             (1 << 4)
2875
2876 struct switchstr
2877 {
2878   const char *part1;
2879   const char **args;
2880   unsigned int live_cond;
2881   bool known;
2882   bool validated;
2883   bool ordering;
2884 };
2885
2886 static struct switchstr *switches;
2887
2888 static int n_switches;
2889
2890 static int n_switches_alloc;
2891
2892 /* Set to zero if -fcompare-debug is disabled, positive if it's
2893    enabled and we're running the first compilation, negative if it's
2894    enabled and we're running the second compilation.  For most of the
2895    time, it's in the range -1..1, but it can be temporarily set to 2
2896    or 3 to indicate that the -fcompare-debug flags didn't come from
2897    the command-line, but rather from the GCC_COMPARE_DEBUG environment
2898    variable, until a synthesized -fcompare-debug flag is added to the
2899    command line.  */
2900 int compare_debug;
2901
2902 /* Set to nonzero if we've seen the -fcompare-debug-second flag.  */
2903 int compare_debug_second;
2904
2905 /* Set to the flags that should be passed to the second compilation in
2906    a -fcompare-debug compilation.  */
2907 const char *compare_debug_opt;
2908
2909 static struct switchstr *switches_debug_check[2];
2910
2911 static int n_switches_debug_check[2];
2912
2913 static int n_switches_alloc_debug_check[2];
2914
2915 static char *debug_check_temp_file[2];
2916
2917 /* Language is one of three things:
2918
2919    1) The name of a real programming language.
2920    2) NULL, indicating that no one has figured out
2921    what it is yet.
2922    3) '*', indicating that the file should be passed
2923    to the linker.  */
2924 struct infile
2925 {
2926   const char *name;
2927   const char *language;
2928   struct compiler *incompiler;
2929   bool compiled;
2930   bool preprocessed;
2931 };
2932
2933 /* Also a vector of input files specified.  */
2934
2935 static struct infile *infiles;
2936
2937 int n_infiles;
2938
2939 static int n_infiles_alloc;
2940
2941 /* True if multiple input files are being compiled to a single
2942    assembly file.  */
2943
2944 static bool combine_inputs;
2945
2946 /* This counts the number of libraries added by lang_specific_driver, so that
2947    we can tell if there were any user supplied any files or libraries.  */
2948
2949 static int added_libraries;
2950
2951 /* And a vector of corresponding output files is made up later.  */
2952
2953 const char **outfiles;
2954 \f
2955 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2956
2957 /* Convert NAME to a new name if it is the standard suffix.  DO_EXE
2958    is true if we should look for an executable suffix.  DO_OBJ
2959    is true if we should look for an object suffix.  */
2960
2961 static const char *
2962 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
2963                   int do_obj ATTRIBUTE_UNUSED)
2964 {
2965 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2966   int i;
2967 #endif
2968   int len;
2969
2970   if (name == NULL)
2971     return NULL;
2972
2973   len = strlen (name);
2974
2975 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2976   /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj".  */
2977   if (do_obj && len > 2
2978       && name[len - 2] == '.'
2979       && name[len - 1] == 'o')
2980     {
2981       obstack_grow (&obstack, name, len - 2);
2982       obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
2983       name = XOBFINISH (&obstack, const char *);
2984     }
2985 #endif
2986
2987 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2988   /* If there is no filetype, make it the executable suffix (which includes
2989      the ".").  But don't get confused if we have just "-o".  */
2990   if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
2991     return name;
2992
2993   for (i = len - 1; i >= 0; i--)
2994     if (IS_DIR_SEPARATOR (name[i]))
2995       break;
2996
2997   for (i++; i < len; i++)
2998     if (name[i] == '.')
2999       return name;
3000
3001   obstack_grow (&obstack, name, len);
3002   obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3003                  strlen (TARGET_EXECUTABLE_SUFFIX));
3004   name = XOBFINISH (&obstack, const char *);
3005 #endif
3006
3007   return name;
3008 }
3009 #endif
3010 \f
3011 /* Display the command line switches accepted by gcc.  */
3012 static void
3013 display_help (void)
3014 {
3015   printf (_("Usage: %s [options] file...\n"), progname);
3016   fputs (_("Options:\n"), stdout);
3017
3018   fputs (_("  -pass-exit-codes         Exit with highest error code from a phase\n"), stdout);
3019   fputs (_("  --help                   Display this information\n"), stdout);
3020   fputs (_("  --target-help            Display target specific command line options\n"), stdout);
3021   fputs (_("  --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
3022   fputs (_("                           Display specific types of command line options\n"), stdout);
3023   if (! verbose_flag)
3024     fputs (_("  (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3025   fputs (_("  --version                Display compiler version information\n"), stdout);
3026   fputs (_("  -dumpspecs               Display all of the built in spec strings\n"), stdout);
3027   fputs (_("  -dumpversion             Display the version of the compiler\n"), stdout);
3028   fputs (_("  -dumpmachine             Display the compiler's target processor\n"), stdout);
3029   fputs (_("  -print-search-dirs       Display the directories in the compiler's search path\n"), stdout);
3030   fputs (_("  -print-libgcc-file-name  Display the name of the compiler's companion library\n"), stdout);
3031   fputs (_("  -print-file-name=<lib>   Display the full path to library <lib>\n"), stdout);
3032   fputs (_("  -print-prog-name=<prog>  Display the full path to compiler component <prog>\n"), stdout);
3033   fputs (_("\
3034   -print-multiarch         Display the target's normalized GNU triplet, used as\n\
3035                            a component in the library path\n"), stdout);
3036   fputs (_("  -print-multi-directory   Display the root directory for versions of libgcc\n"), stdout);
3037   fputs (_("\
3038   -print-multi-lib         Display the mapping between command line options and\n\
3039                            multiple library search directories\n"), stdout);
3040   fputs (_("  -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3041   fputs (_("  -print-sysroot           Display the target libraries directory\n"), stdout);
3042   fputs (_("  -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
3043   fputs (_("  -Wa,<options>            Pass comma-separated <options> on to the assembler\n"), stdout);
3044   fputs (_("  -Wp,<options>            Pass comma-separated <options> on to the preprocessor\n"), stdout);
3045   fputs (_("  -Wl,<options>            Pass comma-separated <options> on to the linker\n"), stdout);
3046   fputs (_("  -Xassembler <arg>        Pass <arg> on to the assembler\n"), stdout);
3047   fputs (_("  -Xpreprocessor <arg>     Pass <arg> on to the preprocessor\n"), stdout);
3048   fputs (_("  -Xlinker <arg>           Pass <arg> on to the linker\n"), stdout);
3049   fputs (_("  -save-temps              Do not delete intermediate files\n"), stdout);
3050   fputs (_("  -save-temps=<arg>        Do not delete intermediate files\n"), stdout);
3051   fputs (_("\
3052   -no-canonical-prefixes   Do not canonicalize paths when building relative\n\
3053                            prefixes to other gcc components\n"), stdout);
3054   fputs (_("  -pipe                    Use pipes rather than intermediate files\n"), stdout);
3055   fputs (_("  -time                    Time the execution of each subprocess\n"), stdout);
3056   fputs (_("  -specs=<file>            Override built-in specs with the contents of <file>\n"), stdout);
3057   fputs (_("  -std=<standard>          Assume that the input sources are for <standard>\n"), stdout);
3058   fputs (_("\
3059   --sysroot=<directory>    Use <directory> as the root directory for headers\n\
3060                            and libraries\n"), stdout);
3061   fputs (_("  -B <directory>           Add <directory> to the compiler's search paths\n"), stdout);
3062   fputs (_("  -v                       Display the programs invoked by the compiler\n"), stdout);
3063   fputs (_("  -###                     Like -v but options quoted and commands not executed\n"), stdout);
3064   fputs (_("  -E                       Preprocess only; do not compile, assemble or link\n"), stdout);
3065   fputs (_("  -S                       Compile only; do not assemble or link\n"), stdout);
3066   fputs (_("  -c                       Compile and assemble, but do not link\n"), stdout);
3067   fputs (_("  -o <file>                Place the output into <file>\n"), stdout);
3068   fputs (_("  -pie                     Create a position independent executable\n"), stdout);
3069   fputs (_("  -shared                  Create a shared library\n"), stdout);
3070   fputs (_("\
3071   -x <language>            Specify the language of the following input files\n\
3072                            Permissible languages include: c c++ assembler none\n\
3073                            'none' means revert to the default behavior of\n\
3074                            guessing the language based on the file's extension\n\
3075 "), stdout);
3076
3077   printf (_("\
3078 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3079  passed on to the various sub-processes invoked by %s.  In order to pass\n\
3080  other options on to these processes the -W<letter> options must be used.\n\
3081 "), progname);
3082
3083   /* The rest of the options are displayed by invocations of the various
3084      sub-processes.  */
3085 }
3086
3087 static void
3088 add_preprocessor_option (const char *option, int len)
3089 {
3090   preprocessor_options.safe_push (save_string (option, len));
3091 }
3092
3093 static void
3094 add_assembler_option (const char *option, int len)
3095 {
3096   assembler_options.safe_push (save_string (option, len));
3097 }
3098
3099 static void
3100 add_linker_option (const char *option, int len)
3101 {
3102   linker_options.safe_push (save_string (option, len));
3103 }
3104 \f
3105 /* Allocate space for an input file in infiles.  */
3106
3107 static void
3108 alloc_infile (void)
3109 {
3110   if (n_infiles_alloc == 0)
3111     {
3112       n_infiles_alloc = 16;
3113       infiles = XNEWVEC (struct infile, n_infiles_alloc);
3114     }
3115   else if (n_infiles_alloc == n_infiles)
3116     {
3117       n_infiles_alloc *= 2;
3118       infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3119     }
3120 }
3121
3122 /* Store an input file with the given NAME and LANGUAGE in
3123    infiles.  */
3124
3125 static void
3126 add_infile (const char *name, const char *language)
3127 {
3128   alloc_infile ();
3129   infiles[n_infiles].name = name;
3130   infiles[n_infiles++].language = language;
3131 }
3132
3133 /* Allocate space for a switch in switches.  */
3134
3135 static void
3136 alloc_switch (void)
3137 {
3138   if (n_switches_alloc == 0)
3139     {
3140       n_switches_alloc = 16;
3141       switches = XNEWVEC (struct switchstr, n_switches_alloc);
3142     }
3143   else if (n_switches_alloc == n_switches)
3144     {
3145       n_switches_alloc *= 2;
3146       switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3147     }
3148 }
3149
3150 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3151    as validated if VALIDATED and KNOWN if it is an internal switch.  */
3152
3153 static void
3154 save_switch (const char *opt, size_t n_args, const char *const *args,
3155              bool validated, bool known)
3156 {
3157   alloc_switch ();
3158   switches[n_switches].part1 = opt + 1;
3159   if (n_args == 0)
3160     switches[n_switches].args = 0;
3161   else
3162     {
3163       switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3164       memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3165       switches[n_switches].args[n_args] = NULL;
3166     }
3167
3168   switches[n_switches].live_cond = 0;
3169   switches[n_switches].validated = validated;
3170   switches[n_switches].known = known;
3171   switches[n_switches].ordering = 0;
3172   n_switches++;
3173 }
3174
3175 /* Handle an option DECODED that is unknown to the option-processing
3176    machinery.  */
3177
3178 static bool
3179 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3180 {
3181   const char *opt = decoded->arg;
3182   if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3183       && !(decoded->errors & CL_ERR_NEGATIVE))
3184     {
3185       /* Leave unknown -Wno-* options for the compiler proper, to be
3186          diagnosed only if there are warnings.  */
3187       save_switch (decoded->canonical_option[0],
3188                    decoded->canonical_option_num_elements - 1,
3189                    &decoded->canonical_option[1], false, true);
3190       return false;
3191     }
3192   if (decoded->opt_index == OPT_SPECIAL_unknown)
3193     {
3194       /* Give it a chance to define it a a spec file.  */
3195       save_switch (decoded->canonical_option[0],
3196                    decoded->canonical_option_num_elements - 1,
3197                    &decoded->canonical_option[1], false, false);
3198       return false;
3199     }
3200   else
3201     return true;
3202 }
3203
3204 /* Handle an option DECODED that is not marked as CL_DRIVER.
3205    LANG_MASK will always be CL_DRIVER.  */
3206
3207 static void
3208 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3209                             unsigned int lang_mask ATTRIBUTE_UNUSED)
3210 {
3211   /* At this point, non-driver options are accepted (and expected to
3212      be passed down by specs) unless marked to be rejected by the
3213      driver.  Options to be rejected by the driver but accepted by the
3214      compilers proper are treated just like completely unknown
3215      options.  */
3216   const struct cl_option *option = &cl_options[decoded->opt_index];
3217
3218   if (option->cl_reject_driver)
3219     error ("unrecognized command line option %qs",
3220            decoded->orig_option_with_args_text);
3221   else
3222     save_switch (decoded->canonical_option[0],
3223                  decoded->canonical_option_num_elements - 1,
3224                  &decoded->canonical_option[1], false, true);
3225 }
3226
3227 static const char *spec_lang = 0;
3228 static int last_language_n_infiles;
3229
3230 /* Handle a driver option; arguments and return value as for
3231    handle_option.  */
3232
3233 static bool
3234 driver_handle_option (struct gcc_options *opts,
3235                       struct gcc_options *opts_set,
3236                       const struct cl_decoded_option *decoded,
3237                       unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3238                       location_t loc,
3239                       const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3240                       diagnostic_context *dc)
3241 {
3242   size_t opt_index = decoded->opt_index;
3243   const char *arg = decoded->arg;
3244   const char *compare_debug_replacement_opt;
3245   int value = decoded->value;
3246   bool validated = false;
3247   bool do_save = true;
3248
3249   gcc_assert (opts == &global_options);
3250   gcc_assert (opts_set == &global_options_set);
3251   gcc_assert (kind == DK_UNSPECIFIED);
3252   gcc_assert (loc == UNKNOWN_LOCATION);
3253   gcc_assert (dc == global_dc);
3254
3255   switch (opt_index)
3256     {
3257     case OPT_dumpspecs:
3258       {
3259         struct spec_list *sl;
3260         init_spec ();
3261         for (sl = specs; sl; sl = sl->next)
3262           printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3263         if (link_command_spec)
3264           printf ("*link_command:\n%s\n\n", link_command_spec);
3265         exit (0);
3266       }
3267
3268     case OPT_dumpversion:
3269       printf ("%s\n", spec_version);
3270       exit (0);
3271
3272     case OPT_dumpmachine:
3273       printf ("%s\n", spec_machine);
3274       exit (0);
3275
3276     case OPT__version:
3277       print_version = 1;
3278
3279       /* CPP driver cannot obtain switch from cc1_options.  */
3280       if (is_cpp_driver)
3281         add_preprocessor_option ("--version", strlen ("--version"));
3282       add_assembler_option ("--version", strlen ("--version"));
3283       add_linker_option ("--version", strlen ("--version"));
3284       break;
3285
3286     case OPT__help:
3287       print_help_list = 1;
3288
3289       /* CPP driver cannot obtain switch from cc1_options.  */
3290       if (is_cpp_driver)
3291         add_preprocessor_option ("--help", 6);
3292       add_assembler_option ("--help", 6);
3293       add_linker_option ("--help", 6);
3294       break;
3295
3296     case OPT__help_:
3297       print_subprocess_help = 2;
3298       break;
3299
3300     case OPT__target_help:
3301       print_subprocess_help = 1;
3302
3303       /* CPP driver cannot obtain switch from cc1_options.  */
3304       if (is_cpp_driver)
3305         add_preprocessor_option ("--target-help", 13);
3306       add_assembler_option ("--target-help", 13);
3307       add_linker_option ("--target-help", 13);
3308       break;
3309
3310     case OPT__no_sysroot_suffix:
3311     case OPT_pass_exit_codes:
3312     case OPT_print_search_dirs:
3313     case OPT_print_file_name_:
3314     case OPT_print_prog_name_:
3315     case OPT_print_multi_lib:
3316     case OPT_print_multi_directory:
3317     case OPT_print_sysroot:
3318     case OPT_print_multi_os_directory:
3319     case OPT_print_multiarch:
3320     case OPT_print_sysroot_headers_suffix:
3321     case OPT_time:
3322     case OPT_wrapper:
3323       /* These options set the variables specified in common.opt
3324          automatically, and do not need to be saved for spec
3325          processing.  */
3326       do_save = false;
3327       break;
3328
3329     case OPT_print_libgcc_file_name:
3330       print_file_name = "libgcc.a";
3331       do_save = false;
3332       break;
3333
3334     case OPT_fcompare_debug_second:
3335       compare_debug_second = 1;
3336       break;
3337
3338     case OPT_fcompare_debug:
3339       switch (value)
3340         {
3341         case 0:
3342           compare_debug_replacement_opt = "-fcompare-debug=";
3343           arg = "";
3344           goto compare_debug_with_arg;
3345
3346         case 1:
3347           compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3348           arg = "-gtoggle";
3349           goto compare_debug_with_arg;
3350
3351         default:
3352           gcc_unreachable ();
3353         }
3354       break;
3355
3356     case OPT_fcompare_debug_:
3357       compare_debug_replacement_opt = decoded->canonical_option[0];
3358     compare_debug_with_arg:
3359       gcc_assert (decoded->canonical_option_num_elements == 1);
3360       gcc_assert (arg != NULL);
3361       if (*arg)
3362         compare_debug = 1;
3363       else
3364         compare_debug = -1;
3365       if (compare_debug < 0)
3366         compare_debug_opt = NULL;
3367       else
3368         compare_debug_opt = arg;
3369       save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3370       return true;
3371
3372     case OPT_Wa_:
3373       {
3374         int prev, j;
3375         /* Pass the rest of this option to the assembler.  */
3376
3377         /* Split the argument at commas.  */
3378         prev = 0;
3379         for (j = 0; arg[j]; j++)
3380           if (arg[j] == ',')
3381             {
3382               add_assembler_option (arg + prev, j - prev);
3383               prev = j + 1;
3384             }
3385
3386         /* Record the part after the last comma.  */
3387         add_assembler_option (arg + prev, j - prev);
3388       }
3389       do_save = false;
3390       break;
3391
3392     case OPT_Wp_:
3393       {
3394         int prev, j;
3395         /* Pass the rest of this option to the preprocessor.  */
3396
3397         /* Split the argument at commas.  */
3398         prev = 0;
3399         for (j = 0; arg[j]; j++)
3400           if (arg[j] == ',')
3401             {
3402               add_preprocessor_option (arg + prev, j - prev);
3403               prev = j + 1;
3404             }
3405
3406         /* Record the part after the last comma.  */
3407         add_preprocessor_option (arg + prev, j - prev);
3408       }
3409       do_save = false;
3410       break;
3411
3412     case OPT_Wl_:
3413       {
3414         int prev, j;
3415         /* Split the argument at commas.  */
3416         prev = 0;
3417         for (j = 0; arg[j]; j++)
3418           if (arg[j] == ',')
3419             {
3420               add_infile (save_string (arg + prev, j - prev), "*");
3421               prev = j + 1;
3422             }
3423         /* Record the part after the last comma.  */
3424         add_infile (arg + prev, "*");
3425       }
3426       do_save = false;
3427       break;
3428
3429     case OPT_Xlinker:
3430       add_infile (arg, "*");
3431       do_save = false;
3432       break;
3433
3434     case OPT_Xpreprocessor:
3435       add_preprocessor_option (arg, strlen (arg));
3436       do_save = false;
3437       break;
3438
3439     case OPT_Xassembler:
3440       add_assembler_option (arg, strlen (arg));
3441       do_save = false;
3442       break;
3443
3444     case OPT_l:
3445       /* POSIX allows separation of -l and the lib arg; canonicalize
3446          by concatenating -l with its arg */
3447       add_infile (concat ("-l", arg, NULL), "*");
3448       do_save = false;
3449       break;
3450
3451     case OPT_L:
3452       /* Similarly, canonicalize -L for linkers that may not accept
3453          separate arguments.  */
3454       save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3455       return true;
3456
3457     case OPT_F:
3458       /* Likewise -F.  */
3459       save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3460       return true;
3461
3462     case OPT_save_temps:
3463       save_temps_flag = SAVE_TEMPS_CWD;
3464       validated = true;
3465       break;
3466
3467     case OPT_save_temps_:
3468       if (strcmp (arg, "cwd") == 0)
3469         save_temps_flag = SAVE_TEMPS_CWD;
3470       else if (strcmp (arg, "obj") == 0
3471                || strcmp (arg, "object") == 0)
3472         save_temps_flag = SAVE_TEMPS_OBJ;
3473       else
3474         fatal_error ("%qs is an unknown -save-temps option",
3475                      decoded->orig_option_with_args_text);
3476       break;
3477
3478     case OPT_no_canonical_prefixes:
3479       /* Already handled as a special case, so ignored here.  */
3480       do_save = false;
3481       break;
3482
3483     case OPT_pipe:
3484       validated = true;
3485       /* These options set the variables specified in common.opt
3486          automatically, but do need to be saved for spec
3487          processing.  */
3488       break;
3489
3490     case OPT_specs_:
3491       {
3492         struct user_specs *user = XNEW (struct user_specs);
3493
3494         user->next = (struct user_specs *) 0;
3495         user->filename = arg;
3496         if (user_specs_tail)
3497           user_specs_tail->next = user;
3498         else
3499           user_specs_head = user;
3500         user_specs_tail = user;
3501       }
3502       validated = true;
3503       break;
3504
3505     case OPT__sysroot_:
3506       target_system_root = arg;
3507       target_system_root_changed = 1;
3508       do_save = false;
3509       break;
3510
3511     case OPT_time_:
3512       if (report_times_to_file)
3513         fclose (report_times_to_file);
3514       report_times_to_file = fopen (arg, "a");
3515       do_save = false;
3516       break;
3517
3518     case OPT____:
3519       /* "-###"
3520          This is similar to -v except that there is no execution
3521          of the commands and the echoed arguments are quoted.  It
3522          is intended for use in shell scripts to capture the
3523          driver-generated command line.  */
3524       verbose_only_flag++;
3525       verbose_flag = 1;
3526       do_save = false;
3527       break;
3528
3529     case OPT_B:
3530       {
3531         size_t len = strlen (arg);
3532
3533         /* Catch the case where the user has forgotten to append a
3534            directory separator to the path.  Note, they may be using
3535            -B to add an executable name prefix, eg "i386-elf-", in
3536            order to distinguish between multiple installations of
3537            GCC in the same directory.  Hence we must check to see
3538            if appending a directory separator actually makes a
3539            valid directory name.  */
3540         if (!IS_DIR_SEPARATOR (arg[len - 1])
3541             && is_directory (arg, false))
3542           {
3543             char *tmp = XNEWVEC (char, len + 2);
3544             strcpy (tmp, arg);
3545             tmp[len] = DIR_SEPARATOR;
3546             tmp[++len] = 0;
3547             arg = tmp;
3548           }
3549
3550         add_prefix (&exec_prefixes, arg, NULL,
3551                     PREFIX_PRIORITY_B_OPT, 0, 0);
3552         add_prefix (&startfile_prefixes, arg, NULL,
3553                     PREFIX_PRIORITY_B_OPT, 0, 0);
3554         add_prefix (&include_prefixes, arg, NULL,
3555                     PREFIX_PRIORITY_B_OPT, 0, 0);
3556       }
3557       validated = true;
3558       break;
3559
3560     case OPT_x:
3561       spec_lang = arg;
3562       if (!strcmp (spec_lang, "none"))
3563         /* Suppress the warning if -xnone comes after the last input
3564            file, because alternate command interfaces like g++ might
3565            find it useful to place -xnone after each input file.  */
3566         spec_lang = 0;
3567       else
3568         last_language_n_infiles = n_infiles;
3569       do_save = false;
3570       break;
3571
3572     case OPT_o:
3573       have_o = 1;
3574 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3575       arg = convert_filename (arg, ! have_c, 0);
3576 #endif
3577       /* Save the output name in case -save-temps=obj was used.  */
3578       save_temps_prefix = xstrdup (arg);
3579       /* On some systems, ld cannot handle "-o" without a space.  So
3580          split the option from its argument.  */
3581       save_switch ("-o", 1, &arg, validated, true);
3582       return true;
3583
3584     case OPT_static_libgcc:
3585     case OPT_shared_libgcc:
3586     case OPT_static_libgfortran:
3587     case OPT_static_libstdc__:
3588       /* These are always valid, since gcc.c itself understands the
3589          first two, gfortranspec.c understands -static-libgfortran and
3590          g++spec.c understands -static-libstdc++ */
3591       validated = true;
3592       break;
3593
3594     default:
3595       /* Various driver options need no special processing at this
3596          point, having been handled in a prescan above or being
3597          handled by specs.  */
3598       break;
3599     }
3600
3601   if (do_save)
3602     save_switch (decoded->canonical_option[0],
3603                  decoded->canonical_option_num_elements - 1,
3604                  &decoded->canonical_option[1], validated, true);
3605   return true;
3606 }
3607
3608 /* Put the driver's standard set of option handlers in *HANDLERS.  */
3609
3610 static void
3611 set_option_handlers (struct cl_option_handlers *handlers)
3612 {
3613   handlers->unknown_option_callback = driver_unknown_option_callback;
3614   handlers->wrong_lang_callback = driver_wrong_lang_callback;
3615   handlers->num_handlers = 3;
3616   handlers->handlers[0].handler = driver_handle_option;
3617   handlers->handlers[0].mask = CL_DRIVER;
3618   handlers->handlers[1].handler = common_handle_option;
3619   handlers->handlers[1].mask = CL_COMMON;
3620   handlers->handlers[2].handler = target_handle_option;
3621   handlers->handlers[2].mask = CL_TARGET;
3622 }
3623
3624 /* Create the vector `switches' and its contents.
3625    Store its length in `n_switches'.  */
3626
3627 static void
3628 process_command (unsigned int decoded_options_count,
3629                  struct cl_decoded_option *decoded_options)
3630 {
3631   const char *temp;
3632   char *temp1;
3633   char *tooldir_prefix, *tooldir_prefix2;
3634   char *(*get_relative_prefix) (const char *, const char *,
3635                                 const char *) = NULL;
3636   struct cl_option_handlers handlers;
3637   unsigned int j;
3638
3639   gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
3640
3641   n_switches = 0;
3642   n_infiles = 0;
3643   added_libraries = 0;
3644
3645   /* Figure compiler version from version string.  */
3646
3647   compiler_version = temp1 = xstrdup (version_string);
3648
3649   for (; *temp1; ++temp1)
3650     {
3651       if (*temp1 == ' ')
3652         {
3653           *temp1 = '\0';
3654           break;
3655         }
3656     }
3657
3658   /* Handle any -no-canonical-prefixes flag early, to assign the function
3659      that builds relative prefixes.  This function creates default search
3660      paths that are needed later in normal option handling.  */
3661
3662   for (j = 1; j < decoded_options_count; j++)
3663     {
3664       if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3665         {
3666           get_relative_prefix = make_relative_prefix_ignore_links;
3667           break;
3668         }
3669     }
3670   if (! get_relative_prefix)
3671     get_relative_prefix = make_relative_prefix;
3672
3673   /* Set up the default search paths.  If there is no GCC_EXEC_PREFIX,
3674      see if we can create it from the pathname specified in
3675      decoded_options[0].arg.  */
3676
3677   gcc_libexec_prefix = standard_libexec_prefix;
3678 #ifndef VMS
3679   /* FIXME: make_relative_prefix doesn't yet work for VMS.  */
3680   if (!gcc_exec_prefix)
3681     {
3682       gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
3683                                              standard_bindir_prefix,
3684                                              standard_exec_prefix);
3685       gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
3686                                              standard_bindir_prefix,
3687                                              standard_libexec_prefix);
3688       if (gcc_exec_prefix)
3689         xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3690     }
3691   else
3692     {
3693       /* make_relative_prefix requires a program name, but
3694          GCC_EXEC_PREFIX is typically a directory name with a trailing
3695          / (which is ignored by make_relative_prefix), so append a
3696          program name.  */
3697       char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3698       gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
3699                                                 standard_exec_prefix,
3700                                                 standard_libexec_prefix);
3701
3702       /* The path is unrelocated, so fallback to the original setting.  */
3703       if (!gcc_libexec_prefix)
3704         gcc_libexec_prefix = standard_libexec_prefix;
3705
3706       free (tmp_prefix);
3707     }
3708 #else
3709 #endif
3710   /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3711      is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3712      or an automatically created GCC_EXEC_PREFIX from
3713      decoded_options[0].arg.  */
3714
3715   /* Do language-specific adjustment/addition of flags.  */
3716   lang_specific_driver (&decoded_options, &decoded_options_count,
3717                         &added_libraries);
3718
3719   if (gcc_exec_prefix)
3720     {
3721       int len = strlen (gcc_exec_prefix);
3722
3723       if (len > (int) sizeof ("/lib/gcc/") - 1
3724           && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3725         {
3726           temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3727           if (IS_DIR_SEPARATOR (*temp)
3728               && filename_ncmp (temp + 1, "lib", 3) == 0
3729               && IS_DIR_SEPARATOR (temp[4])
3730               && filename_ncmp (temp + 5, "gcc", 3) == 0)
3731             len -= sizeof ("/lib/gcc/") - 1;
3732         }
3733
3734       set_std_prefix (gcc_exec_prefix, len);
3735       add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3736                   PREFIX_PRIORITY_LAST, 0, 0);
3737       add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3738                   PREFIX_PRIORITY_LAST, 0, 0);
3739     }
3740
3741   /* COMPILER_PATH and LIBRARY_PATH have values
3742      that are lists of directory names with colons.  */
3743
3744   temp = getenv ("COMPILER_PATH");
3745   if (temp)
3746     {
3747       const char *startp, *endp;
3748       char *nstore = (char *) alloca (strlen (temp) + 3);
3749
3750       startp = endp = temp;
3751       while (1)
3752         {
3753           if (*endp == PATH_SEPARATOR || *endp == 0)
3754             {
3755               strncpy (nstore, startp, endp - startp);
3756               if (endp == startp)
3757                 strcpy (nstore, concat (".", dir_separator_str, NULL));
3758               else if (!IS_DIR_SEPARATOR (endp[-1]))
3759                 {
3760                   nstore[endp - startp] = DIR_SEPARATOR;
3761                   nstore[endp - startp + 1] = 0;
3762                 }
3763               else
3764                 nstore[endp - startp] = 0;
3765               add_prefix (&exec_prefixes, nstore, 0,
3766                           PREFIX_PRIORITY_LAST, 0, 0);
3767               add_prefix (&include_prefixes, nstore, 0,
3768                           PREFIX_PRIORITY_LAST, 0, 0);
3769               if (*endp == 0)
3770                 break;
3771               endp = startp = endp + 1;
3772             }
3773           else
3774             endp++;
3775         }
3776     }
3777
3778   temp = getenv (LIBRARY_PATH_ENV);
3779   if (temp && *cross_compile == '0')
3780     {
3781       const char *startp, *endp;
3782       char *nstore = (char *) alloca (strlen (temp) + 3);
3783
3784       startp = endp = temp;
3785       while (1)
3786         {
3787           if (*endp == PATH_SEPARATOR || *endp == 0)
3788             {
3789               strncpy (nstore, startp, endp - startp);
3790               if (endp == startp)
3791                 strcpy (nstore, concat (".", dir_separator_str, NULL));
3792               else if (!IS_DIR_SEPARATOR (endp[-1]))
3793                 {
3794                   nstore[endp - startp] = DIR_SEPARATOR;
3795                   nstore[endp - startp + 1] = 0;
3796                 }
3797               else
3798                 nstore[endp - startp] = 0;
3799               add_prefix (&startfile_prefixes, nstore, NULL,
3800                           PREFIX_PRIORITY_LAST, 0, 1);
3801               if (*endp == 0)
3802                 break;
3803               endp = startp = endp + 1;
3804             }
3805           else
3806             endp++;
3807         }
3808     }
3809
3810   /* Use LPATH like LIBRARY_PATH (for the CMU build program).  */
3811   temp = getenv ("LPATH");
3812   if (temp && *cross_compile == '0')
3813     {
3814       const char *startp, *endp;
3815       char *nstore = (char *) alloca (strlen (temp) + 3);
3816
3817       startp = endp = temp;
3818       while (1)
3819         {
3820           if (*endp == PATH_SEPARATOR || *endp == 0)
3821             {
3822               strncpy (nstore, startp, endp - startp);
3823               if (endp == startp)
3824                 strcpy (nstore, concat (".", dir_separator_str, NULL));
3825               else if (!IS_DIR_SEPARATOR (endp[-1]))
3826                 {
3827                   nstore[endp - startp] = DIR_SEPARATOR;
3828                   nstore[endp - startp + 1] = 0;
3829                 }
3830               else
3831                 nstore[endp - startp] = 0;
3832               add_prefix (&startfile_prefixes, nstore, NULL,
3833                           PREFIX_PRIORITY_LAST, 0, 1);
3834               if (*endp == 0)
3835                 break;
3836               endp = startp = endp + 1;
3837             }
3838           else
3839             endp++;
3840         }
3841     }
3842
3843   /* Process the options and store input files and switches in their
3844      vectors.  */
3845
3846   last_language_n_infiles = -1;
3847
3848   set_option_handlers (&handlers);
3849
3850   for (j = 1; j < decoded_options_count; j++)
3851     {
3852       switch (decoded_options[j].opt_index)
3853         {
3854         case OPT_S:
3855         case OPT_c:
3856         case OPT_E:
3857           have_c = 1;
3858           break;
3859         }
3860       if (have_c)
3861         break;
3862     }
3863
3864   for (j = 1; j < decoded_options_count; j++)
3865     {
3866       if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
3867         {
3868           const char *arg = decoded_options[j].arg;
3869           const char *p = strrchr (arg, '@');
3870           char *fname;
3871           long offset;
3872           int consumed;
3873 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3874           arg = convert_filename (arg, 0, access (arg, F_OK));
3875 #endif
3876           /* For LTO static archive support we handle input file
3877              specifications that are composed of a filename and
3878              an offset like FNAME@OFFSET.  */
3879           if (p
3880               && p != arg
3881               && sscanf (p, "@%li%n", &offset, &consumed) >= 1
3882               && strlen (p) == (unsigned int)consumed)
3883             {
3884               fname = (char *)xmalloc (p - arg + 1);
3885               memcpy (fname, arg, p - arg);
3886               fname[p - arg] = '\0';
3887               /* Only accept non-stdin and existing FNAME parts, otherwise
3888                  try with the full name.  */
3889               if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
3890                 {
3891                   free (fname);
3892                   fname = xstrdup (arg);
3893                 }
3894             }
3895           else
3896             fname = xstrdup (arg);
3897
3898           if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
3899             perror_with_name (fname);
3900           else
3901             add_infile (arg, spec_lang);
3902
3903           free (fname);
3904           continue;
3905         }
3906
3907       read_cmdline_option (&global_options, &global_options_set,
3908                            decoded_options + j, UNKNOWN_LOCATION,
3909                            CL_DRIVER, &handlers, global_dc);
3910     }
3911
3912   /* If -save-temps=obj and -o name, create the prefix to use for %b.
3913      Otherwise just make -save-temps=obj the same as -save-temps=cwd.  */
3914   if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
3915     {
3916       save_temps_length = strlen (save_temps_prefix);
3917       temp = strrchr (lbasename (save_temps_prefix), '.');
3918       if (temp)
3919         {
3920           save_temps_length -= strlen (temp);
3921           save_temps_prefix[save_temps_length] = '\0';
3922         }
3923
3924     }
3925   else if (save_temps_prefix != NULL)
3926     {
3927       free (save_temps_prefix);
3928       save_temps_prefix = NULL;
3929     }
3930
3931   if (save_temps_flag && use_pipes)
3932     {
3933       /* -save-temps overrides -pipe, so that temp files are produced */
3934       if (save_temps_flag)
3935         warning (0, "-pipe ignored because -save-temps specified");
3936       use_pipes = 0;
3937     }
3938
3939   if (!compare_debug)
3940     {
3941       const char *gcd = getenv ("GCC_COMPARE_DEBUG");
3942
3943       if (gcd && gcd[0] == '-')
3944         {
3945           compare_debug = 2;
3946           compare_debug_opt = gcd;
3947         }
3948       else if (gcd && *gcd && strcmp (gcd, "0"))
3949         {
3950           compare_debug = 3;
3951           compare_debug_opt = "-gtoggle";
3952         }
3953     }
3954   else if (compare_debug < 0)
3955     {
3956       compare_debug = 0;
3957       gcc_assert (!compare_debug_opt);
3958     }
3959
3960   /* Set up the search paths.  We add directories that we expect to
3961      contain GNU Toolchain components before directories specified by
3962      the machine description so that we will find GNU components (like
3963      the GNU assembler) before those of the host system.  */
3964
3965   /* If we don't know where the toolchain has been installed, use the
3966      configured-in locations.  */
3967   if (!gcc_exec_prefix)
3968     {
3969 #ifndef OS2
3970       add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
3971                   PREFIX_PRIORITY_LAST, 1, 0);
3972       add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
3973                   PREFIX_PRIORITY_LAST, 2, 0);
3974       add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3975                   PREFIX_PRIORITY_LAST, 2, 0);
3976 #endif
3977       add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3978                   PREFIX_PRIORITY_LAST, 1, 0);
3979     }
3980
3981   gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
3982   tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
3983                             dir_separator_str, NULL);
3984
3985   /* Look for tools relative to the location from which the driver is
3986      running, or, if that is not available, the configured prefix.  */
3987   tooldir_prefix
3988     = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
3989               spec_machine, dir_separator_str,
3990               spec_version, dir_separator_str, tooldir_prefix2, NULL);
3991   free (tooldir_prefix2);
3992
3993   add_prefix (&exec_prefixes,
3994               concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3995               "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
3996   add_prefix (&startfile_prefixes,
3997               concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3998               "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
3999   free (tooldir_prefix);
4000
4001 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4002   /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4003      then consider it to relocate with the rest of the GCC installation
4004      if GCC_EXEC_PREFIX is set.
4005      ``make_relative_prefix'' is not compiled for VMS, so don't call it.  */
4006   if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4007     {
4008       char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4009                                               standard_bindir_prefix,
4010                                               target_system_root);
4011       if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4012         {
4013           target_system_root = tmp_prefix;
4014           target_system_root_changed = 1;
4015         }
4016     }
4017 #endif
4018
4019   /* More prefixes are enabled in main, after we read the specs file
4020      and determine whether this is cross-compilation or not.  */
4021
4022   if (n_infiles == last_language_n_infiles && spec_lang != 0)
4023     warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4024
4025   /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4026      environment variable.  */
4027   if (compare_debug == 2 || compare_debug == 3)
4028     {
4029       const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4030       save_switch (opt, 0, NULL, false, true);
4031       compare_debug = 1;
4032     }
4033
4034   /* Ensure we only invoke each subprocess once.  */
4035   if (print_subprocess_help || print_help_list || print_version)
4036     {
4037       n_infiles = 0;
4038
4039       /* Create a dummy input file, so that we can pass
4040          the help option on to the various sub-processes.  */
4041       add_infile ("help-dummy", "c");
4042     }
4043
4044   alloc_switch ();
4045   switches[n_switches].part1 = 0;
4046   alloc_infile ();
4047   infiles[n_infiles].name = 0;
4048 }
4049
4050 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4051    and place that in the environment.  */
4052
4053 static void
4054 set_collect_gcc_options (void)
4055 {
4056   int i;
4057   int first_time;
4058
4059   /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4060      the compiler.  */
4061   obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4062                 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4063
4064   first_time = TRUE;
4065   for (i = 0; (int) i < n_switches; i++)
4066     {
4067       const char *const *args;
4068       const char *p, *q;
4069       if (!first_time)
4070         obstack_grow (&collect_obstack, " ", 1);
4071
4072       first_time = FALSE;
4073
4074       /* Ignore elided switches.  */
4075       if ((switches[i].live_cond
4076            & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4077           == SWITCH_IGNORE)
4078         continue;
4079
4080       obstack_grow (&collect_obstack, "'-", 2);
4081       q = switches[i].part1;
4082       while ((p = strchr (q, '\'')))
4083         {
4084           obstack_grow (&collect_obstack, q, p - q);
4085           obstack_grow (&collect_obstack, "'\\''", 4);
4086           q = ++p;
4087         }
4088       obstack_grow (&collect_obstack, q, strlen (q));
4089       obstack_grow (&collect_obstack, "'", 1);
4090
4091       for (args = switches[i].args; args && *args; args++)
4092         {
4093           obstack_grow (&collect_obstack, " '", 2);
4094           q = *args;
4095           while ((p = strchr (q, '\'')))
4096             {
4097               obstack_grow (&collect_obstack, q, p - q);
4098               obstack_grow (&collect_obstack, "'\\''", 4);
4099               q = ++p;
4100             }
4101           obstack_grow (&collect_obstack, q, strlen (q));
4102           obstack_grow (&collect_obstack, "'", 1);
4103         }
4104     }
4105   obstack_grow (&collect_obstack, "\0", 1);
4106   xputenv (XOBFINISH (&collect_obstack, char *));
4107 }
4108 \f
4109 /* Process a spec string, accumulating and running commands.  */
4110
4111 /* These variables describe the input file name.
4112    input_file_number is the index on outfiles of this file,
4113    so that the output file name can be stored for later use by %o.
4114    input_basename is the start of the part of the input file
4115    sans all directory names, and basename_length is the number
4116    of characters starting there excluding the suffix .c or whatever.  */
4117
4118 static const char *gcc_input_filename;
4119 static int input_file_number;
4120 size_t input_filename_length;
4121 static int basename_length;
4122 static int suffixed_basename_length;
4123 static const char *input_basename;
4124 static const char *input_suffix;
4125 #ifndef HOST_LACKS_INODE_NUMBERS
4126 static struct stat input_stat;
4127 #endif
4128 static int input_stat_set;
4129
4130 /* The compiler used to process the current input file.  */
4131 static struct compiler *input_file_compiler;
4132
4133 /* These are variables used within do_spec and do_spec_1.  */
4134
4135 /* Nonzero if an arg has been started and not yet terminated
4136    (with space, tab or newline).  */
4137 static int arg_going;
4138
4139 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4140    is a temporary file name.  */
4141 static int delete_this_arg;
4142
4143 /* Nonzero means %w has been seen; the next arg to be terminated
4144    is the output file name of this compilation.  */
4145 static int this_is_output_file;
4146
4147 /* Nonzero means %s has been seen; the next arg to be terminated
4148    is the name of a library file and we should try the standard
4149    search dirs for it.  */
4150 static int this_is_library_file;
4151
4152 /* Nonzero means %T has been seen; the next arg to be terminated
4153    is the name of a linker script and we should try all of the
4154    standard search dirs for it.  If it is found insert a --script
4155    command line switch and then substitute the full path in place,
4156    otherwise generate an error message.  */
4157 static int this_is_linker_script;
4158
4159 /* Nonzero means that the input of this command is coming from a pipe.  */
4160 static int input_from_pipe;
4161
4162 /* Nonnull means substitute this for any suffix when outputting a switches
4163    arguments.  */
4164 static const char *suffix_subst;
4165
4166 /* If there is an argument being accumulated, terminate it and store it.  */
4167
4168 static void
4169 end_going_arg (void)
4170 {
4171   if (arg_going)
4172     {
4173       const char *string;
4174
4175       obstack_1grow (&obstack, 0);
4176       string = XOBFINISH (&obstack, const char *);
4177       if (this_is_library_file)
4178         string = find_file (string);
4179       if (this_is_linker_script)
4180         {
4181           char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4182
4183           if (full_script_path == NULL)
4184             {
4185               error ("unable to locate default linker script %qs in the library search paths", string);
4186               /* Script was not found on search path.  */
4187               return;
4188             }
4189           store_arg ("--script", false, false);
4190           string = full_script_path;
4191         }
4192       store_arg (string, delete_this_arg, this_is_output_file);
4193       if (this_is_output_file)
4194         outfiles[input_file_number] = string;
4195       arg_going = 0;
4196     }
4197 }
4198
4199
4200 /* Parse the WRAPPER string which is a comma separated list of the command line
4201    and insert them into the beginning of argbuf.  */
4202
4203 static void
4204 insert_wrapper (const char *wrapper)
4205 {
4206   int n = 0;
4207   int i;
4208   char *buf = xstrdup (wrapper);
4209   char *p = buf;
4210   unsigned int old_length = argbuf.length ();
4211
4212   do
4213     {
4214       n++;
4215       while (*p == ',')
4216         p++;
4217     }
4218   while ((p = strchr (p, ',')) != NULL);
4219
4220   argbuf.safe_grow (old_length + n);
4221   memmove (argbuf.address () + n,
4222            argbuf.address (),
4223            old_length * sizeof (const_char_p));
4224
4225   i = 0;
4226   p = buf;
4227   do
4228     {
4229       while (*p == ',')
4230         {
4231           *p = 0;
4232           p++;
4233         }
4234       argbuf[i] = p;
4235       i++;
4236     }
4237   while ((p = strchr (p, ',')) != NULL);
4238   gcc_assert (i == n);
4239 }
4240
4241 /* Process the spec SPEC and run the commands specified therein.
4242    Returns 0 if the spec is successfully processed; -1 if failed.  */
4243
4244 int
4245 do_spec (const char *spec)
4246 {
4247   int value;
4248
4249   value = do_spec_2 (spec);
4250
4251   /* Force out any unfinished command.
4252      If -pipe, this forces out the last command if it ended in `|'.  */
4253   if (value == 0)
4254     {
4255       if (argbuf.length () > 0
4256           && !strcmp (argbuf.last (), "|"))
4257         argbuf.pop ();
4258
4259       set_collect_gcc_options ();
4260
4261       if (argbuf.length () > 0)
4262         value = execute ();
4263     }
4264
4265   return value;
4266 }
4267
4268 static int
4269 do_spec_2 (const char *spec)
4270 {
4271   int result;
4272
4273   clear_args ();
4274   arg_going = 0;
4275   delete_this_arg = 0;
4276   this_is_output_file = 0;
4277   this_is_library_file = 0;
4278   this_is_linker_script = 0;
4279   input_from_pipe = 0;
4280   suffix_subst = NULL;
4281
4282   result = do_spec_1 (spec, 0, NULL);
4283
4284   end_going_arg ();
4285
4286   return result;
4287 }
4288
4289
4290 /* Process the given spec string and add any new options to the end
4291    of the switches/n_switches array.  */
4292
4293 static void
4294 do_option_spec (const char *name, const char *spec)
4295 {
4296   unsigned int i, value_count, value_len;
4297   const char *p, *q, *value;
4298   char *tmp_spec, *tmp_spec_p;
4299
4300   if (configure_default_options[0].name == NULL)
4301     return;
4302
4303   for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4304     if (strcmp (configure_default_options[i].name, name) == 0)
4305       break;
4306   if (i == ARRAY_SIZE (configure_default_options))
4307     return;
4308
4309   value = configure_default_options[i].value;
4310   value_len = strlen (value);
4311
4312   /* Compute the size of the final spec.  */
4313   value_count = 0;
4314   p = spec;
4315   while ((p = strstr (p, "%(VALUE)")) != NULL)
4316     {
4317       p ++;
4318       value_count ++;
4319     }
4320
4321   /* Replace each %(VALUE) by the specified value.  */
4322   tmp_spec = (char *) alloca (strlen (spec) + 1
4323                      + value_count * (value_len - strlen ("%(VALUE)")));
4324   tmp_spec_p = tmp_spec;
4325   q = spec;
4326   while ((p = strstr (q, "%(VALUE)")) != NULL)
4327     {
4328       memcpy (tmp_spec_p, q, p - q);
4329       tmp_spec_p = tmp_spec_p + (p - q);
4330       memcpy (tmp_spec_p, value, value_len);
4331       tmp_spec_p += value_len;
4332       q = p + strlen ("%(VALUE)");
4333     }
4334   strcpy (tmp_spec_p, q);
4335
4336   do_self_spec (tmp_spec);
4337 }
4338
4339 /* Process the given spec string and add any new options to the end
4340    of the switches/n_switches array.  */
4341
4342 static void
4343 do_self_spec (const char *spec)
4344 {
4345   int i;
4346
4347   do_spec_2 (spec);
4348   do_spec_1 (" ", 0, NULL);
4349
4350   /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4351      do_self_specs adds the replacements to switches array, so it shouldn't
4352      be processed afterwards.  */
4353   for (i = 0; i < n_switches; i++)
4354     if ((switches[i].live_cond & SWITCH_IGNORE))
4355       switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4356
4357   if (argbuf.length () > 0)
4358     {
4359       const char **argbuf_copy;
4360       struct cl_decoded_option *decoded_options;
4361       struct cl_option_handlers handlers;
4362       unsigned int decoded_options_count;
4363       unsigned int j;
4364
4365       /* Create a copy of argbuf with a dummy argv[0] entry for
4366          decode_cmdline_options_to_array.  */
4367       argbuf_copy = XNEWVEC (const char *,
4368                              argbuf.length () + 1);
4369       argbuf_copy[0] = "";
4370       memcpy (argbuf_copy + 1, argbuf.address (),
4371               argbuf.length () * sizeof (const char *));
4372
4373       decode_cmdline_options_to_array (argbuf.length () + 1,
4374                                        argbuf_copy,
4375                                        CL_DRIVER, &decoded_options,
4376                                        &decoded_options_count);
4377       free (argbuf_copy);
4378
4379       set_option_handlers (&handlers);
4380
4381       for (j = 1; j < decoded_options_count; j++)
4382         {
4383           switch (decoded_options[j].opt_index)
4384             {
4385             case OPT_SPECIAL_input_file:
4386               /* Specs should only generate options, not input
4387                  files.  */
4388               if (strcmp (decoded_options[j].arg, "-") != 0)
4389                 fatal_error ("switch %qs does not start with %<-%>",
4390                              decoded_options[j].arg);
4391               else
4392                 fatal_error ("spec-generated switch is just %<-%>");
4393               break;
4394
4395             case OPT_fcompare_debug_second:
4396             case OPT_fcompare_debug:
4397             case OPT_fcompare_debug_:
4398             case OPT_o:
4399               /* Avoid duplicate processing of some options from
4400                  compare-debug specs; just save them here.  */
4401               save_switch (decoded_options[j].canonical_option[0],
4402                            (decoded_options[j].canonical_option_num_elements
4403                             - 1),
4404                            &decoded_options[j].canonical_option[1], false, true);
4405               break;
4406
4407             default:
4408               read_cmdline_option (&global_options, &global_options_set,
4409                                    decoded_options + j, UNKNOWN_LOCATION,
4410                                    CL_DRIVER, &handlers, global_dc);
4411               break;
4412             }
4413         }
4414
4415       alloc_switch ();
4416       switches[n_switches].part1 = 0;
4417     }
4418 }
4419
4420 /* Callback for processing %D and %I specs.  */
4421
4422 struct spec_path_info {
4423   const char *option;
4424   const char *append;
4425   size_t append_len;
4426   bool omit_relative;
4427   bool separate_options;
4428 };
4429
4430 static void *
4431 spec_path (char *path, void *data)
4432 {
4433   struct spec_path_info *info = (struct spec_path_info *) data;
4434   size_t len = 0;
4435   char save = 0;
4436
4437   if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4438     return NULL;
4439
4440   if (info->append_len != 0)
4441     {
4442       len = strlen (path);
4443       memcpy (path + len, info->append, info->append_len + 1);
4444     }
4445
4446   if (!is_directory (path, true))
4447     return NULL;
4448
4449   do_spec_1 (info->option, 1, NULL);
4450   if (info->separate_options)
4451     do_spec_1 (" ", 0, NULL);
4452
4453   if (info->append_len == 0)
4454     {
4455       len = strlen (path);
4456       save = path[len - 1];
4457       if (IS_DIR_SEPARATOR (path[len - 1]))
4458         path[len - 1] = '\0';
4459     }
4460
4461   do_spec_1 (path, 1, NULL);
4462   do_spec_1 (" ", 0, NULL);
4463
4464   /* Must not damage the original path.  */
4465   if (info->append_len == 0)
4466     path[len - 1] = save;
4467
4468   return NULL;
4469 }
4470
4471 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4472    argument list. */
4473
4474 static void
4475 create_at_file (char **argv)
4476 {
4477   char *temp_file = make_temp_file ("");
4478   char *at_argument = concat ("@", temp_file, NULL);
4479   FILE *f = fopen (temp_file, "w");
4480   int status;
4481
4482   if (f == NULL)
4483     fatal_error ("could not open temporary response file %s",
4484                  temp_file);
4485
4486   status = writeargv (argv, f);
4487
4488   if (status)
4489     fatal_error ("could not write to temporary response file %s",
4490                  temp_file);
4491
4492   status = fclose (f);
4493
4494   if (EOF == status)
4495     fatal_error ("could not close temporary response file %s",
4496                  temp_file);
4497
4498   store_arg (at_argument, 0, 0);
4499
4500   record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4501 }
4502
4503 /* True if we should compile INFILE. */
4504
4505 static bool
4506 compile_input_file_p (struct infile *infile)
4507 {
4508   if ((!infile->language) || (infile->language[0] != '*'))
4509     if (infile->incompiler == input_file_compiler)
4510       return true;
4511   return false;
4512 }
4513
4514 /* Process each member of VEC as a spec.  */
4515
4516 static void
4517 do_specs_vec (vec<char_p> vec)
4518 {
4519   unsigned ix;
4520   char *opt;
4521
4522   FOR_EACH_VEC_ELT (vec, ix, opt)
4523     {
4524       do_spec_1 (opt, 1, NULL);
4525       /* Make each accumulated option a separate argument.  */
4526       do_spec_1 (" ", 0, NULL);
4527     }
4528 }
4529
4530 /* Process the sub-spec SPEC as a portion of a larger spec.
4531    This is like processing a whole spec except that we do
4532    not initialize at the beginning and we do not supply a
4533    newline by default at the end.
4534    INSWITCH nonzero means don't process %-sequences in SPEC;
4535    in this case, % is treated as an ordinary character.
4536    This is used while substituting switches.
4537    INSWITCH nonzero also causes SPC not to terminate an argument.
4538
4539    Value is zero unless a line was finished
4540    and the command on that line reported an error.  */
4541
4542 static int
4543 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4544 {
4545   const char *p = spec;
4546   int c;
4547   int i;
4548   int value;
4549
4550   /* If it's an empty string argument to a switch, keep it as is.  */
4551   if (inswitch && !*p)
4552     arg_going = 1;
4553
4554   while ((c = *p++))
4555     /* If substituting a switch, treat all chars like letters.
4556        Otherwise, NL, SPC, TAB and % are special.  */
4557     switch (inswitch ? 'a' : c)
4558       {
4559       case '\n':
4560         end_going_arg ();
4561
4562         if (argbuf.length () > 0
4563             && !strcmp (argbuf.last (), "|"))
4564           {
4565             /* A `|' before the newline means use a pipe here,
4566                but only if -pipe was specified.
4567                Otherwise, execute now and don't pass the `|' as an arg.  */
4568             if (use_pipes)
4569               {
4570                 input_from_pipe = 1;
4571                 break;
4572               }
4573             else
4574               argbuf.pop ();
4575           }
4576
4577         set_collect_gcc_options ();
4578
4579         if (argbuf.length () > 0)
4580           {
4581             value = execute ();
4582             if (value)
4583               return value;
4584           }
4585         /* Reinitialize for a new command, and for a new argument.  */
4586         clear_args ();
4587         arg_going = 0;
4588         delete_this_arg = 0;
4589         this_is_output_file = 0;
4590         this_is_library_file = 0;
4591         this_is_linker_script = 0;
4592         input_from_pipe = 0;
4593         break;
4594
4595       case '|':
4596         end_going_arg ();
4597
4598         /* Use pipe */
4599         obstack_1grow (&obstack, c);
4600         arg_going = 1;
4601         break;
4602
4603       case '\t':
4604       case ' ':
4605         end_going_arg ();
4606
4607         /* Reinitialize for a new argument.  */
4608         delete_this_arg = 0;
4609         this_is_output_file = 0;
4610         this_is_library_file = 0;
4611         this_is_linker_script = 0;
4612         break;
4613
4614       case '%':
4615         switch (c = *p++)
4616           {
4617           case 0:
4618             fatal_error ("spec %qs invalid", spec);
4619
4620           case 'b':
4621             if (save_temps_length)
4622               obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4623             else
4624               obstack_grow (&obstack, input_basename, basename_length);
4625             if (compare_debug < 0)
4626               obstack_grow (&obstack, ".gk", 3);
4627             arg_going = 1;
4628             break;
4629
4630           case 'B':
4631             if (save_temps_length)
4632               obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4633             else
4634               obstack_grow (&obstack, input_basename, suffixed_basename_length);
4635             if (compare_debug < 0)
4636               obstack_grow (&obstack, ".gk", 3);
4637             arg_going = 1;
4638             break;
4639
4640           case 'd':
4641             delete_this_arg = 2;
4642             break;
4643
4644           /* Dump out the directories specified with LIBRARY_PATH,
4645              followed by the absolute directories
4646              that we search for startfiles.  */
4647           case 'D':
4648             {
4649               struct spec_path_info info;
4650
4651               info.option = "-L";
4652               info.append_len = 0;
4653 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4654               /* Used on systems which record the specified -L dirs
4655                  and use them to search for dynamic linking.
4656                  Relative directories always come from -B,
4657                  and it is better not to use them for searching
4658                  at run time.  In particular, stage1 loses.  */
4659               info.omit_relative = true;
4660 #else
4661               info.omit_relative = false;
4662 #endif
4663               info.separate_options = false;
4664
4665               for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4666             }
4667             break;
4668
4669           case 'e':
4670             /* %efoo means report an error with `foo' as error message
4671                and don't execute any more commands for this file.  */
4672             {
4673               const char *q = p;
4674               char *buf;
4675               while (*p != 0 && *p != '\n')
4676                 p++;
4677               buf = (char *) alloca (p - q + 1);
4678               strncpy (buf, q, p - q);
4679               buf[p - q] = 0;
4680               error ("%s", _(buf));
4681               return -1;
4682             }
4683             break;
4684           case 'n':
4685             /* %nfoo means report a notice with `foo' on stderr.  */
4686             {
4687               const char *q = p;
4688               char *buf;
4689               while (*p != 0 && *p != '\n')
4690                 p++;
4691               buf = (char *) alloca (p - q + 1);
4692               strncpy (buf, q, p - q);
4693               buf[p - q] = 0;
4694               inform (0, "%s", _(buf));
4695               if (*p)
4696                 p++;
4697             }
4698             break;
4699
4700           case 'j':
4701             {
4702               struct stat st;
4703
4704               /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4705                  defined, and it is not a directory, and it is
4706                  writable, use it.  Otherwise, treat this like any
4707                  other temporary file.  */
4708
4709               if ((!save_temps_flag)
4710                   && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4711                   && (access (HOST_BIT_BUCKET, W_OK) == 0))
4712                 {
4713                   obstack_grow (&obstack, HOST_BIT_BUCKET,
4714                                 strlen (HOST_BIT_BUCKET));
4715                   delete_this_arg = 0;
4716                   arg_going = 1;
4717                   break;
4718                 }
4719             }
4720             goto create_temp_file;
4721           case '|':
4722             if (use_pipes)
4723               {
4724                 obstack_1grow (&obstack, '-');
4725                 delete_this_arg = 0;
4726                 arg_going = 1;
4727
4728                 /* consume suffix */
4729                 while (*p == '.' || ISALNUM ((unsigned char) *p))
4730                   p++;
4731                 if (p[0] == '%' && p[1] == 'O')
4732                   p += 2;
4733
4734                 break;
4735               }
4736             goto create_temp_file;
4737           case 'm':
4738             if (use_pipes)
4739               {
4740                 /* consume suffix */
4741                 while (*p == '.' || ISALNUM ((unsigned char) *p))
4742                   p++;
4743                 if (p[0] == '%' && p[1] == 'O')
4744                   p += 2;
4745
4746                 break;
4747               }
4748             goto create_temp_file;
4749           case 'g':
4750           case 'u':
4751           case 'U':
4752           create_temp_file:
4753               {
4754                 struct temp_name *t;
4755                 int suffix_length;
4756                 const char *suffix = p;
4757                 char *saved_suffix = NULL;
4758
4759                 while (*p == '.' || ISALNUM ((unsigned char) *p))
4760                   p++;
4761                 suffix_length = p - suffix;
4762                 if (p[0] == '%' && p[1] == 'O')
4763                   {
4764                     p += 2;
4765                     /* We don't support extra suffix characters after %O.  */
4766                     if (*p == '.' || ISALNUM ((unsigned char) *p))
4767                       fatal_error ("spec %qs has invalid %<%%0%c%>", spec, *p);
4768                     if (suffix_length == 0)
4769                       suffix = TARGET_OBJECT_SUFFIX;
4770                     else
4771                       {
4772                         saved_suffix
4773                           = XNEWVEC (char, suffix_length
4774                                      + strlen (TARGET_OBJECT_SUFFIX));
4775                         strncpy (saved_suffix, suffix, suffix_length);
4776                         strcpy (saved_suffix + suffix_length,
4777                                 TARGET_OBJECT_SUFFIX);
4778                       }
4779                     suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4780                   }
4781
4782                 if (compare_debug < 0)
4783                   {
4784                     suffix = concat (".gk", suffix, NULL);
4785                     suffix_length += 3;
4786                   }
4787
4788                 /* If -save-temps=obj and -o were specified, use that for the
4789                    temp file.  */
4790                 if (save_temps_length)
4791                   {
4792                     char *tmp;
4793                     temp_filename_length
4794                       = save_temps_length + suffix_length + 1;
4795                     tmp = (char *) alloca (temp_filename_length);
4796                     memcpy (tmp, save_temps_prefix, save_temps_length);
4797                     memcpy (tmp + save_temps_length, suffix, suffix_length);
4798                     tmp[save_temps_length + suffix_length] = '\0';
4799                     temp_filename = save_string (tmp, save_temps_length
4800                                                       + suffix_length);
4801                     obstack_grow (&obstack, temp_filename,
4802                                   temp_filename_length);
4803                     arg_going = 1;
4804                     delete_this_arg = 0;
4805                     break;
4806                   }
4807
4808                 /* If the gcc_input_filename has the same suffix specified
4809                    for the %g, %u, or %U, and -save-temps is specified,
4810                    we could end up using that file as an intermediate
4811                    thus clobbering the user's source file (.e.g.,
4812                    gcc -save-temps foo.s would clobber foo.s with the
4813                    output of cpp0).  So check for this condition and
4814                    generate a temp file as the intermediate.  */
4815
4816                 if (save_temps_flag)
4817                   {
4818                     char *tmp;
4819                     temp_filename_length = basename_length + suffix_length + 1;
4820                     tmp = (char *) alloca (temp_filename_length);
4821                     memcpy (tmp, input_basename, basename_length);
4822                     memcpy (tmp + basename_length, suffix, suffix_length);
4823                     tmp[basename_length + suffix_length] = '\0';
4824                     temp_filename = tmp;
4825
4826                     if (filename_cmp (temp_filename, gcc_input_filename) != 0)
4827                       {
4828 #ifndef HOST_LACKS_INODE_NUMBERS
4829                         struct stat st_temp;
4830
4831                         /* Note, set_input() resets input_stat_set to 0.  */
4832                         if (input_stat_set == 0)
4833                           {
4834                             input_stat_set = stat (gcc_input_filename,
4835                                                    &input_stat);
4836                             if (input_stat_set >= 0)
4837                               input_stat_set = 1;
4838                           }
4839
4840                         /* If we have the stat for the gcc_input_filename
4841                            and we can do the stat for the temp_filename
4842                            then the they could still refer to the same
4843                            file if st_dev/st_ino's are the same.  */
4844                         if (input_stat_set != 1
4845                             || stat (temp_filename, &st_temp) < 0
4846                             || input_stat.st_dev != st_temp.st_dev
4847                             || input_stat.st_ino != st_temp.st_ino)
4848 #else
4849                         /* Just compare canonical pathnames.  */
4850                         char* input_realname = lrealpath (gcc_input_filename);
4851                         char* temp_realname = lrealpath (temp_filename);
4852                         bool files_differ = filename_cmp (input_realname, temp_realname);
4853                         free (input_realname);
4854                         free (temp_realname);
4855                         if (files_differ)
4856 #endif
4857                           {
4858                             temp_filename = save_string (temp_filename,
4859                                                          temp_filename_length + 1);
4860                             obstack_grow (&obstack, temp_filename,
4861                                                     temp_filename_length);
4862                             arg_going = 1;
4863                             delete_this_arg = 0;
4864                             break;
4865                           }
4866                       }
4867                   }
4868
4869                 /* See if we already have an association of %g/%u/%U and
4870                    suffix.  */
4871                 for (t = temp_names; t; t = t->next)
4872                   if (t->length == suffix_length
4873                       && strncmp (t->suffix, suffix, suffix_length) == 0
4874                       && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4875                     break;
4876
4877                 /* Make a new association if needed.  %u and %j
4878                    require one.  */
4879                 if (t == 0 || c == 'u' || c == 'j')
4880                   {
4881                     if (t == 0)
4882                       {
4883                         t = XNEW (struct temp_name);
4884                         t->next = temp_names;
4885                         temp_names = t;
4886                       }
4887                     t->length = suffix_length;
4888                     if (saved_suffix)
4889                       {
4890                         t->suffix = saved_suffix;
4891                         saved_suffix = NULL;
4892                       }
4893                     else
4894                       t->suffix = save_string (suffix, suffix_length);
4895                     t->unique = (c == 'u' || c == 'U' || c == 'j');
4896                     temp_filename = make_temp_file (t->suffix);
4897                     temp_filename_length = strlen (temp_filename);
4898                     t->filename = temp_filename;
4899                     t->filename_length = temp_filename_length;
4900                   }
4901
4902                 free (saved_suffix);
4903
4904                 obstack_grow (&obstack, t->filename, t->filename_length);
4905                 delete_this_arg = 1;
4906               }
4907             arg_going = 1;
4908             break;
4909
4910           case 'i':
4911             if (combine_inputs)
4912               {
4913                 if (at_file_supplied)
4914                   {
4915                     /* We are going to expand `%i' to `@FILE', where FILE
4916                        is a newly-created temporary filename.  The filenames
4917                        that would usually be expanded in place of %o will be
4918                        written to the temporary file.  */
4919                     char **argv;
4920                     int n_files = 0;
4921                     int j;
4922
4923                     for (i = 0; i < n_infiles; i++)
4924                       if (compile_input_file_p (&infiles[i]))
4925                         n_files++;
4926
4927                     argv = (char **) alloca (sizeof (char *) * (n_files + 1));
4928
4929                     /* Copy the strings over.  */
4930                     for (i = 0, j = 0; i < n_infiles; i++)
4931                       if (compile_input_file_p (&infiles[i]))
4932                         {
4933                           argv[j] = CONST_CAST (char *, infiles[i].name);
4934                           infiles[i].compiled = true;
4935                           j++;
4936                         }
4937                     argv[j] = NULL;
4938
4939                     create_at_file (argv);
4940                   }
4941                 else
4942                   for (i = 0; (int) i < n_infiles; i++)
4943                     if (compile_input_file_p (&infiles[i]))
4944                       {
4945                         store_arg (infiles[i].name, 0, 0);
4946                         infiles[i].compiled = true;
4947                       }
4948               }
4949             else
4950               {
4951                 obstack_grow (&obstack, gcc_input_filename,
4952                               input_filename_length);
4953                 arg_going = 1;
4954               }
4955             break;
4956
4957           case 'I':
4958             {
4959               struct spec_path_info info;
4960
4961               if (multilib_dir)
4962                 {
4963                   do_spec_1 ("-imultilib", 1, NULL);
4964                   /* Make this a separate argument.  */
4965                   do_spec_1 (" ", 0, NULL);
4966                   do_spec_1 (multilib_dir, 1, NULL);
4967                   do_spec_1 (" ", 0, NULL);
4968                 }
4969
4970               if (multiarch_dir)
4971                 {
4972                   do_spec_1 ("-imultiarch", 1, NULL);
4973                   /* Make this a separate argument.  */
4974                   do_spec_1 (" ", 0, NULL);
4975                   do_spec_1 (multiarch_dir, 1, NULL);
4976                   do_spec_1 (" ", 0, NULL);
4977                 }
4978
4979               if (gcc_exec_prefix)
4980                 {
4981                   do_spec_1 ("-iprefix", 1, NULL);
4982                   /* Make this a separate argument.  */
4983                   do_spec_1 (" ", 0, NULL);
4984                   do_spec_1 (gcc_exec_prefix, 1, NULL);
4985                   do_spec_1 (" ", 0, NULL);
4986                 }
4987
4988               if (target_system_root_changed ||
4989                   (target_system_root && target_sysroot_hdrs_suffix))
4990                 {
4991                   do_spec_1 ("-isysroot", 1, NULL);
4992                   /* Make this a separate argument.  */
4993                   do_spec_1 (" ", 0, NULL);
4994                   do_spec_1 (target_system_root, 1, NULL);
4995                   if (target_sysroot_hdrs_suffix)
4996                     do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
4997                   do_spec_1 (" ", 0, NULL);
4998                 }
4999
5000               info.option = "-isystem";
5001               info.append = "include";
5002               info.append_len = strlen (info.append);
5003               info.omit_relative = false;
5004               info.separate_options = true;
5005
5006               for_each_path (&include_prefixes, false, info.append_len,
5007                              spec_path, &info);
5008
5009               info.append = "include-fixed";
5010               if (*sysroot_hdrs_suffix_spec)
5011                 info.append = concat (info.append, dir_separator_str,
5012                                       multilib_dir, NULL);
5013               info.append_len = strlen (info.append);
5014               for_each_path (&include_prefixes, false, info.append_len,
5015                              spec_path, &info);
5016             }
5017             break;
5018
5019           case 'o':
5020             {
5021               int max = n_infiles;
5022               max += lang_specific_extra_outfiles;
5023
5024               if (HAVE_GNU_LD && at_file_supplied)
5025                 {
5026                   /* We are going to expand `%o' to `@FILE', where FILE
5027                      is a newly-created temporary filename.  The filenames
5028                      that would usually be expanded in place of %o will be
5029                      written to the temporary file.  */
5030
5031                   char **argv;
5032                   int n_files, j;
5033
5034                   /* Convert OUTFILES into a form suitable for writeargv.  */
5035
5036                   /* Determine how many are non-NULL.  */
5037                   for (n_files = 0, i = 0; i < max; i++)
5038                     n_files += outfiles[i] != NULL;
5039
5040                   argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5041
5042                   /* Copy the strings over.  */
5043                   for (i = 0, j = 0; i < max; i++)
5044                     if (outfiles[i])
5045                       {
5046                         argv[j] = CONST_CAST (char *, outfiles[i]);
5047                         j++;
5048                       }
5049                   argv[j] = NULL;
5050
5051                   create_at_file (argv);
5052                 }
5053               else
5054                 for (i = 0; i < max; i++)
5055                   if (outfiles[i])
5056                     store_arg (outfiles[i], 0, 0);
5057               break;
5058             }
5059
5060           case 'O':
5061             obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5062             arg_going = 1;
5063             break;
5064
5065           case 's':
5066             this_is_library_file = 1;
5067             break;
5068
5069           case 'T':
5070             this_is_linker_script = 1;
5071             break;
5072
5073           case 'V':
5074             outfiles[input_file_number] = NULL;
5075             break;
5076
5077           case 'w':
5078             this_is_output_file = 1;
5079             break;
5080
5081           case 'W':
5082             {
5083               unsigned int cur_index = argbuf.length ();
5084               /* Handle the {...} following the %W.  */
5085               if (*p != '{')
5086                 fatal_error ("spec %qs has invalid %<%%W%c%>", spec, *p);
5087               p = handle_braces (p + 1);
5088               if (p == 0)
5089                 return -1;
5090               end_going_arg ();
5091               /* If any args were output, mark the last one for deletion
5092                  on failure.  */
5093               if (argbuf.length () != cur_index)
5094                 record_temp_file (argbuf.last (), 0, 1);
5095               break;
5096             }
5097
5098           /* %x{OPTION} records OPTION for %X to output.  */
5099           case 'x':
5100             {
5101               const char *p1 = p;
5102               char *string;
5103               char *opt;
5104               unsigned ix;
5105
5106               /* Skip past the option value and make a copy.  */
5107               if (*p != '{')
5108                 fatal_error ("spec %qs has invalid %<%%x%c%>", spec, *p);
5109               while (*p++ != '}')
5110                 ;
5111               string = save_string (p1 + 1, p - p1 - 2);
5112
5113               /* See if we already recorded this option.  */
5114               FOR_EACH_VEC_ELT (linker_options, ix, opt)
5115                 if (! strcmp (string, opt))
5116                   {
5117                     free (string);
5118                     return 0;
5119                   }
5120
5121               /* This option is new; add it.  */
5122               add_linker_option (string, strlen (string));
5123               free (string);
5124             }
5125             break;
5126
5127           /* Dump out the options accumulated previously using %x.  */
5128           case 'X':
5129             do_specs_vec (linker_options);
5130             break;
5131
5132           /* Dump out the options accumulated previously using -Wa,.  */
5133           case 'Y':
5134             do_specs_vec (assembler_options);
5135             break;
5136
5137           /* Dump out the options accumulated previously using -Wp,.  */
5138           case 'Z':
5139             do_specs_vec (preprocessor_options);
5140             break;
5141
5142             /* Here are digits and numbers that just process
5143                a certain constant string as a spec.  */
5144
5145           case '1':
5146             value = do_spec_1 (cc1_spec, 0, NULL);
5147             if (value != 0)
5148               return value;
5149             break;
5150
5151           case '2':
5152             value = do_spec_1 (cc1plus_spec, 0, NULL);
5153             if (value != 0)
5154               return value;
5155             break;
5156
5157           case 'a':
5158             value = do_spec_1 (asm_spec, 0, NULL);
5159             if (value != 0)
5160               return value;
5161             break;
5162
5163           case 'A':
5164             value = do_spec_1 (asm_final_spec, 0, NULL);
5165             if (value != 0)
5166               return value;
5167             break;
5168
5169           case 'C':
5170             {
5171               const char *const spec
5172                 = (input_file_compiler->cpp_spec
5173                    ? input_file_compiler->cpp_spec
5174                    : cpp_spec);
5175               value = do_spec_1 (spec, 0, NULL);
5176               if (value != 0)
5177                 return value;
5178             }
5179             break;
5180
5181           case 'E':
5182             value = do_spec_1 (endfile_spec, 0, NULL);
5183             if (value != 0)
5184               return value;
5185             break;
5186
5187           case 'l':
5188             value = do_spec_1 (link_spec, 0, NULL);
5189             if (value != 0)
5190               return value;
5191             break;
5192
5193           case 'L':
5194             value = do_spec_1 (lib_spec, 0, NULL);
5195             if (value != 0)
5196               return value;
5197             break;
5198
5199           case 'M':
5200             if (multilib_os_dir == NULL)
5201               obstack_1grow (&obstack, '.');
5202             else
5203               obstack_grow (&obstack, multilib_os_dir,
5204                             strlen (multilib_os_dir));
5205             break;
5206
5207           case 'G':
5208             value = do_spec_1 (libgcc_spec, 0, NULL);
5209             if (value != 0)
5210               return value;
5211             break;
5212
5213           case 'R':
5214             /* We assume there is a directory
5215                separator at the end of this string.  */
5216             if (target_system_root)
5217               {
5218                 obstack_grow (&obstack, target_system_root,
5219                               strlen (target_system_root));
5220                 if (target_sysroot_suffix)
5221                   obstack_grow (&obstack, target_sysroot_suffix,
5222                                 strlen (target_sysroot_suffix));
5223               }
5224             break;
5225
5226           case 'S':
5227             value = do_spec_1 (startfile_spec, 0, NULL);
5228             if (value != 0)
5229               return value;
5230             break;
5231
5232             /* Here we define characters other than letters and digits.  */
5233
5234           case '{':
5235             p = handle_braces (p);
5236             if (p == 0)
5237               return -1;
5238             break;
5239
5240           case ':':
5241             p = handle_spec_function (p);
5242             if (p == 0)
5243               return -1;
5244             break;
5245
5246           case '%':
5247             obstack_1grow (&obstack, '%');
5248             break;
5249
5250           case '.':
5251             {
5252               unsigned len = 0;
5253
5254               while (p[len] && p[len] != ' ' && p[len] != '%')
5255                 len++;
5256               suffix_subst = save_string (p - 1, len + 1);
5257               p += len;
5258             }
5259            break;
5260
5261            /* Henceforth ignore the option(s) matching the pattern
5262               after the %<.  */
5263           case '<':
5264           case '>':
5265             {
5266               unsigned len = 0;
5267               int have_wildcard = 0;
5268               int i;
5269               int switch_option;
5270
5271               if (c == '>')
5272                 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5273               else
5274                 switch_option = SWITCH_IGNORE;
5275
5276               while (p[len] && p[len] != ' ' && p[len] != '\t')
5277                 len++;
5278
5279               if (p[len-1] == '*')
5280                 have_wildcard = 1;
5281
5282               for (i = 0; i < n_switches; i++)
5283                 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5284                     && (have_wildcard || switches[i].part1[len] == '\0'))
5285                   {
5286                     switches[i].live_cond |= switch_option;
5287                     /* User switch be validated from validate_all_switches.
5288                        when the definition is seen from the spec file.
5289                        If not defined anywhere, will be rejected.  */
5290                     if (switches[i].known)
5291                       switches[i].validated = true;
5292                   }
5293
5294               p += len;
5295             }
5296             break;
5297
5298           case '*':
5299             if (soft_matched_part)
5300               {
5301                 if (soft_matched_part[0])
5302                   do_spec_1 (soft_matched_part, 1, NULL);
5303                 do_spec_1 (" ", 0, NULL);
5304               }
5305             else
5306               /* Catch the case where a spec string contains something like
5307                  '%{foo:%*}'.  i.e. there is no * in the pattern on the left
5308                  hand side of the :.  */
5309               error ("spec failure: %<%%*%> has not been initialized by pattern match");
5310             break;
5311
5312             /* Process a string found as the value of a spec given by name.
5313                This feature allows individual machine descriptions
5314                to add and use their own specs.  */
5315           case '(':
5316             {
5317               const char *name = p;
5318               struct spec_list *sl;
5319               int len;
5320
5321               /* The string after the S/P is the name of a spec that is to be
5322                  processed.  */
5323               while (*p && *p != ')')
5324                 p++;
5325
5326               /* See if it's in the list.  */
5327               for (len = p - name, sl = specs; sl; sl = sl->next)
5328                 if (sl->name_len == len && !strncmp (sl->name, name, len))
5329                   {
5330                     name = *(sl->ptr_spec);
5331 #ifdef DEBUG_SPECS
5332                     fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5333                              sl->name, name);
5334 #endif
5335                     break;
5336                   }
5337
5338               if (sl)
5339                 {
5340                   value = do_spec_1 (name, 0, NULL);
5341                   if (value != 0)
5342                     return value;
5343                 }
5344
5345               /* Discard the closing paren.  */
5346               if (*p)
5347                 p++;
5348             }
5349             break;
5350
5351           default:
5352             error ("spec failure: unrecognized spec option %qc", c);
5353             break;
5354           }
5355         break;
5356
5357       case '\\':
5358         /* Backslash: treat next character as ordinary.  */
5359         c = *p++;
5360
5361         /* Fall through.  */
5362       default:
5363         /* Ordinary character: put it into the current argument.  */
5364         obstack_1grow (&obstack, c);
5365         arg_going = 1;
5366       }
5367
5368   /* End of string.  If we are processing a spec function, we need to
5369      end any pending argument.  */
5370   if (processing_spec_function)
5371     end_going_arg ();
5372
5373   return 0;
5374 }
5375
5376 /* Look up a spec function.  */
5377
5378 static const struct spec_function *
5379 lookup_spec_function (const char *name)
5380 {
5381   const struct spec_function *sf;
5382
5383   for (sf = static_spec_functions; sf->name != NULL; sf++)
5384     if (strcmp (sf->name, name) == 0)
5385       return sf;
5386
5387   return NULL;
5388 }
5389
5390 /* Evaluate a spec function.  */
5391
5392 static const char *
5393 eval_spec_function (const char *func, const char *args)
5394 {
5395   const struct spec_function *sf;
5396   const char *funcval;
5397
5398   /* Saved spec processing context.  */
5399   vec<const_char_p> save_argbuf;
5400
5401   int save_arg_going;
5402   int save_delete_this_arg;
5403   int save_this_is_output_file;
5404   int save_this_is_library_file;
5405   int save_input_from_pipe;
5406   int save_this_is_linker_script;
5407   const char *save_suffix_subst;
5408
5409   int save_growing_size;
5410   void *save_growing_value;
5411
5412   sf = lookup_spec_function (func);
5413   if (sf == NULL)
5414     fatal_error ("unknown spec function %qs", func);
5415
5416   /* Push the spec processing context.  */
5417   save_argbuf = argbuf;
5418
5419   save_arg_going = arg_going;
5420   save_delete_this_arg = delete_this_arg;
5421   save_this_is_output_file = this_is_output_file;
5422   save_this_is_library_file = this_is_library_file;
5423   save_this_is_linker_script = this_is_linker_script;
5424   save_input_from_pipe = input_from_pipe;
5425   save_suffix_subst = suffix_subst;
5426
5427   /* If we have some object growing now, finalize it so the args and function
5428      eval proceed from a cleared context.  This is needed to prevent the first
5429      constructed arg from mistakenly including the growing value.  We'll push
5430      this value back on the obstack once the function evaluation is done, to
5431      restore a consistent processing context for our caller.  This is fine as
5432      the address of growing objects isn't guaranteed to remain stable until
5433      they are finalized, and we expect this situation to be rare enough for
5434      the extra copy not to be an issue.  */
5435   save_growing_size = obstack_object_size (&obstack);
5436   if (save_growing_size > 0)
5437     save_growing_value = obstack_finish (&obstack);
5438
5439   /* Create a new spec processing context, and build the function
5440      arguments.  */
5441
5442   alloc_args ();
5443   if (do_spec_2 (args) < 0)
5444     fatal_error ("error in args to spec function %qs", func);
5445
5446   /* argbuf_index is an index for the next argument to be inserted, and
5447      so contains the count of the args already inserted.  */
5448
5449   funcval = (*sf->func) (argbuf.length (),
5450                          argbuf.address ());
5451
5452   /* Pop the spec processing context.  */
5453   argbuf.release ();
5454   argbuf = save_argbuf;
5455
5456   arg_going = save_arg_going;
5457   delete_this_arg = save_delete_this_arg;
5458   this_is_output_file = save_this_is_output_file;
5459   this_is_library_file = save_this_is_library_file;
5460   this_is_linker_script = save_this_is_linker_script;
5461   input_from_pipe = save_input_from_pipe;
5462   suffix_subst = save_suffix_subst;
5463
5464   if (save_growing_size > 0)
5465     obstack_grow (&obstack, save_growing_value, save_growing_size);
5466
5467   return funcval;
5468 }
5469
5470 /* Handle a spec function call of the form:
5471
5472    %:function(args)
5473
5474    ARGS is processed as a spec in a separate context and split into an
5475    argument vector in the normal fashion.  The function returns a string
5476    containing a spec which we then process in the caller's context, or
5477    NULL if no processing is required.  */
5478
5479 static const char *
5480 handle_spec_function (const char *p)
5481 {
5482   char *func, *args;
5483   const char *endp, *funcval;
5484   int count;
5485
5486   processing_spec_function++;
5487
5488   /* Get the function name.  */
5489   for (endp = p; *endp != '\0'; endp++)
5490     {
5491       if (*endp == '(')         /* ) */
5492         break;
5493       /* Only allow [A-Za-z0-9], -, and _ in function names.  */
5494       if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5495         fatal_error ("malformed spec function name");
5496     }
5497   if (*endp != '(')             /* ) */
5498     fatal_error ("no arguments for spec function");
5499   func = save_string (p, endp - p);
5500   p = ++endp;
5501
5502   /* Get the arguments.  */
5503   for (count = 0; *endp != '\0'; endp++)
5504     {
5505       /* ( */
5506       if (*endp == ')')
5507         {
5508           if (count == 0)
5509             break;
5510           count--;
5511         }
5512       else if (*endp == '(')    /* ) */
5513         count++;
5514     }
5515   /* ( */
5516   if (*endp != ')')
5517     fatal_error ("malformed spec function arguments");
5518   args = save_string (p, endp - p);
5519   p = ++endp;
5520
5521   /* p now points to just past the end of the spec function expression.  */
5522
5523   funcval = eval_spec_function (func, args);
5524   if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5525     p = NULL;
5526
5527   free (func);
5528   free (args);
5529
5530   processing_spec_function--;
5531
5532   return p;
5533 }
5534
5535 /* Inline subroutine of handle_braces.  Returns true if the current
5536    input suffix matches the atom bracketed by ATOM and END_ATOM.  */
5537 static inline bool
5538 input_suffix_matches (const char *atom, const char *end_atom)
5539 {
5540   return (input_suffix
5541           && !strncmp (input_suffix, atom, end_atom - atom)
5542           && input_suffix[end_atom - atom] == '\0');
5543 }
5544
5545 /* Subroutine of handle_braces.  Returns true if the current
5546    input file's spec name matches the atom bracketed by ATOM and END_ATOM.  */
5547 static bool
5548 input_spec_matches (const char *atom, const char *end_atom)
5549 {
5550   return (input_file_compiler
5551           && input_file_compiler->suffix
5552           && input_file_compiler->suffix[0] != '\0'
5553           && !strncmp (input_file_compiler->suffix + 1, atom,
5554                        end_atom - atom)
5555           && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5556 }
5557
5558 /* Subroutine of handle_braces.  Returns true if a switch
5559    matching the atom bracketed by ATOM and END_ATOM appeared on the
5560    command line.  */
5561 static bool
5562 switch_matches (const char *atom, const char *end_atom, int starred)
5563 {
5564   int i;
5565   int len = end_atom - atom;
5566   int plen = starred ? len : -1;
5567
5568   for (i = 0; i < n_switches; i++)
5569     if (!strncmp (switches[i].part1, atom, len)
5570         && (starred || switches[i].part1[len] == '\0')
5571         && check_live_switch (i, plen))
5572       return true;
5573
5574     /* Check if a switch with separated form matching the atom.
5575        We check -D and -U switches. */
5576     else if (switches[i].args != 0)
5577       {
5578         if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
5579             && *switches[i].part1 == atom[0])
5580           {
5581             if (!strncmp (switches[i].args[0], &atom[1], len - 1)
5582                 && (starred || (switches[i].part1[1] == '\0'
5583                                 && switches[i].args[0][len - 1] == '\0'))
5584                 && check_live_switch (i, (starred ? 1 : -1)))
5585               return true;
5586           }
5587       }
5588
5589   return false;
5590 }
5591
5592 /* Inline subroutine of handle_braces.  Mark all of the switches which
5593    match ATOM (extends to END_ATOM; STARRED indicates whether there
5594    was a star after the atom) for later processing.  */
5595 static inline void
5596 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5597 {
5598   int i;
5599   int len = end_atom - atom;
5600   int plen = starred ? len : -1;
5601
5602   for (i = 0; i < n_switches; i++)
5603     if (!strncmp (switches[i].part1, atom, len)
5604         && (starred || switches[i].part1[len] == '\0')
5605         && check_live_switch (i, plen))
5606       switches[i].ordering = 1;
5607 }
5608
5609 /* Inline subroutine of handle_braces.  Process all the currently
5610    marked switches through give_switch, and clear the marks.  */
5611 static inline void
5612 process_marked_switches (void)
5613 {
5614   int i;
5615
5616   for (i = 0; i < n_switches; i++)
5617     if (switches[i].ordering == 1)
5618       {
5619         switches[i].ordering = 0;
5620         give_switch (i, 0);
5621       }
5622 }
5623
5624 /* Handle a %{ ... } construct.  P points just inside the leading {.
5625    Returns a pointer one past the end of the brace block, or 0
5626    if we call do_spec_1 and that returns -1.  */
5627
5628 static const char *
5629 handle_braces (const char *p)
5630 {
5631   const char *atom, *end_atom;
5632   const char *d_atom = NULL, *d_end_atom = NULL;
5633   const char *orig = p;
5634
5635   bool a_is_suffix;
5636   bool a_is_spectype;
5637   bool a_is_starred;
5638   bool a_is_negated;
5639   bool a_matched;
5640
5641   bool a_must_be_last = false;
5642   bool ordered_set    = false;
5643   bool disjunct_set   = false;
5644   bool disj_matched   = false;
5645   bool disj_starred   = true;
5646   bool n_way_choice   = false;
5647   bool n_way_matched  = false;
5648
5649 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5650
5651   do
5652     {
5653       if (a_must_be_last)
5654         goto invalid;
5655
5656       /* Scan one "atom" (S in the description above of %{}, possibly
5657          with '!', '.', '@', ',', or '*' modifiers).  */
5658       a_matched = false;
5659       a_is_suffix = false;
5660       a_is_starred = false;
5661       a_is_negated = false;
5662       a_is_spectype = false;
5663
5664       SKIP_WHITE();
5665       if (*p == '!')
5666         p++, a_is_negated = true;
5667
5668       SKIP_WHITE();
5669       if (*p == '.')
5670         p++, a_is_suffix = true;
5671       else if (*p == ',')
5672         p++, a_is_spectype = true;
5673
5674       atom = p;
5675       while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5676              || *p == ',' || *p == '.' || *p == '@')
5677         p++;
5678       end_atom = p;
5679
5680       if (*p == '*')
5681         p++, a_is_starred = 1;
5682
5683       SKIP_WHITE();
5684       switch (*p)
5685         {
5686         case '&': case '}':
5687           /* Substitute the switch(es) indicated by the current atom.  */
5688           ordered_set = true;
5689           if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5690               || a_is_spectype || atom == end_atom)
5691             goto invalid;
5692
5693           mark_matching_switches (atom, end_atom, a_is_starred);
5694
5695           if (*p == '}')
5696             process_marked_switches ();
5697           break;
5698
5699         case '|': case ':':
5700           /* Substitute some text if the current atom appears as a switch
5701              or suffix.  */
5702           disjunct_set = true;
5703           if (ordered_set)
5704             goto invalid;
5705
5706           if (atom == end_atom)
5707             {
5708               if (!n_way_choice || disj_matched || *p == '|'
5709                   || a_is_negated || a_is_suffix || a_is_spectype
5710                   || a_is_starred)
5711                 goto invalid;
5712
5713               /* An empty term may appear as the last choice of an
5714                  N-way choice set; it means "otherwise".  */
5715               a_must_be_last = true;
5716               disj_matched = !n_way_matched;
5717               disj_starred = false;
5718             }
5719           else
5720             {
5721               if ((a_is_suffix || a_is_spectype) && a_is_starred)
5722                 goto invalid;
5723
5724               if (!a_is_starred)
5725                 disj_starred = false;
5726
5727               /* Don't bother testing this atom if we already have a
5728                  match.  */
5729               if (!disj_matched && !n_way_matched)
5730                 {
5731                   if (a_is_suffix)
5732                     a_matched = input_suffix_matches (atom, end_atom);
5733                   else if (a_is_spectype)
5734                     a_matched = input_spec_matches (atom, end_atom);
5735                   else
5736                     a_matched = switch_matches (atom, end_atom, a_is_starred);
5737
5738                   if (a_matched != a_is_negated)
5739                     {
5740                       disj_matched = true;
5741                       d_atom = atom;
5742                       d_end_atom = end_atom;
5743                     }
5744                 }
5745             }
5746
5747           if (*p == ':')
5748             {
5749               /* Found the body, that is, the text to substitute if the
5750                  current disjunction matches.  */
5751               p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5752                                       disj_matched && !n_way_matched);
5753               if (p == 0)
5754                 return 0;
5755
5756               /* If we have an N-way choice, reset state for the next
5757                  disjunction.  */
5758               if (*p == ';')
5759                 {
5760                   n_way_choice = true;
5761                   n_way_matched |= disj_matched;
5762                   disj_matched = false;
5763                   disj_starred = true;
5764                   d_atom = d_end_atom = NULL;
5765                 }
5766             }
5767           break;
5768
5769         default:
5770           goto invalid;
5771         }
5772     }
5773   while (*p++ != '}');
5774
5775   return p;
5776
5777  invalid:
5778   fatal_error ("braced spec %qs is invalid at %qc", orig, *p);
5779
5780 #undef SKIP_WHITE
5781 }
5782
5783 /* Subroutine of handle_braces.  Scan and process a brace substitution body
5784    (X in the description of %{} syntax).  P points one past the colon;
5785    ATOM and END_ATOM bracket the first atom which was found to be true
5786    (present) in the current disjunction; STARRED indicates whether all
5787    the atoms in the current disjunction were starred (for syntax validation);
5788    MATCHED indicates whether the disjunction matched or not, and therefore
5789    whether or not the body is to be processed through do_spec_1 or just
5790    skipped.  Returns a pointer to the closing } or ;, or 0 if do_spec_1
5791    returns -1.  */
5792
5793 static const char *
5794 process_brace_body (const char *p, const char *atom, const char *end_atom,
5795                     int starred, int matched)
5796 {
5797   const char *body, *end_body;
5798   unsigned int nesting_level;
5799   bool have_subst     = false;
5800
5801   /* Locate the closing } or ;, honoring nested braces.
5802      Trim trailing whitespace.  */
5803   body = p;
5804   nesting_level = 1;
5805   for (;;)
5806     {
5807       if (*p == '{')
5808         nesting_level++;
5809       else if (*p == '}')
5810         {
5811           if (!--nesting_level)
5812             break;
5813         }
5814       else if (*p == ';' && nesting_level == 1)
5815         break;
5816       else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5817         have_subst = true;
5818       else if (*p == '\0')
5819         goto invalid;
5820       p++;
5821     }
5822
5823   end_body = p;
5824   while (end_body[-1] == ' ' || end_body[-1] == '\t')
5825     end_body--;
5826
5827   if (have_subst && !starred)
5828     goto invalid;
5829
5830   if (matched)
5831     {
5832       /* Copy the substitution body to permanent storage and execute it.
5833          If have_subst is false, this is a simple matter of running the
5834          body through do_spec_1...  */
5835       char *string = save_string (body, end_body - body);
5836       if (!have_subst)
5837         {
5838           if (do_spec_1 (string, 0, NULL) < 0)
5839             return 0;
5840         }
5841       else
5842         {
5843           /* ... but if have_subst is true, we have to process the
5844              body once for each matching switch, with %* set to the
5845              variant part of the switch.  */
5846           unsigned int hard_match_len = end_atom - atom;
5847           int i;
5848
5849           for (i = 0; i < n_switches; i++)
5850             if (!strncmp (switches[i].part1, atom, hard_match_len)
5851                 && check_live_switch (i, hard_match_len))
5852               {
5853                 if (do_spec_1 (string, 0,
5854                                &switches[i].part1[hard_match_len]) < 0)
5855                   return 0;
5856                 /* Pass any arguments this switch has.  */
5857                 give_switch (i, 1);
5858                 suffix_subst = NULL;
5859               }
5860         }
5861     }
5862
5863   return p;
5864
5865  invalid:
5866   fatal_error ("braced spec body %qs is invalid", body);
5867 }
5868 \f
5869 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5870    on the command line.  PREFIX_LENGTH is the length of XXX in an {XXX*}
5871    spec, or -1 if either exact match or %* is used.
5872
5873    A -O switch is obsoleted by a later -O switch.  A -f, -g, -m, or -W switch
5874    whose value does not begin with "no-" is obsoleted by the same value
5875    with the "no-", similarly for a switch with the "no-" prefix.  */
5876
5877 static int
5878 check_live_switch (int switchnum, int prefix_length)
5879 {
5880   const char *name = switches[switchnum].part1;
5881   int i;
5882
5883   /* If we already processed this switch and determined if it was
5884      live or not, return our past determination.  */
5885   if (switches[switchnum].live_cond != 0)
5886     return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
5887             && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
5888             && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
5889                == 0);
5890
5891   /* In the common case of {<at-most-one-letter>*}, a negating
5892      switch would always match, so ignore that case.  We will just
5893      send the conflicting switches to the compiler phase.  */
5894   if (prefix_length >= 0 && prefix_length <= 1)
5895     return 1;
5896
5897   /* Now search for duplicate in a manner that depends on the name.  */
5898   switch (*name)
5899     {
5900     case 'O':
5901       for (i = switchnum + 1; i < n_switches; i++)
5902         if (switches[i].part1[0] == 'O')
5903           {
5904             switches[switchnum].validated = true;
5905             switches[switchnum].live_cond = SWITCH_FALSE;
5906             return 0;
5907           }
5908       break;
5909
5910     case 'W':  case 'f':  case 'm': case 'g':
5911       if (! strncmp (name + 1, "no-", 3))
5912         {
5913           /* We have Xno-YYY, search for XYYY.  */
5914           for (i = switchnum + 1; i < n_switches; i++)
5915             if (switches[i].part1[0] == name[0]
5916                 && ! strcmp (&switches[i].part1[1], &name[4]))
5917               {
5918                 /* --specs are validated with the validate_switches mechanism.  */
5919                 if (switches[switchnum].known)
5920                   switches[switchnum].validated = true;
5921                 switches[switchnum].live_cond = SWITCH_FALSE;
5922                 return 0;
5923               }
5924         }
5925       else
5926         {
5927           /* We have XYYY, search for Xno-YYY.  */
5928           for (i = switchnum + 1; i < n_switches; i++)
5929             if (switches[i].part1[0] == name[0]
5930                 && switches[i].part1[1] == 'n'
5931                 && switches[i].part1[2] == 'o'
5932                 && switches[i].part1[3] == '-'
5933                 && !strcmp (&switches[i].part1[4], &name[1]))
5934               {
5935                 /* --specs are validated with the validate_switches mechanism.  */
5936                 if (switches[switchnum].known)
5937                   switches[switchnum].validated = true;
5938                 switches[switchnum].live_cond = SWITCH_FALSE;
5939                 return 0;
5940               }
5941         }
5942       break;
5943     }
5944
5945   /* Otherwise the switch is live.  */
5946   switches[switchnum].live_cond |= SWITCH_LIVE;
5947   return 1;
5948 }
5949 \f
5950 /* Pass a switch to the current accumulating command
5951    in the same form that we received it.
5952    SWITCHNUM identifies the switch; it is an index into
5953    the vector of switches gcc received, which is `switches'.
5954    This cannot fail since it never finishes a command line.
5955
5956    If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument.  */
5957
5958 static void
5959 give_switch (int switchnum, int omit_first_word)
5960 {
5961   if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
5962     return;
5963
5964   if (!omit_first_word)
5965     {
5966       do_spec_1 ("-", 0, NULL);
5967       do_spec_1 (switches[switchnum].part1, 1, NULL);
5968     }
5969
5970   if (switches[switchnum].args != 0)
5971     {
5972       const char **p;
5973       for (p = switches[switchnum].args; *p; p++)
5974         {
5975           const char *arg = *p;
5976
5977           do_spec_1 (" ", 0, NULL);
5978           if (suffix_subst)
5979             {
5980               unsigned length = strlen (arg);
5981               int dot = 0;
5982
5983               while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5984                 if (arg[length] == '.')
5985                   {
5986                     (CONST_CAST(char *, arg))[length] = 0;
5987                     dot = 1;
5988                     break;
5989                   }
5990               do_spec_1 (arg, 1, NULL);
5991               if (dot)
5992                 (CONST_CAST(char *, arg))[length] = '.';
5993               do_spec_1 (suffix_subst, 1, NULL);
5994             }
5995           else
5996             do_spec_1 (arg, 1, NULL);
5997         }
5998     }
5999
6000   do_spec_1 (" ", 0, NULL);
6001   switches[switchnum].validated = true;
6002 }
6003 \f
6004 /* Search for a file named NAME trying various prefixes including the
6005    user's -B prefix and some standard ones.
6006    Return the absolute file name found.  If nothing is found, return NAME.  */
6007
6008 static const char *
6009 find_file (const char *name)
6010 {
6011   char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6012   return newname ? newname : name;
6013 }
6014
6015 /* Determine whether a directory exists.  If LINKER, return 0 for
6016    certain fixed names not needed by the linker.  */
6017
6018 static int
6019 is_directory (const char *path1, bool linker)
6020 {
6021   int len1;
6022   char *path;
6023   char *cp;
6024   struct stat st;
6025
6026   /* Ensure the string ends with "/.".  The resulting path will be a
6027      directory even if the given path is a symbolic link.  */
6028   len1 = strlen (path1);
6029   path = (char *) alloca (3 + len1);
6030   memcpy (path, path1, len1);
6031   cp = path + len1;
6032   if (!IS_DIR_SEPARATOR (cp[-1]))
6033     *cp++ = DIR_SEPARATOR;
6034   *cp++ = '.';
6035   *cp = '\0';
6036
6037   /* Exclude directories that the linker is known to search.  */
6038   if (linker
6039       && IS_DIR_SEPARATOR (path[0])
6040       && ((cp - path == 6
6041            && filename_ncmp (path + 1, "lib", 3) == 0)
6042           || (cp - path == 10
6043               && filename_ncmp (path + 1, "usr", 3) == 0
6044               && IS_DIR_SEPARATOR (path[4])
6045               && filename_ncmp (path + 5, "lib", 3) == 0)))
6046     return 0;
6047
6048   return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6049 }
6050
6051 /* Set up the various global variables to indicate that we're processing
6052    the input file named FILENAME.  */
6053
6054 void
6055 set_input (const char *filename)
6056 {
6057   const char *p;
6058
6059   gcc_input_filename = filename;
6060   input_filename_length = strlen (gcc_input_filename);
6061   input_basename = lbasename (gcc_input_filename);
6062
6063   /* Find a suffix starting with the last period,
6064      and set basename_length to exclude that suffix.  */
6065   basename_length = strlen (input_basename);
6066   suffixed_basename_length = basename_length;
6067   p = input_basename + basename_length;
6068   while (p != input_basename && *p != '.')
6069     --p;
6070   if (*p == '.' && p != input_basename)
6071     {
6072       basename_length = p - input_basename;
6073       input_suffix = p + 1;
6074     }
6075   else
6076     input_suffix = "";
6077
6078   /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6079      we will need to do a stat on the gcc_input_filename.  The
6080      INPUT_STAT_SET signals that the stat is needed.  */
6081   input_stat_set = 0;
6082 }
6083 \f
6084 /* On fatal signals, delete all the temporary files.  */
6085
6086 static void
6087 fatal_signal (int signum)
6088 {
6089   signal (signum, SIG_DFL);
6090   delete_failure_queue ();
6091   delete_temp_files ();
6092   /* Get the same signal again, this time not handled,
6093      so its normal effect occurs.  */
6094   kill (getpid (), signum);
6095 }
6096
6097 /* Compare the contents of the two files named CMPFILE[0] and
6098    CMPFILE[1].  Return zero if they're identical, nonzero
6099    otherwise.  */
6100
6101 static int
6102 compare_files (char *cmpfile[])
6103 {
6104   int ret = 0;
6105   FILE *temp[2] = { NULL, NULL };
6106   int i;
6107
6108 #if HAVE_MMAP_FILE
6109   {
6110     size_t length[2];
6111     void *map[2] = { NULL, NULL };
6112
6113     for (i = 0; i < 2; i++)
6114       {
6115         struct stat st;
6116
6117         if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6118           {
6119             error ("%s: could not determine length of compare-debug file %s",
6120                    gcc_input_filename, cmpfile[i]);
6121             ret = 1;
6122             break;
6123           }
6124
6125         length[i] = st.st_size;
6126       }
6127
6128     if (!ret && length[0] != length[1])
6129       {
6130         error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
6131         ret = 1;
6132       }
6133
6134     if (!ret)
6135       for (i = 0; i < 2; i++)
6136         {
6137           int fd = open (cmpfile[i], O_RDONLY);
6138           if (fd < 0)
6139             {
6140               error ("%s: could not open compare-debug file %s",
6141                      gcc_input_filename, cmpfile[i]);
6142               ret = 1;
6143               break;
6144             }
6145
6146           map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
6147           close (fd);
6148
6149           if (map[i] == (void *) MAP_FAILED)
6150             {
6151               ret = -1;
6152               break;
6153             }
6154         }
6155
6156     if (!ret)
6157       {
6158         if (memcmp (map[0], map[1], length[0]) != 0)
6159           {
6160             error ("%s: -fcompare-debug failure", gcc_input_filename);
6161             ret = 1;
6162           }
6163       }
6164
6165     for (i = 0; i < 2; i++)
6166       if (map[i])
6167         munmap ((caddr_t) map[i], length[i]);
6168
6169     if (ret >= 0)
6170       return ret;
6171
6172     ret = 0;
6173   }
6174 #endif
6175
6176   for (i = 0; i < 2; i++)
6177     {
6178       temp[i] = fopen (cmpfile[i], "r");
6179       if (!temp[i])
6180         {
6181           error ("%s: could not open compare-debug file %s",
6182                  gcc_input_filename, cmpfile[i]);
6183           ret = 1;
6184           break;
6185         }
6186     }
6187
6188   if (!ret && temp[0] && temp[1])
6189     for (;;)
6190       {
6191         int c0, c1;
6192         c0 = fgetc (temp[0]);
6193         c1 = fgetc (temp[1]);
6194
6195         if (c0 != c1)
6196           {
6197             error ("%s: -fcompare-debug failure",
6198                    gcc_input_filename);
6199             ret = 1;
6200             break;
6201           }
6202
6203         if (c0 == EOF)
6204           break;
6205       }
6206
6207   for (i = 1; i >= 0; i--)
6208     {
6209       if (temp[i])
6210         fclose (temp[i]);
6211     }
6212
6213   return ret;
6214 }
6215
6216 extern int main (int, char **);
6217
6218 int
6219 main (int argc, char **argv)
6220 {
6221   size_t i;
6222   int value;
6223   int linker_was_run = 0;
6224   int lang_n_infiles = 0;
6225   int num_linker_inputs = 0;
6226   char *explicit_link_files;
6227   char *specs_file;
6228   char *lto_wrapper_file;
6229   const char *p;
6230   struct user_specs *uptr;
6231   char **old_argv = argv;
6232   struct cl_decoded_option *decoded_options;
6233   unsigned int decoded_options_count;
6234
6235   p = argv[0] + strlen (argv[0]);
6236   while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6237     --p;
6238   progname = p;
6239
6240   xmalloc_set_program_name (progname);
6241
6242   expandargv (&argc, &argv);
6243
6244   /* Determine if any expansions were made.  */
6245   if (argv != old_argv)
6246     at_file_supplied = true;
6247
6248   /* Register the language-independent parameters.  */
6249   global_init_params ();
6250   finish_params ();
6251
6252   init_options_struct (&global_options, &global_options_set);
6253
6254   decode_cmdline_options_to_array (argc, CONST_CAST2 (const char **, char **,
6255                                                       argv),
6256                                    CL_DRIVER,
6257                                    &decoded_options, &decoded_options_count);
6258
6259   /* Unlock the stdio streams.  */
6260   unlock_std_streams ();
6261
6262   gcc_init_libintl ();
6263
6264   diagnostic_initialize (global_dc, 0);
6265
6266 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6267   /* Perform host dependent initialization when needed.  */
6268   GCC_DRIVER_HOST_INITIALIZATION;
6269 #endif
6270
6271   if (atexit (delete_temp_files) != 0)
6272     fatal_error ("atexit failed");
6273
6274   if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6275     signal (SIGINT, fatal_signal);
6276 #ifdef SIGHUP
6277   if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6278     signal (SIGHUP, fatal_signal);
6279 #endif
6280   if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6281     signal (SIGTERM, fatal_signal);
6282 #ifdef SIGPIPE
6283   if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6284     signal (SIGPIPE, fatal_signal);
6285 #endif
6286 #ifdef SIGCHLD
6287   /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6288      receive the signal.  A different setting is inheritable */
6289   signal (SIGCHLD, SIG_DFL);
6290 #endif
6291
6292   /* Parsing and gimplification sometimes need quite large stack.
6293      Increase stack size limits if possible.  */
6294   stack_limit_increase (64 * 1024 * 1024);
6295
6296   /* Allocate the argument vector.  */
6297   alloc_args ();
6298
6299   obstack_init (&obstack);
6300
6301   /* Build multilib_select, et. al from the separate lines that make up each
6302      multilib selection.  */
6303   {
6304     const char *const *q = multilib_raw;
6305     int need_space;
6306
6307     obstack_init (&multilib_obstack);
6308     while ((p = *q++) != (char *) 0)
6309       obstack_grow (&multilib_obstack, p, strlen (p));
6310
6311     obstack_1grow (&multilib_obstack, 0);
6312     multilib_select = XOBFINISH (&multilib_obstack, const char *);
6313
6314     q = multilib_matches_raw;
6315     while ((p = *q++) != (char *) 0)
6316       obstack_grow (&multilib_obstack, p, strlen (p));
6317
6318     obstack_1grow (&multilib_obstack, 0);
6319     multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6320
6321     q = multilib_exclusions_raw;
6322     while ((p = *q++) != (char *) 0)
6323       obstack_grow (&multilib_obstack, p, strlen (p));
6324
6325     obstack_1grow (&multilib_obstack, 0);
6326     multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6327
6328     need_space = FALSE;
6329     for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6330       {
6331         if (need_space)
6332           obstack_1grow (&multilib_obstack, ' ');
6333         obstack_grow (&multilib_obstack,
6334                       multilib_defaults_raw[i],
6335                       strlen (multilib_defaults_raw[i]));
6336         need_space = TRUE;
6337       }
6338
6339     obstack_1grow (&multilib_obstack, 0);
6340     multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6341   }
6342
6343 #ifdef INIT_ENVIRONMENT
6344   /* Set up any other necessary machine specific environment variables.  */
6345   xputenv (INIT_ENVIRONMENT);
6346 #endif
6347
6348   /* Make a table of what switches there are (switches, n_switches).
6349      Make a table of specified input files (infiles, n_infiles).
6350      Decode switches that are handled locally.  */
6351
6352   process_command (decoded_options_count, decoded_options);
6353
6354   /* Initialize the vector of specs to just the default.
6355      This means one element containing 0s, as a terminator.  */
6356
6357   compilers = XNEWVAR (struct compiler, sizeof default_compilers);
6358   memcpy (compilers, default_compilers, sizeof default_compilers);
6359   n_compilers = n_default_compilers;
6360
6361   /* Read specs from a file if there is one.  */
6362
6363   machine_suffix = concat (spec_machine, dir_separator_str,
6364                            spec_version, dir_separator_str, NULL);
6365   just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6366
6367   specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
6368   /* Read the specs file unless it is a default one.  */
6369   if (specs_file != 0 && strcmp (specs_file, "specs"))
6370     read_specs (specs_file, true, false);
6371   else
6372     init_spec ();
6373
6374   /* We need to check standard_exec_prefix/just_machine_suffix/specs
6375      for any override of as, ld and libraries.  */
6376   specs_file = (char *) alloca (strlen (standard_exec_prefix)
6377                        + strlen (just_machine_suffix) + sizeof ("specs"));
6378
6379   strcpy (specs_file, standard_exec_prefix);
6380   strcat (specs_file, just_machine_suffix);
6381   strcat (specs_file, "specs");
6382   if (access (specs_file, R_OK) == 0)
6383     read_specs (specs_file, true, false);
6384
6385   /* Process any configure-time defaults specified for the command line
6386      options, via OPTION_DEFAULT_SPECS.  */
6387   for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6388     do_option_spec (option_default_specs[i].name,
6389                     option_default_specs[i].spec);
6390
6391   /* Process DRIVER_SELF_SPECS, adding any new options to the end
6392      of the command line.  */
6393
6394   for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6395     do_self_spec (driver_self_specs[i]);
6396
6397   /* If not cross-compiling, look for executables in the standard
6398      places.  */
6399   if (*cross_compile == '0')
6400     {
6401       if (*md_exec_prefix)
6402         {
6403           add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6404                       PREFIX_PRIORITY_LAST, 0, 0);
6405         }
6406     }
6407
6408   /* Process sysroot_suffix_spec.  */
6409   if (*sysroot_suffix_spec != 0
6410       && !no_sysroot_suffix
6411       && do_spec_2 (sysroot_suffix_spec) == 0)
6412     {
6413       if (argbuf.length () > 1)
6414         error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
6415       else if (argbuf.length () == 1)
6416         target_sysroot_suffix = xstrdup (argbuf.last ());
6417     }
6418
6419 #ifdef HAVE_LD_SYSROOT
6420   /* Pass the --sysroot option to the linker, if it supports that.  If
6421      there is a sysroot_suffix_spec, it has already been processed by
6422      this point, so target_system_root really is the system root we
6423      should be using.  */
6424   if (target_system_root)
6425     {
6426       obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6427       obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6428       set_spec ("link", XOBFINISH (&obstack, const char *), false);
6429     }
6430 #endif
6431
6432   /* Process sysroot_hdrs_suffix_spec.  */
6433   if (*sysroot_hdrs_suffix_spec != 0
6434       && !no_sysroot_suffix
6435       && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6436     {
6437       if (argbuf.length () > 1)
6438         error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
6439       else if (argbuf.length () == 1)
6440         target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
6441     }
6442
6443   /* Look for startfiles in the standard places.  */
6444   if (*startfile_prefix_spec != 0
6445       && do_spec_2 (startfile_prefix_spec) == 0
6446       && do_spec_1 (" ", 0, NULL) == 0)
6447     {
6448       const char *arg;
6449       int ndx;
6450       FOR_EACH_VEC_ELT (argbuf, ndx, arg)
6451         add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
6452                               PREFIX_PRIORITY_LAST, 0, 1);
6453     }
6454   /* We should eventually get rid of all these and stick to
6455      startfile_prefix_spec exclusively.  */
6456   else if (*cross_compile == '0' || target_system_root)
6457     {
6458       if (*md_startfile_prefix)
6459         add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6460                               "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6461
6462       if (*md_startfile_prefix_1)
6463         add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6464                               "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6465
6466       /* If standard_startfile_prefix is relative, base it on
6467          standard_exec_prefix.  This lets us move the installed tree
6468          as a unit.  If GCC_EXEC_PREFIX is defined, base
6469          standard_startfile_prefix on that as well.
6470
6471          If the prefix is relative, only search it for native compilers;
6472          otherwise we will search a directory containing host libraries.  */
6473       if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6474         add_sysrooted_prefix (&startfile_prefixes,
6475                               standard_startfile_prefix, "BINUTILS",
6476                               PREFIX_PRIORITY_LAST, 0, 1);
6477       else if (*cross_compile == '0')
6478         {
6479           add_prefix (&startfile_prefixes,
6480                       concat (gcc_exec_prefix
6481                               ? gcc_exec_prefix : standard_exec_prefix,
6482                               machine_suffix,
6483                               standard_startfile_prefix, NULL),
6484                       NULL, PREFIX_PRIORITY_LAST, 0, 1);
6485         }
6486
6487       /* Sysrooted prefixes are relocated because target_system_root is
6488          also relocated by gcc_exec_prefix.  */
6489       if (*standard_startfile_prefix_1)
6490         add_sysrooted_prefix (&startfile_prefixes,
6491                               standard_startfile_prefix_1, "BINUTILS",
6492                               PREFIX_PRIORITY_LAST, 0, 1);
6493       if (*standard_startfile_prefix_2)
6494         add_sysrooted_prefix (&startfile_prefixes,
6495                               standard_startfile_prefix_2, "BINUTILS",
6496                               PREFIX_PRIORITY_LAST, 0, 1);
6497     }
6498
6499   /* Process any user specified specs in the order given on the command
6500      line.  */
6501   for (uptr = user_specs_head; uptr; uptr = uptr->next)
6502     {
6503       char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6504                                     R_OK, true);
6505       read_specs (filename ? filename : uptr->filename, false, true);
6506     }
6507
6508   /* Process any user self specs.  */
6509   {
6510     struct spec_list *sl;
6511     for (sl = specs; sl; sl = sl->next)
6512       if (sl->name_len == sizeof "self_spec" - 1
6513           && !strcmp (sl->name, "self_spec"))
6514         do_self_spec (*sl->ptr_spec);
6515   }
6516
6517   if (compare_debug)
6518     {
6519       enum save_temps save;
6520
6521       if (!compare_debug_second)
6522         {
6523           n_switches_debug_check[1] = n_switches;
6524           n_switches_alloc_debug_check[1] = n_switches_alloc;
6525           switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
6526                                              n_switches_alloc);
6527
6528           do_self_spec ("%:compare-debug-self-opt()");
6529           n_switches_debug_check[0] = n_switches;
6530           n_switches_alloc_debug_check[0] = n_switches_alloc;
6531           switches_debug_check[0] = switches;
6532
6533           n_switches = n_switches_debug_check[1];
6534           n_switches_alloc = n_switches_alloc_debug_check[1];
6535           switches = switches_debug_check[1];
6536         }
6537
6538       /* Avoid crash when computing %j in this early.  */
6539       save = save_temps_flag;
6540       save_temps_flag = SAVE_TEMPS_NONE;
6541
6542       compare_debug = -compare_debug;
6543       do_self_spec ("%:compare-debug-self-opt()");
6544
6545       save_temps_flag = save;
6546
6547       if (!compare_debug_second)
6548         {
6549           n_switches_debug_check[1] = n_switches;
6550           n_switches_alloc_debug_check[1] = n_switches_alloc;
6551           switches_debug_check[1] = switches;
6552           compare_debug = -compare_debug;
6553           n_switches = n_switches_debug_check[0];
6554           n_switches_alloc = n_switches_debug_check[0];
6555           switches = switches_debug_check[0];
6556         }
6557     }
6558
6559
6560   /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake.  */
6561   if (gcc_exec_prefix)
6562     gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6563                               spec_version, dir_separator_str, NULL);
6564
6565   /* Now we have the specs.
6566      Set the `valid' bits for switches that match anything in any spec.  */
6567
6568   validate_all_switches ();
6569
6570   /* Now that we have the switches and the specs, set
6571      the subdirectory based on the options.  */
6572   set_multilib_dir ();
6573
6574   /* Set up to remember the pathname of gcc and any options
6575      needed for collect.  We use argv[0] instead of progname because
6576      we need the complete pathname.  */
6577   obstack_init (&collect_obstack);
6578   obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6579   obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6580   xputenv (XOBFINISH (&collect_obstack, char *));
6581
6582   /* Set up to remember the pathname of the lto wrapper. */
6583
6584   if (have_c)
6585     lto_wrapper_file = NULL;
6586   else
6587     lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
6588                                     X_OK, false);
6589   if (lto_wrapper_file)
6590     {
6591       lto_wrapper_spec = lto_wrapper_file;
6592       obstack_init (&collect_obstack);
6593       obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
6594                     sizeof ("COLLECT_LTO_WRAPPER=") - 1);
6595       obstack_grow (&collect_obstack, lto_wrapper_spec,
6596                     strlen (lto_wrapper_spec) + 1);
6597       xputenv (XOBFINISH (&collect_obstack, char *));
6598     }
6599
6600   /* Reject switches that no pass was interested in.  */
6601
6602   for (i = 0; (int) i < n_switches; i++)
6603     if (! switches[i].validated)
6604       error ("unrecognized command line option %<-%s%>", switches[i].part1);
6605
6606   /* Obey some of the options.  */
6607
6608   if (print_search_dirs)
6609     {
6610       printf (_("install: %s%s\n"),
6611               gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
6612               gcc_exec_prefix ? "" : machine_suffix);
6613       printf (_("programs: %s\n"),
6614               build_search_list (&exec_prefixes, "", false, false));
6615       printf (_("libraries: %s\n"),
6616               build_search_list (&startfile_prefixes, "", false, true));
6617       return (0);
6618     }
6619
6620   if (print_file_name)
6621     {
6622       printf ("%s\n", find_file (print_file_name));
6623       return (0);
6624     }
6625
6626   if (print_prog_name)
6627     {
6628       char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6629       printf ("%s\n", (newname ? newname : print_prog_name));
6630       return (0);
6631     }
6632
6633   if (print_multi_lib)
6634     {
6635       print_multilib_info ();
6636       return (0);
6637     }
6638
6639   if (print_multi_directory)
6640     {
6641       if (multilib_dir == NULL)
6642         printf (".\n");
6643       else
6644         printf ("%s\n", multilib_dir);
6645       return (0);
6646     }
6647
6648   if (print_multiarch)
6649     {
6650       if (multiarch_dir == NULL)
6651         printf ("\n");
6652       else
6653         printf ("%s\n", multiarch_dir);
6654       return (0);
6655     }
6656
6657   if (print_sysroot)
6658     {
6659       if (target_system_root)
6660         {
6661           if (target_sysroot_suffix)
6662             printf ("%s%s\n", target_system_root, target_sysroot_suffix);
6663           else
6664             printf ("%s\n", target_system_root);
6665         }
6666       return (0);
6667     }
6668
6669   if (print_multi_os_directory)
6670     {
6671       if (multilib_os_dir == NULL)
6672         printf (".\n");
6673       else
6674         printf ("%s\n", multilib_os_dir);
6675       return (0);
6676     }
6677
6678   if (print_sysroot_headers_suffix)
6679     {
6680       if (*sysroot_hdrs_suffix_spec)
6681         {
6682           printf("%s\n", (target_sysroot_hdrs_suffix
6683                           ? target_sysroot_hdrs_suffix
6684                           : ""));
6685           return (0);
6686         }
6687       else
6688         /* The error status indicates that only one set of fixed
6689            headers should be built.  */
6690         fatal_error ("not configured with sysroot headers suffix");
6691     }
6692
6693   if (print_help_list)
6694     {
6695       display_help ();
6696
6697       if (! verbose_flag)
6698         {
6699           printf (_("\nFor bug reporting instructions, please see:\n"));
6700           printf ("%s.\n", bug_report_url);
6701
6702           return (0);
6703         }
6704
6705       /* We do not exit here.  Instead we have created a fake input file
6706          called 'help-dummy' which needs to be compiled, and we pass this
6707          on the various sub-processes, along with the --help switch.
6708          Ensure their output appears after ours.  */
6709       fputc ('\n', stdout);
6710       fflush (stdout);
6711     }
6712
6713   if (print_version)
6714     {
6715       printf (_("%s %s%s\n"), progname, pkgversion_string,
6716               version_string);
6717       printf ("Copyright %s 2012 Free Software Foundation, Inc.\n",
6718               _("(C)"));
6719       fputs (_("This is free software; see the source for copying conditions.  There is NO\n\
6720 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
6721              stdout);
6722       if (! verbose_flag)
6723         return 0;
6724
6725       /* We do not exit here. We use the same mechanism of --help to print
6726          the version of the sub-processes. */
6727       fputc ('\n', stdout);
6728       fflush (stdout);
6729     }
6730
6731   if (verbose_flag)
6732     {
6733       int n;
6734       const char *thrmod;
6735
6736       fnotice (stderr, "Target: %s\n", spec_machine);
6737       fnotice (stderr, "Configured with: %s\n", configuration_arguments);
6738
6739 #ifdef THREAD_MODEL_SPEC
6740       /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6741          but there's no point in doing all this processing just to get
6742          thread_model back.  */
6743       obstack_init (&obstack);
6744       do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6745       obstack_1grow (&obstack, '\0');
6746       thrmod = XOBFINISH (&obstack, const char *);
6747 #else
6748       thrmod = thread_model;
6749 #endif
6750
6751       fnotice (stderr, "Thread model: %s\n", thrmod);
6752
6753       /* compiler_version is truncated at the first space when initialized
6754          from version string, so truncate version_string at the first space
6755          before comparing.  */
6756       for (n = 0; version_string[n]; n++)
6757         if (version_string[n] == ' ')
6758           break;
6759
6760       if (! strncmp (version_string, compiler_version, n)
6761           && compiler_version[n] == 0)
6762         fnotice (stderr, "gcc version %s %s\n", version_string,
6763                  pkgversion_string);
6764       else
6765         fnotice (stderr, "gcc driver version %s %sexecuting gcc version %s\n",
6766                  version_string, pkgversion_string, compiler_version);
6767
6768       if (n_infiles == 0)
6769         return (0);
6770     }
6771
6772   if (n_infiles == added_libraries)
6773     fatal_error ("no input files");
6774
6775   if (seen_error ())
6776     goto out;
6777
6778   /* Make a place to record the compiler output file names
6779      that correspond to the input files.  */
6780
6781   i = n_infiles;
6782   i += lang_specific_extra_outfiles;
6783   outfiles = XCNEWVEC (const char *, i);
6784
6785   /* Record which files were specified explicitly as link input.  */
6786
6787   explicit_link_files = XCNEWVEC (char, n_infiles);
6788
6789   combine_inputs = have_o || flag_wpa;
6790
6791   for (i = 0; (int) i < n_infiles; i++)
6792     {
6793       const char *name = infiles[i].name;
6794       struct compiler *compiler = lookup_compiler (name,
6795                                                    strlen (name),
6796                                                    infiles[i].language);
6797
6798       if (compiler && !(compiler->combinable))
6799         combine_inputs = false;
6800
6801       if (lang_n_infiles > 0 && compiler != input_file_compiler
6802           && infiles[i].language && infiles[i].language[0] != '*')
6803         infiles[i].incompiler = compiler;
6804       else if (compiler)
6805         {
6806           lang_n_infiles++;
6807           input_file_compiler = compiler;
6808           infiles[i].incompiler = compiler;
6809         }
6810       else
6811         {
6812           /* Since there is no compiler for this input file, assume it is a
6813              linker file.  */
6814           explicit_link_files[i] = 1;
6815           infiles[i].incompiler = NULL;
6816         }
6817       infiles[i].compiled = false;
6818       infiles[i].preprocessed = false;
6819     }
6820
6821   if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
6822     fatal_error ("cannot specify -o with -c, -S or -E with multiple files");
6823
6824   for (i = 0; (int) i < n_infiles; i++)
6825     {
6826       int this_file_error = 0;
6827
6828       /* Tell do_spec what to substitute for %i.  */
6829
6830       input_file_number = i;
6831       set_input (infiles[i].name);
6832
6833       if (infiles[i].compiled)
6834         continue;
6835
6836       /* Use the same thing in %o, unless cp->spec says otherwise.  */
6837
6838       outfiles[i] = gcc_input_filename;
6839
6840       /* Figure out which compiler from the file's suffix.  */
6841
6842       input_file_compiler
6843         = lookup_compiler (infiles[i].name, input_filename_length,
6844                            infiles[i].language);
6845
6846       if (input_file_compiler)
6847         {
6848           /* Ok, we found an applicable compiler.  Run its spec.  */
6849
6850           if (input_file_compiler->spec[0] == '#')
6851             {
6852               error ("%s: %s compiler not installed on this system",
6853                      gcc_input_filename, &input_file_compiler->spec[1]);
6854               this_file_error = 1;
6855             }
6856           else
6857             {
6858               if (compare_debug)
6859                 {
6860                   free (debug_check_temp_file[0]);
6861                   debug_check_temp_file[0] = NULL;
6862
6863                   free (debug_check_temp_file[1]);
6864                   debug_check_temp_file[1] = NULL;
6865                 }
6866
6867               value = do_spec (input_file_compiler->spec);
6868               infiles[i].compiled = true;
6869               if (value < 0)
6870                 this_file_error = 1;
6871               else if (compare_debug && debug_check_temp_file[0])
6872                 {
6873                   if (verbose_flag)
6874                     inform (0, "recompiling with -fcompare-debug");
6875
6876                   compare_debug = -compare_debug;
6877                   n_switches = n_switches_debug_check[1];
6878                   n_switches_alloc = n_switches_alloc_debug_check[1];
6879                   switches = switches_debug_check[1];
6880
6881                   value = do_spec (input_file_compiler->spec);
6882
6883                   compare_debug = -compare_debug;
6884                   n_switches = n_switches_debug_check[0];
6885                   n_switches_alloc = n_switches_alloc_debug_check[0];
6886                   switches = switches_debug_check[0];
6887
6888                   if (value < 0)
6889                     {
6890                       error ("during -fcompare-debug recompilation");
6891                       this_file_error = 1;
6892                     }
6893
6894                   gcc_assert (debug_check_temp_file[1]
6895                               && filename_cmp (debug_check_temp_file[0],
6896                                                debug_check_temp_file[1]));
6897
6898                   if (verbose_flag)
6899                     inform (0, "comparing final insns dumps");
6900
6901                   if (compare_files (debug_check_temp_file))
6902                     this_file_error = 1;
6903                 }
6904
6905               if (compare_debug)
6906                 {
6907                   free (debug_check_temp_file[0]);
6908                   debug_check_temp_file[0] = NULL;
6909
6910                   free (debug_check_temp_file[1]);
6911                   debug_check_temp_file[1] = NULL;
6912                 }
6913             }
6914         }
6915
6916       /* If this file's name does not contain a recognized suffix,
6917          record it as explicit linker input.  */
6918
6919       else
6920         explicit_link_files[i] = 1;
6921
6922       /* Clear the delete-on-failure queue, deleting the files in it
6923          if this compilation failed.  */
6924
6925       if (this_file_error)
6926         {
6927           delete_failure_queue ();
6928           errorcount++;
6929         }
6930       /* If this compilation succeeded, don't delete those files later.  */
6931       clear_failure_queue ();
6932     }
6933
6934   /* Reset the input file name to the first compile/object file name, for use
6935      with %b in LINK_SPEC. We use the first input file that we can find
6936      a compiler to compile it instead of using infiles.language since for
6937      languages other than C we use aliases that we then lookup later.  */
6938   if (n_infiles > 0)
6939     {
6940       int i;
6941
6942       for (i = 0; i < n_infiles ; i++)
6943         if (infiles[i].incompiler
6944             || (infiles[i].language && infiles[i].language[0] != '*'))
6945           {
6946             set_input (infiles[i].name);
6947             break;
6948           }
6949     }
6950
6951   if (!seen_error ())
6952     {
6953       /* Make sure INPUT_FILE_NUMBER points to first available open
6954          slot.  */
6955       input_file_number = n_infiles;
6956       if (lang_specific_pre_link ())
6957         errorcount++;
6958     }
6959
6960   /* Determine if there are any linker input files.  */
6961   num_linker_inputs = 0;
6962   for (i = 0; (int) i < n_infiles; i++)
6963     if (explicit_link_files[i] || outfiles[i] != NULL)
6964       num_linker_inputs++;
6965
6966   /* Run ld to link all the compiler output files.  */
6967
6968   if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
6969     {
6970       int tmp = execution_count;
6971
6972       if (! have_c)
6973         {
6974 #if HAVE_LTO_PLUGIN > 0
6975 #if HAVE_LTO_PLUGIN == 2
6976           const char *fno_use_linker_plugin = "fno-use-linker-plugin";
6977 #else
6978           const char *fuse_linker_plugin = "fuse-linker-plugin";
6979 #endif
6980 #endif
6981
6982           /* We'll use ld if we can't find collect2.  */
6983           if (! strcmp (linker_name_spec, "collect2"))
6984             {
6985               char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
6986               if (s == NULL)
6987                 linker_name_spec = "ld";
6988             }
6989
6990 #if HAVE_LTO_PLUGIN > 0
6991 #if HAVE_LTO_PLUGIN == 2
6992           if (!switch_matches (fno_use_linker_plugin,
6993                                fno_use_linker_plugin
6994                                + strlen (fno_use_linker_plugin), 0))
6995 #else
6996           if (switch_matches (fuse_linker_plugin,
6997                               fuse_linker_plugin
6998                               + strlen (fuse_linker_plugin), 0))
6999 #endif
7000             {
7001               linker_plugin_file_spec = find_a_file (&exec_prefixes,
7002                                                      LTOPLUGINSONAME, R_OK,
7003                                                      false);
7004               if (!linker_plugin_file_spec)
7005                 fatal_error ("-fuse-linker-plugin, but %s not found",
7006                              LTOPLUGINSONAME);
7007             }
7008 #endif
7009           lto_gcc_spec = argv[0];
7010         }
7011
7012       /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
7013          for collect.  */
7014       putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
7015       putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
7016
7017       if (print_subprocess_help == 1)
7018         {
7019           printf (_("\nLinker options\n==============\n\n"));
7020           printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
7021                     " to the linker.\n\n"));
7022           fflush (stdout);
7023         }
7024       value = do_spec (link_command_spec);
7025       if (value < 0)
7026         errorcount = 1;
7027       linker_was_run = (tmp != execution_count);
7028     }
7029
7030   /* If options said don't run linker,
7031      complain about input files to be given to the linker.  */
7032
7033   if (! linker_was_run && !seen_error ())
7034     for (i = 0; (int) i < n_infiles; i++)
7035       if (explicit_link_files[i]
7036           && !(infiles[i].language && infiles[i].language[0] == '*'))
7037         warning (0, "%s: linker input file unused because linking not done",
7038                  outfiles[i]);
7039
7040   /* Delete some or all of the temporary files we made.  */
7041
7042   if (seen_error ())
7043     delete_failure_queue ();
7044   delete_temp_files ();
7045
7046   if (print_help_list)
7047     {
7048       printf (("\nFor bug reporting instructions, please see:\n"));
7049       printf ("%s\n", bug_report_url);
7050     }
7051
7052  out:
7053   return (signal_count != 0 ? 2
7054           : seen_error () ? (pass_exit_codes ? greatest_status : 1)
7055           : 0);
7056 }
7057
7058 /* Find the proper compilation spec for the file name NAME,
7059    whose length is LENGTH.  LANGUAGE is the specified language,
7060    or 0 if this file is to be passed to the linker.  */
7061
7062 static struct compiler *
7063 lookup_compiler (const char *name, size_t length, const char *language)
7064 {
7065   struct compiler *cp;
7066
7067   /* If this was specified by the user to be a linker input, indicate that.  */
7068   if (language != 0 && language[0] == '*')
7069     return 0;
7070
7071   /* Otherwise, look for the language, if one is spec'd.  */
7072   if (language != 0)
7073     {
7074       for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7075         if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
7076           return cp;
7077
7078       error ("language %s not recognized", language);
7079       return 0;
7080     }
7081
7082   /* Look for a suffix.  */
7083   for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7084     {
7085       if (/* The suffix `-' matches only the file name `-'.  */
7086           (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7087           || (strlen (cp->suffix) < length
7088               /* See if the suffix matches the end of NAME.  */
7089               && !strcmp (cp->suffix,
7090                           name + length - strlen (cp->suffix))
7091          ))
7092         break;
7093     }
7094
7095 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
7096   /* Look again, but case-insensitively this time.  */
7097   if (cp < compilers)
7098     for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7099       {
7100         if (/* The suffix `-' matches only the file name `-'.  */
7101             (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7102             || (strlen (cp->suffix) < length
7103                 /* See if the suffix matches the end of NAME.  */
7104                 && ((!strcmp (cp->suffix,
7105                              name + length - strlen (cp->suffix))
7106                      || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
7107                     && !strcasecmp (cp->suffix,
7108                                     name + length - strlen (cp->suffix)))
7109            ))
7110           break;
7111       }
7112 #endif
7113
7114   if (cp >= compilers)
7115     {
7116       if (cp->spec[0] != '@')
7117         /* A non-alias entry: return it.  */
7118         return cp;
7119
7120       /* An alias entry maps a suffix to a language.
7121          Search for the language; pass 0 for NAME and LENGTH
7122          to avoid infinite recursion if language not found.  */
7123       return lookup_compiler (NULL, 0, cp->spec + 1);
7124     }
7125   return 0;
7126 }
7127 \f
7128 static char *
7129 save_string (const char *s, int len)
7130 {
7131   char *result = XNEWVEC (char, len + 1);
7132
7133   memcpy (result, s, len);
7134   result[len] = 0;
7135   return result;
7136 }
7137
7138 void
7139 pfatal_with_name (const char *name)
7140 {
7141   perror_with_name (name);
7142   delete_temp_files ();
7143   exit (1);
7144 }
7145
7146 static void
7147 perror_with_name (const char *name)
7148 {
7149   error ("%s: %m", name);
7150 }
7151 \f
7152 static inline void
7153 validate_switches_from_spec (const char *spec, bool user)
7154 {
7155   const char *p = spec;
7156   char c;
7157   while ((c = *p++))
7158     if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
7159       /* We have a switch spec.  */
7160       p = validate_switches (p + 1, user);
7161 }
7162
7163 static void
7164 validate_all_switches (void)
7165 {
7166   struct compiler *comp;
7167   struct spec_list *spec;
7168
7169   for (comp = compilers; comp->spec; comp++)
7170     validate_switches_from_spec (comp->spec, false);
7171
7172   /* Look through the linked list of specs read from the specs file.  */
7173   for (spec = specs; spec; spec = spec->next)
7174     validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
7175
7176   validate_switches_from_spec (link_command_spec, false);
7177 }
7178
7179 /* Look at the switch-name that comes after START
7180    and mark as valid all supplied switches that match it.  */
7181
7182 static const char *
7183 validate_switches (const char *start, bool user_spec)
7184 {
7185   const char *p = start;
7186   const char *atom;
7187   size_t len;
7188   int i;
7189   bool suffix = false;
7190   bool starred = false;
7191
7192 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7193
7194 next_member:
7195   SKIP_WHITE ();
7196
7197   if (*p == '!')
7198     p++;
7199
7200   SKIP_WHITE ();
7201   if (*p == '.' || *p == ',')
7202     suffix = true, p++;
7203
7204   atom = p;
7205   while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7206          || *p == ',' || *p == '.' || *p == '@')
7207     p++;
7208   len = p - atom;
7209
7210   if (*p == '*')
7211     starred = true, p++;
7212
7213   SKIP_WHITE ();
7214
7215   if (!suffix)
7216     {
7217       /* Mark all matching switches as valid.  */
7218       for (i = 0; i < n_switches; i++)
7219         if (!strncmp (switches[i].part1, atom, len)
7220             && (starred || switches[i].part1[len] == '\0')
7221             && (switches[i].known || user_spec))
7222               switches[i].validated = true;
7223     }
7224
7225   if (*p) p++;
7226   if (*p && (p[-1] == '|' || p[-1] == '&'))
7227     goto next_member;
7228
7229   if (*p && p[-1] == ':')
7230     {
7231       while (*p && *p != ';' && *p != '}')
7232         {
7233           if (*p == '%')
7234             {
7235               p++;
7236               if (*p == '{' || *p == '<')
7237                 p = validate_switches (p+1, user_spec);
7238               else if (p[0] == 'W' && p[1] == '{')
7239                 p = validate_switches (p+2, user_spec);
7240             }
7241           else
7242             p++;
7243         }
7244
7245       if (*p) p++;
7246       if (*p && p[-1] == ';')
7247         goto next_member;
7248     }
7249
7250   return p;
7251 #undef SKIP_WHITE
7252 }
7253 \f
7254 struct mdswitchstr
7255 {
7256   const char *str;
7257   int len;
7258 };
7259
7260 static struct mdswitchstr *mdswitches;
7261 static int n_mdswitches;
7262
7263 /* Check whether a particular argument was used.  The first time we
7264    canonicalize the switches to keep only the ones we care about.  */
7265
7266 static int
7267 used_arg (const char *p, int len)
7268 {
7269   struct mswitchstr
7270   {
7271     const char *str;
7272     const char *replace;
7273     int len;
7274     int rep_len;
7275   };
7276
7277   static struct mswitchstr *mswitches;
7278   static int n_mswitches;
7279   int i, j;
7280
7281   if (!mswitches)
7282     {
7283       struct mswitchstr *matches;
7284       const char *q;
7285       int cnt = 0;
7286
7287       /* Break multilib_matches into the component strings of string
7288          and replacement string.  */
7289       for (q = multilib_matches; *q != '\0'; q++)
7290         if (*q == ';')
7291           cnt++;
7292
7293       matches
7294         = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
7295       i = 0;
7296       q = multilib_matches;
7297       while (*q != '\0')
7298         {
7299           matches[i].str = q;
7300           while (*q != ' ')
7301             {
7302               if (*q == '\0')
7303                 {
7304                 invalid_matches:
7305                   fatal_error ("multilib spec %qs is invalid",
7306                                multilib_matches);
7307                 }
7308               q++;
7309             }
7310           matches[i].len = q - matches[i].str;
7311
7312           matches[i].replace = ++q;
7313           while (*q != ';' && *q != '\0')
7314             {
7315               if (*q == ' ')
7316                 goto invalid_matches;
7317               q++;
7318             }
7319           matches[i].rep_len = q - matches[i].replace;
7320           i++;
7321           if (*q == ';')
7322             q++;
7323         }
7324
7325       /* Now build a list of the replacement string for switches that we care
7326          about.  Make sure we allocate at least one entry.  This prevents
7327          xmalloc from calling fatal, and prevents us from re-executing this
7328          block of code.  */
7329       mswitches
7330         = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
7331       for (i = 0; i < n_switches; i++)
7332         if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
7333           {
7334             int xlen = strlen (switches[i].part1);
7335             for (j = 0; j < cnt; j++)
7336               if (xlen == matches[j].len
7337                   && ! strncmp (switches[i].part1, matches[j].str, xlen))
7338                 {
7339                   mswitches[n_mswitches].str = matches[j].replace;
7340                   mswitches[n_mswitches].len = matches[j].rep_len;
7341                   mswitches[n_mswitches].replace = (char *) 0;
7342                   mswitches[n_mswitches].rep_len = 0;
7343                   n_mswitches++;
7344                   break;
7345                 }
7346           }
7347
7348       /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7349          on the command line nor any options mutually incompatible with
7350          them.  */
7351       for (i = 0; i < n_mdswitches; i++)
7352         {
7353           const char *r;
7354
7355           for (q = multilib_options; *q != '\0'; q++)
7356             {
7357               while (*q == ' ')
7358                 q++;
7359
7360               r = q;
7361               while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7362                      || strchr (" /", q[mdswitches[i].len]) == NULL)
7363                 {
7364                   while (*q != ' ' && *q != '/' && *q != '\0')
7365                     q++;
7366                   if (*q != '/')
7367                     break;
7368                   q++;
7369                 }
7370
7371               if (*q != ' ' && *q != '\0')
7372                 {
7373                   while (*r != ' ' && *r != '\0')
7374                     {
7375                       q = r;
7376                       while (*q != ' ' && *q != '/' && *q != '\0')
7377                         q++;
7378
7379                       if (used_arg (r, q - r))
7380                         break;
7381
7382                       if (*q != '/')
7383                         {
7384                           mswitches[n_mswitches].str = mdswitches[i].str;
7385                           mswitches[n_mswitches].len = mdswitches[i].len;
7386                           mswitches[n_mswitches].replace = (char *) 0;
7387                           mswitches[n_mswitches].rep_len = 0;
7388                           n_mswitches++;
7389                           break;
7390                         }
7391
7392                       r = q + 1;
7393                     }
7394                   break;
7395                 }
7396             }
7397         }
7398     }
7399
7400   for (i = 0; i < n_mswitches; i++)
7401     if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7402       return 1;
7403
7404   return 0;
7405 }
7406
7407 static int
7408 default_arg (const char *p, int len)
7409 {
7410   int i;
7411
7412   for (i = 0; i < n_mdswitches; i++)
7413     if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7414       return 1;
7415
7416   return 0;
7417 }
7418
7419 /* Work out the subdirectory to use based on the options. The format of
7420    multilib_select is a list of elements. Each element is a subdirectory
7421    name followed by a list of options followed by a semicolon. The format
7422    of multilib_exclusions is the same, but without the preceding
7423    directory. First gcc will check the exclusions, if none of the options
7424    beginning with an exclamation point are present, and all of the other
7425    options are present, then we will ignore this completely. Passing
7426    that, gcc will consider each multilib_select in turn using the same
7427    rules for matching the options. If a match is found, that subdirectory
7428    will be used.
7429    A subdirectory name is optionally followed by a colon and the corresponding
7430    multiarch name.  */
7431
7432 static void
7433 set_multilib_dir (void)
7434 {
7435   const char *p;
7436   unsigned int this_path_len;
7437   const char *this_path, *this_arg;
7438   const char *start, *end;
7439   int not_arg;
7440   int ok, ndfltok, first;
7441
7442   n_mdswitches = 0;
7443   start = multilib_defaults;
7444   while (*start == ' ' || *start == '\t')
7445     start++;
7446   while (*start != '\0')
7447     {
7448       n_mdswitches++;
7449       while (*start != ' ' && *start != '\t' && *start != '\0')
7450         start++;
7451       while (*start == ' ' || *start == '\t')
7452         start++;
7453     }
7454
7455   if (n_mdswitches)
7456     {
7457       int i = 0;
7458
7459       mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
7460       for (start = multilib_defaults; *start != '\0'; start = end + 1)
7461         {
7462           while (*start == ' ' || *start == '\t')
7463             start++;
7464
7465           if (*start == '\0')
7466             break;
7467
7468           for (end = start + 1;
7469                *end != ' ' && *end != '\t' && *end != '\0'; end++)
7470             ;
7471
7472           obstack_grow (&multilib_obstack, start, end - start);
7473           obstack_1grow (&multilib_obstack, 0);
7474           mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7475           mdswitches[i++].len = end - start;
7476
7477           if (*end == '\0')
7478             break;
7479         }
7480     }
7481
7482   p = multilib_exclusions;
7483   while (*p != '\0')
7484     {
7485       /* Ignore newlines.  */
7486       if (*p == '\n')
7487         {
7488           ++p;
7489           continue;
7490         }
7491
7492       /* Check the arguments.  */
7493       ok = 1;
7494       while (*p != ';')
7495         {
7496           if (*p == '\0')
7497             {
7498             invalid_exclusions:
7499               fatal_error ("multilib exclusions %qs is invalid",
7500                            multilib_exclusions);
7501             }
7502
7503           if (! ok)
7504             {
7505               ++p;
7506               continue;
7507             }
7508
7509           this_arg = p;
7510           while (*p != ' ' && *p != ';')
7511             {
7512               if (*p == '\0')
7513                 goto invalid_exclusions;
7514               ++p;
7515             }
7516
7517           if (*this_arg != '!')
7518             not_arg = 0;
7519           else
7520             {
7521               not_arg = 1;
7522               ++this_arg;
7523             }
7524
7525           ok = used_arg (this_arg, p - this_arg);
7526           if (not_arg)
7527             ok = ! ok;
7528
7529           if (*p == ' ')
7530             ++p;
7531         }
7532
7533       if (ok)
7534         return;
7535
7536       ++p;
7537     }
7538
7539   first = 1;
7540   p = multilib_select;
7541   while (*p != '\0')
7542     {
7543       /* Ignore newlines.  */
7544       if (*p == '\n')
7545         {
7546           ++p;
7547           continue;
7548         }
7549
7550       /* Get the initial path.  */
7551       this_path = p;
7552       while (*p != ' ')
7553         {
7554           if (*p == '\0')
7555             {
7556             invalid_select:
7557               fatal_error ("multilib select %qs is invalid",
7558                            multilib_select);
7559             }
7560           ++p;
7561         }
7562       this_path_len = p - this_path;
7563
7564       /* Check the arguments.  */
7565       ok = 1;
7566       ndfltok = 1;
7567       ++p;
7568       while (*p != ';')
7569         {
7570           if (*p == '\0')
7571             goto invalid_select;
7572
7573           if (! ok)
7574             {
7575               ++p;
7576               continue;
7577             }
7578
7579           this_arg = p;
7580           while (*p != ' ' && *p != ';')
7581             {
7582               if (*p == '\0')
7583                 goto invalid_select;
7584               ++p;
7585             }
7586
7587           if (*this_arg != '!')
7588             not_arg = 0;
7589           else
7590             {
7591               not_arg = 1;
7592               ++this_arg;
7593             }
7594
7595           /* If this is a default argument, we can just ignore it.
7596              This is true even if this_arg begins with '!'.  Beginning
7597              with '!' does not mean that this argument is necessarily
7598              inappropriate for this library: it merely means that
7599              there is a more specific library which uses this
7600              argument.  If this argument is a default, we need not
7601              consider that more specific library.  */
7602           ok = used_arg (this_arg, p - this_arg);
7603           if (not_arg)
7604             ok = ! ok;
7605
7606           if (! ok)
7607             ndfltok = 0;
7608
7609           if (default_arg (this_arg, p - this_arg))
7610             ok = 1;
7611
7612           if (*p == ' ')
7613             ++p;
7614         }
7615
7616       if (ok && first)
7617         {
7618           if (this_path_len != 1
7619               || this_path[0] != '.')
7620             {
7621               char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
7622               char *q;
7623
7624               strncpy (new_multilib_dir, this_path, this_path_len);
7625               new_multilib_dir[this_path_len] = '\0';
7626               q = strchr (new_multilib_dir, ':');
7627               if (q != NULL)
7628                 *q = '\0';
7629               multilib_dir = new_multilib_dir;
7630             }
7631           first = 0;
7632         }
7633
7634       if (ndfltok)
7635         {
7636           const char *q = this_path, *end = this_path + this_path_len;
7637
7638           while (q < end && *q != ':')
7639             q++;
7640           if (q < end)
7641             {
7642               const char *q2 = q + 1, *ml_end = end;
7643               char *new_multilib_os_dir;
7644
7645               while (q2 < end && *q2 != ':')
7646                 q2++;
7647               if (*q2 == ':')
7648                 ml_end = q2;
7649               new_multilib_os_dir = XNEWVEC (char, ml_end - q);
7650               memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
7651               new_multilib_os_dir[ml_end - q - 1] = '\0';
7652               multilib_os_dir = *new_multilib_os_dir ? new_multilib_os_dir : ".";
7653
7654               if (q2 < end && *q2 == ':')
7655                 {
7656                   char *new_multiarch_dir = XNEWVEC (char, end - q2);
7657                   memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
7658                   new_multiarch_dir[end - q2 - 1] = '\0';
7659                   multiarch_dir = new_multiarch_dir;
7660                 }
7661               break;
7662             }
7663         }
7664
7665       ++p;
7666     }
7667
7668   if (multilib_dir == NULL && multilib_os_dir != NULL
7669       && strcmp (multilib_os_dir, ".") == 0)
7670     {
7671       free (CONST_CAST (char *, multilib_os_dir));
7672       multilib_os_dir = NULL;
7673     }
7674   else if (multilib_dir != NULL && multilib_os_dir == NULL)
7675     multilib_os_dir = multilib_dir;
7676 }
7677
7678 /* Print out the multiple library subdirectory selection
7679    information.  This prints out a series of lines.  Each line looks
7680    like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7681    required.  Only the desired options are printed out, the negative
7682    matches.  The options are print without a leading dash.  There are
7683    no spaces to make it easy to use the information in the shell.
7684    Each subdirectory is printed only once.  This assumes the ordering
7685    generated by the genmultilib script. Also, we leave out ones that match
7686    the exclusions.  */
7687
7688 static void
7689 print_multilib_info (void)
7690 {
7691   const char *p = multilib_select;
7692   const char *last_path = 0, *this_path;
7693   int skip;
7694   unsigned int last_path_len = 0;
7695
7696   while (*p != '\0')
7697     {
7698       skip = 0;
7699       /* Ignore newlines.  */
7700       if (*p == '\n')
7701         {
7702           ++p;
7703           continue;
7704         }
7705
7706       /* Get the initial path.  */
7707       this_path = p;
7708       while (*p != ' ')
7709         {
7710           if (*p == '\0')
7711             {
7712             invalid_select:
7713               fatal_error ("multilib select %qs is invalid", multilib_select);
7714             }
7715
7716           ++p;
7717         }
7718
7719       /* When --disable-multilib was used but target defines
7720          MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
7721          with .:: for multiarch configurations) are there just to find
7722          multilib_os_dir, so skip them from output.  */
7723       if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
7724         skip = 1;
7725
7726       /* Check for matches with the multilib_exclusions. We don't bother
7727          with the '!' in either list. If any of the exclusion rules match
7728          all of its options with the select rule, we skip it.  */
7729       {
7730         const char *e = multilib_exclusions;
7731         const char *this_arg;
7732
7733         while (*e != '\0')
7734           {
7735             int m = 1;
7736             /* Ignore newlines.  */
7737             if (*e == '\n')
7738               {
7739                 ++e;
7740                 continue;
7741               }
7742
7743             /* Check the arguments.  */
7744             while (*e != ';')
7745               {
7746                 const char *q;
7747                 int mp = 0;
7748
7749                 if (*e == '\0')
7750                   {
7751                   invalid_exclusion:
7752                     fatal_error ("multilib exclusion %qs is invalid",
7753                                  multilib_exclusions);
7754                   }
7755
7756                 if (! m)
7757                   {
7758                     ++e;
7759                     continue;
7760                   }
7761
7762                 this_arg = e;
7763
7764                 while (*e != ' ' && *e != ';')
7765                   {
7766                     if (*e == '\0')
7767                       goto invalid_exclusion;
7768                     ++e;
7769                   }
7770
7771                 q = p + 1;
7772                 while (*q != ';')
7773                   {
7774                     const char *arg;
7775                     int len = e - this_arg;
7776
7777                     if (*q == '\0')
7778                       goto invalid_select;
7779
7780                     arg = q;
7781
7782                     while (*q != ' ' && *q != ';')
7783                       {
7784                         if (*q == '\0')
7785                           goto invalid_select;
7786                         ++q;
7787                       }
7788
7789                     if (! strncmp (arg, this_arg,
7790                                    (len < q - arg) ? q - arg : len)
7791                         || default_arg (this_arg, e - this_arg))
7792                       {
7793                         mp = 1;
7794                         break;
7795                       }
7796
7797                     if (*q == ' ')
7798                       ++q;
7799                   }
7800
7801                 if (! mp)
7802                   m = 0;
7803
7804                 if (*e == ' ')
7805                   ++e;
7806               }
7807
7808             if (m)
7809               {
7810                 skip = 1;
7811                 break;
7812               }
7813
7814             if (*e != '\0')
7815               ++e;
7816           }
7817       }
7818
7819       if (! skip)
7820         {
7821           /* If this is a duplicate, skip it.  */
7822           skip = (last_path != 0
7823                   && (unsigned int) (p - this_path) == last_path_len
7824                   && ! filename_ncmp (last_path, this_path, last_path_len));
7825
7826           last_path = this_path;
7827           last_path_len = p - this_path;
7828         }
7829
7830       /* If this directory requires any default arguments, we can skip
7831          it.  We will already have printed a directory identical to
7832          this one which does not require that default argument.  */
7833       if (! skip)
7834         {
7835           const char *q;
7836
7837           q = p + 1;
7838           while (*q != ';')
7839             {
7840               const char *arg;
7841
7842               if (*q == '\0')
7843                 goto invalid_select;
7844
7845               if (*q == '!')
7846                 arg = NULL;
7847               else
7848                 arg = q;
7849
7850               while (*q != ' ' && *q != ';')
7851                 {
7852                   if (*q == '\0')
7853                     goto invalid_select;
7854                   ++q;
7855                 }
7856
7857               if (arg != NULL
7858                   && default_arg (arg, q - arg))
7859                 {
7860                   skip = 1;
7861                   break;
7862                 }
7863
7864               if (*q == ' ')
7865                 ++q;
7866             }
7867         }
7868
7869       if (! skip)
7870         {
7871           const char *p1;
7872
7873           for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7874             putchar (*p1);
7875           putchar (';');
7876         }
7877
7878       ++p;
7879       while (*p != ';')
7880         {
7881           int use_arg;
7882
7883           if (*p == '\0')
7884             goto invalid_select;
7885
7886           if (skip)
7887             {
7888               ++p;
7889               continue;
7890             }
7891
7892           use_arg = *p != '!';
7893
7894           if (use_arg)
7895             putchar ('@');
7896
7897           while (*p != ' ' && *p != ';')
7898             {
7899               if (*p == '\0')
7900                 goto invalid_select;
7901               if (use_arg)
7902                 putchar (*p);
7903               ++p;
7904             }
7905
7906           if (*p == ' ')
7907             ++p;
7908         }
7909
7910       if (! skip)
7911         {
7912           /* If there are extra options, print them now.  */
7913           if (multilib_extra && *multilib_extra)
7914             {
7915               int print_at = TRUE;
7916               const char *q;
7917
7918               for (q = multilib_extra; *q != '\0'; q++)
7919                 {
7920                   if (*q == ' ')
7921                     print_at = TRUE;
7922                   else
7923                     {
7924                       if (print_at)
7925                         putchar ('@');
7926                       putchar (*q);
7927                       print_at = FALSE;
7928                     }
7929                 }
7930             }
7931
7932           putchar ('\n');
7933         }
7934
7935       ++p;
7936     }
7937 }
7938 \f
7939 /* getenv built-in spec function.
7940
7941    Returns the value of the environment variable given by its first
7942    argument, concatenated with the second argument.  If the
7943    environment variable is not defined, a fatal error is issued.  */
7944
7945 static const char *
7946 getenv_spec_function (int argc, const char **argv)
7947 {
7948   char *value;
7949   char *result;
7950   char *ptr;
7951   size_t len;
7952
7953   if (argc != 2)
7954     return NULL;
7955
7956   value = getenv (argv[0]);
7957   if (!value)
7958     fatal_error ("environment variable %qs not defined", argv[0]);
7959
7960   /* We have to escape every character of the environment variable so
7961      they are not interpreted as active spec characters.  A
7962      particularly painful case is when we are reading a variable
7963      holding a windows path complete with \ separators.  */
7964   len = strlen (value) * 2 + strlen (argv[1]) + 1;
7965   result = XNEWVAR (char, len);
7966   for (ptr = result; *value; ptr += 2)
7967     {
7968       ptr[0] = '\\';
7969       ptr[1] = *value++;
7970     }
7971
7972   strcpy (ptr, argv[1]);
7973
7974   return result;
7975 }
7976
7977 /* if-exists built-in spec function.
7978
7979    Checks to see if the file specified by the absolute pathname in
7980    ARGS exists.  Returns that pathname if found.
7981
7982    The usual use for this function is to check for a library file
7983    (whose name has been expanded with %s).  */
7984
7985 static const char *
7986 if_exists_spec_function (int argc, const char **argv)
7987 {
7988   /* Must have only one argument.  */
7989   if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7990     return argv[0];
7991
7992   return NULL;
7993 }
7994
7995 /* if-exists-else built-in spec function.
7996
7997    This is like if-exists, but takes an additional argument which
7998    is returned if the first argument does not exist.  */
7999
8000 static const char *
8001 if_exists_else_spec_function (int argc, const char **argv)
8002 {
8003   /* Must have exactly two arguments.  */
8004   if (argc != 2)
8005     return NULL;
8006
8007   if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8008     return argv[0];
8009
8010   return argv[1];
8011 }
8012
8013 /* replace-outfile built-in spec function.
8014
8015    This looks for the first argument in the outfiles array's name and
8016    replaces it with the second argument.  */
8017
8018 static const char *
8019 replace_outfile_spec_function (int argc, const char **argv)
8020 {
8021   int i;
8022   /* Must have exactly two arguments.  */
8023   if (argc != 2)
8024     abort ();
8025
8026   for (i = 0; i < n_infiles; i++)
8027     {
8028       if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8029         outfiles[i] = xstrdup (argv[1]);
8030     }
8031   return NULL;
8032 }
8033
8034 /* remove-outfile built-in spec function.
8035  *
8036  *    This looks for the first argument in the outfiles array's name and
8037  *       removes it.  */
8038
8039 static const char *
8040 remove_outfile_spec_function (int argc, const char **argv)
8041 {
8042   int i;
8043   /* Must have exactly one argument.  */
8044   if (argc != 1)
8045     abort ();
8046
8047   for (i = 0; i < n_infiles; i++)
8048     {
8049       if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8050         outfiles[i] = NULL;
8051     }
8052   return NULL;
8053 }
8054
8055 /* Given two version numbers, compares the two numbers.
8056    A version number must match the regular expression
8057    ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
8058 */
8059 static int
8060 compare_version_strings (const char *v1, const char *v2)
8061 {
8062   int rresult;
8063   regex_t r;
8064
8065   if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
8066                REG_EXTENDED | REG_NOSUB) != 0)
8067     abort ();
8068   rresult = regexec (&r, v1, 0, NULL, 0);
8069   if (rresult == REG_NOMATCH)
8070     fatal_error ("invalid version number %qs", v1);
8071   else if (rresult != 0)
8072     abort ();
8073   rresult = regexec (&r, v2, 0, NULL, 0);
8074   if (rresult == REG_NOMATCH)
8075     fatal_error ("invalid version number %qs", v2);
8076   else if (rresult != 0)
8077     abort ();
8078
8079   return strverscmp (v1, v2);
8080 }
8081
8082
8083 /* version_compare built-in spec function.
8084
8085    This takes an argument of the following form:
8086
8087    <comparison-op> <arg1> [<arg2>] <switch> <result>
8088
8089    and produces "result" if the comparison evaluates to true,
8090    and nothing if it doesn't.
8091
8092    The supported <comparison-op> values are:
8093
8094    >=  true if switch is a later (or same) version than arg1
8095    !>  opposite of >=
8096    <   true if switch is an earlier version than arg1
8097    !<  opposite of <
8098    ><  true if switch is arg1 or later, and earlier than arg2
8099    <>  true if switch is earlier than arg1 or is arg2 or later
8100
8101    If the switch is not present, the condition is false unless
8102    the first character of the <comparison-op> is '!'.
8103
8104    For example,
8105    %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
8106    adds -lmx if -mmacosx-version-min=10.3.9 was passed.  */
8107
8108 static const char *
8109 version_compare_spec_function (int argc, const char **argv)
8110 {
8111   int comp1, comp2;
8112   size_t switch_len;
8113   const char *switch_value = NULL;
8114   int nargs = 1, i;
8115   bool result;
8116
8117   if (argc < 3)
8118     fatal_error ("too few arguments to %%:version-compare");
8119   if (argv[0][0] == '\0')
8120     abort ();
8121   if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
8122     nargs = 2;
8123   if (argc != nargs + 3)
8124     fatal_error ("too many arguments to %%:version-compare");
8125
8126   switch_len = strlen (argv[nargs + 1]);
8127   for (i = 0; i < n_switches; i++)
8128     if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
8129         && check_live_switch (i, switch_len))
8130       switch_value = switches[i].part1 + switch_len;
8131
8132   if (switch_value == NULL)
8133     comp1 = comp2 = -1;
8134   else
8135     {
8136       comp1 = compare_version_strings (switch_value, argv[1]);
8137       if (nargs == 2)
8138         comp2 = compare_version_strings (switch_value, argv[2]);
8139       else
8140         comp2 = -1;  /* This value unused.  */
8141     }
8142
8143   switch (argv[0][0] << 8 | argv[0][1])
8144     {
8145     case '>' << 8 | '=':
8146       result = comp1 >= 0;
8147       break;
8148     case '!' << 8 | '<':
8149       result = comp1 >= 0 || switch_value == NULL;
8150       break;
8151     case '<' << 8:
8152       result = comp1 < 0;
8153       break;
8154     case '!' << 8 | '>':
8155       result = comp1 < 0 || switch_value == NULL;
8156       break;
8157     case '>' << 8 | '<':
8158       result = comp1 >= 0 && comp2 < 0;
8159       break;
8160     case '<' << 8 | '>':
8161       result = comp1 < 0 || comp2 >= 0;
8162       break;
8163
8164     default:
8165       fatal_error ("unknown operator %qs in %%:version-compare", argv[0]);
8166     }
8167   if (! result)
8168     return NULL;
8169
8170   return argv[nargs + 2];
8171 }
8172
8173 /* %:include builtin spec function.  This differs from %include in that it
8174    can be nested inside a spec, and thus be conditionalized.  It takes
8175    one argument, the filename, and looks for it in the startfile path.
8176    The result is always NULL, i.e. an empty expansion.  */
8177
8178 static const char *
8179 include_spec_function (int argc, const char **argv)
8180 {
8181   char *file;
8182
8183   if (argc != 1)
8184     abort ();
8185
8186   file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
8187   read_specs (file ? file : argv[0], false, false);
8188
8189   return NULL;
8190 }
8191
8192 /* %:find-file spec function.  This function replaces its argument by
8193     the file found through find_file, that is the -print-file-name gcc
8194     program option. */
8195 static const char *
8196 find_file_spec_function (int argc, const char **argv)
8197 {
8198   const char *file;
8199
8200   if (argc != 1)
8201     abort ();
8202
8203   file = find_file (argv[0]);
8204   return file;
8205 }
8206
8207
8208 /* %:find-plugindir spec function.  This function replaces its argument
8209     by the -iplugindir=<dir> option.  `dir' is found through find_file, that
8210     is the -print-file-name gcc program option. */
8211 static const char *
8212 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
8213 {
8214   const char *option;
8215
8216   if (argc != 0)
8217     abort ();
8218
8219   option = concat ("-iplugindir=", find_file ("plugin"), NULL);
8220   return option;
8221 }
8222
8223
8224 /* %:print-asm-header spec function.  Print a banner to say that the
8225    following output is from the assembler.  */
8226
8227 static const char *
8228 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
8229                                 const char **argv ATTRIBUTE_UNUSED)
8230 {
8231   printf (_("Assembler options\n=================\n\n"));
8232   printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
8233   fflush (stdout);
8234   return NULL;
8235 }
8236
8237 /* Get a random number for -frandom-seed */
8238
8239 static unsigned HOST_WIDE_INT
8240 get_random_number (void)
8241 {
8242   unsigned HOST_WIDE_INT ret = 0;
8243   int fd; 
8244
8245   fd = open ("/dev/urandom", O_RDONLY); 
8246   if (fd >= 0)
8247     {
8248       read (fd, &ret, sizeof (HOST_WIDE_INT));
8249       close (fd);
8250       if (ret)
8251         return ret;
8252     }
8253
8254   /* Get some more or less random data.  */
8255 #ifdef HAVE_GETTIMEOFDAY
8256   {
8257     struct timeval tv;
8258
8259     gettimeofday (&tv, NULL);
8260     ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
8261   }
8262 #else
8263   {
8264     time_t now = time (NULL);
8265
8266     if (now != (time_t)-1)
8267       ret = (unsigned) now;
8268   }
8269 #endif
8270
8271   return ret ^ getpid();
8272 }
8273
8274 /* %:compare-debug-dump-opt spec function.  Save the last argument,
8275    expected to be the last -fdump-final-insns option, or generate a
8276    temporary.  */
8277
8278 static const char *
8279 compare_debug_dump_opt_spec_function (int arg,
8280                                       const char **argv ATTRIBUTE_UNUSED)
8281 {
8282   char *ret;
8283   char *name;
8284   int which;
8285   static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
8286
8287   if (arg != 0)
8288     fatal_error ("too many arguments to %%:compare-debug-dump-opt");
8289
8290   do_spec_2 ("%{fdump-final-insns=*:%*}");
8291   do_spec_1 (" ", 0, NULL);
8292
8293   if (argbuf.length () > 0
8294       && strcmp (argv[argbuf.length () - 1], "."))
8295     {
8296       if (!compare_debug)
8297         return NULL;
8298
8299       name = xstrdup (argv[argbuf.length () - 1]);
8300       ret = NULL;
8301     }
8302   else
8303     {
8304       const char *ext = NULL;
8305
8306       if (argbuf.length () > 0)
8307         {
8308           do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
8309           ext = ".gkd";
8310         }
8311       else if (!compare_debug)
8312         return NULL;
8313       else
8314         do_spec_2 ("%g.gkd");
8315
8316       do_spec_1 (" ", 0, NULL);
8317
8318       gcc_assert (argbuf.length () > 0);
8319
8320       name = concat (argbuf.last (), ext, NULL);
8321
8322       ret = concat ("-fdump-final-insns=", name, NULL);
8323     }
8324
8325   which = compare_debug < 0;
8326   debug_check_temp_file[which] = name;
8327
8328   if (!which)
8329     {
8330       unsigned HOST_WIDE_INT value = get_random_number ();
8331
8332       sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
8333     }
8334
8335   if (*random_seed)
8336     {
8337       char *tmp = ret;
8338       ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
8339                     ret, NULL);
8340       free (tmp);
8341     }
8342
8343   if (which)
8344     *random_seed = 0;
8345
8346   return ret;
8347 }
8348
8349 static const char *debug_auxbase_opt;
8350
8351 /* %:compare-debug-self-opt spec function.  Expands to the options
8352     that are to be passed in the second compilation of
8353     compare-debug.  */
8354
8355 static const char *
8356 compare_debug_self_opt_spec_function (int arg,
8357                                       const char **argv ATTRIBUTE_UNUSED)
8358 {
8359   if (arg != 0)
8360     fatal_error ("too many arguments to %%:compare-debug-self-opt");
8361
8362   if (compare_debug >= 0)
8363     return NULL;
8364
8365   do_spec_2 ("%{c|S:%{o*:%*}}");
8366   do_spec_1 (" ", 0, NULL);
8367
8368   if (argbuf.length () > 0)
8369     debug_auxbase_opt = concat ("-auxbase-strip ",
8370                                 argbuf.last (),
8371                                 NULL);
8372   else
8373     debug_auxbase_opt = NULL;
8374
8375   return concat ("\
8376 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
8377 %<fdump-final-insns=* -w -S -o %j \
8378 %{!fcompare-debug-second:-fcompare-debug-second} \
8379 ", compare_debug_opt, NULL);
8380 }
8381
8382 /* %:compare-debug-auxbase-opt spec function.  Expands to the auxbase
8383     options that are to be passed in the second compilation of
8384     compare-debug.  It expects, as an argument, the basename of the
8385     current input file name, with the .gk suffix appended to it.  */
8386
8387 static const char *
8388 compare_debug_auxbase_opt_spec_function (int arg,
8389                                          const char **argv)
8390 {
8391   char *name;
8392   int len;
8393
8394   if (arg == 0)
8395     fatal_error ("too few arguments to %%:compare-debug-auxbase-opt");
8396
8397   if (arg != 1)
8398     fatal_error ("too many arguments to %%:compare-debug-auxbase-opt");
8399
8400   if (compare_debug >= 0)
8401     return NULL;
8402
8403   len = strlen (argv[0]);
8404   if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
8405     fatal_error ("argument to %%:compare-debug-auxbase-opt "
8406                  "does not end in .gk");
8407
8408   if (debug_auxbase_opt)
8409     return debug_auxbase_opt;
8410
8411 #define OPT "-auxbase "
8412
8413   len -= 3;
8414   name = (char*) xmalloc (sizeof (OPT) + len);
8415   memcpy (name, OPT, sizeof (OPT) - 1);
8416   memcpy (name + sizeof (OPT) - 1, argv[0], len);
8417   name[sizeof (OPT) - 1 + len] = '\0';
8418
8419 #undef OPT
8420
8421   return name;
8422 }
8423
8424 /* %:pass-through-libs spec function.  Finds all -l options and input
8425    file names in the lib spec passed to it, and makes a list of them
8426    prepended with the plugin option to cause them to be passed through
8427    to the final link after all the new object files have been added.  */
8428
8429 const char *
8430 pass_through_libs_spec_func (int argc, const char **argv)
8431 {
8432   char *prepended = xstrdup (" ");
8433   int n;
8434   /* Shlemiel the painter's algorithm.  Innately horrible, but at least
8435      we know that there will never be more than a handful of strings to
8436      concat, and it's only once per run, so it's not worth optimising.  */
8437   for (n = 0; n < argc; n++)
8438     {
8439       char *old = prepended;
8440       /* Anything that isn't an option is a full path to an output
8441          file; pass it through if it ends in '.a'.  Among options,
8442          pass only -l.  */
8443       if (argv[n][0] == '-' && argv[n][1] == 'l')
8444         {
8445           const char *lopt = argv[n] + 2;
8446           /* Handle both joined and non-joined -l options.  If for any
8447              reason there's a trailing -l with no joined or following
8448              arg just discard it.  */
8449           if (!*lopt && ++n >= argc)
8450             break;
8451           else if (!*lopt)
8452             lopt = argv[n];
8453           prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
8454                 lopt, " ", NULL);
8455         }
8456       else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
8457         {
8458           prepended = concat (prepended, "-plugin-opt=-pass-through=",
8459                 argv[n], " ", NULL);
8460         }
8461       if (prepended != old)
8462         free (old);
8463     }
8464   return prepended;
8465 }
8466
8467 /* %:replace-extension spec function.  Replaces the extension of the
8468    first argument with the second argument.  */
8469
8470 const char *
8471 replace_extension_spec_func (int argc, const char **argv)
8472 {
8473   char *name;
8474   char *p;
8475   char *result;
8476   int i;
8477
8478   if (argc != 2)
8479     fatal_error ("too few arguments to %%:replace-extension");
8480
8481   name = xstrdup (argv[0]);
8482
8483   for (i = strlen(name) - 1; i >= 0; i--)
8484     if (IS_DIR_SEPARATOR (name[i]))
8485       break;
8486
8487   p = strrchr (name + i + 1, '.');
8488   if (p != NULL)
8489       *p = '\0';
8490
8491   result = concat (name, argv[1], NULL);
8492
8493   free (name);
8494   return result;
8495 }