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