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