OSDN Git Service

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