OSDN Git Service

58f7a31482c0d970ec23c20ad8db24ff4cfdb53e
[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    2010
5    Free Software Foundation, Inc.
6
7 This file is part of GCC.
8
9 GCC is free software; you can redistribute it and/or modify it under
10 the terms of the GNU General Public License as published by the Free
11 Software Foundation; either version 3, or (at your option) any later
12 version.
13
14 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
15 WARRANTY; without even the implied warranty of MERCHANTABILITY or
16 FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
17 for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with GCC; see the file COPYING3.  If not see
21 <http://www.gnu.org/licenses/>.  */
22
23 /* This program is the user interface to the C compiler and possibly to
24 other compilers.  It is used because compilation is a complicated procedure
25 which involves running several programs and passing temporary files between
26 them, forwarding the users switches to those programs selectively,
27 and deleting the temporary files at the end.
28
29 CC recognizes how to compile each input file by suffixes in the file names.
30 Once it knows which kind of compilation to perform, the procedure for
31 compilation is specified by a string called a "spec".  */
32
33 #include "config.h"
34 #include "system.h"
35 #include "coretypes.h"
36 #include "multilib.h" /* before tm.h */
37 #include "tm.h"
38 #include <signal.h>
39 #if ! defined( SIGCHLD ) && defined( SIGCLD )
40 #  define SIGCHLD SIGCLD
41 #endif
42 #include "xregex.h"
43 #include "obstack.h"
44 #include "intl.h"
45 #include "prefix.h"
46 #include "gcc.h"
47 #include "diagnostic.h"
48 #include "flags.h"
49 #include "opts.h"
50 #include "vec.h"
51
52 #ifdef HAVE_MMAP_FILE
53 # include <sys/mman.h>
54 # ifdef HAVE_MINCORE
55 /* This is on Solaris.  */
56 #  include <sys/types.h>
57 # endif
58 #endif
59
60 #ifndef MAP_FAILED
61 # define MAP_FAILED ((void *)-1)
62 #endif
63
64 /* By default there is no special suffix for target executables.  */
65 /* FIXME: when autoconf is fixed, remove the host check - dj */
66 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
67 #define HAVE_TARGET_EXECUTABLE_SUFFIX
68 #endif
69
70 /* By default there is no special suffix for host executables.  */
71 #ifdef HOST_EXECUTABLE_SUFFIX
72 #define HAVE_HOST_EXECUTABLE_SUFFIX
73 #else
74 #define HOST_EXECUTABLE_SUFFIX ""
75 #endif
76
77 /* By default, the suffix for target object files is ".o".  */
78 #ifdef TARGET_OBJECT_SUFFIX
79 #define HAVE_TARGET_OBJECT_SUFFIX
80 #else
81 #define TARGET_OBJECT_SUFFIX ".o"
82 #endif
83
84 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
85
86 /* Most every one is fine with LIBRARY_PATH.  For some, it conflicts.  */
87 #ifndef LIBRARY_PATH_ENV
88 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
89 #endif
90
91 #ifndef HAVE_KILL
92 #define kill(p,s) raise(s)
93 #endif
94
95 /* If a stage of compilation returns an exit status >= 1,
96    compilation of that file ceases.  */
97
98 #define MIN_FATAL_STATUS 1
99
100 /* Flag set by cppspec.c to 1.  */
101 int is_cpp_driver;
102
103 /* Flag set to nonzero if an @file argument has been supplied to gcc.  */
104 static bool at_file_supplied;
105
106 /* Definition of string containing the arguments given to configure.  */
107 #include "configargs.h"
108
109 /* Flag saying to print the command line options understood by gcc and its
110    sub-processes.  */
111
112 static int print_help_list;
113
114 /* Flag saying to print the version of gcc and its sub-processes.  */
115
116 static int print_version;
117
118 /* Flag indicating whether we should ONLY print the command and
119    arguments (like verbose_flag) without executing the command.
120    Displayed arguments are quoted so that the generated command
121    line is suitable for execution.  This is intended for use in
122    shell scripts to capture the driver-generated command line.  */
123 static int verbose_only_flag;
124
125 /* Flag indicating how to print command line options of sub-processes.  */
126
127 static int print_subprocess_help;
128
129 /* Whether we should report subprocess execution times to a file.  */
130
131 FILE *report_times_to_file = NULL;
132
133 /* Nonzero means place this string before uses of /, so that include
134    and library files can be found in an alternate location.  */
135
136 #ifdef TARGET_SYSTEM_ROOT
137 static const char *target_system_root = TARGET_SYSTEM_ROOT;
138 #else
139 static const char *target_system_root = 0;
140 #endif
141
142 /* Nonzero means pass the updated target_system_root to the compiler.  */
143
144 static int target_system_root_changed;
145
146 /* Nonzero means append this string to target_system_root.  */
147
148 static const char *target_sysroot_suffix = 0;
149
150 /* Nonzero means append this string to target_system_root for headers.  */
151
152 static const char *target_sysroot_hdrs_suffix = 0;
153
154 /* Nonzero means write "temp" files in source directory
155    and use the source file's name in them, and don't delete them.  */
156
157 static enum save_temps {
158   SAVE_TEMPS_NONE,              /* no -save-temps */
159   SAVE_TEMPS_CWD,               /* -save-temps in current directory */
160   SAVE_TEMPS_OBJ                /* -save-temps in object directory */
161 } save_temps_flag;
162
163 /* Output file to use to get the object directory for -save-temps=obj  */
164 static char *save_temps_prefix = 0;
165 static size_t save_temps_length = 0;
166
167 /* The compiler version.  */
168
169 static const char *compiler_version;
170
171 /* The target version.  */
172
173 static const char *const spec_version = DEFAULT_TARGET_VERSION;
174
175 /* The target machine.  */
176
177 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
178
179 /* Nonzero if cross-compiling.
180    When -b is used, the value comes from the `specs' file.  */
181
182 #ifdef CROSS_DIRECTORY_STRUCTURE
183 static const char *cross_compile = "1";
184 #else
185 static const char *cross_compile = "0";
186 #endif
187
188 /* Greatest exit code of sub-processes that has been encountered up to
189    now.  */
190 static int greatest_status = 1;
191
192 /* This is the obstack which we use to allocate many strings.  */
193
194 static struct obstack obstack;
195
196 /* This is the obstack to build an environment variable to pass to
197    collect2 that describes all of the relevant switches of what to
198    pass the compiler in building the list of pointers to constructors
199    and destructors.  */
200
201 static struct obstack collect_obstack;
202
203 /* Forward declaration for prototypes.  */
204 struct path_prefix;
205 struct prefix_list;
206
207 static void init_spec (void);
208 static void store_arg (const char *, int, int);
209 static void insert_wrapper (const char *);
210 static char *load_specs (const char *);
211 static void read_specs (const char *, int);
212 static void set_spec (const char *, const char *);
213 static struct compiler *lookup_compiler (const char *, size_t, const char *);
214 static char *build_search_list (const struct path_prefix *, const char *,
215                                 bool, bool);
216 static void xputenv (const char *);
217 static void putenv_from_prefixes (const struct path_prefix *, const char *,
218                                   bool);
219 static int access_check (const char *, int);
220 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
221 static void add_prefix (struct path_prefix *, const char *, const char *,
222                         int, int, int);
223 static void add_sysrooted_prefix (struct path_prefix *, const char *,
224                                   const char *, int, int, int);
225 static char *skip_whitespace (char *);
226 static void delete_if_ordinary (const char *);
227 static void delete_temp_files (void);
228 static void delete_failure_queue (void);
229 static void clear_failure_queue (void);
230 static int check_live_switch (int, int);
231 static const char *handle_braces (const char *);
232 static inline bool input_suffix_matches (const char *, const char *);
233 static inline bool switch_matches (const char *, const char *, int);
234 static inline void mark_matching_switches (const char *, const char *, int);
235 static inline void process_marked_switches (void);
236 static const char *process_brace_body (const char *, const char *, const char *, int, int);
237 static const struct spec_function *lookup_spec_function (const char *);
238 static const char *eval_spec_function (const char *, const char *);
239 static const char *handle_spec_function (const char *);
240 static char *save_string (const char *, int);
241 static void set_collect_gcc_options (void);
242 static int do_spec_1 (const char *, int, const char *);
243 static int do_spec_2 (const char *);
244 static void do_option_spec (const char *, const char *);
245 static void do_self_spec (const char *);
246 static const char *find_file (const char *);
247 static int is_directory (const char *, bool);
248 static const char *validate_switches (const char *);
249 static void validate_all_switches (void);
250 static inline void validate_switches_from_spec (const char *);
251 static void give_switch (int, int);
252 static int used_arg (const char *, int);
253 static int default_arg (const char *, int);
254 static void set_multilib_dir (void);
255 static void print_multilib_info (void);
256 static void perror_with_name (const char *);
257 static void display_help (void);
258 static void add_preprocessor_option (const char *, int);
259 static void add_assembler_option (const char *, int);
260 static void add_linker_option (const char *, int);
261 static void process_command (unsigned int, struct cl_decoded_option *);
262 static int execute (void);
263 static void alloc_args (void);
264 static void clear_args (void);
265 static void fatal_signal (int);
266 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
267 static void init_gcc_specs (struct obstack *, const char *, const char *,
268                             const char *);
269 #endif
270 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
271 static const char *convert_filename (const char *, int, int);
272 #endif
273
274 static const char *getenv_spec_function (int, const char **);
275 static const char *if_exists_spec_function (int, const char **);
276 static const char *if_exists_else_spec_function (int, const char **);
277 static const char *replace_outfile_spec_function (int, const char **);
278 static const char *remove_outfile_spec_function (int, const char **);
279 static const char *version_compare_spec_function (int, const char **);
280 static const char *include_spec_function (int, const char **);
281 static const char *find_file_spec_function (int, const char **);
282 static const char *find_plugindir_spec_function (int, const char **);
283 static const char *print_asm_header_spec_function (int, const char **);
284 static const char *compare_debug_dump_opt_spec_function (int, const char **);
285 static const char *compare_debug_self_opt_spec_function (int, const char **);
286 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
287 \f
288 /* The Specs Language
289
290 Specs are strings containing lines, each of which (if not blank)
291 is made up of a program name, and arguments separated by spaces.
292 The program name must be exact and start from root, since no path
293 is searched and it is unreliable to depend on the current working directory.
294 Redirection of input or output is not supported; the subprograms must
295 accept filenames saying what files to read and write.
296
297 In addition, the specs can contain %-sequences to substitute variable text
298 or for conditional text.  Here is a table of all defined %-sequences.
299 Note that spaces are not generated automatically around the results of
300 expanding these sequences; therefore, you can concatenate them together
301 or with constant text in a single argument.
302
303  %%     substitute one % into the program name or argument.
304  %i     substitute the name of the input file being processed.
305  %b     substitute the basename of the input file being processed.
306         This is the substring up to (and not including) the last period
307         and not including the directory unless -save-temps was specified
308         to put temporaries in a different location.
309  %B     same as %b, but include the file suffix (text after the last period).
310  %gSUFFIX
311         substitute a file name that has suffix SUFFIX and is chosen
312         once per compilation, and mark the argument a la %d.  To reduce
313         exposure to denial-of-service attacks, the file name is now
314         chosen in a way that is hard to predict even when previously
315         chosen file names are known.  For example, `%g.s ... %g.o ... %g.s'
316         might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'.  SUFFIX matches
317         the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
318         had been pre-processed.  Previously, %g was simply substituted
319         with a file name chosen once per compilation, without regard
320         to any appended suffix (which was therefore treated just like
321         ordinary text), making such attacks more likely to succeed.
322  %|SUFFIX
323         like %g, but if -pipe is in effect, expands simply to "-".
324  %mSUFFIX
325         like %g, but if -pipe is in effect, expands to nothing.  (We have both
326         %| and %m to accommodate differences between system assemblers; see
327         the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
328  %uSUFFIX
329         like %g, but generates a new temporary file name even if %uSUFFIX
330         was already seen.
331  %USUFFIX
332         substitutes the last file name generated with %uSUFFIX, generating a
333         new one if there is no such last file name.  In the absence of any
334         %uSUFFIX, this is just like %gSUFFIX, except they don't share
335         the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
336         would involve the generation of two distinct file names, one
337         for each `%g.s' and another for each `%U.s'.  Previously, %U was
338         simply substituted with a file name chosen for the previous %u,
339         without regard to any appended suffix.
340  %jSUFFIX
341         substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
342         writable, and if save-temps is off; otherwise, substitute the name
343         of a temporary file, just like %u.  This temporary file is not
344         meant for communication between processes, but rather as a junk
345         disposal mechanism.
346  %.SUFFIX
347         substitutes .SUFFIX for the suffixes of a matched switch's args when
348         it is subsequently output with %*. SUFFIX is terminated by the next
349         space or %.
350  %d     marks the argument containing or following the %d as a
351         temporary file name, so that that file will be deleted if GCC exits
352         successfully.  Unlike %g, this contributes no text to the argument.
353  %w     marks the argument containing or following the %w as the
354         "output file" of this compilation.  This puts the argument
355         into the sequence of arguments that %o will substitute later.
356  %V     indicates that this compilation produces no "output file".
357  %W{...}
358         like %{...} but mark last argument supplied within
359         as a file to be deleted on failure.
360  %o     substitutes the names of all the output files, with spaces
361         automatically placed around them.  You should write spaces
362         around the %o as well or the results are undefined.
363         %o is for use in the specs for running the linker.
364         Input files whose names have no recognized suffix are not compiled
365         at all, but they are included among the output files, so they will
366         be linked.
367  %O     substitutes the suffix for object files.  Note that this is
368         handled specially when it immediately follows %g, %u, or %U
369         (with or without a suffix argument) because of the need for
370         those to form complete file names.  The handling is such that
371         %O is treated exactly as if it had already been substituted,
372         except that %g, %u, and %U do not currently support additional
373         SUFFIX characters following %O as they would following, for
374         example, `.o'.
375  %I     Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
376         (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
377         and -B options) and -imultilib as necessary.
378  %s     current argument is the name of a library or startup file of some sort.
379         Search for that file in a standard list of directories
380         and substitute the full name found.
381  %eSTR  Print STR as an error message.  STR is terminated by a newline.
382         Use this when inconsistent options are detected.
383  %nSTR  Print STR as a notice.  STR is terminated by a newline.
384  %x{OPTION}     Accumulate an option for %X.
385  %X     Output the accumulated linker options specified by compilations.
386  %Y     Output the accumulated assembler options specified by compilations.
387  %Z     Output the accumulated preprocessor options specified by compilations.
388  %a     process ASM_SPEC as a spec.
389         This allows config.h to specify part of the spec for running as.
390  %A     process ASM_FINAL_SPEC as a spec.  A capital A is actually
391         used here.  This can be used to run a post-processor after the
392         assembler has done its job.
393  %D     Dump out a -L option for each directory in startfile_prefixes.
394         If multilib_dir is set, extra entries are generated with it affixed.
395  %l     process LINK_SPEC as a spec.
396  %L     process LIB_SPEC as a spec.
397  %G     process LIBGCC_SPEC as a spec.
398  %R     Output the concatenation of target_system_root and
399         target_sysroot_suffix.
400  %S     process STARTFILE_SPEC as a spec.  A capital S is actually used here.
401  %E     process ENDFILE_SPEC as a spec.  A capital E is actually used here.
402  %C     process CPP_SPEC as a spec.
403  %1     process CC1_SPEC as a spec.
404  %2     process CC1PLUS_SPEC as a spec.
405  %*     substitute the variable part of a matched option.  (See below.)
406         Note that each comma in the substituted string is replaced by
407         a single space.
408  %<S    remove all occurrences of -S from the command line.
409         Note - this command is position dependent.  % commands in the
410         spec string before this one will see -S, % commands in the
411         spec string after this one will not.
412  %<S*   remove all occurrences of all switches beginning with -S from the
413         command line.
414  %:function(args)
415         Call the named function FUNCTION, passing it ARGS.  ARGS is
416         first processed as a nested spec string, then split into an
417         argument vector in the usual fashion.  The function returns
418         a string which is processed as if it had appeared literally
419         as part of the current spec.
420  %{S}   substitutes the -S switch, if that switch was given to GCC.
421         If that switch was not specified, this substitutes nothing.
422         Here S is a metasyntactic variable.
423  %{S*}  substitutes all the switches specified to GCC whose names start
424         with -S.  This is used for -o, -I, etc; switches that take
425         arguments.  GCC considers `-o foo' as being one switch whose
426         name starts with `o'.  %{o*} would substitute this text,
427         including the space; thus, two arguments would be generated.
428  %{S*&T*} likewise, but preserve order of S and T options (the order
429         of S and T in the spec is not significant).  Can be any number
430         of ampersand-separated variables; for each the wild card is
431         optional.  Useful for CPP as %{D*&U*&A*}.
432
433  %{S:X}   substitutes X, if the -S switch was given to GCC.
434  %{!S:X}  substitutes X, if the -S switch was NOT given to GCC.
435  %{S*:X}  substitutes X if one or more switches whose names start
436           with -S was given to GCC.  Normally X is substituted only
437           once, no matter how many such switches appeared.  However,
438           if %* appears somewhere in X, then X will be substituted
439           once for each matching switch, with the %* replaced by the
440           part of that switch that matched the '*'.
441  %{.S:X}  substitutes X, if processing a file with suffix S.
442  %{!.S:X} substitutes X, if NOT processing a file with suffix S.
443  %{,S:X}  substitutes X, if processing a file which will use spec S.
444  %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
445
446  %{S|T:X} substitutes X if either -S or -T was given to GCC.  This may be
447           combined with '!', '.', ',', and '*' as above binding stronger
448           than the OR.
449           If %* appears in X, all of the alternatives must be starred, and
450           only the first matching alternative is substituted.
451  %{S:X;   if S was given to GCC, substitutes X;
452    T:Y;   else if T was given to GCC, substitutes Y;
453     :D}   else substitutes D.  There can be as many clauses as you need.
454           This may be combined with '.', '!', ',', '|', and '*' as above.
455
456  %(Spec) processes a specification defined in a specs file as *Spec:
457  %[Spec] as above, but put __ around -D arguments
458
459 The conditional text X in a %{S:X} or similar construct may contain
460 other nested % constructs or spaces, or even newlines.  They are
461 processed as usual, as described above.  Trailing white space in X is
462 ignored.  White space may also appear anywhere on the left side of the
463 colon in these constructs, except between . or * and the corresponding
464 word.
465
466 The -O, -f, -m, and -W switches are handled specifically in these
467 constructs.  If another value of -O or the negated form of a -f, -m, or
468 -W switch is found later in the command line, the earlier switch
469 value is ignored, except with {S*} where S is just one letter; this
470 passes all matching options.
471
472 The character | at the beginning of the predicate text is used to indicate
473 that a command should be piped to the following command, but only if -pipe
474 is specified.
475
476 Note that it is built into GCC which switches take arguments and which
477 do not.  You might think it would be useful to generalize this to
478 allow each compiler's spec to say which switches take arguments.  But
479 this cannot be done in a consistent fashion.  GCC cannot even decide
480 which input files have been specified without knowing which switches
481 take arguments, and it must know which input files to compile in order
482 to tell which compilers to run.
483
484 GCC also knows implicitly that arguments starting in `-l' are to be
485 treated as compiler output files, and passed to the linker in their
486 proper position among the other output files.  */
487 \f
488 /* Define the macros used for specs %a, %l, %L, %S, %C, %1.  */
489
490 /* config.h can define ASM_SPEC to provide extra args to the assembler
491    or extra switch-translations.  */
492 #ifndef ASM_SPEC
493 #define ASM_SPEC ""
494 #endif
495
496 /* config.h can define ASM_FINAL_SPEC to run a post processor after
497    the assembler has run.  */
498 #ifndef ASM_FINAL_SPEC
499 #define ASM_FINAL_SPEC ""
500 #endif
501
502 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
503    or extra switch-translations.  */
504 #ifndef CPP_SPEC
505 #define CPP_SPEC ""
506 #endif
507
508 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
509    or extra switch-translations.  */
510 #ifndef CC1_SPEC
511 #define CC1_SPEC ""
512 #endif
513
514 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
515    or extra switch-translations.  */
516 #ifndef CC1PLUS_SPEC
517 #define CC1PLUS_SPEC ""
518 #endif
519
520 /* config.h can define LINK_SPEC to provide extra args to the linker
521    or extra switch-translations.  */
522 #ifndef LINK_SPEC
523 #define LINK_SPEC ""
524 #endif
525
526 /* config.h can define LIB_SPEC to override the default libraries.  */
527 #ifndef LIB_SPEC
528 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
529 #endif
530
531 /* mudflap specs */
532 #ifndef MFWRAP_SPEC
533 /* XXX: valid only for GNU ld */
534 /* XXX: should exactly match hooks provided by libmudflap.a */
535 #define MFWRAP_SPEC " %{static: %{fmudflap|fmudflapth: \
536  --wrap=malloc --wrap=free --wrap=calloc --wrap=realloc\
537  --wrap=mmap --wrap=munmap --wrap=alloca\
538 } %{fmudflapth: --wrap=pthread_create\
539 }} %{fmudflap|fmudflapth: --wrap=main}"
540 #endif
541 #ifndef MFLIB_SPEC
542 #define MFLIB_SPEC "%{fmudflap|fmudflapth: -export-dynamic}"
543 #endif
544
545 /* When using -fsplit-stack we need to wrap pthread_create, in order
546    to initialize the stack guard.  We always use wrapping, rather than
547    shared library ordering, and we keep the wrapper function in
548    libgcc.  This is not yet a real spec, though it could become one;
549    it is currently just stuffed into LINK_SPEC.  FIXME: This wrapping
550    only works with GNU ld and gold.  FIXME: This is incompatible with
551    -fmudflap when linking statically, which wants to do its own
552    wrapping.  */
553 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
554
555 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
556    included.  */
557 #ifndef LIBGCC_SPEC
558 #if defined(REAL_LIBGCC_SPEC)
559 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
560 #elif defined(LINK_LIBGCC_SPECIAL_1)
561 /* Have gcc do the search for libgcc.a.  */
562 #define LIBGCC_SPEC "libgcc.a%s"
563 #else
564 #define LIBGCC_SPEC "-lgcc"
565 #endif
566 #endif
567
568 /* config.h can define STARTFILE_SPEC to override the default crt0 files.  */
569 #ifndef STARTFILE_SPEC
570 #define STARTFILE_SPEC  \
571   "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
572 #endif
573
574 /* config.h can define ENDFILE_SPEC to override the default crtn files.  */
575 #ifndef ENDFILE_SPEC
576 #define ENDFILE_SPEC ""
577 #endif
578
579 #ifndef LINKER_NAME
580 #define LINKER_NAME "collect2"
581 #endif
582
583 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
584 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
585 #else
586 #define ASM_MAP ""
587 #endif
588
589 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
590    to the assembler.  */
591 #ifndef ASM_DEBUG_SPEC
592 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
593      && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
594 #  define ASM_DEBUG_SPEC                                                \
595       (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG                            \
596        ? "%{!g0:%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}}" ASM_MAP    \
597        : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
598 # else
599 #  if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
600 #   define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
601 #  endif
602 #  if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
603 #   define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
604 #  endif
605 # endif
606 #endif
607 #ifndef ASM_DEBUG_SPEC
608 # define ASM_DEBUG_SPEC ""
609 #endif
610
611 /* Here is the spec for running the linker, after compiling all files.  */
612
613 /* This is overridable by the target in case they need to specify the
614    -lgcc and -lc order specially, yet not require them to override all
615    of LINK_COMMAND_SPEC.  */
616 #ifndef LINK_GCC_C_SEQUENCE_SPEC
617 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
618 #endif
619
620 #ifndef LINK_SSP_SPEC
621 #ifdef TARGET_LIBC_PROVIDES_SSP
622 #define LINK_SSP_SPEC "%{fstack-protector:}"
623 #else
624 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all:-lssp_nonshared -lssp}"
625 #endif
626 #endif
627
628 #ifndef LINK_PIE_SPEC
629 #ifdef HAVE_LD_PIE
630 #define LINK_PIE_SPEC "%{pie:-pie} "
631 #else
632 #define LINK_PIE_SPEC "%{pie:} "
633 #endif
634 #endif
635
636 #ifndef LINK_BUILDID_SPEC
637 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
638 #  define LINK_BUILDID_SPEC "%{!r:--build-id} "
639 # endif
640 #endif
641
642
643 /* -u* was put back because both BSD and SysV seem to support it.  */
644 /* %{static:} simply prevents an error message if the target machine
645    doesn't handle -static.  */
646 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
647    scripts which exist in user specified directories, or in standard
648    directories.  */
649 /* We pass any -flto flags on to the linker, which is expected
650    to understand them.  In practice, this means it had better be collect2.  */
651 #ifndef LINK_COMMAND_SPEC
652 #define LINK_COMMAND_SPEC "\
653 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
654     %(linker) \
655     %{fuse-linker-plugin: \
656     -plugin %(linker_plugin_file) \
657     -plugin-opt=%(lto_wrapper) \
658     -plugin-opt=-fresolution=%u.res \
659     %{static|static-libgcc:-plugin-opt=-pass-through=%(lto_libgcc)}     \
660     %{static:-plugin-opt=-pass-through=-lc}     \
661     } \
662     %{flto*:%<fcompare-debug*} \
663     %{flto*} %l " LINK_PIE_SPEC \
664    "%X %{o*} %{A} %{d} %{e*} %{m} %{N} %{n} %{r}\
665     %{s} %{t} %{u*} %{z} %{Z} %{!A:%{!nostdlib:%{!nostartfiles:%S}}}\
666     %{static:} %{L*} %(mfwrap) %(link_libgcc) %o\
667     %{fopenmp|ftree-parallelize-loops=*:%:include(libgomp.spec)%(link_gomp)}\
668     %(mflib) " STACK_SPLIT_SPEC "\
669     %{fprofile-arcs|fprofile-generate*|coverage:-lgcov}\
670     %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
671     %{!A:%{!nostdlib:%{!nostartfiles:%E}}} %{T*} }}}}}}"
672 #endif
673
674 #ifndef LINK_LIBGCC_SPEC
675 /* Generate -L options for startfile prefix list.  */
676 # define LINK_LIBGCC_SPEC "%D"
677 #endif
678
679 #ifndef STARTFILE_PREFIX_SPEC
680 # define STARTFILE_PREFIX_SPEC ""
681 #endif
682
683 #ifndef SYSROOT_SPEC
684 # define SYSROOT_SPEC "--sysroot=%R"
685 #endif
686
687 #ifndef SYSROOT_SUFFIX_SPEC
688 # define SYSROOT_SUFFIX_SPEC ""
689 #endif
690
691 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
692 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
693 #endif
694
695 static const char *asm_debug;
696 static const char *cpp_spec = CPP_SPEC;
697 static const char *cc1_spec = CC1_SPEC;
698 static const char *cc1plus_spec = CC1PLUS_SPEC;
699 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
700 static const char *link_ssp_spec = LINK_SSP_SPEC;
701 static const char *asm_spec = ASM_SPEC;
702 static const char *asm_final_spec = ASM_FINAL_SPEC;
703 static const char *link_spec = LINK_SPEC;
704 static const char *lib_spec = LIB_SPEC;
705 static const char *mfwrap_spec = MFWRAP_SPEC;
706 static const char *mflib_spec = MFLIB_SPEC;
707 static const char *link_gomp_spec = "";
708 static const char *libgcc_spec = LIBGCC_SPEC;
709 static const char *endfile_spec = ENDFILE_SPEC;
710 static const char *startfile_spec = STARTFILE_SPEC;
711 static const char *linker_name_spec = LINKER_NAME;
712 static const char *linker_plugin_file_spec = "";
713 static const char *lto_wrapper_spec = "";
714 static const char *lto_gcc_spec = "";
715 static const char *lto_libgcc_spec = "";
716 static const char *link_command_spec = LINK_COMMAND_SPEC;
717 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
718 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
719 static const char *sysroot_spec = SYSROOT_SPEC;
720 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
721 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
722
723 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
724    There should be no need to override these in target dependent files,
725    but we need to copy them to the specs file so that newer versions
726    of the GCC driver can correctly drive older tool chains with the
727    appropriate -B options.  */
728
729 /* When cpplib handles traditional preprocessing, get rid of this, and
730    call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
731    that we default the front end language better.  */
732 static const char *trad_capable_cpp =
733 "cc1 -E %{traditional|ftraditional|traditional-cpp:-traditional-cpp}";
734
735 /* We don't wrap .d files in %W{} since a missing .d file, and
736    therefore no dependency entry, confuses make into thinking a .o
737    file that happens to exist is up-to-date.  */
738 static const char *cpp_unique_options =
739 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
740  %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
741  %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
742  %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
743  %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
744  %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
745  %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
746  %{H} %C %{D*&U*&A*} %{i*} %Z %i\
747  %{fmudflap:-D_MUDFLAP -include mf-runtime.h}\
748  %{fmudflapth:-D_MUDFLAP -D_MUDFLAPTH -include mf-runtime.h}\
749  %{E|M|MM:%W{o*}}";
750
751 /* This contains cpp options which are common with cc1_options and are passed
752    only when preprocessing only to avoid duplication.  We pass the cc1 spec
753    options to the preprocessor so that it the cc1 spec may manipulate
754    options used to set target flags.  Those special target flags settings may
755    in turn cause preprocessor symbols to be defined specially.  */
756 static const char *cpp_options =
757 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
758  %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
759  %{undef} %{save-temps*:-fpch-preprocess}";
760
761 /* This contains cpp options which are not passed when the preprocessor
762    output will be used by another program.  */
763 static const char *cpp_debug_options = "%{d*}";
764
765 /* NB: This is shared amongst all front-ends, except for Ada.  */
766 static const char *cc1_options =
767 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
768  %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
769  %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
770  %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
771  %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
772  %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
773  %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
774  %{Qn:-fno-ident} %{-help:--help}\
775  %{-target-help:--target-help}\
776  %{-version:--version}\
777  %{-help=*:--help=%*}\
778  %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
779  %{fsyntax-only:-o %j} %{-param*}\
780  %{fmudflap|fmudflapth:-fno-builtin -fno-merge-constants}\
781  %{coverage:-fprofile-arcs -ftest-coverage}";
782
783 static const char *asm_options =
784 "%{--target-help:%:print-asm-header()} "
785 #if HAVE_GNU_AS
786 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
787    to the assembler equivalents.  */
788 "%{v} %{w:-W} %{I*} "
789 #endif
790 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
791
792 static const char *invoke_as =
793 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
794 "%{!fwpa:\
795    %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
796    %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
797   }";
798 #else
799 "%{!fwpa:\
800    %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
801    %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
802   }";
803 #endif
804
805 /* Some compilers have limits on line lengths, and the multilib_select
806    and/or multilib_matches strings can be very long, so we build them at
807    run time.  */
808 static struct obstack multilib_obstack;
809 static const char *multilib_select;
810 static const char *multilib_matches;
811 static const char *multilib_defaults;
812 static const char *multilib_exclusions;
813
814 /* Check whether a particular argument is a default argument.  */
815
816 #ifndef MULTILIB_DEFAULTS
817 #define MULTILIB_DEFAULTS { "" }
818 #endif
819
820 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
821
822 #ifndef DRIVER_SELF_SPECS
823 #define DRIVER_SELF_SPECS ""
824 #endif
825
826 /* Adding -fopenmp should imply pthreads.  This is particularly important
827    for targets that use different start files and suchlike.  */
828 #ifndef GOMP_SELF_SPECS
829 #define GOMP_SELF_SPECS "%{fopenmp|ftree-parallelize-loops=*: -pthread}"
830 #endif
831
832 static const char *const driver_self_specs[] = {
833   "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
834   DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS
835 };
836
837 #ifndef OPTION_DEFAULT_SPECS
838 #define OPTION_DEFAULT_SPECS { "", "" }
839 #endif
840
841 struct default_spec
842 {
843   const char *name;
844   const char *spec;
845 };
846
847 static const struct default_spec
848   option_default_specs[] = { OPTION_DEFAULT_SPECS };
849
850 struct user_specs
851 {
852   struct user_specs *next;
853   const char *filename;
854 };
855
856 static struct user_specs *user_specs_head, *user_specs_tail;
857
858 \f
859 /* Record the mapping from file suffixes for compilation specs.  */
860
861 struct compiler
862 {
863   const char *suffix;           /* Use this compiler for input files
864                                    whose names end in this suffix.  */
865
866   const char *spec;             /* To use this compiler, run this spec.  */
867
868   const char *cpp_spec;         /* If non-NULL, substitute this spec
869                                    for `%C', rather than the usual
870                                    cpp_spec.  */
871   const int combinable;          /* If nonzero, compiler can deal with
872                                     multiple source files at once (IMA).  */
873   const int needs_preprocessing; /* If nonzero, source files need to
874                                     be run through a preprocessor.  */
875 };
876
877 /* Pointer to a vector of `struct compiler' that gives the spec for
878    compiling a file, based on its suffix.
879    A file that does not end in any of these suffixes will be passed
880    unchanged to the loader and nothing else will be done to it.
881
882    An entry containing two 0s is used to terminate the vector.
883
884    If multiple entries match a file, the last matching one is used.  */
885
886 static struct compiler *compilers;
887
888 /* Number of entries in `compilers', not counting the null terminator.  */
889
890 static int n_compilers;
891
892 /* The default list of file name suffixes and their compilation specs.  */
893
894 static const struct compiler default_compilers[] =
895 {
896   /* Add lists of suffixes of known languages here.  If those languages
897      were not present when we built the driver, we will hit these copies
898      and be given a more meaningful error than "file not used since
899      linking is not done".  */
900   {".m",  "#Objective-C", 0, 0, 0}, {".mi",  "#Objective-C", 0, 0, 0},
901   {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
902   {".mii", "#Objective-C++", 0, 0, 0},
903   {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
904   {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
905   {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
906   {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
907   {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
908   {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
909   {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
910   {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
911   {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
912   {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
913   {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
914   {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
915   {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
916   {".r", "#Ratfor", 0, 0, 0},
917   {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
918   {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
919   {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
920   /* Next come the entries for C.  */
921   {".c", "@c", 0, 0, 1},
922   {"@c",
923    /* cc1 has an integrated ISO C preprocessor.  We should invoke the
924       external preprocessor if -save-temps is given.  */
925      "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
926       %{!E:%{!M:%{!MM:\
927           %{traditional|ftraditional:\
928 %eGNU C no longer supports -traditional without -E}\
929       %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
930           %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
931             cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
932           %(cc1_options)}\
933       %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
934           cc1 %(cpp_unique_options) %(cc1_options)}}}\
935       %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
936   {"-",
937    "%{!E:%e-E or -x required when input is from standard input}\
938     %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
939   {".h", "@c-header", 0, 0, 0},
940   {"@c-header",
941    /* cc1 has an integrated ISO C preprocessor.  We should invoke the
942       external preprocessor if -save-temps is given.  */
943      "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
944       %{!E:%{!M:%{!MM:\
945           %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
946                 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
947                     cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
948                         %(cc1_options)\
949                         %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
950                         %W{o*:--output-pch=%*}}%V}\
951           %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
952                 cc1 %(cpp_unique_options) %(cc1_options)\
953                     %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
954                     %W{o*:--output-pch=%*}}%V}}}}}}", 0, 0, 0},
955   {".i", "@cpp-output", 0, 0, 0},
956   {"@cpp-output",
957    "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 1, 0},
958   {".s", "@assembler", 0, 1, 0},
959   {"@assembler",
960    "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 1, 0},
961   {".sx", "@assembler-with-cpp", 0, 1, 0},
962   {".S", "@assembler-with-cpp", 0, 1, 0},
963   {"@assembler-with-cpp",
964 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
965    "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
966       %{E|M|MM:%(cpp_debug_options)}\
967       %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
968        as %(asm_debug) %(asm_options) %|.s %A }}}}"
969 #else
970    "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
971       %{E|M|MM:%(cpp_debug_options)}\
972       %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
973        as %(asm_debug) %(asm_options) %m.s %A }}}}"
974 #endif
975    , 0, 1, 0},
976
977 #include "specs.h"
978   /* Mark end of table.  */
979   {0, 0, 0, 0, 0}
980 };
981
982 /* Number of elements in default_compilers, not counting the terminator.  */
983
984 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
985
986 /* A vector of options to give to the linker.
987    These options are accumulated by %x,
988    and substituted into the linker command with %X.  */
989 static int n_linker_options;
990 static char **linker_options;
991
992 /* A vector of options to give to the assembler.
993    These options are accumulated by -Wa,
994    and substituted into the assembler command with %Y.  */
995 static int n_assembler_options;
996 static char **assembler_options;
997
998 /* A vector of options to give to the preprocessor.
999    These options are accumulated by -Wp,
1000    and substituted into the preprocessor command with %Z.  */
1001 static int n_preprocessor_options;
1002 static char **preprocessor_options;
1003 \f
1004 static char *
1005 skip_whitespace (char *p)
1006 {
1007   while (1)
1008     {
1009       /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1010          be considered whitespace.  */
1011       if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1012         return p + 1;
1013       else if (*p == '\n' || *p == ' ' || *p == '\t')
1014         p++;
1015       else if (*p == '#')
1016         {
1017           while (*p != '\n')
1018             p++;
1019           p++;
1020         }
1021       else
1022         break;
1023     }
1024
1025   return p;
1026 }
1027 /* Structures to keep track of prefixes to try when looking for files.  */
1028
1029 struct prefix_list
1030 {
1031   const char *prefix;         /* String to prepend to the path.  */
1032   struct prefix_list *next;   /* Next in linked list.  */
1033   int require_machine_suffix; /* Don't use without machine_suffix.  */
1034   /* 2 means try both machine_suffix and just_machine_suffix.  */
1035   int priority;               /* Sort key - priority within list.  */
1036   int os_multilib;            /* 1 if OS multilib scheme should be used,
1037                                  0 for GCC multilib scheme.  */
1038 };
1039
1040 struct path_prefix
1041 {
1042   struct prefix_list *plist;  /* List of prefixes to try */
1043   int max_len;                /* Max length of a prefix in PLIST */
1044   const char *name;           /* Name of this list (used in config stuff) */
1045 };
1046
1047 /* List of prefixes to try when looking for executables.  */
1048
1049 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1050
1051 /* List of prefixes to try when looking for startup (crt0) files.  */
1052
1053 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1054
1055 /* List of prefixes to try when looking for include files.  */
1056
1057 static struct path_prefix include_prefixes = { 0, 0, "include" };
1058
1059 /* Suffix to attach to directories searched for commands.
1060    This looks like `MACHINE/VERSION/'.  */
1061
1062 static const char *machine_suffix = 0;
1063
1064 /* Suffix to attach to directories searched for commands.
1065    This is just `MACHINE/'.  */
1066
1067 static const char *just_machine_suffix = 0;
1068
1069 /* Adjusted value of GCC_EXEC_PREFIX envvar.  */
1070
1071 static const char *gcc_exec_prefix;
1072
1073 /* Adjusted value of standard_libexec_prefix.  */
1074
1075 static const char *gcc_libexec_prefix;
1076
1077 /* Default prefixes to attach to command names.  */
1078
1079 #ifndef STANDARD_STARTFILE_PREFIX_1
1080 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1081 #endif
1082 #ifndef STANDARD_STARTFILE_PREFIX_2
1083 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1084 #endif
1085
1086 #ifdef CROSS_DIRECTORY_STRUCTURE  /* Don't use these prefixes for a cross compiler.  */
1087 #undef MD_EXEC_PREFIX
1088 #undef MD_STARTFILE_PREFIX
1089 #undef MD_STARTFILE_PREFIX_1
1090 #endif
1091
1092 /* If no prefixes defined, use the null string, which will disable them.  */
1093 #ifndef MD_EXEC_PREFIX
1094 #define MD_EXEC_PREFIX ""
1095 #endif
1096 #ifndef MD_STARTFILE_PREFIX
1097 #define MD_STARTFILE_PREFIX ""
1098 #endif
1099 #ifndef MD_STARTFILE_PREFIX_1
1100 #define MD_STARTFILE_PREFIX_1 ""
1101 #endif
1102
1103 /* These directories are locations set at configure-time based on the
1104    --prefix option provided to configure.  Their initializers are
1105    defined in Makefile.in.  These paths are not *directly* used when
1106    gcc_exec_prefix is set because, in that case, we know where the
1107    compiler has been installed, and use paths relative to that
1108    location instead.  */
1109 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1110 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1111 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1112 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1113
1114 /* For native compilers, these are well-known paths containing
1115    components that may be provided by the system.  For cross
1116    compilers, these paths are not used.  */
1117 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1118 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1119 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1120 static const char *const standard_startfile_prefix_1
1121   = STANDARD_STARTFILE_PREFIX_1;
1122 static const char *const standard_startfile_prefix_2
1123   = STANDARD_STARTFILE_PREFIX_2;
1124
1125 /* A relative path to be used in finding the location of tools
1126    relative to the driver.  */
1127 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1128
1129 /* Subdirectory to use for locating libraries.  Set by
1130    set_multilib_dir based on the compilation options.  */
1131
1132 static const char *multilib_dir;
1133
1134 /* Subdirectory to use for locating libraries in OS conventions.  Set by
1135    set_multilib_dir based on the compilation options.  */
1136
1137 static const char *multilib_os_dir;
1138 \f
1139 /* Structure to keep track of the specs that have been defined so far.
1140    These are accessed using %(specname) or %[specname] in a compiler
1141    or link spec.  */
1142
1143 struct spec_list
1144 {
1145                                 /* The following 2 fields must be first */
1146                                 /* to allow EXTRA_SPECS to be initialized */
1147   const char *name;             /* name of the spec.  */
1148   const char *ptr;              /* available ptr if no static pointer */
1149
1150                                 /* The following fields are not initialized */
1151                                 /* by EXTRA_SPECS */
1152   const char **ptr_spec;        /* pointer to the spec itself.  */
1153   struct spec_list *next;       /* Next spec in linked list.  */
1154   int name_len;                 /* length of the name */
1155   int alloc_p;                  /* whether string was allocated */
1156 };
1157
1158 #define INIT_STATIC_SPEC(NAME,PTR) \
1159 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, 0 }
1160
1161 /* List of statically defined specs.  */
1162 static struct spec_list static_specs[] =
1163 {
1164   INIT_STATIC_SPEC ("asm",                      &asm_spec),
1165   INIT_STATIC_SPEC ("asm_debug",                &asm_debug),
1166   INIT_STATIC_SPEC ("asm_final",                &asm_final_spec),
1167   INIT_STATIC_SPEC ("asm_options",              &asm_options),
1168   INIT_STATIC_SPEC ("invoke_as",                &invoke_as),
1169   INIT_STATIC_SPEC ("cpp",                      &cpp_spec),
1170   INIT_STATIC_SPEC ("cpp_options",              &cpp_options),
1171   INIT_STATIC_SPEC ("cpp_debug_options",        &cpp_debug_options),
1172   INIT_STATIC_SPEC ("cpp_unique_options",       &cpp_unique_options),
1173   INIT_STATIC_SPEC ("trad_capable_cpp",         &trad_capable_cpp),
1174   INIT_STATIC_SPEC ("cc1",                      &cc1_spec),
1175   INIT_STATIC_SPEC ("cc1_options",              &cc1_options),
1176   INIT_STATIC_SPEC ("cc1plus",                  &cc1plus_spec),
1177   INIT_STATIC_SPEC ("link_gcc_c_sequence",      &link_gcc_c_sequence_spec),
1178   INIT_STATIC_SPEC ("link_ssp",                 &link_ssp_spec),
1179   INIT_STATIC_SPEC ("endfile",                  &endfile_spec),
1180   INIT_STATIC_SPEC ("link",                     &link_spec),
1181   INIT_STATIC_SPEC ("lib",                      &lib_spec),
1182   INIT_STATIC_SPEC ("mfwrap",                   &mfwrap_spec),
1183   INIT_STATIC_SPEC ("mflib",                    &mflib_spec),
1184   INIT_STATIC_SPEC ("link_gomp",                &link_gomp_spec),
1185   INIT_STATIC_SPEC ("libgcc",                   &libgcc_spec),
1186   INIT_STATIC_SPEC ("startfile",                &startfile_spec),
1187   INIT_STATIC_SPEC ("cross_compile",            &cross_compile),
1188   INIT_STATIC_SPEC ("version",                  &compiler_version),
1189   INIT_STATIC_SPEC ("multilib",                 &multilib_select),
1190   INIT_STATIC_SPEC ("multilib_defaults",        &multilib_defaults),
1191   INIT_STATIC_SPEC ("multilib_extra",           &multilib_extra),
1192   INIT_STATIC_SPEC ("multilib_matches",         &multilib_matches),
1193   INIT_STATIC_SPEC ("multilib_exclusions",      &multilib_exclusions),
1194   INIT_STATIC_SPEC ("multilib_options",         &multilib_options),
1195   INIT_STATIC_SPEC ("linker",                   &linker_name_spec),
1196   INIT_STATIC_SPEC ("linker_plugin_file",       &linker_plugin_file_spec),
1197   INIT_STATIC_SPEC ("lto_wrapper",              &lto_wrapper_spec),
1198   INIT_STATIC_SPEC ("lto_gcc",                  &lto_gcc_spec),
1199   INIT_STATIC_SPEC ("lto_libgcc",               &lto_libgcc_spec),
1200   INIT_STATIC_SPEC ("link_libgcc",              &link_libgcc_spec),
1201   INIT_STATIC_SPEC ("md_exec_prefix",           &md_exec_prefix),
1202   INIT_STATIC_SPEC ("md_startfile_prefix",      &md_startfile_prefix),
1203   INIT_STATIC_SPEC ("md_startfile_prefix_1",    &md_startfile_prefix_1),
1204   INIT_STATIC_SPEC ("startfile_prefix_spec",    &startfile_prefix_spec),
1205   INIT_STATIC_SPEC ("sysroot_spec",             &sysroot_spec),
1206   INIT_STATIC_SPEC ("sysroot_suffix_spec",      &sysroot_suffix_spec),
1207   INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1208 };
1209
1210 #ifdef EXTRA_SPECS              /* additional specs needed */
1211 /* Structure to keep track of just the first two args of a spec_list.
1212    That is all that the EXTRA_SPECS macro gives us.  */
1213 struct spec_list_1
1214 {
1215   const char *const name;
1216   const char *const ptr;
1217 };
1218
1219 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1220 static struct spec_list *extra_specs = (struct spec_list *) 0;
1221 #endif
1222
1223 /* List of dynamically allocates specs that have been defined so far.  */
1224
1225 static struct spec_list *specs = (struct spec_list *) 0;
1226 \f
1227 /* List of static spec functions.  */
1228
1229 static const struct spec_function static_spec_functions[] =
1230 {
1231   { "getenv",                   getenv_spec_function },
1232   { "if-exists",                if_exists_spec_function },
1233   { "if-exists-else",           if_exists_else_spec_function },
1234   { "replace-outfile",          replace_outfile_spec_function },
1235   { "remove-outfile",           remove_outfile_spec_function },
1236   { "version-compare",          version_compare_spec_function },
1237   { "include",                  include_spec_function },
1238   { "find-file",                find_file_spec_function },
1239   { "find-plugindir",           find_plugindir_spec_function },
1240   { "print-asm-header",         print_asm_header_spec_function },
1241   { "compare-debug-dump-opt",   compare_debug_dump_opt_spec_function },
1242   { "compare-debug-self-opt",   compare_debug_self_opt_spec_function },
1243   { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1244 #ifdef EXTRA_SPEC_FUNCTIONS
1245   EXTRA_SPEC_FUNCTIONS
1246 #endif
1247   { 0, 0 }
1248 };
1249
1250 static int processing_spec_function;
1251 \f
1252 /* Add appropriate libgcc specs to OBSTACK, taking into account
1253    various permutations of -shared-libgcc, -shared, and such.  */
1254
1255 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1256
1257 #ifndef USE_LD_AS_NEEDED
1258 #define USE_LD_AS_NEEDED 0
1259 #endif
1260
1261 static void
1262 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1263                 const char *static_name, const char *eh_name)
1264 {
1265   char *buf;
1266
1267   buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1268                 "%{!static:%{!static-libgcc:"
1269 #if USE_LD_AS_NEEDED
1270                 "%{!shared-libgcc:",
1271                 static_name, " --as-needed ", shared_name, " --no-as-needed"
1272                 "}"
1273                 "%{shared-libgcc:",
1274                 shared_name, "%{!shared: ", static_name, "}"
1275                 "}"
1276 #else
1277                 "%{!shared:"
1278                 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1279                 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1280                 "}"
1281 #ifdef LINK_EH_SPEC
1282                 "%{shared:"
1283                 "%{shared-libgcc:", shared_name, "}"
1284                 "%{!shared-libgcc:", static_name, "}"
1285                 "}"
1286 #else
1287                 "%{shared:", shared_name, "}"
1288 #endif
1289 #endif
1290                 "}}", NULL);
1291
1292   obstack_grow (obstack, buf, strlen (buf));
1293   free (buf);
1294 }
1295 #endif /* ENABLE_SHARED_LIBGCC */
1296
1297 /* Initialize the specs lookup routines.  */
1298
1299 static void
1300 init_spec (void)
1301 {
1302   struct spec_list *next = (struct spec_list *) 0;
1303   struct spec_list *sl   = (struct spec_list *) 0;
1304   int i;
1305
1306   if (specs)
1307     return;                     /* Already initialized.  */
1308
1309   if (verbose_flag)
1310     fnotice (stderr, "Using built-in specs.\n");
1311
1312 #ifdef EXTRA_SPECS
1313   extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1314
1315   for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1316     {
1317       sl = &extra_specs[i];
1318       sl->name = extra_specs_1[i].name;
1319       sl->ptr = extra_specs_1[i].ptr;
1320       sl->next = next;
1321       sl->name_len = strlen (sl->name);
1322       sl->ptr_spec = &sl->ptr;
1323       next = sl;
1324     }
1325 #endif
1326
1327   for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1328     {
1329       sl = &static_specs[i];
1330       sl->next = next;
1331       next = sl;
1332     }
1333
1334 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1335   /* ??? If neither -shared-libgcc nor --static-libgcc was
1336      seen, then we should be making an educated guess.  Some proposed
1337      heuristics for ELF include:
1338
1339         (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1340             program will be doing dynamic loading, which will likely
1341             need the shared libgcc.
1342
1343         (2) If "-ldl", then it's also a fair bet that we're doing
1344             dynamic loading.
1345
1346         (3) For each ET_DYN we're linking against (either through -lfoo
1347             or /some/path/foo.so), check to see whether it or one of
1348             its dependencies depends on a shared libgcc.
1349
1350         (4) If "-shared"
1351
1352             If the runtime is fixed to look for program headers instead
1353             of calling __register_frame_info at all, for each object,
1354             use the shared libgcc if any EH symbol referenced.
1355
1356             If crtstuff is fixed to not invoke __register_frame_info
1357             automatically, for each object, use the shared libgcc if
1358             any non-empty unwind section found.
1359
1360      Doing any of this probably requires invoking an external program to
1361      do the actual object file scanning.  */
1362   {
1363     const char *p = libgcc_spec;
1364     int in_sep = 1;
1365
1366     /* Transform the extant libgcc_spec into one that uses the shared libgcc
1367        when given the proper command line arguments.  */
1368     while (*p)
1369       {
1370         if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1371           {
1372             init_gcc_specs (&obstack,
1373                             "-lgcc_s"
1374 #ifdef USE_LIBUNWIND_EXCEPTIONS
1375                             " -lunwind"
1376 #endif
1377                             ,
1378                             "-lgcc",
1379                             "-lgcc_eh"
1380 #ifdef USE_LIBUNWIND_EXCEPTIONS
1381 # ifdef HAVE_LD_STATIC_DYNAMIC
1382                             " %{!static:-Bstatic} -lunwind %{!static:-Bdynamic}"
1383 # else
1384                             " -lunwind"
1385 # endif
1386 #endif
1387                             );
1388
1389             p += 5;
1390             in_sep = 0;
1391           }
1392         else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1393           {
1394             /* Ug.  We don't know shared library extensions.  Hope that
1395                systems that use this form don't do shared libraries.  */
1396             init_gcc_specs (&obstack,
1397                             "-lgcc_s",
1398                             "libgcc.a%s",
1399                             "libgcc_eh.a%s"
1400 #ifdef USE_LIBUNWIND_EXCEPTIONS
1401                             " -lunwind"
1402 #endif
1403                             );
1404             p += 10;
1405             in_sep = 0;
1406           }
1407         else
1408           {
1409             obstack_1grow (&obstack, *p);
1410             in_sep = (*p == ' ');
1411             p += 1;
1412           }
1413       }
1414
1415     obstack_1grow (&obstack, '\0');
1416     libgcc_spec = XOBFINISH (&obstack, const char *);
1417   }
1418 #endif
1419 #ifdef USE_AS_TRADITIONAL_FORMAT
1420   /* Prepend "--traditional-format" to whatever asm_spec we had before.  */
1421   {
1422     static const char tf[] = "--traditional-format ";
1423     obstack_grow (&obstack, tf, sizeof(tf) - 1);
1424     obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1425     asm_spec = XOBFINISH (&obstack, const char *);
1426   }
1427 #endif
1428
1429 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC
1430 # ifdef LINK_BUILDID_SPEC
1431   /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before.  */
1432   obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof(LINK_BUILDID_SPEC) - 1);
1433 # endif
1434 # ifdef LINK_EH_SPEC
1435   /* Prepend LINK_EH_SPEC to whatever link_spec we had before.  */
1436   obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1437 # endif
1438   obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1439   link_spec = XOBFINISH (&obstack, const char *);
1440 #endif
1441
1442   specs = sl;
1443 }
1444 \f
1445 /* Change the value of spec NAME to SPEC.  If SPEC is empty, then the spec is
1446    removed; If the spec starts with a + then SPEC is added to the end of the
1447    current spec.  */
1448
1449 static void
1450 set_spec (const char *name, const char *spec)
1451 {
1452   struct spec_list *sl;
1453   const char *old_spec;
1454   int name_len = strlen (name);
1455   int i;
1456
1457   /* If this is the first call, initialize the statically allocated specs.  */
1458   if (!specs)
1459     {
1460       struct spec_list *next = (struct spec_list *) 0;
1461       for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1462         {
1463           sl = &static_specs[i];
1464           sl->next = next;
1465           next = sl;
1466         }
1467       specs = sl;
1468     }
1469
1470   /* See if the spec already exists.  */
1471   for (sl = specs; sl; sl = sl->next)
1472     if (name_len == sl->name_len && !strcmp (sl->name, name))
1473       break;
1474
1475   if (!sl)
1476     {
1477       /* Not found - make it.  */
1478       sl = XNEW (struct spec_list);
1479       sl->name = xstrdup (name);
1480       sl->name_len = name_len;
1481       sl->ptr_spec = &sl->ptr;
1482       sl->alloc_p = 0;
1483       *(sl->ptr_spec) = "";
1484       sl->next = specs;
1485       specs = sl;
1486     }
1487
1488   old_spec = *(sl->ptr_spec);
1489   *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1490                      ? concat (old_spec, spec + 1, NULL)
1491                      : xstrdup (spec));
1492
1493 #ifdef DEBUG_SPECS
1494   if (verbose_flag)
1495     fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1496 #endif
1497
1498   /* Free the old spec.  */
1499   if (old_spec && sl->alloc_p)
1500     free (CONST_CAST(char *, old_spec));
1501
1502   sl->alloc_p = 1;
1503 }
1504 \f
1505 /* Accumulate a command (program name and args), and run it.  */
1506
1507 typedef const char *const_char_p; /* For DEF_VEC_P.  */
1508 DEF_VEC_P(const_char_p);
1509 DEF_VEC_ALLOC_P(const_char_p,heap);
1510
1511 /* Vector of pointers to arguments in the current line of specifications.  */
1512
1513 static VEC(const_char_p,heap) *argbuf;
1514
1515 /* Position in the argbuf vector containing the name of the output file
1516    (the value associated with the "-o" flag).  */
1517
1518 static int have_o_argbuf_index = 0;
1519
1520 /* Were the options -c, -S or -E passed.  */
1521 static int have_c = 0;
1522
1523 /* Was the option -o passed.  */
1524 static int have_o = 0;
1525
1526 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1527    temp file.  If the HOST_BIT_BUCKET is used for %j, no entry is made for
1528    it here.  */
1529
1530 static struct temp_name {
1531   const char *suffix;   /* suffix associated with the code.  */
1532   int length;           /* strlen (suffix).  */
1533   int unique;           /* Indicates whether %g or %u/%U was used.  */
1534   const char *filename; /* associated filename.  */
1535   int filename_length;  /* strlen (filename).  */
1536   struct temp_name *next;
1537 } *temp_names;
1538
1539 /* Number of commands executed so far.  */
1540
1541 static int execution_count;
1542
1543 /* Number of commands that exited with a signal.  */
1544
1545 static int signal_count;
1546 \f
1547 /* Allocate the argument vector.  */
1548
1549 static void
1550 alloc_args (void)
1551 {
1552   argbuf = VEC_alloc (const_char_p, heap, 10);
1553 }
1554
1555 /* Clear out the vector of arguments (after a command is executed).  */
1556
1557 static void
1558 clear_args (void)
1559 {
1560   VEC_truncate (const_char_p, argbuf, 0);
1561 }
1562
1563 /* Add one argument to the vector at the end.
1564    This is done when a space is seen or at the end of the line.
1565    If DELETE_ALWAYS is nonzero, the arg is a filename
1566     and the file should be deleted eventually.
1567    If DELETE_FAILURE is nonzero, the arg is a filename
1568     and the file should be deleted if this compilation fails.  */
1569
1570 static void
1571 store_arg (const char *arg, int delete_always, int delete_failure)
1572 {
1573   VEC_safe_push (const_char_p, heap, argbuf, arg);
1574
1575   if (strcmp (arg, "-o") == 0)
1576     have_o_argbuf_index = VEC_length (const_char_p, argbuf);
1577   if (delete_always || delete_failure)
1578     {
1579       const char *p;
1580       /* If the temporary file we should delete is specified as
1581          part of a joined argument extract the filename.  */
1582       if (arg[0] == '-'
1583           && (p = strrchr (arg, '=')))
1584         arg = p + 1;
1585       record_temp_file (arg, delete_always, delete_failure);
1586     }
1587 }
1588 \f
1589 /* Load specs from a file name named FILENAME, replacing occurrences of
1590    various different types of line-endings, \r\n, \n\r and just \r, with
1591    a single \n.  */
1592
1593 static char *
1594 load_specs (const char *filename)
1595 {
1596   int desc;
1597   int readlen;
1598   struct stat statbuf;
1599   char *buffer;
1600   char *buffer_p;
1601   char *specs;
1602   char *specs_p;
1603
1604   if (verbose_flag)
1605     fnotice (stderr, "Reading specs from %s\n", filename);
1606
1607   /* Open and stat the file.  */
1608   desc = open (filename, O_RDONLY, 0);
1609   if (desc < 0)
1610     pfatal_with_name (filename);
1611   if (stat (filename, &statbuf) < 0)
1612     pfatal_with_name (filename);
1613
1614   /* Read contents of file into BUFFER.  */
1615   buffer = XNEWVEC (char, statbuf.st_size + 1);
1616   readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1617   if (readlen < 0)
1618     pfatal_with_name (filename);
1619   buffer[readlen] = 0;
1620   close (desc);
1621
1622   specs = XNEWVEC (char, readlen + 1);
1623   specs_p = specs;
1624   for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1625     {
1626       int skip = 0;
1627       char c = *buffer_p;
1628       if (c == '\r')
1629         {
1630           if (buffer_p > buffer && *(buffer_p - 1) == '\n')     /* \n\r */
1631             skip = 1;
1632           else if (*(buffer_p + 1) == '\n')                     /* \r\n */
1633             skip = 1;
1634           else                                                  /* \r */
1635             c = '\n';
1636         }
1637       if (! skip)
1638         *specs_p++ = c;
1639     }
1640   *specs_p = '\0';
1641
1642   free (buffer);
1643   return (specs);
1644 }
1645
1646 /* Read compilation specs from a file named FILENAME,
1647    replacing the default ones.
1648
1649    A suffix which starts with `*' is a definition for
1650    one of the machine-specific sub-specs.  The "suffix" should be
1651    *asm, *cc1, *cpp, *link, *startfile, etc.
1652    The corresponding spec is stored in asm_spec, etc.,
1653    rather than in the `compilers' vector.
1654
1655    Anything invalid in the file is a fatal error.  */
1656
1657 static void
1658 read_specs (const char *filename, int main_p)
1659 {
1660   char *buffer;
1661   char *p;
1662
1663   buffer = load_specs (filename);
1664
1665   /* Scan BUFFER for specs, putting them in the vector.  */
1666   p = buffer;
1667   while (1)
1668     {
1669       char *suffix;
1670       char *spec;
1671       char *in, *out, *p1, *p2, *p3;
1672
1673       /* Advance P in BUFFER to the next nonblank nocomment line.  */
1674       p = skip_whitespace (p);
1675       if (*p == 0)
1676         break;
1677
1678       /* Is this a special command that starts with '%'? */
1679       /* Don't allow this for the main specs file, since it would
1680          encourage people to overwrite it.  */
1681       if (*p == '%' && !main_p)
1682         {
1683           p1 = p;
1684           while (*p && *p != '\n')
1685             p++;
1686
1687           /* Skip '\n'.  */
1688           p++;
1689
1690           if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1691               && (p1[sizeof "%include" - 1] == ' '
1692                   || p1[sizeof "%include" - 1] == '\t'))
1693             {
1694               char *new_filename;
1695
1696               p1 += sizeof ("%include");
1697               while (*p1 == ' ' || *p1 == '\t')
1698                 p1++;
1699
1700               if (*p1++ != '<' || p[-2] != '>')
1701                 fatal_error ("specs %%include syntax malformed after "
1702                              "%ld characters",
1703                              (long) (p1 - buffer + 1));
1704
1705               p[-2] = '\0';
1706               new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1707               read_specs (new_filename ? new_filename : p1, FALSE);
1708               continue;
1709             }
1710           else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1711                    && (p1[sizeof "%include_noerr" - 1] == ' '
1712                        || p1[sizeof "%include_noerr" - 1] == '\t'))
1713             {
1714               char *new_filename;
1715
1716               p1 += sizeof "%include_noerr";
1717               while (*p1 == ' ' || *p1 == '\t')
1718                 p1++;
1719
1720               if (*p1++ != '<' || p[-2] != '>')
1721                 fatal_error ("specs %%include syntax malformed after "
1722                              "%ld characters",
1723                              (long) (p1 - buffer + 1));
1724
1725               p[-2] = '\0';
1726               new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1727               if (new_filename)
1728                 read_specs (new_filename, FALSE);
1729               else if (verbose_flag)
1730                 fnotice (stderr, "could not find specs file %s\n", p1);
1731               continue;
1732             }
1733           else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1734                    && (p1[sizeof "%rename" - 1] == ' '
1735                        || p1[sizeof "%rename" - 1] == '\t'))
1736             {
1737               int name_len;
1738               struct spec_list *sl;
1739               struct spec_list *newsl;
1740
1741               /* Get original name.  */
1742               p1 += sizeof "%rename";
1743               while (*p1 == ' ' || *p1 == '\t')
1744                 p1++;
1745
1746               if (! ISALPHA ((unsigned char) *p1))
1747                 fatal_error ("specs %%rename syntax malformed after "
1748                              "%ld characters",
1749                              (long) (p1 - buffer));
1750
1751               p2 = p1;
1752               while (*p2 && !ISSPACE ((unsigned char) *p2))
1753                 p2++;
1754
1755               if (*p2 != ' ' && *p2 != '\t')
1756                 fatal_error ("specs %%rename syntax malformed after "
1757                              "%ld characters",
1758                              (long) (p2 - buffer));
1759
1760               name_len = p2 - p1;
1761               *p2++ = '\0';
1762               while (*p2 == ' ' || *p2 == '\t')
1763                 p2++;
1764
1765               if (! ISALPHA ((unsigned char) *p2))
1766                 fatal_error ("specs %%rename syntax malformed after "
1767                              "%ld characters",
1768                              (long) (p2 - buffer));
1769
1770               /* Get new spec name.  */
1771               p3 = p2;
1772               while (*p3 && !ISSPACE ((unsigned char) *p3))
1773                 p3++;
1774
1775               if (p3 != p - 1)
1776                 fatal_error ("specs %%rename syntax malformed after "
1777                              "%ld characters",
1778                              (long) (p3 - buffer));
1779               *p3 = '\0';
1780
1781               for (sl = specs; sl; sl = sl->next)
1782                 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1783                   break;
1784
1785               if (!sl)
1786                 fatal_error ("specs %s spec was not found to be renamed", p1);
1787
1788               if (strcmp (p1, p2) == 0)
1789                 continue;
1790
1791               for (newsl = specs; newsl; newsl = newsl->next)
1792                 if (strcmp (newsl->name, p2) == 0)
1793                   fatal_error ("%s: attempt to rename spec %qs to "
1794                                "already defined spec %qs",
1795                     filename, p1, p2);
1796
1797               if (verbose_flag)
1798                 {
1799                   fnotice (stderr, "rename spec %s to %s\n", p1, p2);
1800 #ifdef DEBUG_SPECS
1801                   fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
1802 #endif
1803                 }
1804
1805               set_spec (p2, *(sl->ptr_spec));
1806               if (sl->alloc_p)
1807                 free (CONST_CAST (char *, *(sl->ptr_spec)));
1808
1809               *(sl->ptr_spec) = "";
1810               sl->alloc_p = 0;
1811               continue;
1812             }
1813           else
1814             fatal_error ("specs unknown %% command after %ld characters",
1815                          (long) (p1 - buffer));
1816         }
1817
1818       /* Find the colon that should end the suffix.  */
1819       p1 = p;
1820       while (*p1 && *p1 != ':' && *p1 != '\n')
1821         p1++;
1822
1823       /* The colon shouldn't be missing.  */
1824       if (*p1 != ':')
1825         fatal_error ("specs file malformed after %ld characters",
1826                      (long) (p1 - buffer));
1827
1828       /* Skip back over trailing whitespace.  */
1829       p2 = p1;
1830       while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
1831         p2--;
1832
1833       /* Copy the suffix to a string.  */
1834       suffix = save_string (p, p2 - p);
1835       /* Find the next line.  */
1836       p = skip_whitespace (p1 + 1);
1837       if (p[1] == 0)
1838         fatal_error ("specs file malformed after %ld characters",
1839                      (long) (p - buffer));
1840
1841       p1 = p;
1842       /* Find next blank line or end of string.  */
1843       while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
1844         p1++;
1845
1846       /* Specs end at the blank line and do not include the newline.  */
1847       spec = save_string (p, p1 - p);
1848       p = p1;
1849
1850       /* Delete backslash-newline sequences from the spec.  */
1851       in = spec;
1852       out = spec;
1853       while (*in != 0)
1854         {
1855           if (in[0] == '\\' && in[1] == '\n')
1856             in += 2;
1857           else if (in[0] == '#')
1858             while (*in && *in != '\n')
1859               in++;
1860
1861           else
1862             *out++ = *in++;
1863         }
1864       *out = 0;
1865
1866       if (suffix[0] == '*')
1867         {
1868           if (! strcmp (suffix, "*link_command"))
1869             link_command_spec = spec;
1870           else
1871             set_spec (suffix + 1, spec);
1872         }
1873       else
1874         {
1875           /* Add this pair to the vector.  */
1876           compilers
1877             = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
1878
1879           compilers[n_compilers].suffix = suffix;
1880           compilers[n_compilers].spec = spec;
1881           n_compilers++;
1882           memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
1883         }
1884
1885       if (*suffix == 0)
1886         link_command_spec = spec;
1887     }
1888
1889   if (link_command_spec == 0)
1890     fatal_error ("spec file has no spec for linking");
1891 }
1892 \f
1893 /* Record the names of temporary files we tell compilers to write,
1894    and delete them at the end of the run.  */
1895
1896 /* This is the common prefix we use to make temp file names.
1897    It is chosen once for each run of this program.
1898    It is substituted into a spec by %g or %j.
1899    Thus, all temp file names contain this prefix.
1900    In practice, all temp file names start with this prefix.
1901
1902    This prefix comes from the envvar TMPDIR if it is defined;
1903    otherwise, from the P_tmpdir macro if that is defined;
1904    otherwise, in /usr/tmp or /tmp;
1905    or finally the current directory if all else fails.  */
1906
1907 static const char *temp_filename;
1908
1909 /* Length of the prefix.  */
1910
1911 static int temp_filename_length;
1912
1913 /* Define the list of temporary files to delete.  */
1914
1915 struct temp_file
1916 {
1917   const char *name;
1918   struct temp_file *next;
1919 };
1920
1921 /* Queue of files to delete on success or failure of compilation.  */
1922 static struct temp_file *always_delete_queue;
1923 /* Queue of files to delete on failure of compilation.  */
1924 static struct temp_file *failure_delete_queue;
1925
1926 /* Record FILENAME as a file to be deleted automatically.
1927    ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
1928    otherwise delete it in any case.
1929    FAIL_DELETE nonzero means delete it if a compilation step fails;
1930    otherwise delete it in any case.  */
1931
1932 void
1933 record_temp_file (const char *filename, int always_delete, int fail_delete)
1934 {
1935   char *const name = xstrdup (filename);
1936
1937   if (always_delete)
1938     {
1939       struct temp_file *temp;
1940       for (temp = always_delete_queue; temp; temp = temp->next)
1941         if (! strcmp (name, temp->name))
1942           goto already1;
1943
1944       temp = XNEW (struct temp_file);
1945       temp->next = always_delete_queue;
1946       temp->name = name;
1947       always_delete_queue = temp;
1948
1949     already1:;
1950     }
1951
1952   if (fail_delete)
1953     {
1954       struct temp_file *temp;
1955       for (temp = failure_delete_queue; temp; temp = temp->next)
1956         if (! strcmp (name, temp->name))
1957           goto already2;
1958
1959       temp = XNEW (struct temp_file);
1960       temp->next = failure_delete_queue;
1961       temp->name = name;
1962       failure_delete_queue = temp;
1963
1964     already2:;
1965     }
1966 }
1967
1968 /* Delete all the temporary files whose names we previously recorded.  */
1969
1970 #ifndef DELETE_IF_ORDINARY
1971 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG)        \
1972 do                                                      \
1973   {                                                     \
1974     if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode))  \
1975       if (unlink (NAME) < 0)                            \
1976         if (VERBOSE_FLAG)                               \
1977           perror_with_name (NAME);                      \
1978   } while (0)
1979 #endif
1980
1981 static void
1982 delete_if_ordinary (const char *name)
1983 {
1984   struct stat st;
1985 #ifdef DEBUG
1986   int i, c;
1987
1988   printf ("Delete %s? (y or n) ", name);
1989   fflush (stdout);
1990   i = getchar ();
1991   if (i != '\n')
1992     while ((c = getchar ()) != '\n' && c != EOF)
1993       ;
1994
1995   if (i == 'y' || i == 'Y')
1996 #endif /* DEBUG */
1997   DELETE_IF_ORDINARY (name, st, verbose_flag);
1998 }
1999
2000 static void
2001 delete_temp_files (void)
2002 {
2003   struct temp_file *temp;
2004
2005   for (temp = always_delete_queue; temp; temp = temp->next)
2006     delete_if_ordinary (temp->name);
2007   always_delete_queue = 0;
2008 }
2009
2010 /* Delete all the files to be deleted on error.  */
2011
2012 static void
2013 delete_failure_queue (void)
2014 {
2015   struct temp_file *temp;
2016
2017   for (temp = failure_delete_queue; temp; temp = temp->next)
2018     delete_if_ordinary (temp->name);
2019 }
2020
2021 static void
2022 clear_failure_queue (void)
2023 {
2024   failure_delete_queue = 0;
2025 }
2026 \f
2027 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2028    returns non-NULL.
2029    If DO_MULTI is true iterate over the paths twice, first with multilib
2030    suffix then without, otherwise iterate over the paths once without
2031    adding a multilib suffix.  When DO_MULTI is true, some attempt is made
2032    to avoid visiting the same path twice, but we could do better.  For
2033    instance, /usr/lib/../lib is considered different from /usr/lib.
2034    At least EXTRA_SPACE chars past the end of the path passed to
2035    CALLBACK are available for use by the callback.
2036    CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2037
2038    Returns the value returned by CALLBACK.  */
2039
2040 static void *
2041 for_each_path (const struct path_prefix *paths,
2042                bool do_multi,
2043                size_t extra_space,
2044                void *(*callback) (char *, void *),
2045                void *callback_info)
2046 {
2047   struct prefix_list *pl;
2048   const char *multi_dir = NULL;
2049   const char *multi_os_dir = NULL;
2050   const char *multi_suffix;
2051   const char *just_multi_suffix;
2052   char *path = NULL;
2053   void *ret = NULL;
2054   bool skip_multi_dir = false;
2055   bool skip_multi_os_dir = false;
2056
2057   multi_suffix = machine_suffix;
2058   just_multi_suffix = just_machine_suffix;
2059   if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2060     {
2061       multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2062       multi_suffix = concat (multi_suffix, multi_dir, NULL);
2063       just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2064     }
2065   if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2066     multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2067
2068   while (1)
2069     {
2070       size_t multi_dir_len = 0;
2071       size_t multi_os_dir_len = 0;
2072       size_t suffix_len;
2073       size_t just_suffix_len;
2074       size_t len;
2075
2076       if (multi_dir)
2077         multi_dir_len = strlen (multi_dir);
2078       if (multi_os_dir)
2079         multi_os_dir_len = strlen (multi_os_dir);
2080       suffix_len = strlen (multi_suffix);
2081       just_suffix_len = strlen (just_multi_suffix);
2082
2083       if (path == NULL)
2084         {
2085           len = paths->max_len + extra_space + 1;
2086           if (suffix_len > multi_os_dir_len)
2087             len += suffix_len;
2088           else
2089             len += multi_os_dir_len;
2090           path = XNEWVEC (char, len);
2091         }
2092
2093       for (pl = paths->plist; pl != 0; pl = pl->next)
2094         {
2095           len = strlen (pl->prefix);
2096           memcpy (path, pl->prefix, len);
2097
2098           /* Look first in MACHINE/VERSION subdirectory.  */
2099           if (!skip_multi_dir)
2100             {
2101               memcpy (path + len, multi_suffix, suffix_len + 1);
2102               ret = callback (path, callback_info);
2103               if (ret)
2104                 break;
2105             }
2106
2107           /* Some paths are tried with just the machine (ie. target)
2108              subdir.  This is used for finding as, ld, etc.  */
2109           if (!skip_multi_dir
2110               && pl->require_machine_suffix == 2)
2111             {
2112               memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2113               ret = callback (path, callback_info);
2114               if (ret)
2115                 break;
2116             }
2117
2118           /* Now try the base path.  */
2119           if (!pl->require_machine_suffix
2120               && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2121             {
2122               const char *this_multi;
2123               size_t this_multi_len;
2124
2125               if (pl->os_multilib)
2126                 {
2127                   this_multi = multi_os_dir;
2128                   this_multi_len = multi_os_dir_len;
2129                 }
2130               else
2131                 {
2132                   this_multi = multi_dir;
2133                   this_multi_len = multi_dir_len;
2134                 }
2135
2136               if (this_multi_len)
2137                 memcpy (path + len, this_multi, this_multi_len + 1);
2138               else
2139                 path[len] = '\0';
2140
2141               ret = callback (path, callback_info);
2142               if (ret)
2143                 break;
2144             }
2145         }
2146       if (pl)
2147         break;
2148
2149       if (multi_dir == NULL && multi_os_dir == NULL)
2150         break;
2151
2152       /* Run through the paths again, this time without multilibs.
2153          Don't repeat any we have already seen.  */
2154       if (multi_dir)
2155         {
2156           free (CONST_CAST (char *, multi_dir));
2157           multi_dir = NULL;
2158           free (CONST_CAST (char *, multi_suffix));
2159           multi_suffix = machine_suffix;
2160           free (CONST_CAST (char *, just_multi_suffix));
2161           just_multi_suffix = just_machine_suffix;
2162         }
2163       else
2164         skip_multi_dir = true;
2165       if (multi_os_dir)
2166         {
2167           free (CONST_CAST (char *, multi_os_dir));
2168           multi_os_dir = NULL;
2169         }
2170       else
2171         skip_multi_os_dir = true;
2172     }
2173
2174   if (multi_dir)
2175     {
2176       free (CONST_CAST (char *, multi_dir));
2177       free (CONST_CAST (char *, multi_suffix));
2178       free (CONST_CAST (char *, just_multi_suffix));
2179     }
2180   if (multi_os_dir)
2181     free (CONST_CAST (char *, multi_os_dir));
2182   if (ret != path)
2183     free (path);
2184   return ret;
2185 }
2186
2187 /* Callback for build_search_list.  Adds path to obstack being built.  */
2188
2189 struct add_to_obstack_info {
2190   struct obstack *ob;
2191   bool check_dir;
2192   bool first_time;
2193 };
2194
2195 static void *
2196 add_to_obstack (char *path, void *data)
2197 {
2198   struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2199
2200   if (info->check_dir && !is_directory (path, false))
2201     return NULL;
2202
2203   if (!info->first_time)
2204     obstack_1grow (info->ob, PATH_SEPARATOR);
2205
2206   obstack_grow (info->ob, path, strlen (path));
2207
2208   info->first_time = false;
2209   return NULL;
2210 }
2211
2212 /* Add or change the value of an environment variable, outputting the
2213    change to standard error if in verbose mode.  */
2214 static void
2215 xputenv (const char *string)
2216 {
2217   if (verbose_flag)
2218     fnotice (stderr, "%s\n", string);
2219   putenv (CONST_CAST (char *, string));
2220 }
2221
2222 /* Build a list of search directories from PATHS.
2223    PREFIX is a string to prepend to the list.
2224    If CHECK_DIR_P is true we ensure the directory exists.
2225    If DO_MULTI is true, multilib paths are output first, then
2226    non-multilib paths.
2227    This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2228    It is also used by the --print-search-dirs flag.  */
2229
2230 static char *
2231 build_search_list (const struct path_prefix *paths, const char *prefix,
2232                    bool check_dir, bool do_multi)
2233 {
2234   struct add_to_obstack_info info;
2235
2236   info.ob = &collect_obstack;
2237   info.check_dir = check_dir;
2238   info.first_time = true;
2239
2240   obstack_grow (&collect_obstack, prefix, strlen (prefix));
2241   obstack_1grow (&collect_obstack, '=');
2242
2243   for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2244
2245   obstack_1grow (&collect_obstack, '\0');
2246   return XOBFINISH (&collect_obstack, char *);
2247 }
2248
2249 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2250    for collect.  */
2251
2252 static void
2253 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2254                       bool do_multi)
2255 {
2256   xputenv (build_search_list (paths, env_var, true, do_multi));
2257 }
2258 \f
2259 /* Check whether NAME can be accessed in MODE.  This is like access,
2260    except that it never considers directories to be executable.  */
2261
2262 static int
2263 access_check (const char *name, int mode)
2264 {
2265   if (mode == X_OK)
2266     {
2267       struct stat st;
2268
2269       if (stat (name, &st) < 0
2270           || S_ISDIR (st.st_mode))
2271         return -1;
2272     }
2273
2274   return access (name, mode);
2275 }
2276
2277 /* Callback for find_a_file.  Appends the file name to the directory
2278    path.  If the resulting file exists in the right mode, return the
2279    full pathname to the file.  */
2280
2281 struct file_at_path_info {
2282   const char *name;
2283   const char *suffix;
2284   int name_len;
2285   int suffix_len;
2286   int mode;
2287 };
2288
2289 static void *
2290 file_at_path (char *path, void *data)
2291 {
2292   struct file_at_path_info *info = (struct file_at_path_info *) data;
2293   size_t len = strlen (path);
2294
2295   memcpy (path + len, info->name, info->name_len);
2296   len += info->name_len;
2297
2298   /* Some systems have a suffix for executable files.
2299      So try appending that first.  */
2300   if (info->suffix_len)
2301     {
2302       memcpy (path + len, info->suffix, info->suffix_len + 1);
2303       if (access_check (path, info->mode) == 0)
2304         return path;
2305     }
2306
2307   path[len] = '\0';
2308   if (access_check (path, info->mode) == 0)
2309     return path;
2310
2311   return NULL;
2312 }
2313
2314 /* Search for NAME using the prefix list PREFIXES.  MODE is passed to
2315    access to check permissions.  If DO_MULTI is true, search multilib
2316    paths then non-multilib paths, otherwise do not search multilib paths.
2317    Return 0 if not found, otherwise return its name, allocated with malloc.  */
2318
2319 static char *
2320 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2321              bool do_multi)
2322 {
2323   struct file_at_path_info info;
2324
2325 #ifdef DEFAULT_ASSEMBLER
2326   if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2327     return xstrdup (DEFAULT_ASSEMBLER);
2328 #endif
2329
2330 #ifdef DEFAULT_LINKER
2331   if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2332     return xstrdup (DEFAULT_LINKER);
2333 #endif
2334
2335   /* Determine the filename to execute (special case for absolute paths).  */
2336
2337   if (IS_ABSOLUTE_PATH (name))
2338     {
2339       if (access (name, mode) == 0)
2340         return xstrdup (name);
2341
2342       return NULL;
2343     }
2344
2345   info.name = name;
2346   info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2347   info.name_len = strlen (info.name);
2348   info.suffix_len = strlen (info.suffix);
2349   info.mode = mode;
2350
2351   return (char*) for_each_path (pprefix, do_multi,
2352                                 info.name_len + info.suffix_len,
2353                                 file_at_path, &info);
2354 }
2355
2356 /* Ranking of prefixes in the sort list. -B prefixes are put before
2357    all others.  */
2358
2359 enum path_prefix_priority
2360 {
2361   PREFIX_PRIORITY_B_OPT,
2362   PREFIX_PRIORITY_LAST
2363 };
2364
2365 /* Add an entry for PREFIX in PLIST.  The PLIST is kept in ascending
2366    order according to PRIORITY.  Within each PRIORITY, new entries are
2367    appended.
2368
2369    If WARN is nonzero, we will warn if no file is found
2370    through this prefix.  WARN should point to an int
2371    which will be set to 1 if this entry is used.
2372
2373    COMPONENT is the value to be passed to update_path.
2374
2375    REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2376    the complete value of machine_suffix.
2377    2 means try both machine_suffix and just_machine_suffix.  */
2378
2379 static void
2380 add_prefix (struct path_prefix *pprefix, const char *prefix,
2381             const char *component, /* enum prefix_priority */ int priority,
2382             int require_machine_suffix, int os_multilib)
2383 {
2384   struct prefix_list *pl, **prev;
2385   int len;
2386
2387   for (prev = &pprefix->plist;
2388        (*prev) != NULL && (*prev)->priority <= priority;
2389        prev = &(*prev)->next)
2390     ;
2391
2392   /* Keep track of the longest prefix.  */
2393
2394   prefix = update_path (prefix, component);
2395   len = strlen (prefix);
2396   if (len > pprefix->max_len)
2397     pprefix->max_len = len;
2398
2399   pl = XNEW (struct prefix_list);
2400   pl->prefix = prefix;
2401   pl->require_machine_suffix = require_machine_suffix;
2402   pl->priority = priority;
2403   pl->os_multilib = os_multilib;
2404
2405   /* Insert after PREV.  */
2406   pl->next = (*prev);
2407   (*prev) = pl;
2408 }
2409
2410 /* Same as add_prefix, but prepending target_system_root to prefix.  */
2411 /* The target_system_root prefix has been relocated by gcc_exec_prefix.  */
2412 static void
2413 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2414                       const char *component,
2415                       /* enum prefix_priority */ int priority,
2416                       int require_machine_suffix, int os_multilib)
2417 {
2418   if (!IS_ABSOLUTE_PATH (prefix))
2419     fatal_error ("system path %qs is not absolute", prefix);
2420
2421   if (target_system_root)
2422     {
2423       if (target_sysroot_suffix)
2424           prefix = concat (target_sysroot_suffix, prefix, NULL);
2425       prefix = concat (target_system_root, prefix, NULL);
2426
2427       /* We have to override this because GCC's notion of sysroot
2428          moves along with GCC.  */
2429       component = "GCC";
2430     }
2431
2432   add_prefix (pprefix, prefix, component, priority,
2433               require_machine_suffix, os_multilib);
2434 }
2435 \f
2436 /* Execute the command specified by the arguments on the current line of spec.
2437    When using pipes, this includes several piped-together commands
2438    with `|' between them.
2439
2440    Return 0 if successful, -1 if failed.  */
2441
2442 static int
2443 execute (void)
2444 {
2445   int i;
2446   int n_commands;               /* # of command.  */
2447   char *string;
2448   struct pex_obj *pex;
2449   struct command
2450   {
2451     const char *prog;           /* program name.  */
2452     const char **argv;          /* vector of args.  */
2453   };
2454   const char *arg;
2455
2456   struct command *commands;     /* each command buffer with above info.  */
2457
2458   gcc_assert (!processing_spec_function);
2459
2460   if (wrapper_string)
2461     {
2462       string = find_a_file (&exec_prefixes,
2463                             VEC_index (const_char_p, argbuf, 0), X_OK, false);
2464       if (string)
2465         VEC_replace (const_char_p, argbuf, 0, string);
2466       insert_wrapper (wrapper_string);
2467     }
2468
2469   /* Count # of piped commands.  */
2470   for (n_commands = 1, i = 0; VEC_iterate (const_char_p, argbuf, i, arg); i++)
2471     if (strcmp (arg, "|") == 0)
2472       n_commands++;
2473
2474   /* Get storage for each command.  */
2475   commands = (struct command *) alloca (n_commands * sizeof (struct command));
2476
2477   /* Split argbuf into its separate piped processes,
2478      and record info about each one.
2479      Also search for the programs that are to be run.  */
2480
2481   VEC_safe_push (const_char_p, heap, argbuf, 0);
2482
2483   commands[0].prog = VEC_index (const_char_p, argbuf, 0); /* first command.  */
2484   commands[0].argv = VEC_address (const_char_p, argbuf);
2485
2486   if (!wrapper_string)
2487     {
2488       string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2489       commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2490     }
2491
2492   for (n_commands = 1, i = 0; VEC_iterate (const_char_p, argbuf, i, arg); i++)
2493     if (arg && strcmp (arg, "|") == 0)
2494       {                         /* each command.  */
2495 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2496         fatal_error ("-pipe not supported");
2497 #endif
2498         VEC_replace (const_char_p, argbuf, i, 0); /* Termination of
2499                                                      command args.  */
2500         commands[n_commands].prog = VEC_index (const_char_p, argbuf, i + 1);
2501         commands[n_commands].argv
2502           = &(VEC_address (const_char_p, argbuf))[i + 1];
2503         string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2504                               X_OK, false);
2505         if (string)
2506           commands[n_commands].argv[0] = string;
2507         n_commands++;
2508       }
2509
2510   /* If -v, print what we are about to do, and maybe query.  */
2511
2512   if (verbose_flag)
2513     {
2514       /* For help listings, put a blank line between sub-processes.  */
2515       if (print_help_list)
2516         fputc ('\n', stderr);
2517
2518       /* Print each piped command as a separate line.  */
2519       for (i = 0; i < n_commands; i++)
2520         {
2521           const char *const *j;
2522
2523           if (verbose_only_flag)
2524             {
2525               for (j = commands[i].argv; *j; j++)
2526                 {
2527                   const char *p;
2528                   for (p = *j; *p; ++p)
2529                     if (!ISALNUM ((unsigned char) *p)
2530                         && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2531                       break;
2532                   if (*p || !*j)
2533                     {
2534                       fprintf (stderr, " \"");
2535                       for (p = *j; *p; ++p)
2536                         {
2537                           if (*p == '"' || *p == '\\' || *p == '$')
2538                             fputc ('\\', stderr);
2539                           fputc (*p, stderr);
2540                         }
2541                       fputc ('"', stderr);
2542                     }
2543                   else
2544                     fprintf (stderr, " %s", *j);
2545                 }
2546             }
2547           else
2548             for (j = commands[i].argv; *j; j++)
2549               fprintf (stderr, " %s", *j);
2550
2551           /* Print a pipe symbol after all but the last command.  */
2552           if (i + 1 != n_commands)
2553             fprintf (stderr, " |");
2554           fprintf (stderr, "\n");
2555         }
2556       fflush (stderr);
2557       if (verbose_only_flag != 0)
2558         {
2559           /* verbose_only_flag should act as if the spec was
2560              executed, so increment execution_count before
2561              returning.  This prevents spurious warnings about
2562              unused linker input files, etc.  */
2563           execution_count++;
2564           return 0;
2565         }
2566 #ifdef DEBUG
2567       fnotice (stderr, "\nGo ahead? (y or n) ");
2568       fflush (stderr);
2569       i = getchar ();
2570       if (i != '\n')
2571         while (getchar () != '\n')
2572           ;
2573
2574       if (i != 'y' && i != 'Y')
2575         return 0;
2576 #endif /* DEBUG */
2577     }
2578
2579 #ifdef ENABLE_VALGRIND_CHECKING
2580   /* Run the each command through valgrind.  To simplify prepending the
2581      path to valgrind and the option "-q" (for quiet operation unless
2582      something triggers), we allocate a separate argv array.  */
2583
2584   for (i = 0; i < n_commands; i++)
2585     {
2586       const char **argv;
2587       int argc;
2588       int j;
2589
2590       for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2591         ;
2592
2593       argv = XALLOCAVEC (const char *, argc + 3);
2594
2595       argv[0] = VALGRIND_PATH;
2596       argv[1] = "-q";
2597       for (j = 2; j < argc + 2; j++)
2598         argv[j] = commands[i].argv[j - 2];
2599       argv[j] = NULL;
2600
2601       commands[i].argv = argv;
2602       commands[i].prog = argv[0];
2603     }
2604 #endif
2605
2606   /* Run each piped subprocess.  */
2607
2608   pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2609                                    ? PEX_RECORD_TIMES : 0),
2610                   progname, temp_filename);
2611   if (pex == NULL)
2612     fatal_error ("pex_init failed: %m");
2613
2614   for (i = 0; i < n_commands; i++)
2615     {
2616       const char *errmsg;
2617       int err;
2618       const char *string = commands[i].argv[0];
2619
2620       errmsg = pex_run (pex,
2621                         ((i + 1 == n_commands ? PEX_LAST : 0)
2622                          | (string == commands[i].prog ? PEX_SEARCH : 0)),
2623                         string, CONST_CAST (char **, commands[i].argv),
2624                         NULL, NULL, &err);
2625       if (errmsg != NULL)
2626         {
2627           if (err == 0)
2628             fatal_error (errmsg);
2629           else
2630             {
2631               errno = err;
2632               pfatal_with_name (errmsg);
2633             }
2634         }
2635
2636       if (string != commands[i].prog)
2637         free (CONST_CAST (char *, string));
2638     }
2639
2640   execution_count++;
2641
2642   /* Wait for all the subprocesses to finish.  */
2643
2644   {
2645     int *statuses;
2646     struct pex_time *times = NULL;
2647     int ret_code = 0;
2648
2649     statuses = (int *) alloca (n_commands * sizeof (int));
2650     if (!pex_get_status (pex, n_commands, statuses))
2651       fatal_error ("failed to get exit status: %m");
2652
2653     if (report_times || report_times_to_file)
2654       {
2655         times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2656         if (!pex_get_times (pex, n_commands, times))
2657           fatal_error ("failed to get process times: %m");
2658       }
2659
2660     pex_free (pex);
2661
2662     for (i = 0; i < n_commands; ++i)
2663       {
2664         int status = statuses[i];
2665
2666         if (WIFSIGNALED (status))
2667           {
2668 #ifdef SIGPIPE
2669             /* SIGPIPE is a special case.  It happens in -pipe mode
2670                when the compiler dies before the preprocessor is done,
2671                or the assembler dies before the compiler is done.
2672                There's generally been an error already, and this is
2673                just fallout.  So don't generate another error unless
2674                we would otherwise have succeeded.  */
2675             if (WTERMSIG (status) == SIGPIPE
2676                 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2677               {
2678                 signal_count++;
2679                 ret_code = -1;
2680               }
2681             else
2682 #endif
2683               internal_error ("%s (program %s)",
2684                               strsignal (WTERMSIG (status)), commands[i].prog);
2685           }
2686         else if (WIFEXITED (status)
2687                  && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2688           {
2689             if (WEXITSTATUS (status) > greatest_status)
2690               greatest_status = WEXITSTATUS (status);
2691             ret_code = -1;
2692           }
2693
2694         if (report_times || report_times_to_file)
2695           {
2696             struct pex_time *pt = &times[i];
2697             double ut, st;
2698
2699             ut = ((double) pt->user_seconds
2700                   + (double) pt->user_microseconds / 1.0e6);
2701             st = ((double) pt->system_seconds
2702                   + (double) pt->system_microseconds / 1.0e6);
2703
2704             if (ut + st != 0)
2705               {
2706                 if (report_times)
2707                   fnotice (stderr, "# %s %.2f %.2f\n",
2708                            commands[i].prog, ut, st);
2709
2710                 if (report_times_to_file)
2711                   {
2712                     int c = 0;
2713                     const char *const *j;
2714
2715                     fprintf (report_times_to_file, "%g %g", ut, st);
2716
2717                     for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
2718                       {
2719                         const char *p;
2720                         for (p = *j; *p; ++p)
2721                           if (*p == '"' || *p == '\\' || *p == '$'
2722                               || ISSPACE (*p))
2723                             break;
2724
2725                         if (*p)
2726                           {
2727                             fprintf (report_times_to_file, " \"");
2728                             for (p = *j; *p; ++p)
2729                               {
2730                                 if (*p == '"' || *p == '\\' || *p == '$')
2731                                   fputc ('\\', report_times_to_file);
2732                                 fputc (*p, report_times_to_file);
2733                               }
2734                             fputc ('"', report_times_to_file);
2735                           }
2736                         else
2737                           fprintf (report_times_to_file, " %s", *j);
2738                       }
2739
2740                     fputc ('\n', report_times_to_file);
2741                   }
2742               }
2743           }
2744       }
2745
2746     return ret_code;
2747   }
2748 }
2749 \f
2750 /* Find all the switches given to us
2751    and make a vector describing them.
2752    The elements of the vector are strings, one per switch given.
2753    If a switch uses following arguments, then the `part1' field
2754    is the switch itself and the `args' field
2755    is a null-terminated vector containing the following arguments.
2756    Bits in the `live_cond' field are:
2757    SWITCH_LIVE to indicate this switch is true in a conditional spec.
2758    SWITCH_FALSE to indicate this switch is overridden by a later switch.
2759    SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
2760    SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
2761    in all do_spec calls afterwards.  Used for %<S from self specs.
2762    The `validated' field is nonzero if any spec has looked at this switch;
2763    if it remains zero at the end of the run, it must be meaningless.  */
2764
2765 #define SWITCH_LIVE                     0x1
2766 #define SWITCH_FALSE                    0x2
2767 #define SWITCH_IGNORE                   0x4
2768 #define SWITCH_IGNORE_PERMANENTLY       0x8
2769
2770 struct switchstr
2771 {
2772   const char *part1;
2773   const char **args;
2774   unsigned int live_cond;
2775   unsigned char validated;
2776   unsigned char ordering;
2777 };
2778
2779 static struct switchstr *switches;
2780
2781 static int n_switches;
2782
2783 static int n_switches_alloc;
2784
2785 /* Set to zero if -fcompare-debug is disabled, positive if it's
2786    enabled and we're running the first compilation, negative if it's
2787    enabled and we're running the second compilation.  For most of the
2788    time, it's in the range -1..1, but it can be temporarily set to 2
2789    or 3 to indicate that the -fcompare-debug flags didn't come from
2790    the command-line, but rather from the GCC_COMPARE_DEBUG environment
2791    variable, until a synthesized -fcompare-debug flag is added to the
2792    command line.  */
2793 int compare_debug;
2794
2795 /* Set to nonzero if we've seen the -fcompare-debug-second flag.  */
2796 int compare_debug_second;
2797
2798 /* Set to the flags that should be passed to the second compilation in
2799    a -fcompare-debug compilation.  */
2800 const char *compare_debug_opt;
2801
2802 static struct switchstr *switches_debug_check[2];
2803
2804 static int n_switches_debug_check[2];
2805
2806 static int n_switches_alloc_debug_check[2];
2807
2808 static char *debug_check_temp_file[2];
2809
2810 /* Language is one of three things:
2811
2812    1) The name of a real programming language.
2813    2) NULL, indicating that no one has figured out
2814    what it is yet.
2815    3) '*', indicating that the file should be passed
2816    to the linker.  */
2817 struct infile
2818 {
2819   const char *name;
2820   const char *language;
2821   struct compiler *incompiler;
2822   bool compiled;
2823   bool preprocessed;
2824 };
2825
2826 /* Also a vector of input files specified.  */
2827
2828 static struct infile *infiles;
2829
2830 int n_infiles;
2831
2832 static int n_infiles_alloc;
2833
2834 /* True if multiple input files are being compiled to a single
2835    assembly file.  */
2836
2837 static bool combine_inputs;
2838
2839 /* This counts the number of libraries added by lang_specific_driver, so that
2840    we can tell if there were any user supplied any files or libraries.  */
2841
2842 static int added_libraries;
2843
2844 /* And a vector of corresponding output files is made up later.  */
2845
2846 const char **outfiles;
2847 \f
2848 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2849
2850 /* Convert NAME to a new name if it is the standard suffix.  DO_EXE
2851    is true if we should look for an executable suffix.  DO_OBJ
2852    is true if we should look for an object suffix.  */
2853
2854 static const char *
2855 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
2856                   int do_obj ATTRIBUTE_UNUSED)
2857 {
2858 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2859   int i;
2860 #endif
2861   int len;
2862
2863   if (name == NULL)
2864     return NULL;
2865
2866   len = strlen (name);
2867
2868 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2869   /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj".  */
2870   if (do_obj && len > 2
2871       && name[len - 2] == '.'
2872       && name[len - 1] == 'o')
2873     {
2874       obstack_grow (&obstack, name, len - 2);
2875       obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
2876       name = XOBFINISH (&obstack, const char *);
2877     }
2878 #endif
2879
2880 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2881   /* If there is no filetype, make it the executable suffix (which includes
2882      the ".").  But don't get confused if we have just "-o".  */
2883   if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
2884     return name;
2885
2886   for (i = len - 1; i >= 0; i--)
2887     if (IS_DIR_SEPARATOR (name[i]))
2888       break;
2889
2890   for (i++; i < len; i++)
2891     if (name[i] == '.')
2892       return name;
2893
2894   obstack_grow (&obstack, name, len);
2895   obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
2896                  strlen (TARGET_EXECUTABLE_SUFFIX));
2897   name = XOBFINISH (&obstack, const char *);
2898 #endif
2899
2900   return name;
2901 }
2902 #endif
2903 \f
2904 /* Display the command line switches accepted by gcc.  */
2905 static void
2906 display_help (void)
2907 {
2908   printf (_("Usage: %s [options] file...\n"), progname);
2909   fputs (_("Options:\n"), stdout);
2910
2911   fputs (_("  -pass-exit-codes         Exit with highest error code from a phase\n"), stdout);
2912   fputs (_("  --help                   Display this information\n"), stdout);
2913   fputs (_("  --target-help            Display target specific command line options\n"), stdout);
2914   fputs (_("  --help={target|optimizers|warnings|params|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
2915   fputs (_("                           Display specific types of command line options\n"), stdout);
2916   if (! verbose_flag)
2917     fputs (_("  (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
2918   fputs (_("  --version                Display compiler version information\n"), stdout);
2919   fputs (_("  -dumpspecs               Display all of the built in spec strings\n"), stdout);
2920   fputs (_("  -dumpversion             Display the version of the compiler\n"), stdout);
2921   fputs (_("  -dumpmachine             Display the compiler's target processor\n"), stdout);
2922   fputs (_("  -print-search-dirs       Display the directories in the compiler's search path\n"), stdout);
2923   fputs (_("  -print-libgcc-file-name  Display the name of the compiler's companion library\n"), stdout);
2924   fputs (_("  -print-file-name=<lib>   Display the full path to library <lib>\n"), stdout);
2925   fputs (_("  -print-prog-name=<prog>  Display the full path to compiler component <prog>\n"), stdout);
2926   fputs (_("  -print-multi-directory   Display the root directory for versions of libgcc\n"), stdout);
2927   fputs (_("\
2928   -print-multi-lib         Display the mapping between command line options and\n\
2929                            multiple library search directories\n"), stdout);
2930   fputs (_("  -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
2931   fputs (_("  -print-sysroot           Display the target libraries directory\n"), stdout);
2932   fputs (_("  -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
2933   fputs (_("  -Wa,<options>            Pass comma-separated <options> on to the assembler\n"), stdout);
2934   fputs (_("  -Wp,<options>            Pass comma-separated <options> on to the preprocessor\n"), stdout);
2935   fputs (_("  -Wl,<options>            Pass comma-separated <options> on to the linker\n"), stdout);
2936   fputs (_("  -Xassembler <arg>        Pass <arg> on to the assembler\n"), stdout);
2937   fputs (_("  -Xpreprocessor <arg>     Pass <arg> on to the preprocessor\n"), stdout);
2938   fputs (_("  -Xlinker <arg>           Pass <arg> on to the linker\n"), stdout);
2939   fputs (_("  -save-temps              Do not delete intermediate files\n"), stdout);
2940   fputs (_("  -save-temps=<arg>        Do not delete intermediate files\n"), stdout);
2941   fputs (_("\
2942   -no-canonical-prefixes   Do not canonicalize paths when building relative\n\
2943                            prefixes to other gcc components\n"), stdout);
2944   fputs (_("  -pipe                    Use pipes rather than intermediate files\n"), stdout);
2945   fputs (_("  -time                    Time the execution of each subprocess\n"), stdout);
2946   fputs (_("  -specs=<file>            Override built-in specs with the contents of <file>\n"), stdout);
2947   fputs (_("  -std=<standard>          Assume that the input sources are for <standard>\n"), stdout);
2948   fputs (_("\
2949   --sysroot=<directory>    Use <directory> as the root directory for headers\n\
2950                            and libraries\n"), stdout);
2951   fputs (_("  -B <directory>           Add <directory> to the compiler's search paths\n"), stdout);
2952   fputs (_("  -v                       Display the programs invoked by the compiler\n"), stdout);
2953   fputs (_("  -###                     Like -v but options quoted and commands not executed\n"), stdout);
2954   fputs (_("  -E                       Preprocess only; do not compile, assemble or link\n"), stdout);
2955   fputs (_("  -S                       Compile only; do not assemble or link\n"), stdout);
2956   fputs (_("  -c                       Compile and assemble, but do not link\n"), stdout);
2957   fputs (_("  -o <file>                Place the output into <file>\n"), stdout);
2958   fputs (_("\
2959   -x <language>            Specify the language of the following input files\n\
2960                            Permissible languages include: c c++ assembler none\n\
2961                            'none' means revert to the default behavior of\n\
2962                            guessing the language based on the file's extension\n\
2963 "), stdout);
2964
2965   printf (_("\
2966 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
2967  passed on to the various sub-processes invoked by %s.  In order to pass\n\
2968  other options on to these processes the -W<letter> options must be used.\n\
2969 "), progname);
2970
2971   /* The rest of the options are displayed by invocations of the various
2972      sub-processes.  */
2973 }
2974
2975 static void
2976 add_preprocessor_option (const char *option, int len)
2977 {
2978   n_preprocessor_options++;
2979
2980   if (! preprocessor_options)
2981     preprocessor_options = XNEWVEC (char *, n_preprocessor_options);
2982   else
2983     preprocessor_options = XRESIZEVEC (char *, preprocessor_options,
2984                                        n_preprocessor_options);
2985
2986   preprocessor_options [n_preprocessor_options - 1] =
2987     save_string (option, len);
2988 }
2989
2990 static void
2991 add_assembler_option (const char *option, int len)
2992 {
2993   n_assembler_options++;
2994
2995   if (! assembler_options)
2996     assembler_options = XNEWVEC (char *, n_assembler_options);
2997   else
2998     assembler_options = XRESIZEVEC (char *, assembler_options,
2999                                     n_assembler_options);
3000
3001   assembler_options [n_assembler_options - 1] = save_string (option, len);
3002 }
3003
3004 static void
3005 add_linker_option (const char *option, int len)
3006 {
3007   n_linker_options++;
3008
3009   if (! linker_options)
3010     linker_options = XNEWVEC (char *, n_linker_options);
3011   else
3012     linker_options = XRESIZEVEC (char *, linker_options, n_linker_options);
3013
3014   linker_options [n_linker_options - 1] = save_string (option, len);
3015 }
3016 \f
3017 /* Allocate space for an input file in infiles.  */
3018
3019 static void
3020 alloc_infile (void)
3021 {
3022   if (n_infiles_alloc == 0)
3023     {
3024       n_infiles_alloc = 16;
3025       infiles = XNEWVEC (struct infile, n_infiles_alloc);
3026     }
3027   else if (n_infiles_alloc == n_infiles)
3028     {
3029       n_infiles_alloc *= 2;
3030       infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3031     }
3032 }
3033
3034 /* Store an input file with the given NAME and LANGUAGE in
3035    infiles.  */
3036
3037 static void
3038 add_infile (const char *name, const char *language)
3039 {
3040   alloc_infile ();
3041   infiles[n_infiles].name = name;
3042   infiles[n_infiles++].language = language;
3043 }
3044
3045 /* Allocate space for a switch in switches.  */
3046
3047 static void
3048 alloc_switch (void)
3049 {
3050   if (n_switches_alloc == 0)
3051     {
3052       n_switches_alloc = 16;
3053       switches = XNEWVEC (struct switchstr, n_switches_alloc);
3054     }
3055   else if (n_switches_alloc == n_switches)
3056     {
3057       n_switches_alloc *= 2;
3058       switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3059     }
3060 }
3061
3062 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3063    as validated if VALIDATED.  */
3064
3065 static void
3066 save_switch (const char *opt, size_t n_args, const char *const *args,
3067              bool validated)
3068 {
3069   alloc_switch ();
3070   switches[n_switches].part1 = opt + 1;
3071   if (n_args == 0)
3072     switches[n_switches].args = 0;
3073   else
3074     {
3075       switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3076       memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3077       switches[n_switches].args[n_args] = NULL;
3078     }
3079
3080   switches[n_switches].live_cond = 0;
3081   switches[n_switches].validated = validated;
3082   switches[n_switches].ordering = 0;
3083   n_switches++;
3084 }
3085
3086 /* Handle an option DECODED that is unknown to the option-processing
3087    machinery, but may be known to specs.  */
3088
3089 static bool
3090 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3091 {
3092   save_switch (decoded->canonical_option[0],
3093                decoded->canonical_option_num_elements - 1,
3094                &decoded->canonical_option[1], false);
3095
3096   return false;
3097 }
3098
3099 /* Handle an option DECODED that is not marked as CL_DRIVER.
3100    LANG_MASK will always be CL_DRIVER.  */
3101
3102 static void
3103 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3104                             unsigned int lang_mask ATTRIBUTE_UNUSED)
3105 {
3106   /* At this point, non-driver options are accepted (and expected to
3107      be passed down by specs) unless marked to be rejected by the
3108      driver.  Options to be rejected by the driver but accepted by the
3109      compilers proper are treated just like completely unknown
3110      options.  */
3111   const struct cl_option *option = &cl_options[decoded->opt_index];
3112
3113   if (option->flags & CL_REJECT_DRIVER)
3114     error ("unrecognized command line option %qs",
3115            decoded->orig_option_with_args_text);
3116   else
3117     driver_unknown_option_callback (decoded);
3118 }
3119
3120 /* Note that an option (index OPT_INDEX, argument ARG, value VALUE)
3121    has been successfully handled with a handler for mask MASK.  */
3122
3123 static void
3124 driver_post_handling_callback (const struct cl_decoded_option *decoded ATTRIBUTE_UNUSED,
3125                                unsigned int mask ATTRIBUTE_UNUSED)
3126 {
3127   /* Nothing to do here.  */
3128 }
3129
3130 static const char *spec_lang = 0;
3131 static int last_language_n_infiles;
3132
3133 /* Handle a driver option; arguments and return value as for
3134    handle_option.  */
3135
3136 static bool
3137 driver_handle_option (struct gcc_options *opts,
3138                       struct gcc_options *opts_set,
3139                       const struct cl_decoded_option *decoded,
3140                       unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3141                       location_t loc,
3142                       const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3143                       diagnostic_context *dc)
3144 {
3145   size_t opt_index = decoded->opt_index;
3146   const char *arg = decoded->arg;
3147   const char *compare_debug_replacement_opt;
3148   int value = decoded->value;
3149   bool validated = false;
3150   bool do_save = true;
3151
3152   gcc_assert (opts == &global_options);
3153   gcc_assert (opts_set == &global_options_set);
3154   gcc_assert (kind == DK_UNSPECIFIED);
3155   gcc_assert (loc == UNKNOWN_LOCATION);
3156   gcc_assert (dc == global_dc);
3157
3158   switch (opt_index)
3159     {
3160     case OPT_dumpspecs:
3161       {
3162         struct spec_list *sl;
3163         init_spec ();
3164         for (sl = specs; sl; sl = sl->next)
3165           printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3166         if (link_command_spec)
3167           printf ("*link_command:\n%s\n\n", link_command_spec);
3168         exit (0);
3169       }
3170
3171     case OPT_dumpversion:
3172       printf ("%s\n", spec_version);
3173       exit (0);
3174
3175     case OPT_dumpmachine:
3176       printf ("%s\n", spec_machine);
3177       exit (0);
3178
3179     case OPT__version:
3180       print_version = 1;
3181
3182       /* CPP driver cannot obtain switch from cc1_options.  */
3183       if (is_cpp_driver)
3184         add_preprocessor_option ("--version", strlen ("--version"));
3185       add_assembler_option ("--version", strlen ("--version"));
3186       add_linker_option ("--version", strlen ("--version"));
3187       break;
3188
3189     case OPT__help:
3190       print_help_list = 1;
3191
3192       /* CPP driver cannot obtain switch from cc1_options.  */
3193       if (is_cpp_driver)
3194         add_preprocessor_option ("--help", 6);
3195       add_assembler_option ("--help", 6);
3196       add_linker_option ("--help", 6);
3197       break;
3198
3199     case OPT__help_:
3200       print_subprocess_help = 2;
3201       break;
3202
3203     case OPT__target_help:
3204       print_subprocess_help = 1;
3205
3206       /* CPP driver cannot obtain switch from cc1_options.  */
3207       if (is_cpp_driver)
3208         add_preprocessor_option ("--target-help", 13);
3209       add_assembler_option ("--target-help", 13);
3210       add_linker_option ("--target-help", 13);
3211       break;
3212
3213     case OPT_pass_exit_codes:
3214     case OPT_print_search_dirs:
3215     case OPT_print_file_name_:
3216     case OPT_print_prog_name_:
3217     case OPT_print_multi_lib:
3218     case OPT_print_multi_directory:
3219     case OPT_print_sysroot:
3220     case OPT_print_multi_os_directory:
3221     case OPT_print_sysroot_headers_suffix:
3222     case OPT_time:
3223     case OPT_wrapper:
3224       /* These options set the variables specified in common.opt
3225          automatically, and do not need to be saved for spec
3226          processing.  */
3227       do_save = false;
3228       break;
3229
3230     case OPT_print_libgcc_file_name:
3231       print_file_name = "libgcc.a";
3232       do_save = false;
3233       break;
3234
3235     case OPT_fcompare_debug_second:
3236       compare_debug_second = 1;
3237       break;
3238
3239     case OPT_fcompare_debug:
3240       switch (value)
3241         {
3242         case 0:
3243           compare_debug_replacement_opt = "-fcompare-debug=";
3244           arg = "";
3245           goto compare_debug_with_arg;
3246
3247         case 1:
3248           compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3249           arg = "-gtoggle";
3250           goto compare_debug_with_arg;
3251
3252         default:
3253           gcc_unreachable ();
3254         }
3255       break;
3256
3257     case OPT_fcompare_debug_:
3258       compare_debug_replacement_opt = decoded->canonical_option[0];
3259     compare_debug_with_arg:
3260       gcc_assert (decoded->canonical_option_num_elements == 1);
3261       gcc_assert (arg != NULL);
3262       if (arg)
3263         compare_debug = 1;
3264       else
3265         compare_debug = -1;
3266       if (compare_debug < 0)
3267         compare_debug_opt = NULL;
3268       else
3269         compare_debug_opt = arg;
3270       save_switch (compare_debug_replacement_opt, 0, NULL, validated);
3271       return true;
3272
3273     case OPT_Wa_:
3274       {
3275         int prev, j;
3276         /* Pass the rest of this option to the assembler.  */
3277
3278         /* Split the argument at commas.  */
3279         prev = 0;
3280         for (j = 0; arg[j]; j++)
3281           if (arg[j] == ',')
3282             {
3283               add_assembler_option (arg + prev, j - prev);
3284               prev = j + 1;
3285             }
3286
3287         /* Record the part after the last comma.  */
3288         add_assembler_option (arg + prev, j - prev);
3289       }
3290       do_save = false;
3291       break;
3292
3293     case OPT_Wp_:
3294       {
3295         int prev, j;
3296         /* Pass the rest of this option to the preprocessor.  */
3297
3298         /* Split the argument at commas.  */
3299         prev = 0;
3300         for (j = 0; arg[j]; j++)
3301           if (arg[j] == ',')
3302             {
3303               add_preprocessor_option (arg + prev, j - prev);
3304               prev = j + 1;
3305             }
3306
3307         /* Record the part after the last comma.  */
3308         add_preprocessor_option (arg + prev, j - prev);
3309       }
3310       do_save = false;
3311       break;
3312
3313     case OPT_Wl_:
3314       {
3315         int prev, j;
3316         /* Split the argument at commas.  */
3317         prev = 0;
3318         for (j = 0; arg[j]; j++)
3319           if (arg[j] == ',')
3320             {
3321               add_infile (save_string (arg + prev, j - prev), "*");
3322               prev = j + 1;
3323             }
3324         /* Record the part after the last comma.  */
3325         add_infile (arg + prev, "*");
3326       }
3327       do_save = false;
3328       break;
3329
3330     case OPT_Xlinker:
3331       add_infile (arg, "*");
3332       do_save = false;
3333       break;
3334
3335     case OPT_Xpreprocessor:
3336       add_preprocessor_option (arg, strlen (arg));
3337       do_save = false;
3338       break;
3339
3340     case OPT_Xassembler:
3341       add_assembler_option (arg, strlen (arg));
3342       do_save = false;
3343       break;
3344
3345     case OPT_l:
3346       /* POSIX allows separation of -l and the lib arg; canonicalize
3347          by concatenating -l with its arg */
3348       add_infile (concat ("-l", arg, NULL), "*");
3349       do_save = false;
3350       break;
3351
3352     case OPT_L:
3353       /* Similarly, canonicalize -L for linkers that may not accept
3354          separate arguments.  */
3355       save_switch (concat ("-L", arg, NULL), 0, NULL, validated);
3356       return true;
3357
3358     case OPT_save_temps:
3359       save_temps_flag = SAVE_TEMPS_CWD;
3360       validated = true;
3361       break;
3362
3363     case OPT_save_temps_:
3364       if (strcmp (arg, "cwd") == 0)
3365         save_temps_flag = SAVE_TEMPS_CWD;
3366       else if (strcmp (arg, "obj") == 0
3367                || strcmp (arg, "object") == 0)
3368         save_temps_flag = SAVE_TEMPS_OBJ;
3369       else
3370         fatal_error ("%qs is an unknown -save-temps option",
3371                      decoded->orig_option_with_args_text);
3372       break;
3373
3374     case OPT_no_canonical_prefixes:
3375       /* Already handled as a special case, so ignored here.  */
3376       do_save = false;
3377       break;
3378
3379     case OPT_pipe:
3380       validated = true;
3381       /* These options set the variables specified in common.opt
3382          automatically, but do need to be saved for spec
3383          processing.  */
3384       break;
3385
3386     case OPT_specs_:
3387       {
3388         struct user_specs *user = XNEW (struct user_specs);
3389
3390         user->next = (struct user_specs *) 0;
3391         user->filename = arg;
3392         if (user_specs_tail)
3393           user_specs_tail->next = user;
3394         else
3395           user_specs_head = user;
3396         user_specs_tail = user;
3397       }
3398       do_save = false;
3399       break;
3400
3401     case OPT__sysroot_:
3402       target_system_root = arg;
3403       target_system_root_changed = 1;
3404       do_save = false;
3405       break;
3406
3407     case OPT_time_:
3408       if (report_times_to_file)
3409         fclose (report_times_to_file);
3410       report_times_to_file = fopen (arg, "a");
3411       do_save = false;
3412       break;
3413
3414     case OPT____:
3415       /* "-###"
3416          This is similar to -v except that there is no execution
3417          of the commands and the echoed arguments are quoted.  It
3418          is intended for use in shell scripts to capture the
3419          driver-generated command line.  */
3420       verbose_only_flag++;
3421       verbose_flag = 1;
3422       do_save = false;
3423       break;
3424
3425     case OPT_B:
3426       {
3427         size_t len = strlen (arg);
3428
3429         /* Catch the case where the user has forgotten to append a
3430            directory separator to the path.  Note, they may be using
3431            -B to add an executable name prefix, eg "i386-elf-", in
3432            order to distinguish between multiple installations of
3433            GCC in the same directory.  Hence we must check to see
3434            if appending a directory separator actually makes a
3435            valid directory name.  */
3436         if (!IS_DIR_SEPARATOR (arg[len - 1])
3437             && is_directory (arg, false))
3438           {
3439             char *tmp = XNEWVEC (char, len + 2);
3440             strcpy (tmp, arg);
3441             tmp[len] = DIR_SEPARATOR;
3442             tmp[++len] = 0;
3443             arg = tmp;
3444           }
3445
3446         add_prefix (&exec_prefixes, arg, NULL,
3447                     PREFIX_PRIORITY_B_OPT, 0, 0);
3448         add_prefix (&startfile_prefixes, arg, NULL,
3449                     PREFIX_PRIORITY_B_OPT, 0, 0);
3450         add_prefix (&include_prefixes, arg, NULL,
3451                     PREFIX_PRIORITY_B_OPT, 0, 0);
3452       }
3453       validated = true;
3454       break;
3455
3456     case OPT_x:
3457       spec_lang = arg;
3458       if (!strcmp (spec_lang, "none"))
3459         /* Suppress the warning if -xnone comes after the last input
3460            file, because alternate command interfaces like g++ might
3461            find it useful to place -xnone after each input file.  */
3462         spec_lang = 0;
3463       else
3464         last_language_n_infiles = n_infiles;
3465       do_save = false;
3466       break;
3467
3468     case OPT_o:
3469       have_o = 1;
3470 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3471       arg = convert_filename (arg, ! have_c, 0);
3472 #endif
3473       /* Save the output name in case -save-temps=obj was used.  */
3474       save_temps_prefix = xstrdup (arg);
3475       /* On some systems, ld cannot handle "-o" without a space.  So
3476          split the option from its argument.  */
3477       save_switch ("-o", 1, &arg, validated);
3478       return true;
3479
3480     case OPT_static_libgcc:
3481     case OPT_shared_libgcc:
3482     case OPT_static_libgfortran:
3483     case OPT_static_libstdc__:
3484       /* These are always valid, since gcc.c itself understands the
3485          first two, gfortranspec.c understands -static-libgfortran and
3486          g++spec.c understands -static-libstdc++ */
3487       validated = true;
3488       break;
3489
3490     default:
3491       /* Various driver options need no special processing at this
3492          point, having been handled in a prescan above or being
3493          handled by specs.  */
3494       break;
3495     }
3496
3497   if (do_save)
3498     save_switch (decoded->canonical_option[0],
3499                  decoded->canonical_option_num_elements - 1,
3500                  &decoded->canonical_option[1], validated);
3501   return true;
3502 }
3503
3504 /* Put the driver's standard set of option handlers in *HANDLERS.  */
3505
3506 static void
3507 set_option_handlers (struct cl_option_handlers *handlers)
3508 {
3509   handlers->unknown_option_callback = driver_unknown_option_callback;
3510   handlers->wrong_lang_callback = driver_wrong_lang_callback;
3511   handlers->post_handling_callback = driver_post_handling_callback;
3512   handlers->num_handlers = 1;
3513   handlers->handlers[0].handler = driver_handle_option;
3514   handlers->handlers[0].mask = CL_DRIVER;
3515 }
3516
3517 /* Create the vector `switches' and its contents.
3518    Store its length in `n_switches'.  */
3519
3520 static void
3521 process_command (unsigned int decoded_options_count,
3522                  struct cl_decoded_option *decoded_options)
3523 {
3524   const char *temp;
3525   char *temp1;
3526   const char *tooldir_prefix;
3527   char *(*get_relative_prefix) (const char *, const char *,
3528                                 const char *) = NULL;
3529   struct cl_option_handlers handlers;
3530   unsigned int j;
3531
3532   GET_ENVIRONMENT (gcc_exec_prefix, "GCC_EXEC_PREFIX");
3533
3534   n_switches = 0;
3535   n_infiles = 0;
3536   added_libraries = 0;
3537
3538   /* Figure compiler version from version string.  */
3539
3540   compiler_version = temp1 = xstrdup (version_string);
3541
3542   for (; *temp1; ++temp1)
3543     {
3544       if (*temp1 == ' ')
3545         {
3546           *temp1 = '\0';
3547           break;
3548         }
3549     }
3550
3551   /* Handle any -no-canonical-prefixes flag early, to assign the function
3552      that builds relative prefixes.  This function creates default search
3553      paths that are needed later in normal option handling.  */
3554
3555   for (j = 1; j < decoded_options_count; j++)
3556     {
3557       if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3558         {
3559           get_relative_prefix = make_relative_prefix_ignore_links;
3560           break;
3561         }
3562     }
3563   if (! get_relative_prefix)
3564     get_relative_prefix = make_relative_prefix;
3565
3566   /* Set up the default search paths.  If there is no GCC_EXEC_PREFIX,
3567      see if we can create it from the pathname specified in
3568      decoded_options[0].arg.  */
3569
3570   gcc_libexec_prefix = standard_libexec_prefix;
3571 #ifndef VMS
3572   /* FIXME: make_relative_prefix doesn't yet work for VMS.  */
3573   if (!gcc_exec_prefix)
3574     {
3575       gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
3576                                              standard_bindir_prefix,
3577                                              standard_exec_prefix);
3578       gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
3579                                              standard_bindir_prefix,
3580                                              standard_libexec_prefix);
3581       if (gcc_exec_prefix)
3582         xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3583     }
3584   else