OSDN Git Service

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