2014-07-16 Yvan Roux <yvan.roux@linaro.org>
[official-gcc.git] / gcc-4_8-branch / gcc / gcc.c
blob5ac278ec28b5fc110b8e893dc98a8567c85d82d0
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987-2013 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
9 version.
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 for more details.
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
20 /* This program is the user interface to the C compiler and possibly to
21 other compilers. It is used because compilation is a complicated procedure
22 which involves running several programs and passing temporary files between
23 them, forwarding the users switches to those programs selectively,
24 and deleting the temporary files at the end.
26 CC recognizes how to compile each input file by suffixes in the file names.
27 Once it knows which kind of compilation to perform, the procedure for
28 compilation is specified by a string called a "spec". */
30 #include "config.h"
31 #include "system.h"
32 #include "coretypes.h"
33 #include "multilib.h" /* before tm.h */
34 #include "tm.h"
35 #include "xregex.h"
36 #include "obstack.h"
37 #include "intl.h"
38 #include "prefix.h"
39 #include "gcc.h"
40 #include "diagnostic.h"
41 #include "flags.h"
42 #include "opts.h"
43 #include "params.h"
44 #include "vec.h"
45 #include "filenames.h"
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
51 #endif
53 /* By default there is no special suffix for host executables. */
54 #ifdef HOST_EXECUTABLE_SUFFIX
55 #define HAVE_HOST_EXECUTABLE_SUFFIX
56 #else
57 #define HOST_EXECUTABLE_SUFFIX ""
58 #endif
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"
65 #endif
67 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
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
74 /* If a stage of compilation returns an exit status >= 1,
75 compilation of that file ceases. */
77 #define MIN_FATAL_STATUS 1
79 /* Flag set by cppspec.c to 1. */
80 int is_cpp_driver;
82 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
83 static bool at_file_supplied;
85 /* Definition of string containing the arguments given to configure. */
86 #include "configargs.h"
88 /* Flag saying to print the command line options understood by gcc and its
89 sub-processes. */
91 static int print_help_list;
93 /* Flag saying to print the version of gcc and its sub-processes. */
95 static int print_version;
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. */
102 static int verbose_only_flag;
104 /* Flag indicating how to print command line options of sub-processes. */
106 static int print_subprocess_help;
108 /* Whether we should report subprocess execution times to a file. */
110 FILE *report_times_to_file = NULL;
112 /* Nonzero means place this string before uses of /, so that include
113 and library files can be found in an alternate location. */
115 #ifdef TARGET_SYSTEM_ROOT
116 static const char *target_system_root = TARGET_SYSTEM_ROOT;
117 #else
118 static const char *target_system_root = 0;
119 #endif
121 /* Nonzero means pass the updated target_system_root to the compiler. */
123 static int target_system_root_changed;
125 /* Nonzero means append this string to target_system_root. */
127 static const char *target_sysroot_suffix = 0;
129 /* Nonzero means append this string to target_system_root for headers. */
131 static const char *target_sysroot_hdrs_suffix = 0;
133 /* Nonzero means write "temp" files in source directory
134 and use the source file's name in them, and don't delete them. */
136 static 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;
142 /* Output file to use to get the object directory for -save-temps=obj */
143 static char *save_temps_prefix = 0;
144 static size_t save_temps_length = 0;
146 /* The compiler version. */
148 static const char *compiler_version;
150 /* The target version. */
152 static const char *const spec_version = DEFAULT_TARGET_VERSION;
154 /* The target machine. */
156 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
158 /* Nonzero if cross-compiling.
159 When -b is used, the value comes from the `specs' file. */
161 #ifdef CROSS_DIRECTORY_STRUCTURE
162 static const char *cross_compile = "1";
163 #else
164 static const char *cross_compile = "0";
165 #endif
167 /* Greatest exit code of sub-processes that has been encountered up to
168 now. */
169 static int greatest_status = 1;
171 /* This is the obstack which we use to allocate many strings. */
173 static struct obstack obstack;
175 /* This is the obstack to build an environment variable to pass to
176 collect2 that describes all of the relevant switches of what to
177 pass the compiler in building the list of pointers to constructors
178 and destructors. */
180 static struct obstack collect_obstack;
182 /* Forward declaration for prototypes. */
183 struct path_prefix;
184 struct prefix_list;
186 static void init_spec (void);
187 static void store_arg (const char *, int, int);
188 static void insert_wrapper (const char *);
189 static char *load_specs (const char *);
190 static void read_specs (const char *, bool, bool);
191 static void set_spec (const char *, const char *, bool);
192 static struct compiler *lookup_compiler (const char *, size_t, const char *);
193 static char *build_search_list (const struct path_prefix *, const char *,
194 bool, bool);
195 static void xputenv (const char *);
196 static void putenv_from_prefixes (const struct path_prefix *, const char *,
197 bool);
198 static int access_check (const char *, int);
199 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
200 static void add_prefix (struct path_prefix *, const char *, const char *,
201 int, int, int);
202 static void add_sysrooted_prefix (struct path_prefix *, const char *,
203 const char *, int, int, int);
204 static char *skip_whitespace (char *);
205 static void delete_if_ordinary (const char *);
206 static void delete_temp_files (void);
207 static void delete_failure_queue (void);
208 static void clear_failure_queue (void);
209 static int check_live_switch (int, int);
210 static const char *handle_braces (const char *);
211 static inline bool input_suffix_matches (const char *, const char *);
212 static inline bool switch_matches (const char *, const char *, int);
213 static inline void mark_matching_switches (const char *, const char *, int);
214 static inline void process_marked_switches (void);
215 static const char *process_brace_body (const char *, const char *, const char *, int, int);
216 static const struct spec_function *lookup_spec_function (const char *);
217 static const char *eval_spec_function (const char *, const char *);
218 static const char *handle_spec_function (const char *);
219 static char *save_string (const char *, int);
220 static void set_collect_gcc_options (void);
221 static int do_spec_1 (const char *, int, const char *);
222 static int do_spec_2 (const char *);
223 static void do_option_spec (const char *, const char *);
224 static void do_self_spec (const char *);
225 static const char *find_file (const char *);
226 static int is_directory (const char *, bool);
227 static const char *validate_switches (const char *, bool);
228 static void validate_all_switches (void);
229 static inline void validate_switches_from_spec (const char *, bool);
230 static void give_switch (int, int);
231 static int used_arg (const char *, int);
232 static int default_arg (const char *, int);
233 static void set_multilib_dir (void);
234 static void print_multilib_info (void);
235 static void perror_with_name (const char *);
236 static void display_help (void);
237 static void add_preprocessor_option (const char *, int);
238 static void add_assembler_option (const char *, int);
239 static void add_linker_option (const char *, int);
240 static void process_command (unsigned int, struct cl_decoded_option *);
241 static int execute (void);
242 static void alloc_args (void);
243 static void clear_args (void);
244 static void fatal_signal (int);
245 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
246 static void init_gcc_specs (struct obstack *, const char *, const char *,
247 const char *);
248 #endif
249 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
250 static const char *convert_filename (const char *, int, int);
251 #endif
253 static const char *getenv_spec_function (int, const char **);
254 static const char *if_exists_spec_function (int, const char **);
255 static const char *if_exists_else_spec_function (int, const char **);
256 static const char *replace_outfile_spec_function (int, const char **);
257 static const char *remove_outfile_spec_function (int, const char **);
258 static const char *version_compare_spec_function (int, const char **);
259 static const char *include_spec_function (int, const char **);
260 static const char *find_file_spec_function (int, const char **);
261 static const char *find_plugindir_spec_function (int, const char **);
262 static const char *print_asm_header_spec_function (int, const char **);
263 static const char *compare_debug_dump_opt_spec_function (int, const char **);
264 static const char *compare_debug_self_opt_spec_function (int, const char **);
265 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
266 static const char *pass_through_libs_spec_func (int, const char **);
267 static const char *replace_extension_spec_func (int, const char **);
268 static char *convert_white_space (char *);
270 /* The Specs Language
272 Specs are strings containing lines, each of which (if not blank)
273 is made up of a program name, and arguments separated by spaces.
274 The program name must be exact and start from root, since no path
275 is searched and it is unreliable to depend on the current working directory.
276 Redirection of input or output is not supported; the subprograms must
277 accept filenames saying what files to read and write.
279 In addition, the specs can contain %-sequences to substitute variable text
280 or for conditional text. Here is a table of all defined %-sequences.
281 Note that spaces are not generated automatically around the results of
282 expanding these sequences; therefore, you can concatenate them together
283 or with constant text in a single argument.
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
289 and not including the directory unless -save-temps was specified
290 to put temporaries in a different location.
291 %B same as %b, but include the file suffix (text after the last period).
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
299 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
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.
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.)
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.
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.
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 %.
332 %d marks the argument containing or following the %d as a
333 temporary file name, so that that file will be deleted if GCC exits
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.
338 %V indicates that this compilation produces no "output file".
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.
349 %O substitutes the suffix for object files. Note that this is
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'.
357 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
358 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
359 and -B options) and -imultilib as necessary.
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.
365 %nSTR Print STR as a notice. STR is terminated by a newline.
366 %x{OPTION} Accumulate an option for %X.
367 %X Output the accumulated linker options specified by compilations.
368 %Y Output the accumulated assembler options specified by compilations.
369 %Z Output the accumulated preprocessor options specified by compilations.
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
374 assembler has done its job.
375 %D Dump out a -L option for each directory in startfile_prefixes.
376 If multilib_dir is set, extra entries are generated with it affixed.
377 %l process LINK_SPEC as a spec.
378 %L process LIB_SPEC as a spec.
379 %M Output multilib_os_dir.
380 %G process LIBGCC_SPEC as a spec.
381 %R Output the concatenation of target_system_root and
382 target_sysroot_suffix.
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.
385 %C process CPP_SPEC as a spec.
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.
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.
395 %>S Similar to "%<S", but keep it in the GCC command line.
396 %<S* remove all occurrences of all switches beginning with -S from the
397 command line.
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.
404 %{S} substitutes the -S switch, if that switch was given to GCC.
405 If that switch was not specified, this substitutes nothing.
406 Here S is a metasyntactic variable.
407 %{S*} substitutes all the switches specified to GCC whose names start
408 with -S. This is used for -o, -I, etc; switches that take
409 arguments. GCC considers `-o foo' as being one switch whose
410 name starts with `o'. %{o*} would substitute this text,
411 including the space; thus, two arguments would be generated.
412 %{S*&T*} likewise, but preserve order of S and T options (the order
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*}.
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.
419 %{S*:X} substitutes X if one or more switches whose names start
420 with -S was given to GCC. Normally X is substituted only
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.
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.
430 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
431 combined with '!', '.', ',', and '*' as above binding stronger
432 than the OR.
433 If %* appears in X, all of the alternatives must be starred, and
434 only the first matching alternative is substituted.
435 %{S:X; if S was given to GCC, substitutes X;
436 T:Y; else if T was given to GCC, substitutes Y;
437 :D} else substitutes D. There can be as many clauses as you need.
438 This may be combined with '.', '!', ',', '|', and '*' as above.
440 %(Spec) processes a specification defined in a specs file as *Spec:
442 The conditional text X in a %{S:X} or similar construct may contain
443 other nested % constructs or spaces, or even newlines. They are
444 processed as usual, as described above. Trailing white space in X is
445 ignored. White space may also appear anywhere on the left side of the
446 colon in these constructs, except between . or * and the corresponding
447 word.
449 The -O, -f, -g, -m, and -W switches are handled specifically in these
450 constructs. 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
452 value is ignored, except with {S*} where S is just one letter; this
453 passes all matching options.
455 The character | at the beginning of the predicate text is used to indicate
456 that a command should be piped to the following command, but only if -pipe
457 is specified.
459 Note that it is built into GCC which switches take arguments and which
460 do not. You might think it would be useful to generalize this to
461 allow each compiler's spec to say which switches take arguments. But
462 this cannot be done in a consistent fashion. GCC cannot even decide
463 which input files have been specified without knowing which switches
464 take arguments, and it must know which input files to compile in order
465 to tell which compilers to run.
467 GCC also knows implicitly that arguments starting in `-l' are to be
468 treated as compiler output files, and passed to the linker in their
469 proper position among the other output files. */
471 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
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
479 /* config.h can define ASM_FINAL_SPEC to run a post processor after
480 the assembler has run. */
481 #ifndef ASM_FINAL_SPEC
482 #define ASM_FINAL_SPEC \
483 "%{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} \
490 #endif
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
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
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
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
516 /* config.h can define LIB_SPEC to override the default libraries. */
517 #ifndef LIB_SPEC
518 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
519 #endif
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\
527 --wrap=mmap --wrap=mmap64 --wrap=munmap --wrap=alloca\
528 } %{fmudflapth: --wrap=pthread_create\
529 }} %{fmudflap|fmudflapth: --wrap=main}"
530 #endif
531 #ifndef MFLIB_SPEC
532 #define MFLIB_SPEC "%{fmudflap|fmudflapth: -export-dynamic}"
533 #endif
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}"
545 #ifndef LIBASAN_SPEC
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
552 #ifdef LIBASAN_EARLY_SPEC
553 #define LIBASAN_SPEC ADD_STATIC_LIBASAN_LIBS
554 #elif defined(HAVE_LD_STATIC_DYNAMIC)
555 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
556 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
557 ADD_STATIC_LIBASAN_LIBS
558 #else
559 #define LIBASAN_SPEC "-lasan" ADD_STATIC_LIBASAN_LIBS
560 #endif
561 #endif
563 #ifndef LIBASAN_EARLY_SPEC
564 #define LIBASAN_EARLY_SPEC ""
565 #endif
567 #ifndef LIBTSAN_SPEC
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)
577 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
578 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
579 ADD_STATIC_LIBTSAN_LIBS
580 #else
581 #define LIBTSAN_SPEC "-ltsan" ADD_STATIC_LIBTSAN_LIBS
582 #endif
583 #endif
585 #ifndef LIBTSAN_EARLY_SPEC
586 #define LIBTSAN_EARLY_SPEC ""
587 #endif
589 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
590 included. */
591 #ifndef LIBGCC_SPEC
592 #if defined(REAL_LIBGCC_SPEC)
593 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
594 #elif defined(LINK_LIBGCC_SPECIAL_1)
595 /* Have gcc do the search for libgcc.a. */
596 #define LIBGCC_SPEC "libgcc.a%s"
597 #else
598 #define LIBGCC_SPEC "-lgcc"
599 #endif
600 #endif
602 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
603 #ifndef STARTFILE_SPEC
604 #define STARTFILE_SPEC \
605 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
606 #endif
608 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
609 #ifndef ENDFILE_SPEC
610 #define ENDFILE_SPEC ""
611 #endif
613 #ifndef LINKER_NAME
614 #define LINKER_NAME "collect2"
615 #endif
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
623 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
624 to the assembler. */
625 #ifndef ASM_DEBUG_SPEC
626 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
627 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
628 # define ASM_DEBUG_SPEC \
629 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
630 ? "%{!g0:%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}}" ASM_MAP \
631 : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
632 # else
633 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
634 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
635 # endif
636 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
637 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
638 # endif
639 # endif
640 #endif
641 #ifndef ASM_DEBUG_SPEC
642 # define ASM_DEBUG_SPEC ""
643 #endif
645 /* Here is the spec for running the linker, after compiling all files. */
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
654 #ifndef LINK_SSP_SPEC
655 #ifdef TARGET_LIBC_PROVIDES_SSP
656 #define LINK_SSP_SPEC "%{fstack-protector:}"
657 #else
658 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all:-lssp_nonshared -lssp}"
659 #endif
660 #endif
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
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
676 /* Conditional to test whether the LTO plugin is used or not.
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
681 -fuse-linker-plugin if the linker used understands -plugin. */
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
687 #define PLUGIN_COND "!fno-use-linker-plugin:%{flto|flto=*|fuse-linker-plugin"
688 #define PLUGIN_COND_CLOSE "}"
689 #else
690 /* The linker used has limited plugin support, use LTO plugin with explicit
691 -fuse-linker-plugin. */
692 #define PLUGIN_COND "fuse-linker-plugin"
693 #define PLUGIN_COND_CLOSE ""
694 #endif
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
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
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:%e-fsanitize=address is incompatible with -fsanitize=thread}}\
721 %{fsanitize=thread:" LIBTSAN_SPEC "\
722 %{!pie:%{!shared:%e-fsanitize=thread linking must be done with -pie or -shared}}}}}"
723 #endif
725 /* -u* was put back because both BSD and SysV seem to support it. */
726 /* %{static:} simply prevents an error message if the target machine
727 doesn't handle -static. */
728 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
729 scripts which exist in user specified directories, or in standard
730 directories. */
731 /* We pass any -flto flags on to the linker, which is expected
732 to understand them. In practice, this means it had better be collect2. */
733 /* %{e*} includes -export-dynamic; see comment in common.opt. */
734 #ifndef LINK_COMMAND_SPEC
735 #define LINK_COMMAND_SPEC "\
736 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
737 %(linker) " \
738 LINK_PLUGIN_SPEC \
739 "%{flto|flto=*:%<fcompare-debug*} \
740 %{flto} %{flto=*} %l " LINK_PIE_SPEC \
741 "%{fuse-ld=*:-fuse-ld=%*}\
742 %X %{o*} %{e*} %{N} %{n} %{r}\
743 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}}\
744 %{static:} %{L*} %(mfwrap) %(link_libgcc) " SANITIZER_EARLY_SPEC " %o\
745 %{fopenmp|ftree-parallelize-loops=*:%:include(libgomp.spec)%(link_gomp)}\
746 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
747 %(mflib) " STACK_SPLIT_SPEC "\
748 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
749 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
750 %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
751 #endif
753 #ifndef LINK_LIBGCC_SPEC
754 /* Generate -L options for startfile prefix list. */
755 # define LINK_LIBGCC_SPEC "%D"
756 #endif
758 #ifndef STARTFILE_PREFIX_SPEC
759 # define STARTFILE_PREFIX_SPEC ""
760 #endif
762 #ifndef SYSROOT_SPEC
763 # define SYSROOT_SPEC "--sysroot=%R"
764 #endif
766 #ifndef SYSROOT_SUFFIX_SPEC
767 # define SYSROOT_SUFFIX_SPEC ""
768 #endif
770 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
771 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
772 #endif
774 static const char *asm_debug = ASM_DEBUG_SPEC;
775 static const char *cpp_spec = CPP_SPEC;
776 static const char *cc1_spec = CC1_SPEC;
777 static const char *cc1plus_spec = CC1PLUS_SPEC;
778 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
779 static const char *link_ssp_spec = LINK_SSP_SPEC;
780 static const char *asm_spec = ASM_SPEC;
781 static const char *asm_final_spec = ASM_FINAL_SPEC;
782 static const char *link_spec = LINK_SPEC;
783 static const char *lib_spec = LIB_SPEC;
784 static const char *mfwrap_spec = MFWRAP_SPEC;
785 static const char *mflib_spec = MFLIB_SPEC;
786 static const char *link_gomp_spec = "";
787 static const char *libgcc_spec = LIBGCC_SPEC;
788 static const char *endfile_spec = ENDFILE_SPEC;
789 static const char *startfile_spec = STARTFILE_SPEC;
790 static const char *linker_name_spec = LINKER_NAME;
791 static const char *linker_plugin_file_spec = "";
792 static const char *lto_wrapper_spec = "";
793 static const char *lto_gcc_spec = "";
794 static const char *link_command_spec = LINK_COMMAND_SPEC;
795 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
796 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
797 static const char *sysroot_spec = SYSROOT_SPEC;
798 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
799 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
800 static const char *self_spec = "";
802 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
803 There should be no need to override these in target dependent files,
804 but we need to copy them to the specs file so that newer versions
805 of the GCC driver can correctly drive older tool chains with the
806 appropriate -B options. */
808 /* When cpplib handles traditional preprocessing, get rid of this, and
809 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
810 that we default the front end language better. */
811 static const char *trad_capable_cpp =
812 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
814 /* We don't wrap .d files in %W{} since a missing .d file, and
815 therefore no dependency entry, confuses make into thinking a .o
816 file that happens to exist is up-to-date. */
817 static const char *cpp_unique_options =
818 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
819 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
820 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
821 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
822 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
823 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
824 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
825 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
826 %{fmudflap:-D_MUDFLAP -include mf-runtime.h}\
827 %{fmudflapth:-D_MUDFLAP -D_MUDFLAPTH -include mf-runtime.h}\
828 %{E|M|MM:%W{o*}}";
830 /* This contains cpp options which are common with cc1_options and are passed
831 only when preprocessing only to avoid duplication. We pass the cc1 spec
832 options to the preprocessor so that it the cc1 spec may manipulate
833 options used to set target flags. Those special target flags settings may
834 in turn cause preprocessor symbols to be defined specially. */
835 static const char *cpp_options =
836 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
837 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
838 %{undef} %{save-temps*:-fpch-preprocess}";
840 /* This contains cpp options which are not passed when the preprocessor
841 output will be used by another program. */
842 static const char *cpp_debug_options = "%{d*}";
844 /* NB: This is shared amongst all front-ends, except for Ada. */
845 static const char *cc1_options =
846 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
847 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
848 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
849 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
850 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
851 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
852 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
853 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
854 %{-target-help:--target-help}\
855 %{-version:--version}\
856 %{-help=*:--help=%*}\
857 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
858 %{fsyntax-only:-o %j} %{-param*}\
859 %{fmudflap|fmudflapth:-fno-builtin -fno-merge-constants}\
860 %{coverage:-fprofile-arcs -ftest-coverage}";
862 static const char *asm_options =
863 "%{-target-help:%:print-asm-header()} "
864 #if HAVE_GNU_AS
865 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
866 to the assembler equivalents. */
867 "%{v} %{w:-W} %{I*} "
868 #endif
869 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
871 static const char *invoke_as =
872 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
873 "%{!fwpa:\
874 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
875 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
877 #else
878 "%{!fwpa:\
879 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
880 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
882 #endif
884 /* Some compilers have limits on line lengths, and the multilib_select
885 and/or multilib_matches strings can be very long, so we build them at
886 run time. */
887 static struct obstack multilib_obstack;
888 static const char *multilib_select;
889 static const char *multilib_matches;
890 static const char *multilib_defaults;
891 static const char *multilib_exclusions;
892 static const char *multilib_reuse;
894 /* Check whether a particular argument is a default argument. */
896 #ifndef MULTILIB_DEFAULTS
897 #define MULTILIB_DEFAULTS { "" }
898 #endif
900 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
902 #ifndef DRIVER_SELF_SPECS
903 #define DRIVER_SELF_SPECS ""
904 #endif
906 /* Adding -fopenmp should imply pthreads. This is particularly important
907 for targets that use different start files and suchlike. */
908 #ifndef GOMP_SELF_SPECS
909 #define GOMP_SELF_SPECS "%{fopenmp|ftree-parallelize-loops=*: -pthread}"
910 #endif
912 /* Likewise for -fgnu-tm. */
913 #ifndef GTM_SELF_SPECS
914 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
915 #endif
917 static const char *const driver_self_specs[] = {
918 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
919 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS
922 #ifndef OPTION_DEFAULT_SPECS
923 #define OPTION_DEFAULT_SPECS { "", "" }
924 #endif
926 struct default_spec
928 const char *name;
929 const char *spec;
932 static const struct default_spec
933 option_default_specs[] = { OPTION_DEFAULT_SPECS };
935 struct user_specs
937 struct user_specs *next;
938 const char *filename;
941 static struct user_specs *user_specs_head, *user_specs_tail;
944 /* Record the mapping from file suffixes for compilation specs. */
946 struct compiler
948 const char *suffix; /* Use this compiler for input files
949 whose names end in this suffix. */
951 const char *spec; /* To use this compiler, run this spec. */
953 const char *cpp_spec; /* If non-NULL, substitute this spec
954 for `%C', rather than the usual
955 cpp_spec. */
956 const int combinable; /* If nonzero, compiler can deal with
957 multiple source files at once (IMA). */
958 const int needs_preprocessing; /* If nonzero, source files need to
959 be run through a preprocessor. */
962 /* Pointer to a vector of `struct compiler' that gives the spec for
963 compiling a file, based on its suffix.
964 A file that does not end in any of these suffixes will be passed
965 unchanged to the loader and nothing else will be done to it.
967 An entry containing two 0s is used to terminate the vector.
969 If multiple entries match a file, the last matching one is used. */
971 static struct compiler *compilers;
973 /* Number of entries in `compilers', not counting the null terminator. */
975 static int n_compilers;
977 /* The default list of file name suffixes and their compilation specs. */
979 static const struct compiler default_compilers[] =
981 /* Add lists of suffixes of known languages here. If those languages
982 were not present when we built the driver, we will hit these copies
983 and be given a more meaningful error than "file not used since
984 linking is not done". */
985 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
986 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
987 {".mii", "#Objective-C++", 0, 0, 0},
988 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
989 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
990 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
991 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
992 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
993 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
994 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
995 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
996 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
997 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
998 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
999 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1000 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1001 {".r", "#Ratfor", 0, 0, 0},
1002 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
1003 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
1004 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
1005 {".go", "#Go", 0, 1, 0},
1006 /* Next come the entries for C. */
1007 {".c", "@c", 0, 0, 1},
1008 {"@c",
1009 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1010 external preprocessor if -save-temps is given. */
1011 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1012 %{!E:%{!M:%{!MM:\
1013 %{traditional:\
1014 %eGNU C no longer supports -traditional without -E}\
1015 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1016 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1017 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1018 %(cc1_options)}\
1019 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1020 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1021 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1022 {"-",
1023 "%{!E:%e-E or -x required when input is from standard input}\
1024 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1025 {".h", "@c-header", 0, 0, 0},
1026 {"@c-header",
1027 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1028 external preprocessor if -save-temps is given. */
1029 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1030 %{!E:%{!M:%{!MM:\
1031 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1032 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1033 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1034 %(cc1_options)\
1035 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1036 %W{o*:--output-pch=%*}}%V}\
1037 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1038 cc1 %(cpp_unique_options) %(cc1_options)\
1039 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1040 %W{o*:--output-pch=%*}}%V}}}}}}", 0, 0, 0},
1041 {".i", "@cpp-output", 0, 0, 0},
1042 {"@cpp-output",
1043 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1044 {".s", "@assembler", 0, 0, 0},
1045 {"@assembler",
1046 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1047 {".sx", "@assembler-with-cpp", 0, 0, 0},
1048 {".S", "@assembler-with-cpp", 0, 0, 0},
1049 {"@assembler-with-cpp",
1050 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1051 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1052 %{E|M|MM:%(cpp_debug_options)}\
1053 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1054 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1055 #else
1056 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1057 %{E|M|MM:%(cpp_debug_options)}\
1058 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1059 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1060 #endif
1061 , 0, 0, 0},
1063 #include "specs.h"
1064 /* Mark end of table. */
1065 {0, 0, 0, 0, 0}
1068 /* Number of elements in default_compilers, not counting the terminator. */
1070 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1072 typedef char *char_p; /* For DEF_VEC_P. */
1074 /* A vector of options to give to the linker.
1075 These options are accumulated by %x,
1076 and substituted into the linker command with %X. */
1077 static vec<char_p> linker_options;
1079 /* A vector of options to give to the assembler.
1080 These options are accumulated by -Wa,
1081 and substituted into the assembler command with %Y. */
1082 static vec<char_p> assembler_options;
1084 /* A vector of options to give to the preprocessor.
1085 These options are accumulated by -Wp,
1086 and substituted into the preprocessor command with %Z. */
1087 static vec<char_p> preprocessor_options;
1089 static char *
1090 skip_whitespace (char *p)
1092 while (1)
1094 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1095 be considered whitespace. */
1096 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1097 return p + 1;
1098 else if (*p == '\n' || *p == ' ' || *p == '\t')
1099 p++;
1100 else if (*p == '#')
1102 while (*p != '\n')
1103 p++;
1104 p++;
1106 else
1107 break;
1110 return p;
1112 /* Structures to keep track of prefixes to try when looking for files. */
1114 struct prefix_list
1116 const char *prefix; /* String to prepend to the path. */
1117 struct prefix_list *next; /* Next in linked list. */
1118 int require_machine_suffix; /* Don't use without machine_suffix. */
1119 /* 2 means try both machine_suffix and just_machine_suffix. */
1120 int priority; /* Sort key - priority within list. */
1121 int os_multilib; /* 1 if OS multilib scheme should be used,
1122 0 for GCC multilib scheme. */
1125 struct path_prefix
1127 struct prefix_list *plist; /* List of prefixes to try */
1128 int max_len; /* Max length of a prefix in PLIST */
1129 const char *name; /* Name of this list (used in config stuff) */
1132 /* List of prefixes to try when looking for executables. */
1134 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1136 /* List of prefixes to try when looking for startup (crt0) files. */
1138 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1140 /* List of prefixes to try when looking for include files. */
1142 static struct path_prefix include_prefixes = { 0, 0, "include" };
1144 /* Suffix to attach to directories searched for commands.
1145 This looks like `MACHINE/VERSION/'. */
1147 static const char *machine_suffix = 0;
1149 /* Suffix to attach to directories searched for commands.
1150 This is just `MACHINE/'. */
1152 static const char *just_machine_suffix = 0;
1154 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1156 static const char *gcc_exec_prefix;
1158 /* Adjusted value of standard_libexec_prefix. */
1160 static const char *gcc_libexec_prefix;
1162 /* Default prefixes to attach to command names. */
1164 #ifndef STANDARD_STARTFILE_PREFIX_1
1165 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1166 #endif
1167 #ifndef STANDARD_STARTFILE_PREFIX_2
1168 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1169 #endif
1171 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1172 #undef MD_EXEC_PREFIX
1173 #undef MD_STARTFILE_PREFIX
1174 #undef MD_STARTFILE_PREFIX_1
1175 #endif
1177 /* If no prefixes defined, use the null string, which will disable them. */
1178 #ifndef MD_EXEC_PREFIX
1179 #define MD_EXEC_PREFIX ""
1180 #endif
1181 #ifndef MD_STARTFILE_PREFIX
1182 #define MD_STARTFILE_PREFIX ""
1183 #endif
1184 #ifndef MD_STARTFILE_PREFIX_1
1185 #define MD_STARTFILE_PREFIX_1 ""
1186 #endif
1188 /* These directories are locations set at configure-time based on the
1189 --prefix option provided to configure. Their initializers are
1190 defined in Makefile.in. These paths are not *directly* used when
1191 gcc_exec_prefix is set because, in that case, we know where the
1192 compiler has been installed, and use paths relative to that
1193 location instead. */
1194 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1195 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1196 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1197 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1199 /* For native compilers, these are well-known paths containing
1200 components that may be provided by the system. For cross
1201 compilers, these paths are not used. */
1202 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1203 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1204 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1205 static const char *const standard_startfile_prefix_1
1206 = STANDARD_STARTFILE_PREFIX_1;
1207 static const char *const standard_startfile_prefix_2
1208 = STANDARD_STARTFILE_PREFIX_2;
1210 /* A relative path to be used in finding the location of tools
1211 relative to the driver. */
1212 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1214 /* Subdirectory to use for locating libraries. Set by
1215 set_multilib_dir based on the compilation options. */
1217 static const char *multilib_dir;
1219 /* Subdirectory to use for locating libraries in OS conventions. Set by
1220 set_multilib_dir based on the compilation options. */
1222 static const char *multilib_os_dir;
1224 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1225 set_multilib_dir based on the compilation options. */
1227 static const char *multiarch_dir;
1229 /* Structure to keep track of the specs that have been defined so far.
1230 These are accessed using %(specname) in a compiler or link
1231 spec. */
1233 struct spec_list
1235 /* The following 2 fields must be first */
1236 /* to allow EXTRA_SPECS to be initialized */
1237 const char *name; /* name of the spec. */
1238 const char *ptr; /* available ptr if no static pointer */
1240 /* The following fields are not initialized */
1241 /* by EXTRA_SPECS */
1242 const char **ptr_spec; /* pointer to the spec itself. */
1243 struct spec_list *next; /* Next spec in linked list. */
1244 int name_len; /* length of the name */
1245 bool user_p; /* whether string come from file spec. */
1246 bool alloc_p; /* whether string was allocated */
1249 #define INIT_STATIC_SPEC(NAME,PTR) \
1250 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false }
1252 /* List of statically defined specs. */
1253 static struct spec_list static_specs[] =
1255 INIT_STATIC_SPEC ("asm", &asm_spec),
1256 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1257 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1258 INIT_STATIC_SPEC ("asm_options", &asm_options),
1259 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1260 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1261 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1262 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1263 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1264 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1265 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1266 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1267 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1268 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1269 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1270 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1271 INIT_STATIC_SPEC ("link", &link_spec),
1272 INIT_STATIC_SPEC ("lib", &lib_spec),
1273 INIT_STATIC_SPEC ("mfwrap", &mfwrap_spec),
1274 INIT_STATIC_SPEC ("mflib", &mflib_spec),
1275 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1276 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1277 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1278 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1279 INIT_STATIC_SPEC ("version", &compiler_version),
1280 INIT_STATIC_SPEC ("multilib", &multilib_select),
1281 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1282 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1283 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1284 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1285 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1286 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1287 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1288 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1289 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1290 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1291 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1292 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1293 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1294 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1295 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1296 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1297 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1298 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1299 INIT_STATIC_SPEC ("self_spec", &self_spec),
1302 #ifdef EXTRA_SPECS /* additional specs needed */
1303 /* Structure to keep track of just the first two args of a spec_list.
1304 That is all that the EXTRA_SPECS macro gives us. */
1305 struct spec_list_1
1307 const char *const name;
1308 const char *const ptr;
1311 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1312 static struct spec_list *extra_specs = (struct spec_list *) 0;
1313 #endif
1315 /* List of dynamically allocates specs that have been defined so far. */
1317 static struct spec_list *specs = (struct spec_list *) 0;
1319 /* List of static spec functions. */
1321 static const struct spec_function static_spec_functions[] =
1323 { "getenv", getenv_spec_function },
1324 { "if-exists", if_exists_spec_function },
1325 { "if-exists-else", if_exists_else_spec_function },
1326 { "replace-outfile", replace_outfile_spec_function },
1327 { "remove-outfile", remove_outfile_spec_function },
1328 { "version-compare", version_compare_spec_function },
1329 { "include", include_spec_function },
1330 { "find-file", find_file_spec_function },
1331 { "find-plugindir", find_plugindir_spec_function },
1332 { "print-asm-header", print_asm_header_spec_function },
1333 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1334 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1335 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1336 { "pass-through-libs", pass_through_libs_spec_func },
1337 { "replace-extension", replace_extension_spec_func },
1338 #ifdef EXTRA_SPEC_FUNCTIONS
1339 EXTRA_SPEC_FUNCTIONS
1340 #endif
1341 { 0, 0 }
1344 static int processing_spec_function;
1346 /* Add appropriate libgcc specs to OBSTACK, taking into account
1347 various permutations of -shared-libgcc, -shared, and such. */
1349 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1351 #ifndef USE_LD_AS_NEEDED
1352 #define USE_LD_AS_NEEDED 0
1353 #endif
1355 static void
1356 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1357 const char *static_name, const char *eh_name)
1359 char *buf;
1361 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1362 "%{!static:%{!static-libgcc:"
1363 #if USE_LD_AS_NEEDED
1364 "%{!shared-libgcc:",
1365 static_name, " --as-needed ", shared_name, " --no-as-needed"
1367 "%{shared-libgcc:",
1368 shared_name, "%{!shared: ", static_name, "}"
1370 #else
1371 "%{!shared:"
1372 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1373 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1375 #ifdef LINK_EH_SPEC
1376 "%{shared:"
1377 "%{shared-libgcc:", shared_name, "}"
1378 "%{!shared-libgcc:", static_name, "}"
1380 #else
1381 "%{shared:", shared_name, "}"
1382 #endif
1383 #endif
1384 "}}", NULL);
1386 obstack_grow (obstack, buf, strlen (buf));
1387 free (buf);
1389 #endif /* ENABLE_SHARED_LIBGCC */
1391 /* Initialize the specs lookup routines. */
1393 static void
1394 init_spec (void)
1396 struct spec_list *next = (struct spec_list *) 0;
1397 struct spec_list *sl = (struct spec_list *) 0;
1398 int i;
1400 if (specs)
1401 return; /* Already initialized. */
1403 if (verbose_flag)
1404 fnotice (stderr, "Using built-in specs.\n");
1406 #ifdef EXTRA_SPECS
1407 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1409 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1411 sl = &extra_specs[i];
1412 sl->name = extra_specs_1[i].name;
1413 sl->ptr = extra_specs_1[i].ptr;
1414 sl->next = next;
1415 sl->name_len = strlen (sl->name);
1416 sl->ptr_spec = &sl->ptr;
1417 next = sl;
1419 #endif
1421 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1423 sl = &static_specs[i];
1424 sl->next = next;
1425 next = sl;
1428 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1429 /* ??? If neither -shared-libgcc nor --static-libgcc was
1430 seen, then we should be making an educated guess. Some proposed
1431 heuristics for ELF include:
1433 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1434 program will be doing dynamic loading, which will likely
1435 need the shared libgcc.
1437 (2) If "-ldl", then it's also a fair bet that we're doing
1438 dynamic loading.
1440 (3) For each ET_DYN we're linking against (either through -lfoo
1441 or /some/path/foo.so), check to see whether it or one of
1442 its dependencies depends on a shared libgcc.
1444 (4) If "-shared"
1446 If the runtime is fixed to look for program headers instead
1447 of calling __register_frame_info at all, for each object,
1448 use the shared libgcc if any EH symbol referenced.
1450 If crtstuff is fixed to not invoke __register_frame_info
1451 automatically, for each object, use the shared libgcc if
1452 any non-empty unwind section found.
1454 Doing any of this probably requires invoking an external program to
1455 do the actual object file scanning. */
1457 const char *p = libgcc_spec;
1458 int in_sep = 1;
1460 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1461 when given the proper command line arguments. */
1462 while (*p)
1464 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1466 init_gcc_specs (&obstack,
1467 "-lgcc_s"
1468 #ifdef USE_LIBUNWIND_EXCEPTIONS
1469 " -lunwind"
1470 #endif
1472 "-lgcc",
1473 "-lgcc_eh"
1474 #ifdef USE_LIBUNWIND_EXCEPTIONS
1475 # ifdef HAVE_LD_STATIC_DYNAMIC
1476 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1477 " %{!static:" LD_DYNAMIC_OPTION "}"
1478 # else
1479 " -lunwind"
1480 # endif
1481 #endif
1484 p += 5;
1485 in_sep = 0;
1487 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1489 /* Ug. We don't know shared library extensions. Hope that
1490 systems that use this form don't do shared libraries. */
1491 init_gcc_specs (&obstack,
1492 "-lgcc_s",
1493 "libgcc.a%s",
1494 "libgcc_eh.a%s"
1495 #ifdef USE_LIBUNWIND_EXCEPTIONS
1496 " -lunwind"
1497 #endif
1499 p += 10;
1500 in_sep = 0;
1502 else
1504 obstack_1grow (&obstack, *p);
1505 in_sep = (*p == ' ');
1506 p += 1;
1510 obstack_1grow (&obstack, '\0');
1511 libgcc_spec = XOBFINISH (&obstack, const char *);
1513 #endif
1514 #ifdef USE_AS_TRADITIONAL_FORMAT
1515 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1517 static const char tf[] = "--traditional-format ";
1518 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1519 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1520 asm_spec = XOBFINISH (&obstack, const char *);
1522 #endif
1524 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1525 defined LINKER_HASH_STYLE
1526 # ifdef LINK_BUILDID_SPEC
1527 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1528 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof(LINK_BUILDID_SPEC) - 1);
1529 # endif
1530 # ifdef LINK_EH_SPEC
1531 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1532 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1533 # endif
1534 # ifdef LINKER_HASH_STYLE
1535 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1536 before. */
1538 static const char hash_style[] = "--hash-style=";
1539 obstack_grow (&obstack, hash_style, sizeof(hash_style) - 1);
1540 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof(LINKER_HASH_STYLE) - 1);
1541 obstack_1grow (&obstack, ' ');
1543 # endif
1544 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1545 link_spec = XOBFINISH (&obstack, const char *);
1546 #endif
1548 specs = sl;
1551 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1552 removed; If the spec starts with a + then SPEC is added to the end of the
1553 current spec. */
1555 static void
1556 set_spec (const char *name, const char *spec, bool user_p)
1558 struct spec_list *sl;
1559 const char *old_spec;
1560 int name_len = strlen (name);
1561 int i;
1563 /* If this is the first call, initialize the statically allocated specs. */
1564 if (!specs)
1566 struct spec_list *next = (struct spec_list *) 0;
1567 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1569 sl = &static_specs[i];
1570 sl->next = next;
1571 next = sl;
1573 specs = sl;
1576 /* See if the spec already exists. */
1577 for (sl = specs; sl; sl = sl->next)
1578 if (name_len == sl->name_len && !strcmp (sl->name, name))
1579 break;
1581 if (!sl)
1583 /* Not found - make it. */
1584 sl = XNEW (struct spec_list);
1585 sl->name = xstrdup (name);
1586 sl->name_len = name_len;
1587 sl->ptr_spec = &sl->ptr;
1588 sl->alloc_p = 0;
1589 *(sl->ptr_spec) = "";
1590 sl->next = specs;
1591 specs = sl;
1594 old_spec = *(sl->ptr_spec);
1595 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1596 ? concat (old_spec, spec + 1, NULL)
1597 : xstrdup (spec));
1599 #ifdef DEBUG_SPECS
1600 if (verbose_flag)
1601 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1602 #endif
1604 /* Free the old spec. */
1605 if (old_spec && sl->alloc_p)
1606 free (CONST_CAST(char *, old_spec));
1608 sl->user_p = user_p;
1609 sl->alloc_p = true;
1612 /* Accumulate a command (program name and args), and run it. */
1614 typedef const char *const_char_p; /* For DEF_VEC_P. */
1616 /* Vector of pointers to arguments in the current line of specifications. */
1618 static vec<const_char_p> argbuf;
1620 /* Position in the argbuf vector containing the name of the output file
1621 (the value associated with the "-o" flag). */
1623 static int have_o_argbuf_index = 0;
1625 /* Were the options -c, -S or -E passed. */
1626 static int have_c = 0;
1628 /* Was the option -o passed. */
1629 static int have_o = 0;
1631 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1632 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1633 it here. */
1635 static struct temp_name {
1636 const char *suffix; /* suffix associated with the code. */
1637 int length; /* strlen (suffix). */
1638 int unique; /* Indicates whether %g or %u/%U was used. */
1639 const char *filename; /* associated filename. */
1640 int filename_length; /* strlen (filename). */
1641 struct temp_name *next;
1642 } *temp_names;
1644 /* Number of commands executed so far. */
1646 static int execution_count;
1648 /* Number of commands that exited with a signal. */
1650 static int signal_count;
1652 /* Allocate the argument vector. */
1654 static void
1655 alloc_args (void)
1657 argbuf.create (10);
1660 /* Clear out the vector of arguments (after a command is executed). */
1662 static void
1663 clear_args (void)
1665 argbuf.truncate (0);
1668 /* Add one argument to the vector at the end.
1669 This is done when a space is seen or at the end of the line.
1670 If DELETE_ALWAYS is nonzero, the arg is a filename
1671 and the file should be deleted eventually.
1672 If DELETE_FAILURE is nonzero, the arg is a filename
1673 and the file should be deleted if this compilation fails. */
1675 static void
1676 store_arg (const char *arg, int delete_always, int delete_failure)
1678 argbuf.safe_push (arg);
1680 if (strcmp (arg, "-o") == 0)
1681 have_o_argbuf_index = argbuf.length ();
1682 if (delete_always || delete_failure)
1684 const char *p;
1685 /* If the temporary file we should delete is specified as
1686 part of a joined argument extract the filename. */
1687 if (arg[0] == '-'
1688 && (p = strrchr (arg, '=')))
1689 arg = p + 1;
1690 record_temp_file (arg, delete_always, delete_failure);
1694 /* Load specs from a file name named FILENAME, replacing occurrences of
1695 various different types of line-endings, \r\n, \n\r and just \r, with
1696 a single \n. */
1698 static char *
1699 load_specs (const char *filename)
1701 int desc;
1702 int readlen;
1703 struct stat statbuf;
1704 char *buffer;
1705 char *buffer_p;
1706 char *specs;
1707 char *specs_p;
1709 if (verbose_flag)
1710 fnotice (stderr, "Reading specs from %s\n", filename);
1712 /* Open and stat the file. */
1713 desc = open (filename, O_RDONLY, 0);
1714 if (desc < 0)
1715 pfatal_with_name (filename);
1716 if (stat (filename, &statbuf) < 0)
1717 pfatal_with_name (filename);
1719 /* Read contents of file into BUFFER. */
1720 buffer = XNEWVEC (char, statbuf.st_size + 1);
1721 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1722 if (readlen < 0)
1723 pfatal_with_name (filename);
1724 buffer[readlen] = 0;
1725 close (desc);
1727 specs = XNEWVEC (char, readlen + 1);
1728 specs_p = specs;
1729 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1731 int skip = 0;
1732 char c = *buffer_p;
1733 if (c == '\r')
1735 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1736 skip = 1;
1737 else if (*(buffer_p + 1) == '\n') /* \r\n */
1738 skip = 1;
1739 else /* \r */
1740 c = '\n';
1742 if (! skip)
1743 *specs_p++ = c;
1745 *specs_p = '\0';
1747 free (buffer);
1748 return (specs);
1751 /* Read compilation specs from a file named FILENAME,
1752 replacing the default ones.
1754 A suffix which starts with `*' is a definition for
1755 one of the machine-specific sub-specs. The "suffix" should be
1756 *asm, *cc1, *cpp, *link, *startfile, etc.
1757 The corresponding spec is stored in asm_spec, etc.,
1758 rather than in the `compilers' vector.
1760 Anything invalid in the file is a fatal error. */
1762 static void
1763 read_specs (const char *filename, bool main_p, bool user_p)
1765 char *buffer;
1766 char *p;
1768 buffer = load_specs (filename);
1770 /* Scan BUFFER for specs, putting them in the vector. */
1771 p = buffer;
1772 while (1)
1774 char *suffix;
1775 char *spec;
1776 char *in, *out, *p1, *p2, *p3;
1778 /* Advance P in BUFFER to the next nonblank nocomment line. */
1779 p = skip_whitespace (p);
1780 if (*p == 0)
1781 break;
1783 /* Is this a special command that starts with '%'? */
1784 /* Don't allow this for the main specs file, since it would
1785 encourage people to overwrite it. */
1786 if (*p == '%' && !main_p)
1788 p1 = p;
1789 while (*p && *p != '\n')
1790 p++;
1792 /* Skip '\n'. */
1793 p++;
1795 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1796 && (p1[sizeof "%include" - 1] == ' '
1797 || p1[sizeof "%include" - 1] == '\t'))
1799 char *new_filename;
1801 p1 += sizeof ("%include");
1802 while (*p1 == ' ' || *p1 == '\t')
1803 p1++;
1805 if (*p1++ != '<' || p[-2] != '>')
1806 fatal_error ("specs %%include syntax malformed after "
1807 "%ld characters",
1808 (long) (p1 - buffer + 1));
1810 p[-2] = '\0';
1811 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1812 read_specs (new_filename ? new_filename : p1, false, user_p);
1813 continue;
1815 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1816 && (p1[sizeof "%include_noerr" - 1] == ' '
1817 || p1[sizeof "%include_noerr" - 1] == '\t'))
1819 char *new_filename;
1821 p1 += sizeof "%include_noerr";
1822 while (*p1 == ' ' || *p1 == '\t')
1823 p1++;
1825 if (*p1++ != '<' || p[-2] != '>')
1826 fatal_error ("specs %%include syntax malformed after "
1827 "%ld characters",
1828 (long) (p1 - buffer + 1));
1830 p[-2] = '\0';
1831 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1832 if (new_filename)
1833 read_specs (new_filename, false, user_p);
1834 else if (verbose_flag)
1835 fnotice (stderr, "could not find specs file %s\n", p1);
1836 continue;
1838 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1839 && (p1[sizeof "%rename" - 1] == ' '
1840 || p1[sizeof "%rename" - 1] == '\t'))
1842 int name_len;
1843 struct spec_list *sl;
1844 struct spec_list *newsl;
1846 /* Get original name. */
1847 p1 += sizeof "%rename";
1848 while (*p1 == ' ' || *p1 == '\t')
1849 p1++;
1851 if (! ISALPHA ((unsigned char) *p1))
1852 fatal_error ("specs %%rename syntax malformed after "
1853 "%ld characters",
1854 (long) (p1 - buffer));
1856 p2 = p1;
1857 while (*p2 && !ISSPACE ((unsigned char) *p2))
1858 p2++;
1860 if (*p2 != ' ' && *p2 != '\t')
1861 fatal_error ("specs %%rename syntax malformed after "
1862 "%ld characters",
1863 (long) (p2 - buffer));
1865 name_len = p2 - p1;
1866 *p2++ = '\0';
1867 while (*p2 == ' ' || *p2 == '\t')
1868 p2++;
1870 if (! ISALPHA ((unsigned char) *p2))
1871 fatal_error ("specs %%rename syntax malformed after "
1872 "%ld characters",
1873 (long) (p2 - buffer));
1875 /* Get new spec name. */
1876 p3 = p2;
1877 while (*p3 && !ISSPACE ((unsigned char) *p3))
1878 p3++;
1880 if (p3 != p - 1)
1881 fatal_error ("specs %%rename syntax malformed after "
1882 "%ld characters",
1883 (long) (p3 - buffer));
1884 *p3 = '\0';
1886 for (sl = specs; sl; sl = sl->next)
1887 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1888 break;
1890 if (!sl)
1891 fatal_error ("specs %s spec was not found to be renamed", p1);
1893 if (strcmp (p1, p2) == 0)
1894 continue;
1896 for (newsl = specs; newsl; newsl = newsl->next)
1897 if (strcmp (newsl->name, p2) == 0)
1898 fatal_error ("%s: attempt to rename spec %qs to "
1899 "already defined spec %qs",
1900 filename, p1, p2);
1902 if (verbose_flag)
1904 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
1905 #ifdef DEBUG_SPECS
1906 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
1907 #endif
1910 set_spec (p2, *(sl->ptr_spec), user_p);
1911 if (sl->alloc_p)
1912 free (CONST_CAST (char *, *(sl->ptr_spec)));
1914 *(sl->ptr_spec) = "";
1915 sl->alloc_p = 0;
1916 continue;
1918 else
1919 fatal_error ("specs unknown %% command after %ld characters",
1920 (long) (p1 - buffer));
1923 /* Find the colon that should end the suffix. */
1924 p1 = p;
1925 while (*p1 && *p1 != ':' && *p1 != '\n')
1926 p1++;
1928 /* The colon shouldn't be missing. */
1929 if (*p1 != ':')
1930 fatal_error ("specs file malformed after %ld characters",
1931 (long) (p1 - buffer));
1933 /* Skip back over trailing whitespace. */
1934 p2 = p1;
1935 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
1936 p2--;
1938 /* Copy the suffix to a string. */
1939 suffix = save_string (p, p2 - p);
1940 /* Find the next line. */
1941 p = skip_whitespace (p1 + 1);
1942 if (p[1] == 0)
1943 fatal_error ("specs file malformed after %ld characters",
1944 (long) (p - buffer));
1946 p1 = p;
1947 /* Find next blank line or end of string. */
1948 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
1949 p1++;
1951 /* Specs end at the blank line and do not include the newline. */
1952 spec = save_string (p, p1 - p);
1953 p = p1;
1955 /* Delete backslash-newline sequences from the spec. */
1956 in = spec;
1957 out = spec;
1958 while (*in != 0)
1960 if (in[0] == '\\' && in[1] == '\n')
1961 in += 2;
1962 else if (in[0] == '#')
1963 while (*in && *in != '\n')
1964 in++;
1966 else
1967 *out++ = *in++;
1969 *out = 0;
1971 if (suffix[0] == '*')
1973 if (! strcmp (suffix, "*link_command"))
1974 link_command_spec = spec;
1975 else
1976 set_spec (suffix + 1, spec, user_p);
1978 else
1980 /* Add this pair to the vector. */
1981 compilers
1982 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
1984 compilers[n_compilers].suffix = suffix;
1985 compilers[n_compilers].spec = spec;
1986 n_compilers++;
1987 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
1990 if (*suffix == 0)
1991 link_command_spec = spec;
1994 if (link_command_spec == 0)
1995 fatal_error ("spec file has no spec for linking");
1998 /* Record the names of temporary files we tell compilers to write,
1999 and delete them at the end of the run. */
2001 /* This is the common prefix we use to make temp file names.
2002 It is chosen once for each run of this program.
2003 It is substituted into a spec by %g or %j.
2004 Thus, all temp file names contain this prefix.
2005 In practice, all temp file names start with this prefix.
2007 This prefix comes from the envvar TMPDIR if it is defined;
2008 otherwise, from the P_tmpdir macro if that is defined;
2009 otherwise, in /usr/tmp or /tmp;
2010 or finally the current directory if all else fails. */
2012 static const char *temp_filename;
2014 /* Length of the prefix. */
2016 static int temp_filename_length;
2018 /* Define the list of temporary files to delete. */
2020 struct temp_file
2022 const char *name;
2023 struct temp_file *next;
2026 /* Queue of files to delete on success or failure of compilation. */
2027 static struct temp_file *always_delete_queue;
2028 /* Queue of files to delete on failure of compilation. */
2029 static struct temp_file *failure_delete_queue;
2031 /* Record FILENAME as a file to be deleted automatically.
2032 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2033 otherwise delete it in any case.
2034 FAIL_DELETE nonzero means delete it if a compilation step fails;
2035 otherwise delete it in any case. */
2037 void
2038 record_temp_file (const char *filename, int always_delete, int fail_delete)
2040 char *const name = xstrdup (filename);
2042 if (always_delete)
2044 struct temp_file *temp;
2045 for (temp = always_delete_queue; temp; temp = temp->next)
2046 if (! filename_cmp (name, temp->name))
2047 goto already1;
2049 temp = XNEW (struct temp_file);
2050 temp->next = always_delete_queue;
2051 temp->name = name;
2052 always_delete_queue = temp;
2054 already1:;
2057 if (fail_delete)
2059 struct temp_file *temp;
2060 for (temp = failure_delete_queue; temp; temp = temp->next)
2061 if (! filename_cmp (name, temp->name))
2063 free (name);
2064 goto already2;
2067 temp = XNEW (struct temp_file);
2068 temp->next = failure_delete_queue;
2069 temp->name = name;
2070 failure_delete_queue = temp;
2072 already2:;
2076 /* Delete all the temporary files whose names we previously recorded. */
2078 #ifndef DELETE_IF_ORDINARY
2079 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2080 do \
2082 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2083 if (unlink (NAME) < 0) \
2084 if (VERBOSE_FLAG) \
2085 perror_with_name (NAME); \
2086 } while (0)
2087 #endif
2089 static void
2090 delete_if_ordinary (const char *name)
2092 struct stat st;
2093 #ifdef DEBUG
2094 int i, c;
2096 printf ("Delete %s? (y or n) ", name);
2097 fflush (stdout);
2098 i = getchar ();
2099 if (i != '\n')
2100 while ((c = getchar ()) != '\n' && c != EOF)
2103 if (i == 'y' || i == 'Y')
2104 #endif /* DEBUG */
2105 DELETE_IF_ORDINARY (name, st, verbose_flag);
2108 static void
2109 delete_temp_files (void)
2111 struct temp_file *temp;
2113 for (temp = always_delete_queue; temp; temp = temp->next)
2114 delete_if_ordinary (temp->name);
2115 always_delete_queue = 0;
2118 /* Delete all the files to be deleted on error. */
2120 static void
2121 delete_failure_queue (void)
2123 struct temp_file *temp;
2125 for (temp = failure_delete_queue; temp; temp = temp->next)
2126 delete_if_ordinary (temp->name);
2129 static void
2130 clear_failure_queue (void)
2132 failure_delete_queue = 0;
2135 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2136 returns non-NULL.
2137 If DO_MULTI is true iterate over the paths twice, first with multilib
2138 suffix then without, otherwise iterate over the paths once without
2139 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2140 to avoid visiting the same path twice, but we could do better. For
2141 instance, /usr/lib/../lib is considered different from /usr/lib.
2142 At least EXTRA_SPACE chars past the end of the path passed to
2143 CALLBACK are available for use by the callback.
2144 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2146 Returns the value returned by CALLBACK. */
2148 static void *
2149 for_each_path (const struct path_prefix *paths,
2150 bool do_multi,
2151 size_t extra_space,
2152 void *(*callback) (char *, void *),
2153 void *callback_info)
2155 struct prefix_list *pl;
2156 const char *multi_dir = NULL;
2157 const char *multi_os_dir = NULL;
2158 const char *multiarch_suffix = NULL;
2159 const char *multi_suffix;
2160 const char *just_multi_suffix;
2161 char *path = NULL;
2162 void *ret = NULL;
2163 bool skip_multi_dir = false;
2164 bool skip_multi_os_dir = false;
2166 multi_suffix = machine_suffix;
2167 just_multi_suffix = just_machine_suffix;
2168 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2170 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2171 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2172 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2174 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2175 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2176 if (multiarch_dir)
2177 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2179 while (1)
2181 size_t multi_dir_len = 0;
2182 size_t multi_os_dir_len = 0;
2183 size_t multiarch_len = 0;
2184 size_t suffix_len;
2185 size_t just_suffix_len;
2186 size_t len;
2188 if (multi_dir)
2189 multi_dir_len = strlen (multi_dir);
2190 if (multi_os_dir)
2191 multi_os_dir_len = strlen (multi_os_dir);
2192 if (multiarch_suffix)
2193 multiarch_len = strlen (multiarch_suffix);
2194 suffix_len = strlen (multi_suffix);
2195 just_suffix_len = strlen (just_multi_suffix);
2197 if (path == NULL)
2199 len = paths->max_len + extra_space + 1;
2200 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2201 path = XNEWVEC (char, len);
2204 for (pl = paths->plist; pl != 0; pl = pl->next)
2206 len = strlen (pl->prefix);
2207 memcpy (path, pl->prefix, len);
2209 /* Look first in MACHINE/VERSION subdirectory. */
2210 if (!skip_multi_dir)
2212 memcpy (path + len, multi_suffix, suffix_len + 1);
2213 ret = callback (path, callback_info);
2214 if (ret)
2215 break;
2218 /* Some paths are tried with just the machine (ie. target)
2219 subdir. This is used for finding as, ld, etc. */
2220 if (!skip_multi_dir
2221 && pl->require_machine_suffix == 2)
2223 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2224 ret = callback (path, callback_info);
2225 if (ret)
2226 break;
2229 /* Now try the multiarch path. */
2230 if (!skip_multi_dir && !multi_dir
2231 && !pl->require_machine_suffix && multiarch_dir)
2233 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2234 ret = callback (path, callback_info);
2235 if (ret)
2236 break;
2239 /* Now try the base path. */
2240 if (!pl->require_machine_suffix
2241 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2243 const char *this_multi;
2244 size_t this_multi_len;
2246 if (pl->os_multilib)
2248 this_multi = multi_os_dir;
2249 this_multi_len = multi_os_dir_len;
2251 else
2253 this_multi = multi_dir;
2254 this_multi_len = multi_dir_len;
2257 if (this_multi_len)
2258 memcpy (path + len, this_multi, this_multi_len + 1);
2259 else
2260 path[len] = '\0';
2262 ret = callback (path, callback_info);
2263 if (ret)
2264 break;
2267 /* Now try the multiarch path. */
2268 if (!skip_multi_dir
2269 && !pl->require_machine_suffix && multiarch_dir)
2271 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2272 ret = callback (path, callback_info);
2273 if (ret)
2274 break;
2277 if (pl)
2278 break;
2280 if (multi_dir == NULL && multi_os_dir == NULL)
2281 break;
2283 /* Run through the paths again, this time without multilibs.
2284 Don't repeat any we have already seen. */
2285 if (multi_dir)
2287 free (CONST_CAST (char *, multi_dir));
2288 multi_dir = NULL;
2289 free (CONST_CAST (char *, multi_suffix));
2290 multi_suffix = machine_suffix;
2291 free (CONST_CAST (char *, just_multi_suffix));
2292 just_multi_suffix = just_machine_suffix;
2294 else
2295 skip_multi_dir = true;
2296 if (multi_os_dir)
2298 free (CONST_CAST (char *, multi_os_dir));
2299 multi_os_dir = NULL;
2301 else
2302 skip_multi_os_dir = true;
2305 if (multi_dir)
2307 free (CONST_CAST (char *, multi_dir));
2308 free (CONST_CAST (char *, multi_suffix));
2309 free (CONST_CAST (char *, just_multi_suffix));
2311 if (multi_os_dir)
2312 free (CONST_CAST (char *, multi_os_dir));
2313 if (ret != path)
2314 free (path);
2315 return ret;
2318 /* Callback for build_search_list. Adds path to obstack being built. */
2320 struct add_to_obstack_info {
2321 struct obstack *ob;
2322 bool check_dir;
2323 bool first_time;
2326 static void *
2327 add_to_obstack (char *path, void *data)
2329 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2331 if (info->check_dir && !is_directory (path, false))
2332 return NULL;
2334 if (!info->first_time)
2335 obstack_1grow (info->ob, PATH_SEPARATOR);
2337 obstack_grow (info->ob, path, strlen (path));
2339 info->first_time = false;
2340 return NULL;
2343 /* Add or change the value of an environment variable, outputting the
2344 change to standard error if in verbose mode. */
2345 static void
2346 xputenv (const char *string)
2348 if (verbose_flag)
2349 fnotice (stderr, "%s\n", string);
2350 putenv (CONST_CAST (char *, string));
2353 /* Build a list of search directories from PATHS.
2354 PREFIX is a string to prepend to the list.
2355 If CHECK_DIR_P is true we ensure the directory exists.
2356 If DO_MULTI is true, multilib paths are output first, then
2357 non-multilib paths.
2358 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2359 It is also used by the --print-search-dirs flag. */
2361 static char *
2362 build_search_list (const struct path_prefix *paths, const char *prefix,
2363 bool check_dir, bool do_multi)
2365 struct add_to_obstack_info info;
2367 info.ob = &collect_obstack;
2368 info.check_dir = check_dir;
2369 info.first_time = true;
2371 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2372 obstack_1grow (&collect_obstack, '=');
2374 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2376 obstack_1grow (&collect_obstack, '\0');
2377 return XOBFINISH (&collect_obstack, char *);
2380 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2381 for collect. */
2383 static void
2384 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2385 bool do_multi)
2387 xputenv (build_search_list (paths, env_var, true, do_multi));
2390 /* Check whether NAME can be accessed in MODE. This is like access,
2391 except that it never considers directories to be executable. */
2393 static int
2394 access_check (const char *name, int mode)
2396 if (mode == X_OK)
2398 struct stat st;
2400 if (stat (name, &st) < 0
2401 || S_ISDIR (st.st_mode))
2402 return -1;
2405 return access (name, mode);
2408 /* Callback for find_a_file. Appends the file name to the directory
2409 path. If the resulting file exists in the right mode, return the
2410 full pathname to the file. */
2412 struct file_at_path_info {
2413 const char *name;
2414 const char *suffix;
2415 int name_len;
2416 int suffix_len;
2417 int mode;
2420 static void *
2421 file_at_path (char *path, void *data)
2423 struct file_at_path_info *info = (struct file_at_path_info *) data;
2424 size_t len = strlen (path);
2426 memcpy (path + len, info->name, info->name_len);
2427 len += info->name_len;
2429 /* Some systems have a suffix for executable files.
2430 So try appending that first. */
2431 if (info->suffix_len)
2433 memcpy (path + len, info->suffix, info->suffix_len + 1);
2434 if (access_check (path, info->mode) == 0)
2435 return path;
2438 path[len] = '\0';
2439 if (access_check (path, info->mode) == 0)
2440 return path;
2442 return NULL;
2445 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2446 access to check permissions. If DO_MULTI is true, search multilib
2447 paths then non-multilib paths, otherwise do not search multilib paths.
2448 Return 0 if not found, otherwise return its name, allocated with malloc. */
2450 static char *
2451 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2452 bool do_multi)
2454 struct file_at_path_info info;
2456 #ifdef DEFAULT_ASSEMBLER
2457 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2458 return xstrdup (DEFAULT_ASSEMBLER);
2459 #endif
2461 #ifdef DEFAULT_LINKER
2462 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2463 return xstrdup (DEFAULT_LINKER);
2464 #endif
2466 /* Determine the filename to execute (special case for absolute paths). */
2468 if (IS_ABSOLUTE_PATH (name))
2470 if (access (name, mode) == 0)
2471 return xstrdup (name);
2473 return NULL;
2476 info.name = name;
2477 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2478 info.name_len = strlen (info.name);
2479 info.suffix_len = strlen (info.suffix);
2480 info.mode = mode;
2482 return (char*) for_each_path (pprefix, do_multi,
2483 info.name_len + info.suffix_len,
2484 file_at_path, &info);
2487 /* Ranking of prefixes in the sort list. -B prefixes are put before
2488 all others. */
2490 enum path_prefix_priority
2492 PREFIX_PRIORITY_B_OPT,
2493 PREFIX_PRIORITY_LAST
2496 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2497 order according to PRIORITY. Within each PRIORITY, new entries are
2498 appended.
2500 If WARN is nonzero, we will warn if no file is found
2501 through this prefix. WARN should point to an int
2502 which will be set to 1 if this entry is used.
2504 COMPONENT is the value to be passed to update_path.
2506 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2507 the complete value of machine_suffix.
2508 2 means try both machine_suffix and just_machine_suffix. */
2510 static void
2511 add_prefix (struct path_prefix *pprefix, const char *prefix,
2512 const char *component, /* enum prefix_priority */ int priority,
2513 int require_machine_suffix, int os_multilib)
2515 struct prefix_list *pl, **prev;
2516 int len;
2518 for (prev = &pprefix->plist;
2519 (*prev) != NULL && (*prev)->priority <= priority;
2520 prev = &(*prev)->next)
2523 /* Keep track of the longest prefix. */
2525 prefix = update_path (prefix, component);
2526 len = strlen (prefix);
2527 if (len > pprefix->max_len)
2528 pprefix->max_len = len;
2530 pl = XNEW (struct prefix_list);
2531 pl->prefix = prefix;
2532 pl->require_machine_suffix = require_machine_suffix;
2533 pl->priority = priority;
2534 pl->os_multilib = os_multilib;
2536 /* Insert after PREV. */
2537 pl->next = (*prev);
2538 (*prev) = pl;
2541 /* Same as add_prefix, but prepending target_system_root to prefix. */
2542 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2543 static void
2544 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2545 const char *component,
2546 /* enum prefix_priority */ int priority,
2547 int require_machine_suffix, int os_multilib)
2549 if (!IS_ABSOLUTE_PATH (prefix))
2550 fatal_error ("system path %qs is not absolute", prefix);
2552 if (target_system_root)
2554 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2555 size_t sysroot_len = strlen (target_system_root);
2557 if (sysroot_len > 0
2558 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2559 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2561 if (target_sysroot_suffix)
2562 prefix = concat (sysroot_no_trailing_dir_separator,
2563 target_sysroot_suffix, prefix, NULL);
2564 else
2565 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2567 free (sysroot_no_trailing_dir_separator);
2569 /* We have to override this because GCC's notion of sysroot
2570 moves along with GCC. */
2571 component = "GCC";
2574 add_prefix (pprefix, prefix, component, priority,
2575 require_machine_suffix, os_multilib);
2578 /* Execute the command specified by the arguments on the current line of spec.
2579 When using pipes, this includes several piped-together commands
2580 with `|' between them.
2582 Return 0 if successful, -1 if failed. */
2584 static int
2585 execute (void)
2587 int i;
2588 int n_commands; /* # of command. */
2589 char *string;
2590 struct pex_obj *pex;
2591 struct command
2593 const char *prog; /* program name. */
2594 const char **argv; /* vector of args. */
2596 const char *arg;
2598 struct command *commands; /* each command buffer with above info. */
2600 gcc_assert (!processing_spec_function);
2602 if (wrapper_string)
2604 string = find_a_file (&exec_prefixes,
2605 argbuf[0], X_OK, false);
2606 if (string)
2607 argbuf[0] = string;
2608 insert_wrapper (wrapper_string);
2611 /* Count # of piped commands. */
2612 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2613 if (strcmp (arg, "|") == 0)
2614 n_commands++;
2616 /* Get storage for each command. */
2617 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2619 /* Split argbuf into its separate piped processes,
2620 and record info about each one.
2621 Also search for the programs that are to be run. */
2623 argbuf.safe_push (0);
2625 commands[0].prog = argbuf[0]; /* first command. */
2626 commands[0].argv = argbuf.address ();
2628 if (!wrapper_string)
2630 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2631 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2634 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2635 if (arg && strcmp (arg, "|") == 0)
2636 { /* each command. */
2637 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2638 fatal_error ("-pipe not supported");
2639 #endif
2640 argbuf[i] = 0; /* Termination of
2641 command args. */
2642 commands[n_commands].prog = argbuf[i + 1];
2643 commands[n_commands].argv
2644 = &(argbuf.address ())[i + 1];
2645 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2646 X_OK, false);
2647 if (string)
2648 commands[n_commands].argv[0] = string;
2649 n_commands++;
2652 /* If -v, print what we are about to do, and maybe query. */
2654 if (verbose_flag)
2656 /* For help listings, put a blank line between sub-processes. */
2657 if (print_help_list)
2658 fputc ('\n', stderr);
2660 /* Print each piped command as a separate line. */
2661 for (i = 0; i < n_commands; i++)
2663 const char *const *j;
2665 if (verbose_only_flag)
2667 for (j = commands[i].argv; *j; j++)
2669 const char *p;
2670 for (p = *j; *p; ++p)
2671 if (!ISALNUM ((unsigned char) *p)
2672 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2673 break;
2674 if (*p || !*j)
2676 fprintf (stderr, " \"");
2677 for (p = *j; *p; ++p)
2679 if (*p == '"' || *p == '\\' || *p == '$')
2680 fputc ('\\', stderr);
2681 fputc (*p, stderr);
2683 fputc ('"', stderr);
2685 /* If it's empty, print "". */
2686 else if (!**j)
2687 fprintf (stderr, " \"\"");
2688 else
2689 fprintf (stderr, " %s", *j);
2692 else
2693 for (j = commands[i].argv; *j; j++)
2694 /* If it's empty, print "". */
2695 if (!**j)
2696 fprintf (stderr, " \"\"");
2697 else
2698 fprintf (stderr, " %s", *j);
2700 /* Print a pipe symbol after all but the last command. */
2701 if (i + 1 != n_commands)
2702 fprintf (stderr, " |");
2703 fprintf (stderr, "\n");
2705 fflush (stderr);
2706 if (verbose_only_flag != 0)
2708 /* verbose_only_flag should act as if the spec was
2709 executed, so increment execution_count before
2710 returning. This prevents spurious warnings about
2711 unused linker input files, etc. */
2712 execution_count++;
2713 return 0;
2715 #ifdef DEBUG
2716 fnotice (stderr, "\nGo ahead? (y or n) ");
2717 fflush (stderr);
2718 i = getchar ();
2719 if (i != '\n')
2720 while (getchar () != '\n')
2723 if (i != 'y' && i != 'Y')
2724 return 0;
2725 #endif /* DEBUG */
2728 #ifdef ENABLE_VALGRIND_CHECKING
2729 /* Run the each command through valgrind. To simplify prepending the
2730 path to valgrind and the option "-q" (for quiet operation unless
2731 something triggers), we allocate a separate argv array. */
2733 for (i = 0; i < n_commands; i++)
2735 const char **argv;
2736 int argc;
2737 int j;
2739 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2742 argv = XALLOCAVEC (const char *, argc + 3);
2744 argv[0] = VALGRIND_PATH;
2745 argv[1] = "-q";
2746 for (j = 2; j < argc + 2; j++)
2747 argv[j] = commands[i].argv[j - 2];
2748 argv[j] = NULL;
2750 commands[i].argv = argv;
2751 commands[i].prog = argv[0];
2753 #endif
2755 /* Run each piped subprocess. */
2757 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2758 ? PEX_RECORD_TIMES : 0),
2759 progname, temp_filename);
2760 if (pex == NULL)
2761 fatal_error ("pex_init failed: %m");
2763 for (i = 0; i < n_commands; i++)
2765 const char *errmsg;
2766 int err;
2767 const char *string = commands[i].argv[0];
2769 errmsg = pex_run (pex,
2770 ((i + 1 == n_commands ? PEX_LAST : 0)
2771 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2772 string, CONST_CAST (char **, commands[i].argv),
2773 NULL, NULL, &err);
2774 if (errmsg != NULL)
2776 if (err == 0)
2777 fatal_error (errmsg);
2778 else
2780 errno = err;
2781 pfatal_with_name (errmsg);
2785 if (string != commands[i].prog)
2786 free (CONST_CAST (char *, string));
2789 execution_count++;
2791 /* Wait for all the subprocesses to finish. */
2794 int *statuses;
2795 struct pex_time *times = NULL;
2796 int ret_code = 0;
2798 statuses = (int *) alloca (n_commands * sizeof (int));
2799 if (!pex_get_status (pex, n_commands, statuses))
2800 fatal_error ("failed to get exit status: %m");
2802 if (report_times || report_times_to_file)
2804 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2805 if (!pex_get_times (pex, n_commands, times))
2806 fatal_error ("failed to get process times: %m");
2809 pex_free (pex);
2811 for (i = 0; i < n_commands; ++i)
2813 int status = statuses[i];
2815 if (WIFSIGNALED (status))
2817 #ifdef SIGPIPE
2818 /* SIGPIPE is a special case. It happens in -pipe mode
2819 when the compiler dies before the preprocessor is done,
2820 or the assembler dies before the compiler is done.
2821 There's generally been an error already, and this is
2822 just fallout. So don't generate another error unless
2823 we would otherwise have succeeded. */
2824 if (WTERMSIG (status) == SIGPIPE
2825 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2827 signal_count++;
2828 ret_code = -1;
2830 else
2831 #endif
2832 internal_error ("%s (program %s)",
2833 strsignal (WTERMSIG (status)), commands[i].prog);
2835 else if (WIFEXITED (status)
2836 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2838 if (WEXITSTATUS (status) > greatest_status)
2839 greatest_status = WEXITSTATUS (status);
2840 ret_code = -1;
2843 if (report_times || report_times_to_file)
2845 struct pex_time *pt = &times[i];
2846 double ut, st;
2848 ut = ((double) pt->user_seconds
2849 + (double) pt->user_microseconds / 1.0e6);
2850 st = ((double) pt->system_seconds
2851 + (double) pt->system_microseconds / 1.0e6);
2853 if (ut + st != 0)
2855 if (report_times)
2856 fnotice (stderr, "# %s %.2f %.2f\n",
2857 commands[i].prog, ut, st);
2859 if (report_times_to_file)
2861 int c = 0;
2862 const char *const *j;
2864 fprintf (report_times_to_file, "%g %g", ut, st);
2866 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
2868 const char *p;
2869 for (p = *j; *p; ++p)
2870 if (*p == '"' || *p == '\\' || *p == '$'
2871 || ISSPACE (*p))
2872 break;
2874 if (*p)
2876 fprintf (report_times_to_file, " \"");
2877 for (p = *j; *p; ++p)
2879 if (*p == '"' || *p == '\\' || *p == '$')
2880 fputc ('\\', report_times_to_file);
2881 fputc (*p, report_times_to_file);
2883 fputc ('"', report_times_to_file);
2885 else
2886 fprintf (report_times_to_file, " %s", *j);
2889 fputc ('\n', report_times_to_file);
2895 return ret_code;
2899 /* Find all the switches given to us
2900 and make a vector describing them.
2901 The elements of the vector are strings, one per switch given.
2902 If a switch uses following arguments, then the `part1' field
2903 is the switch itself and the `args' field
2904 is a null-terminated vector containing the following arguments.
2905 Bits in the `live_cond' field are:
2906 SWITCH_LIVE to indicate this switch is true in a conditional spec.
2907 SWITCH_FALSE to indicate this switch is overridden by a later switch.
2908 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
2909 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
2910 in all do_spec calls afterwards. Used for %<S from self specs.
2911 The `validated' field is nonzero if any spec has looked at this switch;
2912 if it remains zero at the end of the run, it must be meaningless. */
2914 #define SWITCH_LIVE (1 << 0)
2915 #define SWITCH_FALSE (1 << 1)
2916 #define SWITCH_IGNORE (1 << 2)
2917 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
2918 #define SWITCH_KEEP_FOR_GCC (1 << 4)
2920 struct switchstr
2922 const char *part1;
2923 const char **args;
2924 unsigned int live_cond;
2925 bool known;
2926 bool validated;
2927 bool ordering;
2930 static struct switchstr *switches;
2932 static int n_switches;
2934 static int n_switches_alloc;
2936 /* Set to zero if -fcompare-debug is disabled, positive if it's
2937 enabled and we're running the first compilation, negative if it's
2938 enabled and we're running the second compilation. For most of the
2939 time, it's in the range -1..1, but it can be temporarily set to 2
2940 or 3 to indicate that the -fcompare-debug flags didn't come from
2941 the command-line, but rather from the GCC_COMPARE_DEBUG environment
2942 variable, until a synthesized -fcompare-debug flag is added to the
2943 command line. */
2944 int compare_debug;
2946 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
2947 int compare_debug_second;
2949 /* Set to the flags that should be passed to the second compilation in
2950 a -fcompare-debug compilation. */
2951 const char *compare_debug_opt;
2953 static struct switchstr *switches_debug_check[2];
2955 static int n_switches_debug_check[2];
2957 static int n_switches_alloc_debug_check[2];
2959 static char *debug_check_temp_file[2];
2961 /* Language is one of three things:
2963 1) The name of a real programming language.
2964 2) NULL, indicating that no one has figured out
2965 what it is yet.
2966 3) '*', indicating that the file should be passed
2967 to the linker. */
2968 struct infile
2970 const char *name;
2971 const char *language;
2972 struct compiler *incompiler;
2973 bool compiled;
2974 bool preprocessed;
2977 /* Also a vector of input files specified. */
2979 static struct infile *infiles;
2981 int n_infiles;
2983 static int n_infiles_alloc;
2985 /* True if multiple input files are being compiled to a single
2986 assembly file. */
2988 static bool combine_inputs;
2990 /* This counts the number of libraries added by lang_specific_driver, so that
2991 we can tell if there were any user supplied any files or libraries. */
2993 static int added_libraries;
2995 /* And a vector of corresponding output files is made up later. */
2997 const char **outfiles;
2999 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3001 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
3002 is true if we should look for an executable suffix. DO_OBJ
3003 is true if we should look for an object suffix. */
3005 static const char *
3006 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
3007 int do_obj ATTRIBUTE_UNUSED)
3009 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3010 int i;
3011 #endif
3012 int len;
3014 if (name == NULL)
3015 return NULL;
3017 len = strlen (name);
3019 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3020 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3021 if (do_obj && len > 2
3022 && name[len - 2] == '.'
3023 && name[len - 1] == 'o')
3025 obstack_grow (&obstack, name, len - 2);
3026 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3027 name = XOBFINISH (&obstack, const char *);
3029 #endif
3031 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3032 /* If there is no filetype, make it the executable suffix (which includes
3033 the "."). But don't get confused if we have just "-o". */
3034 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3035 return name;
3037 for (i = len - 1; i >= 0; i--)
3038 if (IS_DIR_SEPARATOR (name[i]))
3039 break;
3041 for (i++; i < len; i++)
3042 if (name[i] == '.')
3043 return name;
3045 obstack_grow (&obstack, name, len);
3046 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3047 strlen (TARGET_EXECUTABLE_SUFFIX));
3048 name = XOBFINISH (&obstack, const char *);
3049 #endif
3051 return name;
3053 #endif
3055 /* Display the command line switches accepted by gcc. */
3056 static void
3057 display_help (void)
3059 printf (_("Usage: %s [options] file...\n"), progname);
3060 fputs (_("Options:\n"), stdout);
3062 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3063 fputs (_(" --help Display this information\n"), stdout);
3064 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3065 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
3066 fputs (_(" Display specific types of command line options\n"), stdout);
3067 if (! verbose_flag)
3068 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3069 fputs (_(" --version Display compiler version information\n"), stdout);
3070 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3071 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3072 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3073 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3074 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3075 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3076 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3077 fputs (_("\
3078 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3079 a component in the library path\n"), stdout);
3080 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3081 fputs (_("\
3082 -print-multi-lib Display the mapping between command line options and\n\
3083 multiple library search directories\n"), stdout);
3084 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3085 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
3086 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
3087 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3088 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3089 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3090 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3091 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3092 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3093 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3094 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
3095 fputs (_("\
3096 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3097 prefixes to other gcc components\n"), stdout);
3098 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3099 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3100 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3101 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3102 fputs (_("\
3103 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3104 and libraries\n"), stdout);
3105 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3106 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3107 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3108 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3109 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3110 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3111 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3112 fputs (_(" -pie Create a position independent executable\n"), stdout);
3113 fputs (_(" -shared Create a shared library\n"), stdout);
3114 fputs (_("\
3115 -x <language> Specify the language of the following input files\n\
3116 Permissible languages include: c c++ assembler none\n\
3117 'none' means revert to the default behavior of\n\
3118 guessing the language based on the file's extension\n\
3119 "), stdout);
3121 printf (_("\
3122 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3123 passed on to the various sub-processes invoked by %s. In order to pass\n\
3124 other options on to these processes the -W<letter> options must be used.\n\
3125 "), progname);
3127 /* The rest of the options are displayed by invocations of the various
3128 sub-processes. */
3131 static void
3132 add_preprocessor_option (const char *option, int len)
3134 preprocessor_options.safe_push (save_string (option, len));
3137 static void
3138 add_assembler_option (const char *option, int len)
3140 assembler_options.safe_push (save_string (option, len));
3143 static void
3144 add_linker_option (const char *option, int len)
3146 linker_options.safe_push (save_string (option, len));
3149 /* Allocate space for an input file in infiles. */
3151 static void
3152 alloc_infile (void)
3154 if (n_infiles_alloc == 0)
3156 n_infiles_alloc = 16;
3157 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3159 else if (n_infiles_alloc == n_infiles)
3161 n_infiles_alloc *= 2;
3162 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3166 /* Store an input file with the given NAME and LANGUAGE in
3167 infiles. */
3169 static void
3170 add_infile (const char *name, const char *language)
3172 alloc_infile ();
3173 infiles[n_infiles].name = name;
3174 infiles[n_infiles++].language = language;
3177 /* Allocate space for a switch in switches. */
3179 static void
3180 alloc_switch (void)
3182 if (n_switches_alloc == 0)
3184 n_switches_alloc = 16;
3185 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3187 else if (n_switches_alloc == n_switches)
3189 n_switches_alloc *= 2;
3190 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3194 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3195 as validated if VALIDATED and KNOWN if it is an internal switch. */
3197 static void
3198 save_switch (const char *opt, size_t n_args, const char *const *args,
3199 bool validated, bool known)
3201 alloc_switch ();
3202 switches[n_switches].part1 = opt + 1;
3203 if (n_args == 0)
3204 switches[n_switches].args = 0;
3205 else
3207 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3208 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3209 switches[n_switches].args[n_args] = NULL;
3212 switches[n_switches].live_cond = 0;
3213 switches[n_switches].validated = validated;
3214 switches[n_switches].known = known;
3215 switches[n_switches].ordering = 0;
3216 n_switches++;
3219 /* Handle an option DECODED that is unknown to the option-processing
3220 machinery. */
3222 static bool
3223 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3225 const char *opt = decoded->arg;
3226 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3227 && !(decoded->errors & CL_ERR_NEGATIVE))
3229 /* Leave unknown -Wno-* options for the compiler proper, to be
3230 diagnosed only if there are warnings. */
3231 save_switch (decoded->canonical_option[0],
3232 decoded->canonical_option_num_elements - 1,
3233 &decoded->canonical_option[1], false, true);
3234 return false;
3236 if (decoded->opt_index == OPT_SPECIAL_unknown)
3238 /* Give it a chance to define it a a spec file. */
3239 save_switch (decoded->canonical_option[0],
3240 decoded->canonical_option_num_elements - 1,
3241 &decoded->canonical_option[1], false, false);
3242 return false;
3244 else
3245 return true;
3248 /* Handle an option DECODED that is not marked as CL_DRIVER.
3249 LANG_MASK will always be CL_DRIVER. */
3251 static void
3252 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3253 unsigned int lang_mask ATTRIBUTE_UNUSED)
3255 /* At this point, non-driver options are accepted (and expected to
3256 be passed down by specs) unless marked to be rejected by the
3257 driver. Options to be rejected by the driver but accepted by the
3258 compilers proper are treated just like completely unknown
3259 options. */
3260 const struct cl_option *option = &cl_options[decoded->opt_index];
3262 if (option->cl_reject_driver)
3263 error ("unrecognized command line option %qs",
3264 decoded->orig_option_with_args_text);
3265 else
3266 save_switch (decoded->canonical_option[0],
3267 decoded->canonical_option_num_elements - 1,
3268 &decoded->canonical_option[1], false, true);
3271 static const char *spec_lang = 0;
3272 static int last_language_n_infiles;
3274 /* Handle a driver option; arguments and return value as for
3275 handle_option. */
3277 static bool
3278 driver_handle_option (struct gcc_options *opts,
3279 struct gcc_options *opts_set,
3280 const struct cl_decoded_option *decoded,
3281 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3282 location_t loc,
3283 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3284 diagnostic_context *dc)
3286 size_t opt_index = decoded->opt_index;
3287 const char *arg = decoded->arg;
3288 const char *compare_debug_replacement_opt;
3289 int value = decoded->value;
3290 bool validated = false;
3291 bool do_save = true;
3293 gcc_assert (opts == &global_options);
3294 gcc_assert (opts_set == &global_options_set);
3295 gcc_assert (kind == DK_UNSPECIFIED);
3296 gcc_assert (loc == UNKNOWN_LOCATION);
3297 gcc_assert (dc == global_dc);
3299 switch (opt_index)
3301 case OPT_dumpspecs:
3303 struct spec_list *sl;
3304 init_spec ();
3305 for (sl = specs; sl; sl = sl->next)
3306 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3307 if (link_command_spec)
3308 printf ("*link_command:\n%s\n\n", link_command_spec);
3309 exit (0);
3312 case OPT_dumpversion:
3313 printf ("%s\n", spec_version);
3314 exit (0);
3316 case OPT_dumpmachine:
3317 printf ("%s\n", spec_machine);
3318 exit (0);
3320 case OPT__version:
3321 print_version = 1;
3323 /* CPP driver cannot obtain switch from cc1_options. */
3324 if (is_cpp_driver)
3325 add_preprocessor_option ("--version", strlen ("--version"));
3326 add_assembler_option ("--version", strlen ("--version"));
3327 add_linker_option ("--version", strlen ("--version"));
3328 break;
3330 case OPT__help:
3331 print_help_list = 1;
3333 /* CPP driver cannot obtain switch from cc1_options. */
3334 if (is_cpp_driver)
3335 add_preprocessor_option ("--help", 6);
3336 add_assembler_option ("--help", 6);
3337 add_linker_option ("--help", 6);
3338 break;
3340 case OPT__help_:
3341 print_subprocess_help = 2;
3342 break;
3344 case OPT__target_help:
3345 print_subprocess_help = 1;
3347 /* CPP driver cannot obtain switch from cc1_options. */
3348 if (is_cpp_driver)
3349 add_preprocessor_option ("--target-help", 13);
3350 add_assembler_option ("--target-help", 13);
3351 add_linker_option ("--target-help", 13);
3352 break;
3354 case OPT__no_sysroot_suffix:
3355 case OPT_pass_exit_codes:
3356 case OPT_print_search_dirs:
3357 case OPT_print_file_name_:
3358 case OPT_print_prog_name_:
3359 case OPT_print_multi_lib:
3360 case OPT_print_multi_directory:
3361 case OPT_print_sysroot:
3362 case OPT_print_multi_os_directory:
3363 case OPT_print_multiarch:
3364 case OPT_print_sysroot_headers_suffix:
3365 case OPT_time:
3366 case OPT_wrapper:
3367 /* These options set the variables specified in common.opt
3368 automatically, and do not need to be saved for spec
3369 processing. */
3370 do_save = false;
3371 break;
3373 case OPT_print_libgcc_file_name:
3374 print_file_name = "libgcc.a";
3375 do_save = false;
3376 break;
3378 case OPT_fcompare_debug_second:
3379 compare_debug_second = 1;
3380 break;
3382 case OPT_fcompare_debug:
3383 switch (value)
3385 case 0:
3386 compare_debug_replacement_opt = "-fcompare-debug=";
3387 arg = "";
3388 goto compare_debug_with_arg;
3390 case 1:
3391 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3392 arg = "-gtoggle";
3393 goto compare_debug_with_arg;
3395 default:
3396 gcc_unreachable ();
3398 break;
3400 case OPT_fcompare_debug_:
3401 compare_debug_replacement_opt = decoded->canonical_option[0];
3402 compare_debug_with_arg:
3403 gcc_assert (decoded->canonical_option_num_elements == 1);
3404 gcc_assert (arg != NULL);
3405 if (*arg)
3406 compare_debug = 1;
3407 else
3408 compare_debug = -1;
3409 if (compare_debug < 0)
3410 compare_debug_opt = NULL;
3411 else
3412 compare_debug_opt = arg;
3413 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3414 return true;
3416 case OPT_Wa_:
3418 int prev, j;
3419 /* Pass the rest of this option to the assembler. */
3421 /* Split the argument at commas. */
3422 prev = 0;
3423 for (j = 0; arg[j]; j++)
3424 if (arg[j] == ',')
3426 add_assembler_option (arg + prev, j - prev);
3427 prev = j + 1;
3430 /* Record the part after the last comma. */
3431 add_assembler_option (arg + prev, j - prev);
3433 do_save = false;
3434 break;
3436 case OPT_Wp_:
3438 int prev, j;
3439 /* Pass the rest of this option to the preprocessor. */
3441 /* Split the argument at commas. */
3442 prev = 0;
3443 for (j = 0; arg[j]; j++)
3444 if (arg[j] == ',')
3446 add_preprocessor_option (arg + prev, j - prev);
3447 prev = j + 1;
3450 /* Record the part after the last comma. */
3451 add_preprocessor_option (arg + prev, j - prev);
3453 do_save = false;
3454 break;
3456 case OPT_Wl_:
3458 int prev, j;
3459 /* Split the argument at commas. */
3460 prev = 0;
3461 for (j = 0; arg[j]; j++)
3462 if (arg[j] == ',')
3464 add_infile (save_string (arg + prev, j - prev), "*");
3465 prev = j + 1;
3467 /* Record the part after the last comma. */
3468 add_infile (arg + prev, "*");
3470 do_save = false;
3471 break;
3473 case OPT_Xlinker:
3474 add_infile (arg, "*");
3475 do_save = false;
3476 break;
3478 case OPT_Xpreprocessor:
3479 add_preprocessor_option (arg, strlen (arg));
3480 do_save = false;
3481 break;
3483 case OPT_Xassembler:
3484 add_assembler_option (arg, strlen (arg));
3485 do_save = false;
3486 break;
3488 case OPT_l:
3489 /* POSIX allows separation of -l and the lib arg; canonicalize
3490 by concatenating -l with its arg */
3491 add_infile (concat ("-l", arg, NULL), "*");
3492 do_save = false;
3493 break;
3495 case OPT_L:
3496 /* Similarly, canonicalize -L for linkers that may not accept
3497 separate arguments. */
3498 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3499 return true;
3501 case OPT_F:
3502 /* Likewise -F. */
3503 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3504 return true;
3506 case OPT_save_temps:
3507 save_temps_flag = SAVE_TEMPS_CWD;
3508 validated = true;
3509 break;
3511 case OPT_save_temps_:
3512 if (strcmp (arg, "cwd") == 0)
3513 save_temps_flag = SAVE_TEMPS_CWD;
3514 else if (strcmp (arg, "obj") == 0
3515 || strcmp (arg, "object") == 0)
3516 save_temps_flag = SAVE_TEMPS_OBJ;
3517 else
3518 fatal_error ("%qs is an unknown -save-temps option",
3519 decoded->orig_option_with_args_text);
3520 break;
3522 case OPT_no_canonical_prefixes:
3523 /* Already handled as a special case, so ignored here. */
3524 do_save = false;
3525 break;
3527 case OPT_pipe:
3528 validated = true;
3529 /* These options set the variables specified in common.opt
3530 automatically, but do need to be saved for spec
3531 processing. */
3532 break;
3534 case OPT_specs_:
3536 struct user_specs *user = XNEW (struct user_specs);
3538 user->next = (struct user_specs *) 0;
3539 user->filename = arg;
3540 if (user_specs_tail)
3541 user_specs_tail->next = user;
3542 else
3543 user_specs_head = user;
3544 user_specs_tail = user;
3546 validated = true;
3547 break;
3549 case OPT__sysroot_:
3550 target_system_root = arg;
3551 target_system_root_changed = 1;
3552 do_save = false;
3553 break;
3555 case OPT_time_:
3556 if (report_times_to_file)
3557 fclose (report_times_to_file);
3558 report_times_to_file = fopen (arg, "a");
3559 do_save = false;
3560 break;
3562 case OPT____:
3563 /* "-###"
3564 This is similar to -v except that there is no execution
3565 of the commands and the echoed arguments are quoted. It
3566 is intended for use in shell scripts to capture the
3567 driver-generated command line. */
3568 verbose_only_flag++;
3569 verbose_flag = 1;
3570 do_save = false;
3571 break;
3573 case OPT_B:
3575 size_t len = strlen (arg);
3577 /* Catch the case where the user has forgotten to append a
3578 directory separator to the path. Note, they may be using
3579 -B to add an executable name prefix, eg "i386-elf-", in
3580 order to distinguish between multiple installations of
3581 GCC in the same directory. Hence we must check to see
3582 if appending a directory separator actually makes a
3583 valid directory name. */
3584 if (!IS_DIR_SEPARATOR (arg[len - 1])
3585 && is_directory (arg, false))
3587 char *tmp = XNEWVEC (char, len + 2);
3588 strcpy (tmp, arg);
3589 tmp[len] = DIR_SEPARATOR;
3590 tmp[++len] = 0;
3591 arg = tmp;
3594 add_prefix (&exec_prefixes, arg, NULL,
3595 PREFIX_PRIORITY_B_OPT, 0, 0);
3596 add_prefix (&startfile_prefixes, arg, NULL,
3597 PREFIX_PRIORITY_B_OPT, 0, 0);
3598 add_prefix (&include_prefixes, arg, NULL,
3599 PREFIX_PRIORITY_B_OPT, 0, 0);
3601 validated = true;
3602 break;
3604 case OPT_x:
3605 spec_lang = arg;
3606 if (!strcmp (spec_lang, "none"))
3607 /* Suppress the warning if -xnone comes after the last input
3608 file, because alternate command interfaces like g++ might
3609 find it useful to place -xnone after each input file. */
3610 spec_lang = 0;
3611 else
3612 last_language_n_infiles = n_infiles;
3613 do_save = false;
3614 break;
3616 case OPT_o:
3617 have_o = 1;
3618 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3619 arg = convert_filename (arg, ! have_c, 0);
3620 #endif
3621 /* Save the output name in case -save-temps=obj was used. */
3622 save_temps_prefix = xstrdup (arg);
3623 /* On some systems, ld cannot handle "-o" without a space. So
3624 split the option from its argument. */
3625 save_switch ("-o", 1, &arg, validated, true);
3626 return true;
3628 case OPT_static_libgcc:
3629 case OPT_shared_libgcc:
3630 case OPT_static_libgfortran:
3631 case OPT_static_libstdc__:
3632 /* These are always valid, since gcc.c itself understands the
3633 first two, gfortranspec.c understands -static-libgfortran and
3634 g++spec.c understands -static-libstdc++ */
3635 validated = true;
3636 break;
3638 default:
3639 /* Various driver options need no special processing at this
3640 point, having been handled in a prescan above or being
3641 handled by specs. */
3642 break;
3645 if (do_save)
3646 save_switch (decoded->canonical_option[0],
3647 decoded->canonical_option_num_elements - 1,
3648 &decoded->canonical_option[1], validated, true);
3649 return true;
3652 /* Put the driver's standard set of option handlers in *HANDLERS. */
3654 static void
3655 set_option_handlers (struct cl_option_handlers *handlers)
3657 handlers->unknown_option_callback = driver_unknown_option_callback;
3658 handlers->wrong_lang_callback = driver_wrong_lang_callback;
3659 handlers->num_handlers = 3;
3660 handlers->handlers[0].handler = driver_handle_option;
3661 handlers->handlers[0].mask = CL_DRIVER;
3662 handlers->handlers[1].handler = common_handle_option;
3663 handlers->handlers[1].mask = CL_COMMON;
3664 handlers->handlers[2].handler = target_handle_option;
3665 handlers->handlers[2].mask = CL_TARGET;
3668 /* Create the vector `switches' and its contents.
3669 Store its length in `n_switches'. */
3671 static void
3672 process_command (unsigned int decoded_options_count,
3673 struct cl_decoded_option *decoded_options)
3675 const char *temp;
3676 char *temp1;
3677 char *tooldir_prefix, *tooldir_prefix2;
3678 char *(*get_relative_prefix) (const char *, const char *,
3679 const char *) = NULL;
3680 struct cl_option_handlers handlers;
3681 unsigned int j;
3683 gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
3685 n_switches = 0;
3686 n_infiles = 0;
3687 added_libraries = 0;
3689 /* Figure compiler version from version string. */
3691 compiler_version = temp1 = xstrdup (version_string);
3693 for (; *temp1; ++temp1)
3695 if (*temp1 == ' ')
3697 *temp1 = '\0';
3698 break;
3702 /* Handle any -no-canonical-prefixes flag early, to assign the function
3703 that builds relative prefixes. This function creates default search
3704 paths that are needed later in normal option handling. */
3706 for (j = 1; j < decoded_options_count; j++)
3708 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3710 get_relative_prefix = make_relative_prefix_ignore_links;
3711 break;
3714 if (! get_relative_prefix)
3715 get_relative_prefix = make_relative_prefix;
3717 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3718 see if we can create it from the pathname specified in
3719 decoded_options[0].arg. */
3721 gcc_libexec_prefix = standard_libexec_prefix;
3722 #ifndef VMS
3723 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3724 if (!gcc_exec_prefix)
3726 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
3727 standard_bindir_prefix,
3728 standard_exec_prefix);
3729 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
3730 standard_bindir_prefix,
3731 standard_libexec_prefix);
3732 if (gcc_exec_prefix)
3733 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3735 else
3737 /* make_relative_prefix requires a program name, but
3738 GCC_EXEC_PREFIX is typically a directory name with a trailing
3739 / (which is ignored by make_relative_prefix), so append a
3740 program name. */
3741 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3742 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
3743 standard_exec_prefix,
3744 standard_libexec_prefix);
3746 /* The path is unrelocated, so fallback to the original setting. */
3747 if (!gcc_libexec_prefix)
3748 gcc_libexec_prefix = standard_libexec_prefix;
3750 free (tmp_prefix);
3752 #else
3753 #endif
3754 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3755 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3756 or an automatically created GCC_EXEC_PREFIX from
3757 decoded_options[0].arg. */
3759 /* Do language-specific adjustment/addition of flags. */
3760 lang_specific_driver (&decoded_options, &decoded_options_count,
3761 &added_libraries);
3763 if (gcc_exec_prefix)
3765 int len = strlen (gcc_exec_prefix);
3767 if (len > (int) sizeof ("/lib/gcc/") - 1
3768 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3770 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3771 if (IS_DIR_SEPARATOR (*temp)
3772 && filename_ncmp (temp + 1, "lib", 3) == 0
3773 && IS_DIR_SEPARATOR (temp[4])
3774 && filename_ncmp (temp + 5, "gcc", 3) == 0)
3775 len -= sizeof ("/lib/gcc/") - 1;
3778 set_std_prefix (gcc_exec_prefix, len);
3779 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3780 PREFIX_PRIORITY_LAST, 0, 0);
3781 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3782 PREFIX_PRIORITY_LAST, 0, 0);
3785 /* COMPILER_PATH and LIBRARY_PATH have values
3786 that are lists of directory names with colons. */
3788 temp = getenv ("COMPILER_PATH");
3789 if (temp)
3791 const char *startp, *endp;
3792 char *nstore = (char *) alloca (strlen (temp) + 3);
3794 startp = endp = temp;
3795 while (1)
3797 if (*endp == PATH_SEPARATOR || *endp == 0)
3799 strncpy (nstore, startp, endp - startp);
3800 if (endp == startp)
3801 strcpy (nstore, concat (".", dir_separator_str, NULL));
3802 else if (!IS_DIR_SEPARATOR (endp[-1]))
3804 nstore[endp - startp] = DIR_SEPARATOR;
3805 nstore[endp - startp + 1] = 0;
3807 else
3808 nstore[endp - startp] = 0;
3809 add_prefix (&exec_prefixes, nstore, 0,
3810 PREFIX_PRIORITY_LAST, 0, 0);
3811 add_prefix (&include_prefixes, nstore, 0,
3812 PREFIX_PRIORITY_LAST, 0, 0);
3813 if (*endp == 0)
3814 break;
3815 endp = startp = endp + 1;
3817 else
3818 endp++;
3822 temp = getenv (LIBRARY_PATH_ENV);
3823 if (temp && *cross_compile == '0')
3825 const char *startp, *endp;
3826 char *nstore = (char *) alloca (strlen (temp) + 3);
3828 startp = endp = temp;
3829 while (1)
3831 if (*endp == PATH_SEPARATOR || *endp == 0)
3833 strncpy (nstore, startp, endp - startp);
3834 if (endp == startp)
3835 strcpy (nstore, concat (".", dir_separator_str, NULL));
3836 else if (!IS_DIR_SEPARATOR (endp[-1]))
3838 nstore[endp - startp] = DIR_SEPARATOR;
3839 nstore[endp - startp + 1] = 0;
3841 else
3842 nstore[endp - startp] = 0;
3843 add_prefix (&startfile_prefixes, nstore, NULL,
3844 PREFIX_PRIORITY_LAST, 0, 1);
3845 if (*endp == 0)
3846 break;
3847 endp = startp = endp + 1;
3849 else
3850 endp++;
3854 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3855 temp = getenv ("LPATH");
3856 if (temp && *cross_compile == '0')
3858 const char *startp, *endp;
3859 char *nstore = (char *) alloca (strlen (temp) + 3);
3861 startp = endp = temp;
3862 while (1)
3864 if (*endp == PATH_SEPARATOR || *endp == 0)
3866 strncpy (nstore, startp, endp - startp);
3867 if (endp == startp)
3868 strcpy (nstore, concat (".", dir_separator_str, NULL));
3869 else if (!IS_DIR_SEPARATOR (endp[-1]))
3871 nstore[endp - startp] = DIR_SEPARATOR;
3872 nstore[endp - startp + 1] = 0;
3874 else
3875 nstore[endp - startp] = 0;
3876 add_prefix (&startfile_prefixes, nstore, NULL,
3877 PREFIX_PRIORITY_LAST, 0, 1);
3878 if (*endp == 0)
3879 break;
3880 endp = startp = endp + 1;
3882 else
3883 endp++;
3887 /* Process the options and store input files and switches in their
3888 vectors. */
3890 last_language_n_infiles = -1;
3892 set_option_handlers (&handlers);
3894 for (j = 1; j < decoded_options_count; j++)
3896 switch (decoded_options[j].opt_index)
3898 case OPT_S:
3899 case OPT_c:
3900 case OPT_E:
3901 have_c = 1;
3902 break;
3904 if (have_c)
3905 break;
3908 for (j = 1; j < decoded_options_count; j++)
3910 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
3912 const char *arg = decoded_options[j].arg;
3913 const char *p = strrchr (arg, '@');
3914 char *fname;
3915 long offset;
3916 int consumed;
3917 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3918 arg = convert_filename (arg, 0, access (arg, F_OK));
3919 #endif
3920 /* For LTO static archive support we handle input file
3921 specifications that are composed of a filename and
3922 an offset like FNAME@OFFSET. */
3923 if (p
3924 && p != arg
3925 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
3926 && strlen (p) == (unsigned int)consumed)
3928 fname = (char *)xmalloc (p - arg + 1);
3929 memcpy (fname, arg, p - arg);
3930 fname[p - arg] = '\0';
3931 /* Only accept non-stdin and existing FNAME parts, otherwise
3932 try with the full name. */
3933 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
3935 free (fname);
3936 fname = xstrdup (arg);
3939 else
3940 fname = xstrdup (arg);
3942 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
3943 perror_with_name (fname);
3944 else
3945 add_infile (arg, spec_lang);
3947 free (fname);
3948 continue;
3951 read_cmdline_option (&global_options, &global_options_set,
3952 decoded_options + j, UNKNOWN_LOCATION,
3953 CL_DRIVER, &handlers, global_dc);
3956 /* If -save-temps=obj and -o name, create the prefix to use for %b.
3957 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
3958 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
3960 save_temps_length = strlen (save_temps_prefix);
3961 temp = strrchr (lbasename (save_temps_prefix), '.');
3962 if (temp)
3964 save_temps_length -= strlen (temp);
3965 save_temps_prefix[save_temps_length] = '\0';
3969 else if (save_temps_prefix != NULL)
3971 free (save_temps_prefix);
3972 save_temps_prefix = NULL;
3975 if (save_temps_flag && use_pipes)
3977 /* -save-temps overrides -pipe, so that temp files are produced */
3978 if (save_temps_flag)
3979 warning (0, "-pipe ignored because -save-temps specified");
3980 use_pipes = 0;
3983 if (!compare_debug)
3985 const char *gcd = getenv ("GCC_COMPARE_DEBUG");
3987 if (gcd && gcd[0] == '-')
3989 compare_debug = 2;
3990 compare_debug_opt = gcd;
3992 else if (gcd && *gcd && strcmp (gcd, "0"))
3994 compare_debug = 3;
3995 compare_debug_opt = "-gtoggle";
3998 else if (compare_debug < 0)
4000 compare_debug = 0;
4001 gcc_assert (!compare_debug_opt);
4004 /* Set up the search paths. We add directories that we expect to
4005 contain GNU Toolchain components before directories specified by
4006 the machine description so that we will find GNU components (like
4007 the GNU assembler) before those of the host system. */
4009 /* If we don't know where the toolchain has been installed, use the
4010 configured-in locations. */
4011 if (!gcc_exec_prefix)
4013 #ifndef OS2
4014 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4015 PREFIX_PRIORITY_LAST, 1, 0);
4016 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4017 PREFIX_PRIORITY_LAST, 2, 0);
4018 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4019 PREFIX_PRIORITY_LAST, 2, 0);
4020 #endif
4021 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4022 PREFIX_PRIORITY_LAST, 1, 0);
4025 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4026 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
4027 dir_separator_str, NULL);
4029 /* Look for tools relative to the location from which the driver is
4030 running, or, if that is not available, the configured prefix. */
4031 tooldir_prefix
4032 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4033 spec_machine, dir_separator_str,
4034 spec_version, dir_separator_str, tooldir_prefix2, NULL);
4035 free (tooldir_prefix2);
4037 add_prefix (&exec_prefixes,
4038 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4039 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4040 add_prefix (&startfile_prefixes,
4041 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4042 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4043 free (tooldir_prefix);
4045 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4046 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4047 then consider it to relocate with the rest of the GCC installation
4048 if GCC_EXEC_PREFIX is set.
4049 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4050 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4052 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4053 standard_bindir_prefix,
4054 target_system_root);
4055 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4057 target_system_root = tmp_prefix;
4058 target_system_root_changed = 1;
4061 #endif
4063 /* More prefixes are enabled in main, after we read the specs file
4064 and determine whether this is cross-compilation or not. */
4066 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4067 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4069 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4070 environment variable. */
4071 if (compare_debug == 2 || compare_debug == 3)
4073 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4074 save_switch (opt, 0, NULL, false, true);
4075 compare_debug = 1;
4078 /* Ensure we only invoke each subprocess once. */
4079 if (print_subprocess_help || print_help_list || print_version)
4081 n_infiles = 0;
4083 /* Create a dummy input file, so that we can pass
4084 the help option on to the various sub-processes. */
4085 add_infile ("help-dummy", "c");
4088 alloc_switch ();
4089 switches[n_switches].part1 = 0;
4090 alloc_infile ();
4091 infiles[n_infiles].name = 0;
4094 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4095 and place that in the environment. */
4097 static void
4098 set_collect_gcc_options (void)
4100 int i;
4101 int first_time;
4103 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4104 the compiler. */
4105 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4106 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4108 first_time = TRUE;
4109 for (i = 0; (int) i < n_switches; i++)
4111 const char *const *args;
4112 const char *p, *q;
4113 if (!first_time)
4114 obstack_grow (&collect_obstack, " ", 1);
4116 first_time = FALSE;
4118 /* Ignore elided switches. */
4119 if ((switches[i].live_cond
4120 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4121 == SWITCH_IGNORE)
4122 continue;
4124 obstack_grow (&collect_obstack, "'-", 2);
4125 q = switches[i].part1;
4126 while ((p = strchr (q, '\'')))
4128 obstack_grow (&collect_obstack, q, p - q);
4129 obstack_grow (&collect_obstack, "'\\''", 4);
4130 q = ++p;
4132 obstack_grow (&collect_obstack, q, strlen (q));
4133 obstack_grow (&collect_obstack, "'", 1);
4135 for (args = switches[i].args; args && *args; args++)
4137 obstack_grow (&collect_obstack, " '", 2);
4138 q = *args;
4139 while ((p = strchr (q, '\'')))
4141 obstack_grow (&collect_obstack, q, p - q);
4142 obstack_grow (&collect_obstack, "'\\''", 4);
4143 q = ++p;
4145 obstack_grow (&collect_obstack, q, strlen (q));
4146 obstack_grow (&collect_obstack, "'", 1);
4149 obstack_grow (&collect_obstack, "\0", 1);
4150 xputenv (XOBFINISH (&collect_obstack, char *));
4153 /* Process a spec string, accumulating and running commands. */
4155 /* These variables describe the input file name.
4156 input_file_number is the index on outfiles of this file,
4157 so that the output file name can be stored for later use by %o.
4158 input_basename is the start of the part of the input file
4159 sans all directory names, and basename_length is the number
4160 of characters starting there excluding the suffix .c or whatever. */
4162 static const char *gcc_input_filename;
4163 static int input_file_number;
4164 size_t input_filename_length;
4165 static int basename_length;
4166 static int suffixed_basename_length;
4167 static const char *input_basename;
4168 static const char *input_suffix;
4169 #ifndef HOST_LACKS_INODE_NUMBERS
4170 static struct stat input_stat;
4171 #endif
4172 static int input_stat_set;
4174 /* The compiler used to process the current input file. */
4175 static struct compiler *input_file_compiler;
4177 /* These are variables used within do_spec and do_spec_1. */
4179 /* Nonzero if an arg has been started and not yet terminated
4180 (with space, tab or newline). */
4181 static int arg_going;
4183 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4184 is a temporary file name. */
4185 static int delete_this_arg;
4187 /* Nonzero means %w has been seen; the next arg to be terminated
4188 is the output file name of this compilation. */
4189 static int this_is_output_file;
4191 /* Nonzero means %s has been seen; the next arg to be terminated
4192 is the name of a library file and we should try the standard
4193 search dirs for it. */
4194 static int this_is_library_file;
4196 /* Nonzero means %T has been seen; the next arg to be terminated
4197 is the name of a linker script and we should try all of the
4198 standard search dirs for it. If it is found insert a --script
4199 command line switch and then substitute the full path in place,
4200 otherwise generate an error message. */
4201 static int this_is_linker_script;
4203 /* Nonzero means that the input of this command is coming from a pipe. */
4204 static int input_from_pipe;
4206 /* Nonnull means substitute this for any suffix when outputting a switches
4207 arguments. */
4208 static const char *suffix_subst;
4210 /* If there is an argument being accumulated, terminate it and store it. */
4212 static void
4213 end_going_arg (void)
4215 if (arg_going)
4217 const char *string;
4219 obstack_1grow (&obstack, 0);
4220 string = XOBFINISH (&obstack, const char *);
4221 if (this_is_library_file)
4222 string = find_file (string);
4223 if (this_is_linker_script)
4225 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4227 if (full_script_path == NULL)
4229 error ("unable to locate default linker script %qs in the library search paths", string);
4230 /* Script was not found on search path. */
4231 return;
4233 store_arg ("--script", false, false);
4234 string = full_script_path;
4236 store_arg (string, delete_this_arg, this_is_output_file);
4237 if (this_is_output_file)
4238 outfiles[input_file_number] = string;
4239 arg_going = 0;
4244 /* Parse the WRAPPER string which is a comma separated list of the command line
4245 and insert them into the beginning of argbuf. */
4247 static void
4248 insert_wrapper (const char *wrapper)
4250 int n = 0;
4251 int i;
4252 char *buf = xstrdup (wrapper);
4253 char *p = buf;
4254 unsigned int old_length = argbuf.length ();
4258 n++;
4259 while (*p == ',')
4260 p++;
4262 while ((p = strchr (p, ',')) != NULL);
4264 argbuf.safe_grow (old_length + n);
4265 memmove (argbuf.address () + n,
4266 argbuf.address (),
4267 old_length * sizeof (const_char_p));
4269 i = 0;
4270 p = buf;
4273 while (*p == ',')
4275 *p = 0;
4276 p++;
4278 argbuf[i] = p;
4279 i++;
4281 while ((p = strchr (p, ',')) != NULL);
4282 gcc_assert (i == n);
4285 /* Process the spec SPEC and run the commands specified therein.
4286 Returns 0 if the spec is successfully processed; -1 if failed. */
4289 do_spec (const char *spec)
4291 int value;
4293 value = do_spec_2 (spec);
4295 /* Force out any unfinished command.
4296 If -pipe, this forces out the last command if it ended in `|'. */
4297 if (value == 0)
4299 if (argbuf.length () > 0
4300 && !strcmp (argbuf.last (), "|"))
4301 argbuf.pop ();
4303 set_collect_gcc_options ();
4305 if (argbuf.length () > 0)
4306 value = execute ();
4309 return value;
4312 static int
4313 do_spec_2 (const char *spec)
4315 int result;
4317 clear_args ();
4318 arg_going = 0;
4319 delete_this_arg = 0;
4320 this_is_output_file = 0;
4321 this_is_library_file = 0;
4322 this_is_linker_script = 0;
4323 input_from_pipe = 0;
4324 suffix_subst = NULL;
4326 result = do_spec_1 (spec, 0, NULL);
4328 end_going_arg ();
4330 return result;
4334 /* Process the given spec string and add any new options to the end
4335 of the switches/n_switches array. */
4337 static void
4338 do_option_spec (const char *name, const char *spec)
4340 unsigned int i, value_count, value_len;
4341 const char *p, *q, *value;
4342 char *tmp_spec, *tmp_spec_p;
4344 if (configure_default_options[0].name == NULL)
4345 return;
4347 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4348 if (strcmp (configure_default_options[i].name, name) == 0)
4349 break;
4350 if (i == ARRAY_SIZE (configure_default_options))
4351 return;
4353 value = configure_default_options[i].value;
4354 value_len = strlen (value);
4356 /* Compute the size of the final spec. */
4357 value_count = 0;
4358 p = spec;
4359 while ((p = strstr (p, "%(VALUE)")) != NULL)
4361 p ++;
4362 value_count ++;
4365 /* Replace each %(VALUE) by the specified value. */
4366 tmp_spec = (char *) alloca (strlen (spec) + 1
4367 + value_count * (value_len - strlen ("%(VALUE)")));
4368 tmp_spec_p = tmp_spec;
4369 q = spec;
4370 while ((p = strstr (q, "%(VALUE)")) != NULL)
4372 memcpy (tmp_spec_p, q, p - q);
4373 tmp_spec_p = tmp_spec_p + (p - q);
4374 memcpy (tmp_spec_p, value, value_len);
4375 tmp_spec_p += value_len;
4376 q = p + strlen ("%(VALUE)");
4378 strcpy (tmp_spec_p, q);
4380 do_self_spec (tmp_spec);
4383 /* Process the given spec string and add any new options to the end
4384 of the switches/n_switches array. */
4386 static void
4387 do_self_spec (const char *spec)
4389 int i;
4391 do_spec_2 (spec);
4392 do_spec_1 (" ", 0, NULL);
4394 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4395 do_self_specs adds the replacements to switches array, so it shouldn't
4396 be processed afterwards. */
4397 for (i = 0; i < n_switches; i++)
4398 if ((switches[i].live_cond & SWITCH_IGNORE))
4399 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4401 if (argbuf.length () > 0)
4403 const char **argbuf_copy;
4404 struct cl_decoded_option *decoded_options;
4405 struct cl_option_handlers handlers;
4406 unsigned int decoded_options_count;
4407 unsigned int j;
4409 /* Create a copy of argbuf with a dummy argv[0] entry for
4410 decode_cmdline_options_to_array. */
4411 argbuf_copy = XNEWVEC (const char *,
4412 argbuf.length () + 1);
4413 argbuf_copy[0] = "";
4414 memcpy (argbuf_copy + 1, argbuf.address (),
4415 argbuf.length () * sizeof (const char *));
4417 decode_cmdline_options_to_array (argbuf.length () + 1,
4418 argbuf_copy,
4419 CL_DRIVER, &decoded_options,
4420 &decoded_options_count);
4421 free (argbuf_copy);
4423 set_option_handlers (&handlers);
4425 for (j = 1; j < decoded_options_count; j++)
4427 switch (decoded_options[j].opt_index)
4429 case OPT_SPECIAL_input_file:
4430 /* Specs should only generate options, not input
4431 files. */
4432 if (strcmp (decoded_options[j].arg, "-") != 0)
4433 fatal_error ("switch %qs does not start with %<-%>",
4434 decoded_options[j].arg);
4435 else
4436 fatal_error ("spec-generated switch is just %<-%>");
4437 break;
4439 case OPT_fcompare_debug_second:
4440 case OPT_fcompare_debug:
4441 case OPT_fcompare_debug_:
4442 case OPT_o:
4443 /* Avoid duplicate processing of some options from
4444 compare-debug specs; just save them here. */
4445 save_switch (decoded_options[j].canonical_option[0],
4446 (decoded_options[j].canonical_option_num_elements
4447 - 1),
4448 &decoded_options[j].canonical_option[1], false, true);
4449 break;
4451 default:
4452 read_cmdline_option (&global_options, &global_options_set,
4453 decoded_options + j, UNKNOWN_LOCATION,
4454 CL_DRIVER, &handlers, global_dc);
4455 break;
4459 alloc_switch ();
4460 switches[n_switches].part1 = 0;
4464 /* Callback for processing %D and %I specs. */
4466 struct spec_path_info {
4467 const char *option;
4468 const char *append;
4469 size_t append_len;
4470 bool omit_relative;
4471 bool separate_options;
4474 static void *
4475 spec_path (char *path, void *data)
4477 struct spec_path_info *info = (struct spec_path_info *) data;
4478 size_t len = 0;
4479 char save = 0;
4481 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4482 return NULL;
4484 if (info->append_len != 0)
4486 len = strlen (path);
4487 memcpy (path + len, info->append, info->append_len + 1);
4490 if (!is_directory (path, true))
4491 return NULL;
4493 do_spec_1 (info->option, 1, NULL);
4494 if (info->separate_options)
4495 do_spec_1 (" ", 0, NULL);
4497 if (info->append_len == 0)
4499 len = strlen (path);
4500 save = path[len - 1];
4501 if (IS_DIR_SEPARATOR (path[len - 1]))
4502 path[len - 1] = '\0';
4505 do_spec_1 (path, 1, NULL);
4506 do_spec_1 (" ", 0, NULL);
4508 /* Must not damage the original path. */
4509 if (info->append_len == 0)
4510 path[len - 1] = save;
4512 return NULL;
4515 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4516 argument list. */
4518 static void
4519 create_at_file (char **argv)
4521 char *temp_file = make_temp_file ("");
4522 char *at_argument = concat ("@", temp_file, NULL);
4523 FILE *f = fopen (temp_file, "w");
4524 int status;
4526 if (f == NULL)
4527 fatal_error ("could not open temporary response file %s",
4528 temp_file);
4530 status = writeargv (argv, f);
4532 if (status)
4533 fatal_error ("could not write to temporary response file %s",
4534 temp_file);
4536 status = fclose (f);
4538 if (EOF == status)
4539 fatal_error ("could not close temporary response file %s",
4540 temp_file);
4542 store_arg (at_argument, 0, 0);
4544 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4547 /* True if we should compile INFILE. */
4549 static bool
4550 compile_input_file_p (struct infile *infile)
4552 if ((!infile->language) || (infile->language[0] != '*'))
4553 if (infile->incompiler == input_file_compiler)
4554 return true;
4555 return false;
4558 /* Process each member of VEC as a spec. */
4560 static void
4561 do_specs_vec (vec<char_p> vec)
4563 unsigned ix;
4564 char *opt;
4566 FOR_EACH_VEC_ELT (vec, ix, opt)
4568 do_spec_1 (opt, 1, NULL);
4569 /* Make each accumulated option a separate argument. */
4570 do_spec_1 (" ", 0, NULL);
4574 /* Process the sub-spec SPEC as a portion of a larger spec.
4575 This is like processing a whole spec except that we do
4576 not initialize at the beginning and we do not supply a
4577 newline by default at the end.
4578 INSWITCH nonzero means don't process %-sequences in SPEC;
4579 in this case, % is treated as an ordinary character.
4580 This is used while substituting switches.
4581 INSWITCH nonzero also causes SPC not to terminate an argument.
4583 Value is zero unless a line was finished
4584 and the command on that line reported an error. */
4586 static int
4587 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4589 const char *p = spec;
4590 int c;
4591 int i;
4592 int value;
4594 /* If it's an empty string argument to a switch, keep it as is. */
4595 if (inswitch && !*p)
4596 arg_going = 1;
4598 while ((c = *p++))
4599 /* If substituting a switch, treat all chars like letters.
4600 Otherwise, NL, SPC, TAB and % are special. */
4601 switch (inswitch ? 'a' : c)
4603 case '\n':
4604 end_going_arg ();
4606 if (argbuf.length () > 0
4607 && !strcmp (argbuf.last (), "|"))
4609 /* A `|' before the newline means use a pipe here,
4610 but only if -pipe was specified.
4611 Otherwise, execute now and don't pass the `|' as an arg. */
4612 if (use_pipes)
4614 input_from_pipe = 1;
4615 break;
4617 else
4618 argbuf.pop ();
4621 set_collect_gcc_options ();
4623 if (argbuf.length () > 0)
4625 value = execute ();
4626 if (value)
4627 return value;
4629 /* Reinitialize for a new command, and for a new argument. */
4630 clear_args ();
4631 arg_going = 0;
4632 delete_this_arg = 0;
4633 this_is_output_file = 0;
4634 this_is_library_file = 0;
4635 this_is_linker_script = 0;
4636 input_from_pipe = 0;
4637 break;
4639 case '|':
4640 end_going_arg ();
4642 /* Use pipe */
4643 obstack_1grow (&obstack, c);
4644 arg_going = 1;
4645 break;
4647 case '\t':
4648 case ' ':
4649 end_going_arg ();
4651 /* Reinitialize for a new argument. */
4652 delete_this_arg = 0;
4653 this_is_output_file = 0;
4654 this_is_library_file = 0;
4655 this_is_linker_script = 0;
4656 break;
4658 case '%':
4659 switch (c = *p++)
4661 case 0:
4662 fatal_error ("spec %qs invalid", spec);
4664 case 'b':
4665 if (save_temps_length)
4666 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4667 else
4668 obstack_grow (&obstack, input_basename, basename_length);
4669 if (compare_debug < 0)
4670 obstack_grow (&obstack, ".gk", 3);
4671 arg_going = 1;
4672 break;
4674 case 'B':
4675 if (save_temps_length)
4676 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4677 else
4678 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4679 if (compare_debug < 0)
4680 obstack_grow (&obstack, ".gk", 3);
4681 arg_going = 1;
4682 break;
4684 case 'd':
4685 delete_this_arg = 2;
4686 break;
4688 /* Dump out the directories specified with LIBRARY_PATH,
4689 followed by the absolute directories
4690 that we search for startfiles. */
4691 case 'D':
4693 struct spec_path_info info;
4695 info.option = "-L";
4696 info.append_len = 0;
4697 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4698 /* Used on systems which record the specified -L dirs
4699 and use them to search for dynamic linking.
4700 Relative directories always come from -B,
4701 and it is better not to use them for searching
4702 at run time. In particular, stage1 loses. */
4703 info.omit_relative = true;
4704 #else
4705 info.omit_relative = false;
4706 #endif
4707 info.separate_options = false;
4709 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4711 break;
4713 case 'e':
4714 /* %efoo means report an error with `foo' as error message
4715 and don't execute any more commands for this file. */
4717 const char *q = p;
4718 char *buf;
4719 while (*p != 0 && *p != '\n')
4720 p++;
4721 buf = (char *) alloca (p - q + 1);
4722 strncpy (buf, q, p - q);
4723 buf[p - q] = 0;
4724 error ("%s", _(buf));
4725 return -1;
4727 break;
4728 case 'n':
4729 /* %nfoo means report a notice with `foo' on stderr. */
4731 const char *q = p;
4732 char *buf;
4733 while (*p != 0 && *p != '\n')
4734 p++;
4735 buf = (char *) alloca (p - q + 1);
4736 strncpy (buf, q, p - q);
4737 buf[p - q] = 0;
4738 inform (0, "%s", _(buf));
4739 if (*p)
4740 p++;
4742 break;
4744 case 'j':
4746 struct stat st;
4748 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4749 defined, and it is not a directory, and it is
4750 writable, use it. Otherwise, treat this like any
4751 other temporary file. */
4753 if ((!save_temps_flag)
4754 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4755 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4757 obstack_grow (&obstack, HOST_BIT_BUCKET,
4758 strlen (HOST_BIT_BUCKET));
4759 delete_this_arg = 0;
4760 arg_going = 1;
4761 break;
4764 goto create_temp_file;
4765 case '|':
4766 if (use_pipes)
4768 obstack_1grow (&obstack, '-');
4769 delete_this_arg = 0;
4770 arg_going = 1;
4772 /* consume suffix */
4773 while (*p == '.' || ISALNUM ((unsigned char) *p))
4774 p++;
4775 if (p[0] == '%' && p[1] == 'O')
4776 p += 2;
4778 break;
4780 goto create_temp_file;
4781 case 'm':
4782 if (use_pipes)
4784 /* consume suffix */
4785 while (*p == '.' || ISALNUM ((unsigned char) *p))
4786 p++;
4787 if (p[0] == '%' && p[1] == 'O')
4788 p += 2;
4790 break;
4792 goto create_temp_file;
4793 case 'g':
4794 case 'u':
4795 case 'U':
4796 create_temp_file:
4798 struct temp_name *t;
4799 int suffix_length;
4800 const char *suffix = p;
4801 char *saved_suffix = NULL;
4803 while (*p == '.' || ISALNUM ((unsigned char) *p))
4804 p++;
4805 suffix_length = p - suffix;
4806 if (p[0] == '%' && p[1] == 'O')
4808 p += 2;
4809 /* We don't support extra suffix characters after %O. */
4810 if (*p == '.' || ISALNUM ((unsigned char) *p))
4811 fatal_error ("spec %qs has invalid %<%%0%c%>", spec, *p);
4812 if (suffix_length == 0)
4813 suffix = TARGET_OBJECT_SUFFIX;
4814 else
4816 saved_suffix
4817 = XNEWVEC (char, suffix_length
4818 + strlen (TARGET_OBJECT_SUFFIX));
4819 strncpy (saved_suffix, suffix, suffix_length);
4820 strcpy (saved_suffix + suffix_length,
4821 TARGET_OBJECT_SUFFIX);
4823 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4826 if (compare_debug < 0)
4828 suffix = concat (".gk", suffix, NULL);
4829 suffix_length += 3;
4832 /* If -save-temps=obj and -o were specified, use that for the
4833 temp file. */
4834 if (save_temps_length)
4836 char *tmp;
4837 temp_filename_length
4838 = save_temps_length + suffix_length + 1;
4839 tmp = (char *) alloca (temp_filename_length);
4840 memcpy (tmp, save_temps_prefix, save_temps_length);
4841 memcpy (tmp + save_temps_length, suffix, suffix_length);
4842 tmp[save_temps_length + suffix_length] = '\0';
4843 temp_filename = save_string (tmp, save_temps_length
4844 + suffix_length);
4845 obstack_grow (&obstack, temp_filename,
4846 temp_filename_length);
4847 arg_going = 1;
4848 delete_this_arg = 0;
4849 break;
4852 /* If the gcc_input_filename has the same suffix specified
4853 for the %g, %u, or %U, and -save-temps is specified,
4854 we could end up using that file as an intermediate
4855 thus clobbering the user's source file (.e.g.,
4856 gcc -save-temps foo.s would clobber foo.s with the
4857 output of cpp0). So check for this condition and
4858 generate a temp file as the intermediate. */
4860 if (save_temps_flag)
4862 char *tmp;
4863 temp_filename_length = basename_length + suffix_length + 1;
4864 tmp = (char *) alloca (temp_filename_length);
4865 memcpy (tmp, input_basename, basename_length);
4866 memcpy (tmp + basename_length, suffix, suffix_length);
4867 tmp[basename_length + suffix_length] = '\0';
4868 temp_filename = tmp;
4870 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
4872 #ifndef HOST_LACKS_INODE_NUMBERS
4873 struct stat st_temp;
4875 /* Note, set_input() resets input_stat_set to 0. */
4876 if (input_stat_set == 0)
4878 input_stat_set = stat (gcc_input_filename,
4879 &input_stat);
4880 if (input_stat_set >= 0)
4881 input_stat_set = 1;
4884 /* If we have the stat for the gcc_input_filename
4885 and we can do the stat for the temp_filename
4886 then the they could still refer to the same
4887 file if st_dev/st_ino's are the same. */
4888 if (input_stat_set != 1
4889 || stat (temp_filename, &st_temp) < 0
4890 || input_stat.st_dev != st_temp.st_dev
4891 || input_stat.st_ino != st_temp.st_ino)
4892 #else
4893 /* Just compare canonical pathnames. */
4894 char* input_realname = lrealpath (gcc_input_filename);
4895 char* temp_realname = lrealpath (temp_filename);
4896 bool files_differ = filename_cmp (input_realname, temp_realname);
4897 free (input_realname);
4898 free (temp_realname);
4899 if (files_differ)
4900 #endif
4902 temp_filename = save_string (temp_filename,
4903 temp_filename_length + 1);
4904 obstack_grow (&obstack, temp_filename,
4905 temp_filename_length);
4906 arg_going = 1;
4907 delete_this_arg = 0;
4908 break;
4913 /* See if we already have an association of %g/%u/%U and
4914 suffix. */
4915 for (t = temp_names; t; t = t->next)
4916 if (t->length == suffix_length
4917 && strncmp (t->suffix, suffix, suffix_length) == 0
4918 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4919 break;
4921 /* Make a new association if needed. %u and %j
4922 require one. */
4923 if (t == 0 || c == 'u' || c == 'j')
4925 if (t == 0)
4927 t = XNEW (struct temp_name);
4928 t->next = temp_names;
4929 temp_names = t;
4931 t->length = suffix_length;
4932 if (saved_suffix)
4934 t->suffix = saved_suffix;
4935 saved_suffix = NULL;
4937 else
4938 t->suffix = save_string (suffix, suffix_length);
4939 t->unique = (c == 'u' || c == 'U' || c == 'j');
4940 temp_filename = make_temp_file (t->suffix);
4941 temp_filename_length = strlen (temp_filename);
4942 t->filename = temp_filename;
4943 t->filename_length = temp_filename_length;
4946 free (saved_suffix);
4948 obstack_grow (&obstack, t->filename, t->filename_length);
4949 delete_this_arg = 1;
4951 arg_going = 1;
4952 break;
4954 case 'i':
4955 if (combine_inputs)
4957 if (at_file_supplied)
4959 /* We are going to expand `%i' to `@FILE', where FILE
4960 is a newly-created temporary filename. The filenames
4961 that would usually be expanded in place of %o will be
4962 written to the temporary file. */
4963 char **argv;
4964 int n_files = 0;
4965 int j;
4967 for (i = 0; i < n_infiles; i++)
4968 if (compile_input_file_p (&infiles[i]))
4969 n_files++;
4971 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
4973 /* Copy the strings over. */
4974 for (i = 0, j = 0; i < n_infiles; i++)
4975 if (compile_input_file_p (&infiles[i]))
4977 argv[j] = CONST_CAST (char *, infiles[i].name);
4978 infiles[i].compiled = true;
4979 j++;
4981 argv[j] = NULL;
4983 create_at_file (argv);
4985 else
4986 for (i = 0; (int) i < n_infiles; i++)
4987 if (compile_input_file_p (&infiles[i]))
4989 store_arg (infiles[i].name, 0, 0);
4990 infiles[i].compiled = true;
4993 else
4995 obstack_grow (&obstack, gcc_input_filename,
4996 input_filename_length);
4997 arg_going = 1;
4999 break;
5001 case 'I':
5003 struct spec_path_info info;
5005 if (multilib_dir)
5007 do_spec_1 ("-imultilib", 1, NULL);
5008 /* Make this a separate argument. */
5009 do_spec_1 (" ", 0, NULL);
5010 do_spec_1 (multilib_dir, 1, NULL);
5011 do_spec_1 (" ", 0, NULL);
5014 if (multiarch_dir)
5016 do_spec_1 ("-imultiarch", 1, NULL);
5017 /* Make this a separate argument. */
5018 do_spec_1 (" ", 0, NULL);
5019 do_spec_1 (multiarch_dir, 1, NULL);
5020 do_spec_1 (" ", 0, NULL);
5023 if (gcc_exec_prefix)
5025 do_spec_1 ("-iprefix", 1, NULL);
5026 /* Make this a separate argument. */
5027 do_spec_1 (" ", 0, NULL);
5028 do_spec_1 (gcc_exec_prefix, 1, NULL);
5029 do_spec_1 (" ", 0, NULL);
5032 if (target_system_root_changed ||
5033 (target_system_root && target_sysroot_hdrs_suffix))
5035 do_spec_1 ("-isysroot", 1, NULL);
5036 /* Make this a separate argument. */
5037 do_spec_1 (" ", 0, NULL);
5038 do_spec_1 (target_system_root, 1, NULL);
5039 if (target_sysroot_hdrs_suffix)
5040 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5041 do_spec_1 (" ", 0, NULL);
5044 info.option = "-isystem";
5045 info.append = "include";
5046 info.append_len = strlen (info.append);
5047 info.omit_relative = false;
5048 info.separate_options = true;
5050 for_each_path (&include_prefixes, false, info.append_len,
5051 spec_path, &info);
5053 info.append = "include-fixed";
5054 if (*sysroot_hdrs_suffix_spec)
5055 info.append = concat (info.append, dir_separator_str,
5056 multilib_dir, NULL);
5057 info.append_len = strlen (info.append);
5058 for_each_path (&include_prefixes, false, info.append_len,
5059 spec_path, &info);
5061 break;
5063 case 'o':
5065 int max = n_infiles;
5066 max += lang_specific_extra_outfiles;
5068 if (HAVE_GNU_LD && at_file_supplied)
5070 /* We are going to expand `%o' to `@FILE', where FILE
5071 is a newly-created temporary filename. The filenames
5072 that would usually be expanded in place of %o will be
5073 written to the temporary file. */
5075 char **argv;
5076 int n_files, j;
5078 /* Convert OUTFILES into a form suitable for writeargv. */
5080 /* Determine how many are non-NULL. */
5081 for (n_files = 0, i = 0; i < max; i++)
5082 n_files += outfiles[i] != NULL;
5084 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5086 /* Copy the strings over. */
5087 for (i = 0, j = 0; i < max; i++)
5088 if (outfiles[i])
5090 argv[j] = CONST_CAST (char *, outfiles[i]);
5091 j++;
5093 argv[j] = NULL;
5095 create_at_file (argv);
5097 else
5098 for (i = 0; i < max; i++)
5099 if (outfiles[i])
5100 store_arg (outfiles[i], 0, 0);
5101 break;
5104 case 'O':
5105 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5106 arg_going = 1;
5107 break;
5109 case 's':
5110 this_is_library_file = 1;
5111 break;
5113 case 'T':
5114 this_is_linker_script = 1;
5115 break;
5117 case 'V':
5118 outfiles[input_file_number] = NULL;
5119 break;
5121 case 'w':
5122 this_is_output_file = 1;
5123 break;
5125 case 'W':
5127 unsigned int cur_index = argbuf.length ();
5128 /* Handle the {...} following the %W. */
5129 if (*p != '{')
5130 fatal_error ("spec %qs has invalid %<%%W%c%>", spec, *p);
5131 p = handle_braces (p + 1);
5132 if (p == 0)
5133 return -1;
5134 end_going_arg ();
5135 /* If any args were output, mark the last one for deletion
5136 on failure. */
5137 if (argbuf.length () != cur_index)
5138 record_temp_file (argbuf.last (), 0, 1);
5139 break;
5142 /* %x{OPTION} records OPTION for %X to output. */
5143 case 'x':
5145 const char *p1 = p;
5146 char *string;
5147 char *opt;
5148 unsigned ix;
5150 /* Skip past the option value and make a copy. */
5151 if (*p != '{')
5152 fatal_error ("spec %qs has invalid %<%%x%c%>", spec, *p);
5153 while (*p++ != '}')
5155 string = save_string (p1 + 1, p - p1 - 2);
5157 /* See if we already recorded this option. */
5158 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5159 if (! strcmp (string, opt))
5161 free (string);
5162 return 0;
5165 /* This option is new; add it. */
5166 add_linker_option (string, strlen (string));
5167 free (string);
5169 break;
5171 /* Dump out the options accumulated previously using %x. */
5172 case 'X':
5173 do_specs_vec (linker_options);
5174 break;
5176 /* Dump out the options accumulated previously using -Wa,. */
5177 case 'Y':
5178 do_specs_vec (assembler_options);
5179 break;
5181 /* Dump out the options accumulated previously using -Wp,. */
5182 case 'Z':
5183 do_specs_vec (preprocessor_options);
5184 break;
5186 /* Here are digits and numbers that just process
5187 a certain constant string as a spec. */
5189 case '1':
5190 value = do_spec_1 (cc1_spec, 0, NULL);
5191 if (value != 0)
5192 return value;
5193 break;
5195 case '2':
5196 value = do_spec_1 (cc1plus_spec, 0, NULL);
5197 if (value != 0)
5198 return value;
5199 break;
5201 case 'a':
5202 value = do_spec_1 (asm_spec, 0, NULL);
5203 if (value != 0)
5204 return value;
5205 break;
5207 case 'A':
5208 value = do_spec_1 (asm_final_spec, 0, NULL);
5209 if (value != 0)
5210 return value;
5211 break;
5213 case 'C':
5215 const char *const spec
5216 = (input_file_compiler->cpp_spec
5217 ? input_file_compiler->cpp_spec
5218 : cpp_spec);
5219 value = do_spec_1 (spec, 0, NULL);
5220 if (value != 0)
5221 return value;
5223 break;
5225 case 'E':
5226 value = do_spec_1 (endfile_spec, 0, NULL);
5227 if (value != 0)
5228 return value;
5229 break;
5231 case 'l':
5232 value = do_spec_1 (link_spec, 0, NULL);
5233 if (value != 0)
5234 return value;
5235 break;
5237 case 'L':
5238 value = do_spec_1 (lib_spec, 0, NULL);
5239 if (value != 0)
5240 return value;
5241 break;
5243 case 'M':
5244 if (multilib_os_dir == NULL)
5245 obstack_1grow (&obstack, '.');
5246 else
5247 obstack_grow (&obstack, multilib_os_dir,
5248 strlen (multilib_os_dir));
5249 break;
5251 case 'G':
5252 value = do_spec_1 (libgcc_spec, 0, NULL);
5253 if (value != 0)
5254 return value;
5255 break;
5257 case 'R':
5258 /* We assume there is a directory
5259 separator at the end of this string. */
5260 if (target_system_root)
5262 obstack_grow (&obstack, target_system_root,
5263 strlen (target_system_root));
5264 if (target_sysroot_suffix)
5265 obstack_grow (&obstack, target_sysroot_suffix,
5266 strlen (target_sysroot_suffix));
5268 break;
5270 case 'S':
5271 value = do_spec_1 (startfile_spec, 0, NULL);
5272 if (value != 0)
5273 return value;
5274 break;
5276 /* Here we define characters other than letters and digits. */
5278 case '{':
5279 p = handle_braces (p);
5280 if (p == 0)
5281 return -1;
5282 break;
5284 case ':':
5285 p = handle_spec_function (p);
5286 if (p == 0)
5287 return -1;
5288 break;
5290 case '%':
5291 obstack_1grow (&obstack, '%');
5292 break;
5294 case '.':
5296 unsigned len = 0;
5298 while (p[len] && p[len] != ' ' && p[len] != '%')
5299 len++;
5300 suffix_subst = save_string (p - 1, len + 1);
5301 p += len;
5303 break;
5305 /* Henceforth ignore the option(s) matching the pattern
5306 after the %<. */
5307 case '<':
5308 case '>':
5310 unsigned len = 0;
5311 int have_wildcard = 0;
5312 int i;
5313 int switch_option;
5315 if (c == '>')
5316 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5317 else
5318 switch_option = SWITCH_IGNORE;
5320 while (p[len] && p[len] != ' ' && p[len] != '\t')
5321 len++;
5323 if (p[len-1] == '*')
5324 have_wildcard = 1;
5326 for (i = 0; i < n_switches; i++)
5327 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5328 && (have_wildcard || switches[i].part1[len] == '\0'))
5330 switches[i].live_cond |= switch_option;
5331 /* User switch be validated from validate_all_switches.
5332 when the definition is seen from the spec file.
5333 If not defined anywhere, will be rejected. */
5334 if (switches[i].known)
5335 switches[i].validated = true;
5338 p += len;
5340 break;
5342 case '*':
5343 if (soft_matched_part)
5345 if (soft_matched_part[0])
5346 do_spec_1 (soft_matched_part, 1, NULL);
5347 do_spec_1 (" ", 0, NULL);
5349 else
5350 /* Catch the case where a spec string contains something like
5351 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5352 hand side of the :. */
5353 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5354 break;
5356 /* Process a string found as the value of a spec given by name.
5357 This feature allows individual machine descriptions
5358 to add and use their own specs. */
5359 case '(':
5361 const char *name = p;
5362 struct spec_list *sl;
5363 int len;
5365 /* The string after the S/P is the name of a spec that is to be
5366 processed. */
5367 while (*p && *p != ')')
5368 p++;
5370 /* See if it's in the list. */
5371 for (len = p - name, sl = specs; sl; sl = sl->next)
5372 if (sl->name_len == len && !strncmp (sl->name, name, len))
5374 name = *(sl->ptr_spec);
5375 #ifdef DEBUG_SPECS
5376 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5377 sl->name, name);
5378 #endif
5379 break;
5382 if (sl)
5384 value = do_spec_1 (name, 0, NULL);
5385 if (value != 0)
5386 return value;
5389 /* Discard the closing paren. */
5390 if (*p)
5391 p++;
5393 break;
5395 default:
5396 error ("spec failure: unrecognized spec option %qc", c);
5397 break;
5399 break;
5401 case '\\':
5402 /* Backslash: treat next character as ordinary. */
5403 c = *p++;
5405 /* Fall through. */
5406 default:
5407 /* Ordinary character: put it into the current argument. */
5408 obstack_1grow (&obstack, c);
5409 arg_going = 1;
5412 /* End of string. If we are processing a spec function, we need to
5413 end any pending argument. */
5414 if (processing_spec_function)
5415 end_going_arg ();
5417 return 0;
5420 /* Look up a spec function. */
5422 static const struct spec_function *
5423 lookup_spec_function (const char *name)
5425 const struct spec_function *sf;
5427 for (sf = static_spec_functions; sf->name != NULL; sf++)
5428 if (strcmp (sf->name, name) == 0)
5429 return sf;
5431 return NULL;
5434 /* Evaluate a spec function. */
5436 static const char *
5437 eval_spec_function (const char *func, const char *args)
5439 const struct spec_function *sf;
5440 const char *funcval;
5442 /* Saved spec processing context. */
5443 vec<const_char_p> save_argbuf;
5445 int save_arg_going;
5446 int save_delete_this_arg;
5447 int save_this_is_output_file;
5448 int save_this_is_library_file;
5449 int save_input_from_pipe;
5450 int save_this_is_linker_script;
5451 const char *save_suffix_subst;
5453 int save_growing_size;
5454 void *save_growing_value = NULL;
5456 sf = lookup_spec_function (func);
5457 if (sf == NULL)
5458 fatal_error ("unknown spec function %qs", func);
5460 /* Push the spec processing context. */
5461 save_argbuf = argbuf;
5463 save_arg_going = arg_going;
5464 save_delete_this_arg = delete_this_arg;
5465 save_this_is_output_file = this_is_output_file;
5466 save_this_is_library_file = this_is_library_file;
5467 save_this_is_linker_script = this_is_linker_script;
5468 save_input_from_pipe = input_from_pipe;
5469 save_suffix_subst = suffix_subst;
5471 /* If we have some object growing now, finalize it so the args and function
5472 eval proceed from a cleared context. This is needed to prevent the first
5473 constructed arg from mistakenly including the growing value. We'll push
5474 this value back on the obstack once the function evaluation is done, to
5475 restore a consistent processing context for our caller. This is fine as
5476 the address of growing objects isn't guaranteed to remain stable until
5477 they are finalized, and we expect this situation to be rare enough for
5478 the extra copy not to be an issue. */
5479 save_growing_size = obstack_object_size (&obstack);
5480 if (save_growing_size > 0)
5481 save_growing_value = obstack_finish (&obstack);
5483 /* Create a new spec processing context, and build the function
5484 arguments. */
5486 alloc_args ();
5487 if (do_spec_2 (args) < 0)
5488 fatal_error ("error in args to spec function %qs", func);
5490 /* argbuf_index is an index for the next argument to be inserted, and
5491 so contains the count of the args already inserted. */
5493 funcval = (*sf->func) (argbuf.length (),
5494 argbuf.address ());
5496 /* Pop the spec processing context. */
5497 argbuf.release ();
5498 argbuf = save_argbuf;
5500 arg_going = save_arg_going;
5501 delete_this_arg = save_delete_this_arg;
5502 this_is_output_file = save_this_is_output_file;
5503 this_is_library_file = save_this_is_library_file;
5504 this_is_linker_script = save_this_is_linker_script;
5505 input_from_pipe = save_input_from_pipe;
5506 suffix_subst = save_suffix_subst;
5508 if (save_growing_size > 0)
5509 obstack_grow (&obstack, save_growing_value, save_growing_size);
5511 return funcval;
5514 /* Handle a spec function call of the form:
5516 %:function(args)
5518 ARGS is processed as a spec in a separate context and split into an
5519 argument vector in the normal fashion. The function returns a string
5520 containing a spec which we then process in the caller's context, or
5521 NULL if no processing is required. */
5523 static const char *
5524 handle_spec_function (const char *p)
5526 char *func, *args;
5527 const char *endp, *funcval;
5528 int count;
5530 processing_spec_function++;
5532 /* Get the function name. */
5533 for (endp = p; *endp != '\0'; endp++)
5535 if (*endp == '(') /* ) */
5536 break;
5537 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5538 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5539 fatal_error ("malformed spec function name");
5541 if (*endp != '(') /* ) */
5542 fatal_error ("no arguments for spec function");
5543 func = save_string (p, endp - p);
5544 p = ++endp;
5546 /* Get the arguments. */
5547 for (count = 0; *endp != '\0'; endp++)
5549 /* ( */
5550 if (*endp == ')')
5552 if (count == 0)
5553 break;
5554 count--;
5556 else if (*endp == '(') /* ) */
5557 count++;
5559 /* ( */
5560 if (*endp != ')')
5561 fatal_error ("malformed spec function arguments");
5562 args = save_string (p, endp - p);
5563 p = ++endp;
5565 /* p now points to just past the end of the spec function expression. */
5567 funcval = eval_spec_function (func, args);
5568 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5569 p = NULL;
5571 free (func);
5572 free (args);
5574 processing_spec_function--;
5576 return p;
5579 /* Inline subroutine of handle_braces. Returns true if the current
5580 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5581 static inline bool
5582 input_suffix_matches (const char *atom, const char *end_atom)
5584 return (input_suffix
5585 && !strncmp (input_suffix, atom, end_atom - atom)
5586 && input_suffix[end_atom - atom] == '\0');
5589 /* Subroutine of handle_braces. Returns true if the current
5590 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
5591 static bool
5592 input_spec_matches (const char *atom, const char *end_atom)
5594 return (input_file_compiler
5595 && input_file_compiler->suffix
5596 && input_file_compiler->suffix[0] != '\0'
5597 && !strncmp (input_file_compiler->suffix + 1, atom,
5598 end_atom - atom)
5599 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5602 /* Subroutine of handle_braces. Returns true if a switch
5603 matching the atom bracketed by ATOM and END_ATOM appeared on the
5604 command line. */
5605 static bool
5606 switch_matches (const char *atom, const char *end_atom, int starred)
5608 int i;
5609 int len = end_atom - atom;
5610 int plen = starred ? len : -1;
5612 for (i = 0; i < n_switches; i++)
5613 if (!strncmp (switches[i].part1, atom, len)
5614 && (starred || switches[i].part1[len] == '\0')
5615 && check_live_switch (i, plen))
5616 return true;
5618 /* Check if a switch with separated form matching the atom.
5619 We check -D and -U switches. */
5620 else if (switches[i].args != 0)
5622 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
5623 && *switches[i].part1 == atom[0])
5625 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
5626 && (starred || (switches[i].part1[1] == '\0'
5627 && switches[i].args[0][len - 1] == '\0'))
5628 && check_live_switch (i, (starred ? 1 : -1)))
5629 return true;
5633 return false;
5636 /* Inline subroutine of handle_braces. Mark all of the switches which
5637 match ATOM (extends to END_ATOM; STARRED indicates whether there
5638 was a star after the atom) for later processing. */
5639 static inline void
5640 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5642 int i;
5643 int len = end_atom - atom;
5644 int plen = starred ? len : -1;
5646 for (i = 0; i < n_switches; i++)
5647 if (!strncmp (switches[i].part1, atom, len)
5648 && (starred || switches[i].part1[len] == '\0')
5649 && check_live_switch (i, plen))
5650 switches[i].ordering = 1;
5653 /* Inline subroutine of handle_braces. Process all the currently
5654 marked switches through give_switch, and clear the marks. */
5655 static inline void
5656 process_marked_switches (void)
5658 int i;
5660 for (i = 0; i < n_switches; i++)
5661 if (switches[i].ordering == 1)
5663 switches[i].ordering = 0;
5664 give_switch (i, 0);
5668 /* Handle a %{ ... } construct. P points just inside the leading {.
5669 Returns a pointer one past the end of the brace block, or 0
5670 if we call do_spec_1 and that returns -1. */
5672 static const char *
5673 handle_braces (const char *p)
5675 const char *atom, *end_atom;
5676 const char *d_atom = NULL, *d_end_atom = NULL;
5677 const char *orig = p;
5679 bool a_is_suffix;
5680 bool a_is_spectype;
5681 bool a_is_starred;
5682 bool a_is_negated;
5683 bool a_matched;
5685 bool a_must_be_last = false;
5686 bool ordered_set = false;
5687 bool disjunct_set = false;
5688 bool disj_matched = false;
5689 bool disj_starred = true;
5690 bool n_way_choice = false;
5691 bool n_way_matched = false;
5693 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5697 if (a_must_be_last)
5698 goto invalid;
5700 /* Scan one "atom" (S in the description above of %{}, possibly
5701 with '!', '.', '@', ',', or '*' modifiers). */
5702 a_matched = false;
5703 a_is_suffix = false;
5704 a_is_starred = false;
5705 a_is_negated = false;
5706 a_is_spectype = false;
5708 SKIP_WHITE();
5709 if (*p == '!')
5710 p++, a_is_negated = true;
5712 SKIP_WHITE();
5713 if (*p == '.')
5714 p++, a_is_suffix = true;
5715 else if (*p == ',')
5716 p++, a_is_spectype = true;
5718 atom = p;
5719 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5720 || *p == ',' || *p == '.' || *p == '@')
5721 p++;
5722 end_atom = p;
5724 if (*p == '*')
5725 p++, a_is_starred = 1;
5727 SKIP_WHITE();
5728 switch (*p)
5730 case '&': case '}':
5731 /* Substitute the switch(es) indicated by the current atom. */
5732 ordered_set = true;
5733 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5734 || a_is_spectype || atom == end_atom)
5735 goto invalid;
5737 mark_matching_switches (atom, end_atom, a_is_starred);
5739 if (*p == '}')
5740 process_marked_switches ();
5741 break;
5743 case '|': case ':':
5744 /* Substitute some text if the current atom appears as a switch
5745 or suffix. */
5746 disjunct_set = true;
5747 if (ordered_set)
5748 goto invalid;
5750 if (atom == end_atom)
5752 if (!n_way_choice || disj_matched || *p == '|'
5753 || a_is_negated || a_is_suffix || a_is_spectype
5754 || a_is_starred)
5755 goto invalid;
5757 /* An empty term may appear as the last choice of an
5758 N-way choice set; it means "otherwise". */
5759 a_must_be_last = true;
5760 disj_matched = !n_way_matched;
5761 disj_starred = false;
5763 else
5765 if ((a_is_suffix || a_is_spectype) && a_is_starred)
5766 goto invalid;
5768 if (!a_is_starred)
5769 disj_starred = false;
5771 /* Don't bother testing this atom if we already have a
5772 match. */
5773 if (!disj_matched && !n_way_matched)
5775 if (a_is_suffix)
5776 a_matched = input_suffix_matches (atom, end_atom);
5777 else if (a_is_spectype)
5778 a_matched = input_spec_matches (atom, end_atom);
5779 else
5780 a_matched = switch_matches (atom, end_atom, a_is_starred);
5782 if (a_matched != a_is_negated)
5784 disj_matched = true;
5785 d_atom = atom;
5786 d_end_atom = end_atom;
5791 if (*p == ':')
5793 /* Found the body, that is, the text to substitute if the
5794 current disjunction matches. */
5795 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5796 disj_matched && !n_way_matched);
5797 if (p == 0)
5798 return 0;
5800 /* If we have an N-way choice, reset state for the next
5801 disjunction. */
5802 if (*p == ';')
5804 n_way_choice = true;
5805 n_way_matched |= disj_matched;
5806 disj_matched = false;
5807 disj_starred = true;
5808 d_atom = d_end_atom = NULL;
5811 break;
5813 default:
5814 goto invalid;
5817 while (*p++ != '}');
5819 return p;
5821 invalid:
5822 fatal_error ("braced spec %qs is invalid at %qc", orig, *p);
5824 #undef SKIP_WHITE
5827 /* Subroutine of handle_braces. Scan and process a brace substitution body
5828 (X in the description of %{} syntax). P points one past the colon;
5829 ATOM and END_ATOM bracket the first atom which was found to be true
5830 (present) in the current disjunction; STARRED indicates whether all
5831 the atoms in the current disjunction were starred (for syntax validation);
5832 MATCHED indicates whether the disjunction matched or not, and therefore
5833 whether or not the body is to be processed through do_spec_1 or just
5834 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5835 returns -1. */
5837 static const char *
5838 process_brace_body (const char *p, const char *atom, const char *end_atom,
5839 int starred, int matched)
5841 const char *body, *end_body;
5842 unsigned int nesting_level;
5843 bool have_subst = false;
5845 /* Locate the closing } or ;, honoring nested braces.
5846 Trim trailing whitespace. */
5847 body = p;
5848 nesting_level = 1;
5849 for (;;)
5851 if (*p == '{')
5852 nesting_level++;
5853 else if (*p == '}')
5855 if (!--nesting_level)
5856 break;
5858 else if (*p == ';' && nesting_level == 1)
5859 break;
5860 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5861 have_subst = true;
5862 else if (*p == '\0')
5863 goto invalid;
5864 p++;
5867 end_body = p;
5868 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5869 end_body--;
5871 if (have_subst && !starred)
5872 goto invalid;
5874 if (matched)
5876 /* Copy the substitution body to permanent storage and execute it.
5877 If have_subst is false, this is a simple matter of running the
5878 body through do_spec_1... */
5879 char *string = save_string (body, end_body - body);
5880 if (!have_subst)
5882 if (do_spec_1 (string, 0, NULL) < 0)
5883 return 0;
5885 else
5887 /* ... but if have_subst is true, we have to process the
5888 body once for each matching switch, with %* set to the
5889 variant part of the switch. */
5890 unsigned int hard_match_len = end_atom - atom;
5891 int i;
5893 for (i = 0; i < n_switches; i++)
5894 if (!strncmp (switches[i].part1, atom, hard_match_len)
5895 && check_live_switch (i, hard_match_len))
5897 if (do_spec_1 (string, 0,
5898 &switches[i].part1[hard_match_len]) < 0)
5899 return 0;
5900 /* Pass any arguments this switch has. */
5901 give_switch (i, 1);
5902 suffix_subst = NULL;
5907 return p;
5909 invalid:
5910 fatal_error ("braced spec body %qs is invalid", body);
5913 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5914 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5915 spec, or -1 if either exact match or %* is used.
5917 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
5918 whose value does not begin with "no-" is obsoleted by the same value
5919 with the "no-", similarly for a switch with the "no-" prefix. */
5921 static int
5922 check_live_switch (int switchnum, int prefix_length)
5924 const char *name = switches[switchnum].part1;
5925 int i;
5927 /* If we already processed this switch and determined if it was
5928 live or not, return our past determination. */
5929 if (switches[switchnum].live_cond != 0)
5930 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
5931 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
5932 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
5933 == 0);
5935 /* In the common case of {<at-most-one-letter>*}, a negating
5936 switch would always match, so ignore that case. We will just
5937 send the conflicting switches to the compiler phase. */
5938 if (prefix_length >= 0 && prefix_length <= 1)
5939 return 1;
5941 /* Now search for duplicate in a manner that depends on the name. */
5942 switch (*name)
5944 case 'O':
5945 for (i = switchnum + 1; i < n_switches; i++)
5946 if (switches[i].part1[0] == 'O')
5948 switches[switchnum].validated = true;
5949 switches[switchnum].live_cond = SWITCH_FALSE;
5950 return 0;
5952 break;
5954 case 'W': case 'f': case 'm': case 'g':
5955 if (! strncmp (name + 1, "no-", 3))
5957 /* We have Xno-YYY, search for XYYY. */
5958 for (i = switchnum + 1; i < n_switches; i++)
5959 if (switches[i].part1[0] == name[0]
5960 && ! strcmp (&switches[i].part1[1], &name[4]))
5962 /* --specs are validated with the validate_switches mechanism. */
5963 if (switches[switchnum].known)
5964 switches[switchnum].validated = true;
5965 switches[switchnum].live_cond = SWITCH_FALSE;
5966 return 0;
5969 else
5971 /* We have XYYY, search for Xno-YYY. */
5972 for (i = switchnum + 1; i < n_switches; i++)
5973 if (switches[i].part1[0] == name[0]
5974 && switches[i].part1[1] == 'n'
5975 && switches[i].part1[2] == 'o'
5976 && switches[i].part1[3] == '-'
5977 && !strcmp (&switches[i].part1[4], &name[1]))
5979 /* --specs are validated with the validate_switches mechanism. */
5980 if (switches[switchnum].known)
5981 switches[switchnum].validated = true;
5982 switches[switchnum].live_cond = SWITCH_FALSE;
5983 return 0;
5986 break;
5989 /* Otherwise the switch is live. */
5990 switches[switchnum].live_cond |= SWITCH_LIVE;
5991 return 1;
5994 /* Pass a switch to the current accumulating command
5995 in the same form that we received it.
5996 SWITCHNUM identifies the switch; it is an index into
5997 the vector of switches gcc received, which is `switches'.
5998 This cannot fail since it never finishes a command line.
6000 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
6002 static void
6003 give_switch (int switchnum, int omit_first_word)
6005 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
6006 return;
6008 if (!omit_first_word)
6010 do_spec_1 ("-", 0, NULL);
6011 do_spec_1 (switches[switchnum].part1, 1, NULL);
6014 if (switches[switchnum].args != 0)
6016 const char **p;
6017 for (p = switches[switchnum].args; *p; p++)
6019 const char *arg = *p;
6021 do_spec_1 (" ", 0, NULL);
6022 if (suffix_subst)
6024 unsigned length = strlen (arg);
6025 int dot = 0;
6027 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6028 if (arg[length] == '.')
6030 (CONST_CAST(char *, arg))[length] = 0;
6031 dot = 1;
6032 break;
6034 do_spec_1 (arg, 1, NULL);
6035 if (dot)
6036 (CONST_CAST(char *, arg))[length] = '.';
6037 do_spec_1 (suffix_subst, 1, NULL);
6039 else
6040 do_spec_1 (arg, 1, NULL);
6044 do_spec_1 (" ", 0, NULL);
6045 switches[switchnum].validated = true;
6048 /* Search for a file named NAME trying various prefixes including the
6049 user's -B prefix and some standard ones.
6050 Return the absolute file name found. If nothing is found, return NAME. */
6052 static const char *
6053 find_file (const char *name)
6055 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6056 return newname ? newname : name;
6059 /* Determine whether a directory exists. If LINKER, return 0 for
6060 certain fixed names not needed by the linker. */
6062 static int
6063 is_directory (const char *path1, bool linker)
6065 int len1;
6066 char *path;
6067 char *cp;
6068 struct stat st;
6070 /* Ensure the string ends with "/.". The resulting path will be a
6071 directory even if the given path is a symbolic link. */
6072 len1 = strlen (path1);
6073 path = (char *) alloca (3 + len1);
6074 memcpy (path, path1, len1);
6075 cp = path + len1;
6076 if (!IS_DIR_SEPARATOR (cp[-1]))
6077 *cp++ = DIR_SEPARATOR;
6078 *cp++ = '.';
6079 *cp = '\0';
6081 /* Exclude directories that the linker is known to search. */
6082 if (linker
6083 && IS_DIR_SEPARATOR (path[0])
6084 && ((cp - path == 6
6085 && filename_ncmp (path + 1, "lib", 3) == 0)
6086 || (cp - path == 10
6087 && filename_ncmp (path + 1, "usr", 3) == 0
6088 && IS_DIR_SEPARATOR (path[4])
6089 && filename_ncmp (path + 5, "lib", 3) == 0)))
6090 return 0;
6092 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6095 /* Set up the various global variables to indicate that we're processing
6096 the input file named FILENAME. */
6098 void
6099 set_input (const char *filename)
6101 const char *p;
6103 gcc_input_filename = filename;
6104 input_filename_length = strlen (gcc_input_filename);
6105 input_basename = lbasename (gcc_input_filename);
6107 /* Find a suffix starting with the last period,
6108 and set basename_length to exclude that suffix. */
6109 basename_length = strlen (input_basename);
6110 suffixed_basename_length = basename_length;
6111 p = input_basename + basename_length;
6112 while (p != input_basename && *p != '.')
6113 --p;
6114 if (*p == '.' && p != input_basename)
6116 basename_length = p - input_basename;
6117 input_suffix = p + 1;
6119 else
6120 input_suffix = "";
6122 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6123 we will need to do a stat on the gcc_input_filename. The
6124 INPUT_STAT_SET signals that the stat is needed. */
6125 input_stat_set = 0;
6128 /* On fatal signals, delete all the temporary files. */
6130 static void
6131 fatal_signal (int signum)
6133 signal (signum, SIG_DFL);
6134 delete_failure_queue ();
6135 delete_temp_files ();
6136 /* Get the same signal again, this time not handled,
6137 so its normal effect occurs. */
6138 kill (getpid (), signum);
6141 /* Compare the contents of the two files named CMPFILE[0] and
6142 CMPFILE[1]. Return zero if they're identical, nonzero
6143 otherwise. */
6145 static int
6146 compare_files (char *cmpfile[])
6148 int ret = 0;
6149 FILE *temp[2] = { NULL, NULL };
6150 int i;
6152 #if HAVE_MMAP_FILE
6154 size_t length[2];
6155 void *map[2] = { NULL, NULL };
6157 for (i = 0; i < 2; i++)
6159 struct stat st;
6161 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6163 error ("%s: could not determine length of compare-debug file %s",
6164 gcc_input_filename, cmpfile[i]);
6165 ret = 1;
6166 break;
6169 length[i] = st.st_size;
6172 if (!ret && length[0] != length[1])
6174 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
6175 ret = 1;
6178 if (!ret)
6179 for (i = 0; i < 2; i++)
6181 int fd = open (cmpfile[i], O_RDONLY);
6182 if (fd < 0)
6184 error ("%s: could not open compare-debug file %s",
6185 gcc_input_filename, cmpfile[i]);
6186 ret = 1;
6187 break;
6190 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
6191 close (fd);
6193 if (map[i] == (void *) MAP_FAILED)
6195 ret = -1;
6196 break;
6200 if (!ret)
6202 if (memcmp (map[0], map[1], length[0]) != 0)
6204 error ("%s: -fcompare-debug failure", gcc_input_filename);
6205 ret = 1;
6209 for (i = 0; i < 2; i++)
6210 if (map[i])
6211 munmap ((caddr_t) map[i], length[i]);
6213 if (ret >= 0)
6214 return ret;
6216 ret = 0;
6218 #endif
6220 for (i = 0; i < 2; i++)
6222 temp[i] = fopen (cmpfile[i], "r");
6223 if (!temp[i])
6225 error ("%s: could not open compare-debug file %s",
6226 gcc_input_filename, cmpfile[i]);
6227 ret = 1;
6228 break;
6232 if (!ret && temp[0] && temp[1])
6233 for (;;)
6235 int c0, c1;
6236 c0 = fgetc (temp[0]);
6237 c1 = fgetc (temp[1]);
6239 if (c0 != c1)
6241 error ("%s: -fcompare-debug failure",
6242 gcc_input_filename);
6243 ret = 1;
6244 break;
6247 if (c0 == EOF)
6248 break;
6251 for (i = 1; i >= 0; i--)
6253 if (temp[i])
6254 fclose (temp[i]);
6257 return ret;
6260 extern int main (int, char **);
6263 main (int argc, char **argv)
6265 size_t i;
6266 int value;
6267 int linker_was_run = 0;
6268 int lang_n_infiles = 0;
6269 int num_linker_inputs = 0;
6270 char *explicit_link_files;
6271 char *specs_file;
6272 char *lto_wrapper_file;
6273 const char *p;
6274 struct user_specs *uptr;
6275 char **old_argv = argv;
6276 struct cl_decoded_option *decoded_options;
6277 unsigned int decoded_options_count;
6279 p = argv[0] + strlen (argv[0]);
6280 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6281 --p;
6282 progname = p;
6284 xmalloc_set_program_name (progname);
6286 expandargv (&argc, &argv);
6288 /* Determine if any expansions were made. */
6289 if (argv != old_argv)
6290 at_file_supplied = true;
6292 /* Register the language-independent parameters. */
6293 global_init_params ();
6294 finish_params ();
6296 init_options_struct (&global_options, &global_options_set);
6298 decode_cmdline_options_to_array (argc, CONST_CAST2 (const char **, char **,
6299 argv),
6300 CL_DRIVER,
6301 &decoded_options, &decoded_options_count);
6303 /* Unlock the stdio streams. */
6304 unlock_std_streams ();
6306 gcc_init_libintl ();
6308 diagnostic_initialize (global_dc, 0);
6310 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6311 /* Perform host dependent initialization when needed. */
6312 GCC_DRIVER_HOST_INITIALIZATION;
6313 #endif
6315 if (atexit (delete_temp_files) != 0)
6316 fatal_error ("atexit failed");
6318 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6319 signal (SIGINT, fatal_signal);
6320 #ifdef SIGHUP
6321 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6322 signal (SIGHUP, fatal_signal);
6323 #endif
6324 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6325 signal (SIGTERM, fatal_signal);
6326 #ifdef SIGPIPE
6327 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6328 signal (SIGPIPE, fatal_signal);
6329 #endif
6330 #ifdef SIGCHLD
6331 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6332 receive the signal. A different setting is inheritable */
6333 signal (SIGCHLD, SIG_DFL);
6334 #endif
6336 /* Parsing and gimplification sometimes need quite large stack.
6337 Increase stack size limits if possible. */
6338 stack_limit_increase (64 * 1024 * 1024);
6340 /* Allocate the argument vector. */
6341 alloc_args ();
6343 obstack_init (&obstack);
6345 /* Build multilib_select, et. al from the separate lines that make up each
6346 multilib selection. */
6348 const char *const *q = multilib_raw;
6349 int need_space;
6351 obstack_init (&multilib_obstack);
6352 while ((p = *q++) != (char *) 0)
6353 obstack_grow (&multilib_obstack, p, strlen (p));
6355 obstack_1grow (&multilib_obstack, 0);
6356 multilib_select = XOBFINISH (&multilib_obstack, const char *);
6358 q = multilib_matches_raw;
6359 while ((p = *q++) != (char *) 0)
6360 obstack_grow (&multilib_obstack, p, strlen (p));
6362 obstack_1grow (&multilib_obstack, 0);
6363 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6365 q = multilib_exclusions_raw;
6366 while ((p = *q++) != (char *) 0)
6367 obstack_grow (&multilib_obstack, p, strlen (p));
6369 obstack_1grow (&multilib_obstack, 0);
6370 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6372 q = multilib_reuse_raw;
6373 while ((p = *q++) != (char *) 0)
6374 obstack_grow (&multilib_obstack, p, strlen (p));
6376 obstack_1grow (&multilib_obstack, 0);
6377 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
6379 need_space = FALSE;
6380 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6382 if (need_space)
6383 obstack_1grow (&multilib_obstack, ' ');
6384 obstack_grow (&multilib_obstack,
6385 multilib_defaults_raw[i],
6386 strlen (multilib_defaults_raw[i]));
6387 need_space = TRUE;
6390 obstack_1grow (&multilib_obstack, 0);
6391 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6394 #ifdef INIT_ENVIRONMENT
6395 /* Set up any other necessary machine specific environment variables. */
6396 xputenv (INIT_ENVIRONMENT);
6397 #endif
6399 /* Make a table of what switches there are (switches, n_switches).
6400 Make a table of specified input files (infiles, n_infiles).
6401 Decode switches that are handled locally. */
6403 process_command (decoded_options_count, decoded_options);
6405 /* Initialize the vector of specs to just the default.
6406 This means one element containing 0s, as a terminator. */
6408 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
6409 memcpy (compilers, default_compilers, sizeof default_compilers);
6410 n_compilers = n_default_compilers;
6412 /* Read specs from a file if there is one. */
6414 machine_suffix = concat (spec_machine, dir_separator_str,
6415 spec_version, dir_separator_str, NULL);
6416 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6418 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
6419 /* Read the specs file unless it is a default one. */
6420 if (specs_file != 0 && strcmp (specs_file, "specs"))
6421 read_specs (specs_file, true, false);
6422 else
6423 init_spec ();
6425 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6426 for any override of as, ld and libraries. */
6427 specs_file = (char *) alloca (strlen (standard_exec_prefix)
6428 + strlen (just_machine_suffix) + sizeof ("specs"));
6430 strcpy (specs_file, standard_exec_prefix);
6431 strcat (specs_file, just_machine_suffix);
6432 strcat (specs_file, "specs");
6433 if (access (specs_file, R_OK) == 0)
6434 read_specs (specs_file, true, false);
6436 /* Process any configure-time defaults specified for the command line
6437 options, via OPTION_DEFAULT_SPECS. */
6438 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6439 do_option_spec (option_default_specs[i].name,
6440 option_default_specs[i].spec);
6442 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6443 of the command line. */
6445 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6446 do_self_spec (driver_self_specs[i]);
6448 /* If not cross-compiling, look for executables in the standard
6449 places. */
6450 if (*cross_compile == '0')
6452 if (*md_exec_prefix)
6454 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6455 PREFIX_PRIORITY_LAST, 0, 0);
6459 /* Process sysroot_suffix_spec. */
6460 if (*sysroot_suffix_spec != 0
6461 && !no_sysroot_suffix
6462 && do_spec_2 (sysroot_suffix_spec) == 0)
6464 if (argbuf.length () > 1)
6465 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
6466 else if (argbuf.length () == 1)
6467 target_sysroot_suffix = xstrdup (argbuf.last ());
6470 #ifdef HAVE_LD_SYSROOT
6471 /* Pass the --sysroot option to the linker, if it supports that. If
6472 there is a sysroot_suffix_spec, it has already been processed by
6473 this point, so target_system_root really is the system root we
6474 should be using. */
6475 if (target_system_root)
6477 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6478 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6479 set_spec ("link", XOBFINISH (&obstack, const char *), false);
6481 #endif
6483 /* Process sysroot_hdrs_suffix_spec. */
6484 if (*sysroot_hdrs_suffix_spec != 0
6485 && !no_sysroot_suffix
6486 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6488 if (argbuf.length () > 1)
6489 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
6490 else if (argbuf.length () == 1)
6491 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
6494 /* Look for startfiles in the standard places. */
6495 if (*startfile_prefix_spec != 0
6496 && do_spec_2 (startfile_prefix_spec) == 0
6497 && do_spec_1 (" ", 0, NULL) == 0)
6499 const char *arg;
6500 int ndx;
6501 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
6502 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
6503 PREFIX_PRIORITY_LAST, 0, 1);
6505 /* We should eventually get rid of all these and stick to
6506 startfile_prefix_spec exclusively. */
6507 else if (*cross_compile == '0' || target_system_root)
6509 if (*md_startfile_prefix)
6510 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6511 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6513 if (*md_startfile_prefix_1)
6514 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6515 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6517 /* If standard_startfile_prefix is relative, base it on
6518 standard_exec_prefix. This lets us move the installed tree
6519 as a unit. If GCC_EXEC_PREFIX is defined, base
6520 standard_startfile_prefix on that as well.
6522 If the prefix is relative, only search it for native compilers;
6523 otherwise we will search a directory containing host libraries. */
6524 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6525 add_sysrooted_prefix (&startfile_prefixes,
6526 standard_startfile_prefix, "BINUTILS",
6527 PREFIX_PRIORITY_LAST, 0, 1);
6528 else if (*cross_compile == '0')
6530 add_prefix (&startfile_prefixes,
6531 concat (gcc_exec_prefix
6532 ? gcc_exec_prefix : standard_exec_prefix,
6533 machine_suffix,
6534 standard_startfile_prefix, NULL),
6535 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6538 /* Sysrooted prefixes are relocated because target_system_root is
6539 also relocated by gcc_exec_prefix. */
6540 if (*standard_startfile_prefix_1)
6541 add_sysrooted_prefix (&startfile_prefixes,
6542 standard_startfile_prefix_1, "BINUTILS",
6543 PREFIX_PRIORITY_LAST, 0, 1);
6544 if (*standard_startfile_prefix_2)
6545 add_sysrooted_prefix (&startfile_prefixes,
6546 standard_startfile_prefix_2, "BINUTILS",
6547 PREFIX_PRIORITY_LAST, 0, 1);
6550 /* Process any user specified specs in the order given on the command
6551 line. */
6552 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6554 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6555 R_OK, true);
6556 read_specs (filename ? filename : uptr->filename, false, true);
6559 /* Process any user self specs. */
6561 struct spec_list *sl;
6562 for (sl = specs; sl; sl = sl->next)
6563 if (sl->name_len == sizeof "self_spec" - 1
6564 && !strcmp (sl->name, "self_spec"))
6565 do_self_spec (*sl->ptr_spec);
6568 if (compare_debug)
6570 enum save_temps save;
6572 if (!compare_debug_second)
6574 n_switches_debug_check[1] = n_switches;
6575 n_switches_alloc_debug_check[1] = n_switches_alloc;
6576 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
6577 n_switches_alloc);
6579 do_self_spec ("%:compare-debug-self-opt()");
6580 n_switches_debug_check[0] = n_switches;
6581 n_switches_alloc_debug_check[0] = n_switches_alloc;
6582 switches_debug_check[0] = switches;
6584 n_switches = n_switches_debug_check[1];
6585 n_switches_alloc = n_switches_alloc_debug_check[1];
6586 switches = switches_debug_check[1];
6589 /* Avoid crash when computing %j in this early. */
6590 save = save_temps_flag;
6591 save_temps_flag = SAVE_TEMPS_NONE;
6593 compare_debug = -compare_debug;
6594 do_self_spec ("%:compare-debug-self-opt()");
6596 save_temps_flag = save;
6598 if (!compare_debug_second)
6600 n_switches_debug_check[1] = n_switches;
6601 n_switches_alloc_debug_check[1] = n_switches_alloc;
6602 switches_debug_check[1] = switches;
6603 compare_debug = -compare_debug;
6604 n_switches = n_switches_debug_check[0];
6605 n_switches_alloc = n_switches_debug_check[0];
6606 switches = switches_debug_check[0];
6611 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6612 if (gcc_exec_prefix)
6613 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6614 spec_version, dir_separator_str, NULL);
6616 /* Now we have the specs.
6617 Set the `valid' bits for switches that match anything in any spec. */
6619 validate_all_switches ();
6621 /* Now that we have the switches and the specs, set
6622 the subdirectory based on the options. */
6623 set_multilib_dir ();
6625 /* Set up to remember the pathname of gcc and any options
6626 needed for collect. We use argv[0] instead of progname because
6627 we need the complete pathname. */
6628 obstack_init (&collect_obstack);
6629 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6630 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6631 xputenv (XOBFINISH (&collect_obstack, char *));
6633 /* Set up to remember the pathname of the lto wrapper. */
6635 if (have_c)
6636 lto_wrapper_file = NULL;
6637 else
6638 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
6639 X_OK, false);
6640 if (lto_wrapper_file)
6642 lto_wrapper_file = convert_white_space (lto_wrapper_file);
6643 lto_wrapper_spec = lto_wrapper_file;
6644 obstack_init (&collect_obstack);
6645 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
6646 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
6647 obstack_grow (&collect_obstack, lto_wrapper_spec,
6648 strlen (lto_wrapper_spec) + 1);
6649 xputenv (XOBFINISH (&collect_obstack, char *));
6652 /* Reject switches that no pass was interested in. */
6654 for (i = 0; (int) i < n_switches; i++)
6655 if (! switches[i].validated)
6656 error ("unrecognized command line option %<-%s%>", switches[i].part1);
6658 /* Obey some of the options. */
6660 if (print_search_dirs)
6662 printf (_("install: %s%s\n"),
6663 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
6664 gcc_exec_prefix ? "" : machine_suffix);
6665 printf (_("programs: %s\n"),
6666 build_search_list (&exec_prefixes, "", false, false));
6667 printf (_("libraries: %s\n"),
6668 build_search_list (&startfile_prefixes, "", false, true));
6669 return (0);
6672 if (print_file_name)
6674 printf ("%s\n", find_file (print_file_name));
6675 return (0);
6678 if (print_prog_name)
6680 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6681 printf ("%s\n", (newname ? newname : print_prog_name));
6682 return (0);
6685 if (print_multi_lib)
6687 print_multilib_info ();
6688 return (0);
6691 if (print_multi_directory)
6693 if (multilib_dir == NULL)
6694 printf (".\n");
6695 else
6696 printf ("%s\n", multilib_dir);
6697 return (0);
6700 if (print_multiarch)
6702 if (multiarch_dir == NULL)
6703 printf ("\n");
6704 else
6705 printf ("%s\n", multiarch_dir);
6706 return (0);
6709 if (print_sysroot)
6711 if (target_system_root)
6713 if (target_sysroot_suffix)
6714 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
6715 else
6716 printf ("%s\n", target_system_root);
6718 return (0);
6721 if (print_multi_os_directory)
6723 if (multilib_os_dir == NULL)
6724 printf (".\n");
6725 else
6726 printf ("%s\n", multilib_os_dir);
6727 return (0);
6730 if (print_sysroot_headers_suffix)
6732 if (*sysroot_hdrs_suffix_spec)
6734 printf("%s\n", (target_sysroot_hdrs_suffix
6735 ? target_sysroot_hdrs_suffix
6736 : ""));
6737 return (0);
6739 else
6740 /* The error status indicates that only one set of fixed
6741 headers should be built. */
6742 fatal_error ("not configured with sysroot headers suffix");
6745 if (print_help_list)
6747 display_help ();
6749 if (! verbose_flag)
6751 printf (_("\nFor bug reporting instructions, please see:\n"));
6752 printf ("%s.\n", bug_report_url);
6754 return (0);
6757 /* We do not exit here. Instead we have created a fake input file
6758 called 'help-dummy' which needs to be compiled, and we pass this
6759 on the various sub-processes, along with the --help switch.
6760 Ensure their output appears after ours. */
6761 fputc ('\n', stdout);
6762 fflush (stdout);
6765 if (print_version)
6767 printf (_("%s %s%s\n"), progname, pkgversion_string,
6768 version_string);
6769 printf ("Copyright %s 2013 Free Software Foundation, Inc.\n",
6770 _("(C)"));
6771 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
6772 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
6773 stdout);
6774 if (! verbose_flag)
6775 return 0;
6777 /* We do not exit here. We use the same mechanism of --help to print
6778 the version of the sub-processes. */
6779 fputc ('\n', stdout);
6780 fflush (stdout);
6783 if (verbose_flag)
6785 int n;
6786 const char *thrmod;
6788 fnotice (stderr, "Target: %s\n", spec_machine);
6789 fnotice (stderr, "Configured with: %s\n", configuration_arguments);
6791 #ifdef THREAD_MODEL_SPEC
6792 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6793 but there's no point in doing all this processing just to get
6794 thread_model back. */
6795 obstack_init (&obstack);
6796 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6797 obstack_1grow (&obstack, '\0');
6798 thrmod = XOBFINISH (&obstack, const char *);
6799 #else
6800 thrmod = thread_model;
6801 #endif
6803 fnotice (stderr, "Thread model: %s\n", thrmod);
6805 /* compiler_version is truncated at the first space when initialized
6806 from version string, so truncate version_string at the first space
6807 before comparing. */
6808 for (n = 0; version_string[n]; n++)
6809 if (version_string[n] == ' ')
6810 break;
6812 if (! strncmp (version_string, compiler_version, n)
6813 && compiler_version[n] == 0)
6814 fnotice (stderr, "gcc version %s %s\n", version_string,
6815 pkgversion_string);
6816 else
6817 fnotice (stderr, "gcc driver version %s %sexecuting gcc version %s\n",
6818 version_string, pkgversion_string, compiler_version);
6820 if (n_infiles == 0)
6821 return (0);
6824 if (n_infiles == added_libraries)
6825 fatal_error ("no input files");
6827 if (seen_error ())
6828 goto out;
6830 /* Make a place to record the compiler output file names
6831 that correspond to the input files. */
6833 i = n_infiles;
6834 i += lang_specific_extra_outfiles;
6835 outfiles = XCNEWVEC (const char *, i);
6837 /* Record which files were specified explicitly as link input. */
6839 explicit_link_files = XCNEWVEC (char, n_infiles);
6841 combine_inputs = have_o || flag_wpa;
6843 for (i = 0; (int) i < n_infiles; i++)
6845 const char *name = infiles[i].name;
6846 struct compiler *compiler = lookup_compiler (name,
6847 strlen (name),
6848 infiles[i].language);
6850 if (compiler && !(compiler->combinable))
6851 combine_inputs = false;
6853 if (lang_n_infiles > 0 && compiler != input_file_compiler
6854 && infiles[i].language && infiles[i].language[0] != '*')
6855 infiles[i].incompiler = compiler;
6856 else if (compiler)
6858 lang_n_infiles++;
6859 input_file_compiler = compiler;
6860 infiles[i].incompiler = compiler;
6862 else
6864 /* Since there is no compiler for this input file, assume it is a
6865 linker file. */
6866 explicit_link_files[i] = 1;
6867 infiles[i].incompiler = NULL;
6869 infiles[i].compiled = false;
6870 infiles[i].preprocessed = false;
6873 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
6874 fatal_error ("cannot specify -o with -c, -S or -E with multiple files");
6876 for (i = 0; (int) i < n_infiles; i++)
6878 int this_file_error = 0;
6880 /* Tell do_spec what to substitute for %i. */
6882 input_file_number = i;
6883 set_input (infiles[i].name);
6885 if (infiles[i].compiled)
6886 continue;
6888 /* Use the same thing in %o, unless cp->spec says otherwise. */
6890 outfiles[i] = gcc_input_filename;
6892 /* Figure out which compiler from the file's suffix. */
6894 input_file_compiler
6895 = lookup_compiler (infiles[i].name, input_filename_length,
6896 infiles[i].language);
6898 if (input_file_compiler)
6900 /* Ok, we found an applicable compiler. Run its spec. */
6902 if (input_file_compiler->spec[0] == '#')
6904 error ("%s: %s compiler not installed on this system",
6905 gcc_input_filename, &input_file_compiler->spec[1]);
6906 this_file_error = 1;
6908 else
6910 if (compare_debug)
6912 free (debug_check_temp_file[0]);
6913 debug_check_temp_file[0] = NULL;
6915 free (debug_check_temp_file[1]);
6916 debug_check_temp_file[1] = NULL;
6919 value = do_spec (input_file_compiler->spec);
6920 infiles[i].compiled = true;
6921 if (value < 0)
6922 this_file_error = 1;
6923 else if (compare_debug && debug_check_temp_file[0])
6925 if (verbose_flag)
6926 inform (0, "recompiling with -fcompare-debug");
6928 compare_debug = -compare_debug;
6929 n_switches = n_switches_debug_check[1];
6930 n_switches_alloc = n_switches_alloc_debug_check[1];
6931 switches = switches_debug_check[1];
6933 value = do_spec (input_file_compiler->spec);
6935 compare_debug = -compare_debug;
6936 n_switches = n_switches_debug_check[0];
6937 n_switches_alloc = n_switches_alloc_debug_check[0];
6938 switches = switches_debug_check[0];
6940 if (value < 0)
6942 error ("during -fcompare-debug recompilation");
6943 this_file_error = 1;
6946 gcc_assert (debug_check_temp_file[1]
6947 && filename_cmp (debug_check_temp_file[0],
6948 debug_check_temp_file[1]));
6950 if (verbose_flag)
6951 inform (0, "comparing final insns dumps");
6953 if (compare_files (debug_check_temp_file))
6954 this_file_error = 1;
6957 if (compare_debug)
6959 free (debug_check_temp_file[0]);
6960 debug_check_temp_file[0] = NULL;
6962 free (debug_check_temp_file[1]);
6963 debug_check_temp_file[1] = NULL;
6968 /* If this file's name does not contain a recognized suffix,
6969 record it as explicit linker input. */
6971 else
6972 explicit_link_files[i] = 1;
6974 /* Clear the delete-on-failure queue, deleting the files in it
6975 if this compilation failed. */
6977 if (this_file_error)
6979 delete_failure_queue ();
6980 errorcount++;
6982 /* If this compilation succeeded, don't delete those files later. */
6983 clear_failure_queue ();
6986 /* Reset the input file name to the first compile/object file name, for use
6987 with %b in LINK_SPEC. We use the first input file that we can find
6988 a compiler to compile it instead of using infiles.language since for
6989 languages other than C we use aliases that we then lookup later. */
6990 if (n_infiles > 0)
6992 int i;
6994 for (i = 0; i < n_infiles ; i++)
6995 if (infiles[i].incompiler
6996 || (infiles[i].language && infiles[i].language[0] != '*'))
6998 set_input (infiles[i].name);
6999 break;
7003 if (!seen_error ())
7005 /* Make sure INPUT_FILE_NUMBER points to first available open
7006 slot. */
7007 input_file_number = n_infiles;
7008 if (lang_specific_pre_link ())
7009 errorcount++;
7012 /* Determine if there are any linker input files. */
7013 num_linker_inputs = 0;
7014 for (i = 0; (int) i < n_infiles; i++)
7015 if (explicit_link_files[i] || outfiles[i] != NULL)
7016 num_linker_inputs++;
7018 /* Run ld to link all the compiler output files. */
7020 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
7022 int tmp = execution_count;
7024 if (! have_c)
7026 #if HAVE_LTO_PLUGIN > 0
7027 #if HAVE_LTO_PLUGIN == 2
7028 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
7029 #else
7030 const char *fuse_linker_plugin = "fuse-linker-plugin";
7031 #endif
7032 #endif
7034 /* We'll use ld if we can't find collect2. */
7035 if (! strcmp (linker_name_spec, "collect2"))
7037 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
7038 if (s == NULL)
7039 linker_name_spec = "ld";
7042 #if HAVE_LTO_PLUGIN > 0
7043 #if HAVE_LTO_PLUGIN == 2
7044 if (!switch_matches (fno_use_linker_plugin,
7045 fno_use_linker_plugin
7046 + strlen (fno_use_linker_plugin), 0))
7047 #else
7048 if (switch_matches (fuse_linker_plugin,
7049 fuse_linker_plugin
7050 + strlen (fuse_linker_plugin), 0))
7051 #endif
7053 char *temp_spec = find_a_file (&exec_prefixes,
7054 LTOPLUGINSONAME, R_OK,
7055 false);
7056 if (!temp_spec)
7057 fatal_error ("-fuse-linker-plugin, but %s not found",
7058 LTOPLUGINSONAME);
7059 linker_plugin_file_spec = convert_white_space (temp_spec);
7061 #endif
7062 lto_gcc_spec = argv[0];
7065 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
7066 for collect. */
7067 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
7068 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
7070 if (print_subprocess_help == 1)
7072 printf (_("\nLinker options\n==============\n\n"));
7073 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
7074 " to the linker.\n\n"));
7075 fflush (stdout);
7077 value = do_spec (link_command_spec);
7078 if (value < 0)
7079 errorcount = 1;
7080 linker_was_run = (tmp != execution_count);
7083 /* If options said don't run linker,
7084 complain about input files to be given to the linker. */
7086 if (! linker_was_run && !seen_error ())
7087 for (i = 0; (int) i < n_infiles; i++)
7088 if (explicit_link_files[i]
7089 && !(infiles[i].language && infiles[i].language[0] == '*'))
7090 warning (0, "%s: linker input file unused because linking not done",
7091 outfiles[i]);
7093 /* Delete some or all of the temporary files we made. */
7095 if (seen_error ())
7096 delete_failure_queue ();
7097 delete_temp_files ();
7099 if (print_help_list)
7101 printf (("\nFor bug reporting instructions, please see:\n"));
7102 printf ("%s\n", bug_report_url);
7105 out:
7106 return (signal_count != 0 ? 2
7107 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
7108 : 0);
7111 /* Find the proper compilation spec for the file name NAME,
7112 whose length is LENGTH. LANGUAGE is the specified language,
7113 or 0 if this file is to be passed to the linker. */
7115 static struct compiler *
7116 lookup_compiler (const char *name, size_t length, const char *language)
7118 struct compiler *cp;
7120 /* If this was specified by the user to be a linker input, indicate that. */
7121 if (language != 0 && language[0] == '*')
7122 return 0;
7124 /* Otherwise, look for the language, if one is spec'd. */
7125 if (language != 0)
7127 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7128 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
7129 return cp;
7131 error ("language %s not recognized", language);
7132 return 0;
7135 /* Look for a suffix. */
7136 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7138 if (/* The suffix `-' matches only the file name `-'. */
7139 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7140 || (strlen (cp->suffix) < length
7141 /* See if the suffix matches the end of NAME. */
7142 && !strcmp (cp->suffix,
7143 name + length - strlen (cp->suffix))
7145 break;
7148 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
7149 /* Look again, but case-insensitively this time. */
7150 if (cp < compilers)
7151 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7153 if (/* The suffix `-' matches only the file name `-'. */
7154 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7155 || (strlen (cp->suffix) < length
7156 /* See if the suffix matches the end of NAME. */
7157 && ((!strcmp (cp->suffix,
7158 name + length - strlen (cp->suffix))
7159 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
7160 && !strcasecmp (cp->suffix,
7161 name + length - strlen (cp->suffix)))
7163 break;
7165 #endif
7167 if (cp >= compilers)
7169 if (cp->spec[0] != '@')
7170 /* A non-alias entry: return it. */
7171 return cp;
7173 /* An alias entry maps a suffix to a language.
7174 Search for the language; pass 0 for NAME and LENGTH
7175 to avoid infinite recursion if language not found. */
7176 return lookup_compiler (NULL, 0, cp->spec + 1);
7178 return 0;
7181 static char *
7182 save_string (const char *s, int len)
7184 char *result = XNEWVEC (char, len + 1);
7186 memcpy (result, s, len);
7187 result[len] = 0;
7188 return result;
7191 void
7192 pfatal_with_name (const char *name)
7194 perror_with_name (name);
7195 delete_temp_files ();
7196 exit (1);
7199 static void
7200 perror_with_name (const char *name)
7202 error ("%s: %m", name);
7205 static inline void
7206 validate_switches_from_spec (const char *spec, bool user)
7208 const char *p = spec;
7209 char c;
7210 while ((c = *p++))
7211 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
7212 /* We have a switch spec. */
7213 p = validate_switches (p + 1, user);
7216 static void
7217 validate_all_switches (void)
7219 struct compiler *comp;
7220 struct spec_list *spec;
7222 for (comp = compilers; comp->spec; comp++)
7223 validate_switches_from_spec (comp->spec, false);
7225 /* Look through the linked list of specs read from the specs file. */
7226 for (spec = specs; spec; spec = spec->next)
7227 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
7229 validate_switches_from_spec (link_command_spec, false);
7232 /* Look at the switch-name that comes after START
7233 and mark as valid all supplied switches that match it. */
7235 static const char *
7236 validate_switches (const char *start, bool user_spec)
7238 const char *p = start;
7239 const char *atom;
7240 size_t len;
7241 int i;
7242 bool suffix = false;
7243 bool starred = false;
7245 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7247 next_member:
7248 SKIP_WHITE ();
7250 if (*p == '!')
7251 p++;
7253 SKIP_WHITE ();
7254 if (*p == '.' || *p == ',')
7255 suffix = true, p++;
7257 atom = p;
7258 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7259 || *p == ',' || *p == '.' || *p == '@')
7260 p++;
7261 len = p - atom;
7263 if (*p == '*')
7264 starred = true, p++;
7266 SKIP_WHITE ();
7268 if (!suffix)
7270 /* Mark all matching switches as valid. */
7271 for (i = 0; i < n_switches; i++)
7272 if (!strncmp (switches[i].part1, atom, len)
7273 && (starred || switches[i].part1[len] == '\0')
7274 && (switches[i].known || user_spec))
7275 switches[i].validated = true;
7278 if (*p) p++;
7279 if (*p && (p[-1] == '|' || p[-1] == '&'))
7280 goto next_member;
7282 if (*p && p[-1] == ':')
7284 while (*p && *p != ';' && *p != '}')
7286 if (*p == '%')
7288 p++;
7289 if (*p == '{' || *p == '<')
7290 p = validate_switches (p+1, user_spec);
7291 else if (p[0] == 'W' && p[1] == '{')
7292 p = validate_switches (p+2, user_spec);
7294 else
7295 p++;
7298 if (*p) p++;
7299 if (*p && p[-1] == ';')
7300 goto next_member;
7303 return p;
7304 #undef SKIP_WHITE
7307 struct mdswitchstr
7309 const char *str;
7310 int len;
7313 static struct mdswitchstr *mdswitches;
7314 static int n_mdswitches;
7316 /* Check whether a particular argument was used. The first time we
7317 canonicalize the switches to keep only the ones we care about. */
7319 static int
7320 used_arg (const char *p, int len)
7322 struct mswitchstr
7324 const char *str;
7325 const char *replace;
7326 int len;
7327 int rep_len;
7330 static struct mswitchstr *mswitches;
7331 static int n_mswitches;
7332 int i, j;
7334 if (!mswitches)
7336 struct mswitchstr *matches;
7337 const char *q;
7338 int cnt = 0;
7340 /* Break multilib_matches into the component strings of string
7341 and replacement string. */
7342 for (q = multilib_matches; *q != '\0'; q++)
7343 if (*q == ';')
7344 cnt++;
7346 matches
7347 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
7348 i = 0;
7349 q = multilib_matches;
7350 while (*q != '\0')
7352 matches[i].str = q;
7353 while (*q != ' ')
7355 if (*q == '\0')
7357 invalid_matches:
7358 fatal_error ("multilib spec %qs is invalid",
7359 multilib_matches);
7361 q++;
7363 matches[i].len = q - matches[i].str;
7365 matches[i].replace = ++q;
7366 while (*q != ';' && *q != '\0')
7368 if (*q == ' ')
7369 goto invalid_matches;
7370 q++;
7372 matches[i].rep_len = q - matches[i].replace;
7373 i++;
7374 if (*q == ';')
7375 q++;
7378 /* Now build a list of the replacement string for switches that we care
7379 about. Make sure we allocate at least one entry. This prevents
7380 xmalloc from calling fatal, and prevents us from re-executing this
7381 block of code. */
7382 mswitches
7383 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
7384 for (i = 0; i < n_switches; i++)
7385 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
7387 int xlen = strlen (switches[i].part1);
7388 for (j = 0; j < cnt; j++)
7389 if (xlen == matches[j].len
7390 && ! strncmp (switches[i].part1, matches[j].str, xlen))
7392 mswitches[n_mswitches].str = matches[j].replace;
7393 mswitches[n_mswitches].len = matches[j].rep_len;
7394 mswitches[n_mswitches].replace = (char *) 0;
7395 mswitches[n_mswitches].rep_len = 0;
7396 n_mswitches++;
7397 break;
7401 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7402 on the command line nor any options mutually incompatible with
7403 them. */
7404 for (i = 0; i < n_mdswitches; i++)
7406 const char *r;
7408 for (q = multilib_options; *q != '\0'; q++)
7410 while (*q == ' ')
7411 q++;
7413 r = q;
7414 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7415 || strchr (" /", q[mdswitches[i].len]) == NULL)
7417 while (*q != ' ' && *q != '/' && *q != '\0')
7418 q++;
7419 if (*q != '/')
7420 break;
7421 q++;
7424 if (*q != ' ' && *q != '\0')
7426 while (*r != ' ' && *r != '\0')
7428 q = r;
7429 while (*q != ' ' && *q != '/' && *q != '\0')
7430 q++;
7432 if (used_arg (r, q - r))
7433 break;
7435 if (*q != '/')
7437 mswitches[n_mswitches].str = mdswitches[i].str;
7438 mswitches[n_mswitches].len = mdswitches[i].len;
7439 mswitches[n_mswitches].replace = (char *) 0;
7440 mswitches[n_mswitches].rep_len = 0;
7441 n_mswitches++;
7442 break;
7445 r = q + 1;
7447 break;
7453 for (i = 0; i < n_mswitches; i++)
7454 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7455 return 1;
7457 return 0;
7460 static int
7461 default_arg (const char *p, int len)
7463 int i;
7465 for (i = 0; i < n_mdswitches; i++)
7466 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7467 return 1;
7469 return 0;
7472 /* Work out the subdirectory to use based on the options. The format of
7473 multilib_select is a list of elements. Each element is a subdirectory
7474 name followed by a list of options followed by a semicolon. The format
7475 of multilib_exclusions is the same, but without the preceding
7476 directory. First gcc will check the exclusions, if none of the options
7477 beginning with an exclamation point are present, and all of the other
7478 options are present, then we will ignore this completely. Passing
7479 that, gcc will consider each multilib_select in turn using the same
7480 rules for matching the options. If a match is found, that subdirectory
7481 will be used.
7482 A subdirectory name is optionally followed by a colon and the corresponding
7483 multiarch name. */
7485 static void
7486 set_multilib_dir (void)
7488 const char *p;
7489 unsigned int this_path_len;
7490 const char *this_path, *this_arg;
7491 const char *start, *end;
7492 int not_arg;
7493 int ok, ndfltok, first;
7495 n_mdswitches = 0;
7496 start = multilib_defaults;
7497 while (*start == ' ' || *start == '\t')
7498 start++;
7499 while (*start != '\0')
7501 n_mdswitches++;
7502 while (*start != ' ' && *start != '\t' && *start != '\0')
7503 start++;
7504 while (*start == ' ' || *start == '\t')
7505 start++;
7508 if (n_mdswitches)
7510 int i = 0;
7512 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
7513 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7515 while (*start == ' ' || *start == '\t')
7516 start++;
7518 if (*start == '\0')
7519 break;
7521 for (end = start + 1;
7522 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7525 obstack_grow (&multilib_obstack, start, end - start);
7526 obstack_1grow (&multilib_obstack, 0);
7527 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7528 mdswitches[i++].len = end - start;
7530 if (*end == '\0')
7531 break;
7535 p = multilib_exclusions;
7536 while (*p != '\0')
7538 /* Ignore newlines. */
7539 if (*p == '\n')
7541 ++p;
7542 continue;
7545 /* Check the arguments. */
7546 ok = 1;
7547 while (*p != ';')
7549 if (*p == '\0')
7551 invalid_exclusions:
7552 fatal_error ("multilib exclusions %qs is invalid",
7553 multilib_exclusions);
7556 if (! ok)
7558 ++p;
7559 continue;
7562 this_arg = p;
7563 while (*p != ' ' && *p != ';')
7565 if (*p == '\0')
7566 goto invalid_exclusions;
7567 ++p;
7570 if (*this_arg != '!')
7571 not_arg = 0;
7572 else
7574 not_arg = 1;
7575 ++this_arg;
7578 ok = used_arg (this_arg, p - this_arg);
7579 if (not_arg)
7580 ok = ! ok;
7582 if (*p == ' ')
7583 ++p;
7586 if (ok)
7587 return;
7589 ++p;
7592 first = 1;
7593 p = multilib_select;
7595 /* Append multilib reuse rules if any. With those rules, we can reuse
7596 one multilib for certain different options sets. */
7597 if (strlen (multilib_reuse) > 0)
7598 p = concat (p, multilib_reuse, NULL);
7600 while (*p != '\0')
7602 /* Ignore newlines. */
7603 if (*p == '\n')
7605 ++p;
7606 continue;
7609 /* Get the initial path. */
7610 this_path = p;
7611 while (*p != ' ')
7613 if (*p == '\0')
7615 invalid_select:
7616 fatal_error ("multilib select %qs %qs is invalid",
7617 multilib_select, multilib_reuse);
7619 ++p;
7621 this_path_len = p - this_path;
7623 /* Check the arguments. */
7624 ok = 1;
7625 ndfltok = 1;
7626 ++p;
7627 while (*p != ';')
7629 if (*p == '\0')
7630 goto invalid_select;
7632 if (! ok)
7634 ++p;
7635 continue;
7638 this_arg = p;
7639 while (*p != ' ' && *p != ';')
7641 if (*p == '\0')
7642 goto invalid_select;
7643 ++p;
7646 if (*this_arg != '!')
7647 not_arg = 0;
7648 else
7650 not_arg = 1;
7651 ++this_arg;
7654 /* If this is a default argument, we can just ignore it.
7655 This is true even if this_arg begins with '!'. Beginning
7656 with '!' does not mean that this argument is necessarily
7657 inappropriate for this library: it merely means that
7658 there is a more specific library which uses this
7659 argument. If this argument is a default, we need not
7660 consider that more specific library. */
7661 ok = used_arg (this_arg, p - this_arg);
7662 if (not_arg)
7663 ok = ! ok;
7665 if (! ok)
7666 ndfltok = 0;
7668 if (default_arg (this_arg, p - this_arg))
7669 ok = 1;
7671 if (*p == ' ')
7672 ++p;
7675 if (first)
7677 if (this_path_len > 3
7678 && this_path[0] == '.'
7679 && this_path[1] == ':'
7680 && this_path[2] == ':')
7682 char *new_multiarch_dir = XNEWVEC (char, this_path_len + 1);
7684 strncpy (new_multiarch_dir, this_path, this_path_len);
7685 new_multiarch_dir[this_path_len] = '\0';
7686 multiarch_dir = &new_multiarch_dir[3];
7690 if (ok && first)
7692 if (this_path_len != 1
7693 || this_path[0] != '.')
7695 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
7696 char *q;
7698 strncpy (new_multilib_dir, this_path, this_path_len);
7699 new_multilib_dir[this_path_len] = '\0';
7700 q = strchr (new_multilib_dir, ':');
7701 if (q != NULL)
7702 *q = '\0';
7703 multilib_dir = new_multilib_dir;
7705 first = 0;
7708 if (ndfltok)
7710 const char *q = this_path, *end = this_path + this_path_len;
7712 while (q < end && *q != ':')
7713 q++;
7714 if (q < end)
7716 const char *q2 = q + 1, *ml_end = end;
7717 char *new_multilib_os_dir;
7719 while (q2 < end && *q2 != ':')
7720 q2++;
7721 if (*q2 == ':')
7722 ml_end = q2;
7723 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
7724 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
7725 new_multilib_os_dir[ml_end - q - 1] = '\0';
7726 multilib_os_dir = *new_multilib_os_dir ? new_multilib_os_dir : ".";
7728 if (q2 < end && *q2 == ':')
7730 char *new_multiarch_dir = XNEWVEC (char, end - q2);
7731 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
7732 new_multiarch_dir[end - q2 - 1] = '\0';
7733 multiarch_dir = new_multiarch_dir;
7735 break;
7739 ++p;
7742 if (multilib_dir == NULL && multilib_os_dir != NULL
7743 && strcmp (multilib_os_dir, ".") == 0)
7745 free (CONST_CAST (char *, multilib_os_dir));
7746 multilib_os_dir = NULL;
7748 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7749 multilib_os_dir = multilib_dir;
7752 /* Print out the multiple library subdirectory selection
7753 information. This prints out a series of lines. Each line looks
7754 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7755 required. Only the desired options are printed out, the negative
7756 matches. The options are print without a leading dash. There are
7757 no spaces to make it easy to use the information in the shell.
7758 Each subdirectory is printed only once. This assumes the ordering
7759 generated by the genmultilib script. Also, we leave out ones that match
7760 the exclusions. */
7762 static void
7763 print_multilib_info (void)
7765 const char *p = multilib_select;
7766 const char *last_path = 0, *this_path;
7767 int skip;
7768 unsigned int last_path_len = 0;
7770 while (*p != '\0')
7772 skip = 0;
7773 /* Ignore newlines. */
7774 if (*p == '\n')
7776 ++p;
7777 continue;
7780 /* Get the initial path. */
7781 this_path = p;
7782 while (*p != ' ')
7784 if (*p == '\0')
7786 invalid_select:
7787 fatal_error ("multilib select %qs is invalid", multilib_select);
7790 ++p;
7793 /* When --disable-multilib was used but target defines
7794 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
7795 with .:: for multiarch configurations) are there just to find
7796 multilib_os_dir, so skip them from output. */
7797 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
7798 skip = 1;
7800 /* Check for matches with the multilib_exclusions. We don't bother
7801 with the '!' in either list. If any of the exclusion rules match
7802 all of its options with the select rule, we skip it. */
7804 const char *e = multilib_exclusions;
7805 const char *this_arg;
7807 while (*e != '\0')
7809 int m = 1;
7810 /* Ignore newlines. */
7811 if (*e == '\n')
7813 ++e;
7814 continue;
7817 /* Check the arguments. */
7818 while (*e != ';')
7820 const char *q;
7821 int mp = 0;
7823 if (*e == '\0')
7825 invalid_exclusion:
7826 fatal_error ("multilib exclusion %qs is invalid",
7827 multilib_exclusions);
7830 if (! m)
7832 ++e;
7833 continue;
7836 this_arg = e;
7838 while (*e != ' ' && *e != ';')
7840 if (*e == '\0')
7841 goto invalid_exclusion;
7842 ++e;
7845 q = p + 1;
7846 while (*q != ';')
7848 const char *arg;
7849 int len = e - this_arg;
7851 if (*q == '\0')
7852 goto invalid_select;
7854 arg = q;
7856 while (*q != ' ' && *q != ';')
7858 if (*q == '\0')
7859 goto invalid_select;
7860 ++q;
7863 if (! strncmp (arg, this_arg,
7864 (len < q - arg) ? q - arg : len)
7865 || default_arg (this_arg, e - this_arg))
7867 mp = 1;
7868 break;
7871 if (*q == ' ')
7872 ++q;
7875 if (! mp)
7876 m = 0;
7878 if (*e == ' ')
7879 ++e;
7882 if (m)
7884 skip = 1;
7885 break;
7888 if (*e != '\0')
7889 ++e;
7893 if (! skip)
7895 /* If this is a duplicate, skip it. */
7896 skip = (last_path != 0
7897 && (unsigned int) (p - this_path) == last_path_len
7898 && ! filename_ncmp (last_path, this_path, last_path_len));
7900 last_path = this_path;
7901 last_path_len = p - this_path;
7904 /* If this directory requires any default arguments, we can skip
7905 it. We will already have printed a directory identical to
7906 this one which does not require that default argument. */
7907 if (! skip)
7909 const char *q;
7911 q = p + 1;
7912 while (*q != ';')
7914 const char *arg;
7916 if (*q == '\0')
7917 goto invalid_select;
7919 if (*q == '!')
7920 arg = NULL;
7921 else
7922 arg = q;
7924 while (*q != ' ' && *q != ';')
7926 if (*q == '\0')
7927 goto invalid_select;
7928 ++q;
7931 if (arg != NULL
7932 && default_arg (arg, q - arg))
7934 skip = 1;
7935 break;
7938 if (*q == ' ')
7939 ++q;
7943 if (! skip)
7945 const char *p1;
7947 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7948 putchar (*p1);
7949 putchar (';');
7952 ++p;
7953 while (*p != ';')
7955 int use_arg;
7957 if (*p == '\0')
7958 goto invalid_select;
7960 if (skip)
7962 ++p;
7963 continue;
7966 use_arg = *p != '!';
7968 if (use_arg)
7969 putchar ('@');
7971 while (*p != ' ' && *p != ';')
7973 if (*p == '\0')
7974 goto invalid_select;
7975 if (use_arg)
7976 putchar (*p);
7977 ++p;
7980 if (*p == ' ')
7981 ++p;
7984 if (! skip)
7986 /* If there are extra options, print them now. */
7987 if (multilib_extra && *multilib_extra)
7989 int print_at = TRUE;
7990 const char *q;
7992 for (q = multilib_extra; *q != '\0'; q++)
7994 if (*q == ' ')
7995 print_at = TRUE;
7996 else
7998 if (print_at)
7999 putchar ('@');
8000 putchar (*q);
8001 print_at = FALSE;
8006 putchar ('\n');
8009 ++p;
8013 /* getenv built-in spec function.
8015 Returns the value of the environment variable given by its first
8016 argument, concatenated with the second argument. If the
8017 environment variable is not defined, a fatal error is issued. */
8019 static const char *
8020 getenv_spec_function (int argc, const char **argv)
8022 char *value;
8023 char *result;
8024 char *ptr;
8025 size_t len;
8027 if (argc != 2)
8028 return NULL;
8030 value = getenv (argv[0]);
8031 if (!value)
8032 fatal_error ("environment variable %qs not defined", argv[0]);
8034 /* We have to escape every character of the environment variable so
8035 they are not interpreted as active spec characters. A
8036 particularly painful case is when we are reading a variable
8037 holding a windows path complete with \ separators. */
8038 len = strlen (value) * 2 + strlen (argv[1]) + 1;
8039 result = XNEWVAR (char, len);
8040 for (ptr = result; *value; ptr += 2)
8042 ptr[0] = '\\';
8043 ptr[1] = *value++;
8046 strcpy (ptr, argv[1]);
8048 return result;
8051 /* if-exists built-in spec function.
8053 Checks to see if the file specified by the absolute pathname in
8054 ARGS exists. Returns that pathname if found.
8056 The usual use for this function is to check for a library file
8057 (whose name has been expanded with %s). */
8059 static const char *
8060 if_exists_spec_function (int argc, const char **argv)
8062 /* Must have only one argument. */
8063 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8064 return argv[0];
8066 return NULL;
8069 /* if-exists-else built-in spec function.
8071 This is like if-exists, but takes an additional argument which
8072 is returned if the first argument does not exist. */
8074 static const char *
8075 if_exists_else_spec_function (int argc, const char **argv)
8077 /* Must have exactly two arguments. */
8078 if (argc != 2)
8079 return NULL;
8081 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8082 return argv[0];
8084 return argv[1];
8087 /* replace-outfile built-in spec function.
8089 This looks for the first argument in the outfiles array's name and
8090 replaces it with the second argument. */
8092 static const char *
8093 replace_outfile_spec_function (int argc, const char **argv)
8095 int i;
8096 /* Must have exactly two arguments. */
8097 if (argc != 2)
8098 abort ();
8100 for (i = 0; i < n_infiles; i++)
8102 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8103 outfiles[i] = xstrdup (argv[1]);
8105 return NULL;
8108 /* remove-outfile built-in spec function.
8110 * This looks for the first argument in the outfiles array's name and
8111 * removes it. */
8113 static const char *
8114 remove_outfile_spec_function (int argc, const char **argv)
8116 int i;
8117 /* Must have exactly one argument. */
8118 if (argc != 1)
8119 abort ();
8121 for (i = 0; i < n_infiles; i++)
8123 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8124 outfiles[i] = NULL;
8126 return NULL;
8129 /* Given two version numbers, compares the two numbers.
8130 A version number must match the regular expression
8131 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
8133 static int
8134 compare_version_strings (const char *v1, const char *v2)
8136 int rresult;
8137 regex_t r;
8139 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
8140 REG_EXTENDED | REG_NOSUB) != 0)
8141 abort ();
8142 rresult = regexec (&r, v1, 0, NULL, 0);
8143 if (rresult == REG_NOMATCH)
8144 fatal_error ("invalid version number %qs", v1);
8145 else if (rresult != 0)
8146 abort ();
8147 rresult = regexec (&r, v2, 0, NULL, 0);
8148 if (rresult == REG_NOMATCH)
8149 fatal_error ("invalid version number %qs", v2);
8150 else if (rresult != 0)
8151 abort ();
8153 return strverscmp (v1, v2);
8157 /* version_compare built-in spec function.
8159 This takes an argument of the following form:
8161 <comparison-op> <arg1> [<arg2>] <switch> <result>
8163 and produces "result" if the comparison evaluates to true,
8164 and nothing if it doesn't.
8166 The supported <comparison-op> values are:
8168 >= true if switch is a later (or same) version than arg1
8169 !> opposite of >=
8170 < true if switch is an earlier version than arg1
8171 !< opposite of <
8172 >< true if switch is arg1 or later, and earlier than arg2
8173 <> true if switch is earlier than arg1 or is arg2 or later
8175 If the switch is not present, the condition is false unless
8176 the first character of the <comparison-op> is '!'.
8178 For example,
8179 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
8180 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
8182 static const char *
8183 version_compare_spec_function (int argc, const char **argv)
8185 int comp1, comp2;
8186 size_t switch_len;
8187 const char *switch_value = NULL;
8188 int nargs = 1, i;
8189 bool result;
8191 if (argc < 3)
8192 fatal_error ("too few arguments to %%:version-compare");
8193 if (argv[0][0] == '\0')
8194 abort ();
8195 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
8196 nargs = 2;
8197 if (argc != nargs + 3)
8198 fatal_error ("too many arguments to %%:version-compare");
8200 switch_len = strlen (argv[nargs + 1]);
8201 for (i = 0; i < n_switches; i++)
8202 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
8203 && check_live_switch (i, switch_len))
8204 switch_value = switches[i].part1 + switch_len;
8206 if (switch_value == NULL)
8207 comp1 = comp2 = -1;
8208 else
8210 comp1 = compare_version_strings (switch_value, argv[1]);
8211 if (nargs == 2)
8212 comp2 = compare_version_strings (switch_value, argv[2]);
8213 else
8214 comp2 = -1; /* This value unused. */
8217 switch (argv[0][0] << 8 | argv[0][1])
8219 case '>' << 8 | '=':
8220 result = comp1 >= 0;
8221 break;
8222 case '!' << 8 | '<':
8223 result = comp1 >= 0 || switch_value == NULL;
8224 break;
8225 case '<' << 8:
8226 result = comp1 < 0;
8227 break;
8228 case '!' << 8 | '>':
8229 result = comp1 < 0 || switch_value == NULL;
8230 break;
8231 case '>' << 8 | '<':
8232 result = comp1 >= 0 && comp2 < 0;
8233 break;
8234 case '<' << 8 | '>':
8235 result = comp1 < 0 || comp2 >= 0;
8236 break;
8238 default:
8239 fatal_error ("unknown operator %qs in %%:version-compare", argv[0]);
8241 if (! result)
8242 return NULL;
8244 return argv[nargs + 2];
8247 /* %:include builtin spec function. This differs from %include in that it
8248 can be nested inside a spec, and thus be conditionalized. It takes
8249 one argument, the filename, and looks for it in the startfile path.
8250 The result is always NULL, i.e. an empty expansion. */
8252 static const char *
8253 include_spec_function (int argc, const char **argv)
8255 char *file;
8257 if (argc != 1)
8258 abort ();
8260 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
8261 read_specs (file ? file : argv[0], false, false);
8263 return NULL;
8266 /* %:find-file spec function. This function replaces its argument by
8267 the file found through find_file, that is the -print-file-name gcc
8268 program option. */
8269 static const char *
8270 find_file_spec_function (int argc, const char **argv)
8272 const char *file;
8274 if (argc != 1)
8275 abort ();
8277 file = find_file (argv[0]);
8278 return file;
8282 /* %:find-plugindir spec function. This function replaces its argument
8283 by the -iplugindir=<dir> option. `dir' is found through find_file, that
8284 is the -print-file-name gcc program option. */
8285 static const char *
8286 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
8288 const char *option;
8290 if (argc != 0)
8291 abort ();
8293 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
8294 return option;
8298 /* %:print-asm-header spec function. Print a banner to say that the
8299 following output is from the assembler. */
8301 static const char *
8302 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
8303 const char **argv ATTRIBUTE_UNUSED)
8305 printf (_("Assembler options\n=================\n\n"));
8306 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
8307 fflush (stdout);
8308 return NULL;
8311 /* Get a random number for -frandom-seed */
8313 static unsigned HOST_WIDE_INT
8314 get_random_number (void)
8316 unsigned HOST_WIDE_INT ret = 0;
8317 int fd;
8319 fd = open ("/dev/urandom", O_RDONLY);
8320 if (fd >= 0)
8322 read (fd, &ret, sizeof (HOST_WIDE_INT));
8323 close (fd);
8324 if (ret)
8325 return ret;
8328 /* Get some more or less random data. */
8329 #ifdef HAVE_GETTIMEOFDAY
8331 struct timeval tv;
8333 gettimeofday (&tv, NULL);
8334 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
8336 #else
8338 time_t now = time (NULL);
8340 if (now != (time_t)-1)
8341 ret = (unsigned) now;
8343 #endif
8345 return ret ^ getpid();
8348 /* %:compare-debug-dump-opt spec function. Save the last argument,
8349 expected to be the last -fdump-final-insns option, or generate a
8350 temporary. */
8352 static const char *
8353 compare_debug_dump_opt_spec_function (int arg,
8354 const char **argv ATTRIBUTE_UNUSED)
8356 char *ret;
8357 char *name;
8358 int which;
8359 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
8361 if (arg != 0)
8362 fatal_error ("too many arguments to %%:compare-debug-dump-opt");
8364 do_spec_2 ("%{fdump-final-insns=*:%*}");
8365 do_spec_1 (" ", 0, NULL);
8367 if (argbuf.length () > 0
8368 && strcmp (argv[argbuf.length () - 1], "."))
8370 if (!compare_debug)
8371 return NULL;
8373 name = xstrdup (argv[argbuf.length () - 1]);
8374 ret = NULL;
8376 else
8378 const char *ext = NULL;
8380 if (argbuf.length () > 0)
8382 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
8383 ext = ".gkd";
8385 else if (!compare_debug)
8386 return NULL;
8387 else
8388 do_spec_2 ("%g.gkd");
8390 do_spec_1 (" ", 0, NULL);
8392 gcc_assert (argbuf.length () > 0);
8394 name = concat (argbuf.last (), ext, NULL);
8396 ret = concat ("-fdump-final-insns=", name, NULL);
8399 which = compare_debug < 0;
8400 debug_check_temp_file[which] = name;
8402 if (!which)
8404 unsigned HOST_WIDE_INT value = get_random_number ();
8406 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
8409 if (*random_seed)
8411 char *tmp = ret;
8412 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
8413 ret, NULL);
8414 free (tmp);
8417 if (which)
8418 *random_seed = 0;
8420 return ret;
8423 static const char *debug_auxbase_opt;
8425 /* %:compare-debug-self-opt spec function. Expands to the options
8426 that are to be passed in the second compilation of
8427 compare-debug. */
8429 static const char *
8430 compare_debug_self_opt_spec_function (int arg,
8431 const char **argv ATTRIBUTE_UNUSED)
8433 if (arg != 0)
8434 fatal_error ("too many arguments to %%:compare-debug-self-opt");
8436 if (compare_debug >= 0)
8437 return NULL;
8439 do_spec_2 ("%{c|S:%{o*:%*}}");
8440 do_spec_1 (" ", 0, NULL);
8442 if (argbuf.length () > 0)
8443 debug_auxbase_opt = concat ("-auxbase-strip ",
8444 argbuf.last (),
8445 NULL);
8446 else
8447 debug_auxbase_opt = NULL;
8449 return concat ("\
8450 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
8451 %<fdump-final-insns=* -w -S -o %j \
8452 %{!fcompare-debug-second:-fcompare-debug-second} \
8453 ", compare_debug_opt, NULL);
8456 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
8457 options that are to be passed in the second compilation of
8458 compare-debug. It expects, as an argument, the basename of the
8459 current input file name, with the .gk suffix appended to it. */
8461 static const char *
8462 compare_debug_auxbase_opt_spec_function (int arg,
8463 const char **argv)
8465 char *name;
8466 int len;
8468 if (arg == 0)
8469 fatal_error ("too few arguments to %%:compare-debug-auxbase-opt");
8471 if (arg != 1)
8472 fatal_error ("too many arguments to %%:compare-debug-auxbase-opt");
8474 if (compare_debug >= 0)
8475 return NULL;
8477 len = strlen (argv[0]);
8478 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
8479 fatal_error ("argument to %%:compare-debug-auxbase-opt "
8480 "does not end in .gk");
8482 if (debug_auxbase_opt)
8483 return debug_auxbase_opt;
8485 #define OPT "-auxbase "
8487 len -= 3;
8488 name = (char*) xmalloc (sizeof (OPT) + len);
8489 memcpy (name, OPT, sizeof (OPT) - 1);
8490 memcpy (name + sizeof (OPT) - 1, argv[0], len);
8491 name[sizeof (OPT) - 1 + len] = '\0';
8493 #undef OPT
8495 return name;
8498 /* %:pass-through-libs spec function. Finds all -l options and input
8499 file names in the lib spec passed to it, and makes a list of them
8500 prepended with the plugin option to cause them to be passed through
8501 to the final link after all the new object files have been added. */
8503 const char *
8504 pass_through_libs_spec_func (int argc, const char **argv)
8506 char *prepended = xstrdup (" ");
8507 int n;
8508 /* Shlemiel the painter's algorithm. Innately horrible, but at least
8509 we know that there will never be more than a handful of strings to
8510 concat, and it's only once per run, so it's not worth optimising. */
8511 for (n = 0; n < argc; n++)
8513 char *old = prepended;
8514 /* Anything that isn't an option is a full path to an output
8515 file; pass it through if it ends in '.a'. Among options,
8516 pass only -l. */
8517 if (argv[n][0] == '-' && argv[n][1] == 'l')
8519 const char *lopt = argv[n] + 2;
8520 /* Handle both joined and non-joined -l options. If for any
8521 reason there's a trailing -l with no joined or following
8522 arg just discard it. */
8523 if (!*lopt && ++n >= argc)
8524 break;
8525 else if (!*lopt)
8526 lopt = argv[n];
8527 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
8528 lopt, " ", NULL);
8530 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
8532 prepended = concat (prepended, "-plugin-opt=-pass-through=",
8533 argv[n], " ", NULL);
8535 if (prepended != old)
8536 free (old);
8538 return prepended;
8541 /* %:replace-extension spec function. Replaces the extension of the
8542 first argument with the second argument. */
8544 const char *
8545 replace_extension_spec_func (int argc, const char **argv)
8547 char *name;
8548 char *p;
8549 char *result;
8550 int i;
8552 if (argc != 2)
8553 fatal_error ("too few arguments to %%:replace-extension");
8555 name = xstrdup (argv[0]);
8557 for (i = strlen(name) - 1; i >= 0; i--)
8558 if (IS_DIR_SEPARATOR (name[i]))
8559 break;
8561 p = strrchr (name + i + 1, '.');
8562 if (p != NULL)
8563 *p = '\0';
8565 result = concat (name, argv[1], NULL);
8567 free (name);
8568 return result;
8571 /* Insert backslash before spaces in ORIG (usually a file path), to
8572 avoid being broken by spec parser.
8574 This function is needed as do_spec_1 treats white space (' ' and '\t')
8575 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
8576 the file name should be treated as a single argument rather than being
8577 broken into multiple. Solution is to insert '\\' before the space in a
8578 file name.
8580 This function converts and only converts all occurrence of ' '
8581 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
8582 "a b" -> "a\\ b"
8583 "a b" -> "a\\ \\ b"
8584 "a\tb" -> "a\\\tb"
8585 "a\\ b" -> "a\\\\ b"
8587 orig: input null-terminating string that was allocated by xalloc. The
8588 memory it points to might be freed in this function. Behavior undefined
8589 if ORIG wasn't xalloced or was freed already at entry.
8591 Return: ORIG if no conversion needed. Otherwise a newly allocated string
8592 that was converted from ORIG. */
8594 static char *
8595 convert_white_space (char *orig)
8597 int len, number_of_space = 0;
8599 for (len = 0; orig[len]; len++)
8600 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
8602 if (number_of_space)
8604 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
8605 int j, k;
8606 for (j = 0, k = 0; j <= len; j++, k++)
8608 if (orig[j] == ' ' || orig[j] == '\t')
8609 new_spec[k++] = '\\';
8610 new_spec[k] = orig[j];
8612 free (orig);
8613 return new_spec;
8615 else
8616 return orig;