PR libstdc++/56278
[official-gcc.git] / gcc / gcc.c
blob5022789609c6e71dbadb3bc64138dc6493ec5f03
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 **);
269 /* The Specs Language
271 Specs are strings containing lines, each of which (if not blank)
272 is made up of a program name, and arguments separated by spaces.
273 The program name must be exact and start from root, since no path
274 is searched and it is unreliable to depend on the current working directory.
275 Redirection of input or output is not supported; the subprograms must
276 accept filenames saying what files to read and write.
278 In addition, the specs can contain %-sequences to substitute variable text
279 or for conditional text. Here is a table of all defined %-sequences.
280 Note that spaces are not generated automatically around the results of
281 expanding these sequences; therefore, you can concatenate them together
282 or with constant text in a single argument.
284 %% substitute one % into the program name or argument.
285 %i substitute the name of the input file being processed.
286 %b substitute the basename of the input file being processed.
287 This is the substring up to (and not including) the last period
288 and not including the directory unless -save-temps was specified
289 to put temporaries in a different location.
290 %B same as %b, but include the file suffix (text after the last period).
291 %gSUFFIX
292 substitute a file name that has suffix SUFFIX and is chosen
293 once per compilation, and mark the argument a la %d. To reduce
294 exposure to denial-of-service attacks, the file name is now
295 chosen in a way that is hard to predict even when previously
296 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
297 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
298 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
299 had been pre-processed. Previously, %g was simply substituted
300 with a file name chosen once per compilation, without regard
301 to any appended suffix (which was therefore treated just like
302 ordinary text), making such attacks more likely to succeed.
303 %|SUFFIX
304 like %g, but if -pipe is in effect, expands simply to "-".
305 %mSUFFIX
306 like %g, but if -pipe is in effect, expands to nothing. (We have both
307 %| and %m to accommodate differences between system assemblers; see
308 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
309 %uSUFFIX
310 like %g, but generates a new temporary file name even if %uSUFFIX
311 was already seen.
312 %USUFFIX
313 substitutes the last file name generated with %uSUFFIX, generating a
314 new one if there is no such last file name. In the absence of any
315 %uSUFFIX, this is just like %gSUFFIX, except they don't share
316 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
317 would involve the generation of two distinct file names, one
318 for each `%g.s' and another for each `%U.s'. Previously, %U was
319 simply substituted with a file name chosen for the previous %u,
320 without regard to any appended suffix.
321 %jSUFFIX
322 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
323 writable, and if save-temps is off; otherwise, substitute the name
324 of a temporary file, just like %u. This temporary file is not
325 meant for communication between processes, but rather as a junk
326 disposal mechanism.
327 %.SUFFIX
328 substitutes .SUFFIX for the suffixes of a matched switch's args when
329 it is subsequently output with %*. SUFFIX is terminated by the next
330 space or %.
331 %d marks the argument containing or following the %d as a
332 temporary file name, so that that file will be deleted if GCC exits
333 successfully. Unlike %g, this contributes no text to the argument.
334 %w marks the argument containing or following the %w as the
335 "output file" of this compilation. This puts the argument
336 into the sequence of arguments that %o will substitute later.
337 %V indicates that this compilation produces no "output file".
338 %W{...}
339 like %{...} but mark last argument supplied within
340 as a file to be deleted on failure.
341 %o substitutes the names of all the output files, with spaces
342 automatically placed around them. You should write spaces
343 around the %o as well or the results are undefined.
344 %o is for use in the specs for running the linker.
345 Input files whose names have no recognized suffix are not compiled
346 at all, but they are included among the output files, so they will
347 be linked.
348 %O substitutes the suffix for object files. Note that this is
349 handled specially when it immediately follows %g, %u, or %U
350 (with or without a suffix argument) because of the need for
351 those to form complete file names. The handling is such that
352 %O is treated exactly as if it had already been substituted,
353 except that %g, %u, and %U do not currently support additional
354 SUFFIX characters following %O as they would following, for
355 example, `.o'.
356 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
357 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
358 and -B options) and -imultilib as necessary.
359 %s current argument is the name of a library or startup file of some sort.
360 Search for that file in a standard list of directories
361 and substitute the full name found.
362 %eSTR Print STR as an error message. STR is terminated by a newline.
363 Use this when inconsistent options are detected.
364 %nSTR Print STR as a notice. STR is terminated by a newline.
365 %x{OPTION} Accumulate an option for %X.
366 %X Output the accumulated linker options specified by compilations.
367 %Y Output the accumulated assembler options specified by compilations.
368 %Z Output the accumulated preprocessor options specified by compilations.
369 %a process ASM_SPEC as a spec.
370 This allows config.h to specify part of the spec for running as.
371 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
372 used here. This can be used to run a post-processor after the
373 assembler has done its job.
374 %D Dump out a -L option for each directory in startfile_prefixes.
375 If multilib_dir is set, extra entries are generated with it affixed.
376 %l process LINK_SPEC as a spec.
377 %L process LIB_SPEC as a spec.
378 %M Output multilib_os_dir.
379 %G process LIBGCC_SPEC as a spec.
380 %R Output the concatenation of target_system_root and
381 target_sysroot_suffix.
382 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
383 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
384 %C process CPP_SPEC as a spec.
385 %1 process CC1_SPEC as a spec.
386 %2 process CC1PLUS_SPEC as a spec.
387 %* substitute the variable part of a matched option. (See below.)
388 Note that each comma in the substituted string is replaced by
389 a single space.
390 %<S remove all occurrences of -S from the command line.
391 Note - this command is position dependent. % commands in the
392 spec string before this one will see -S, % commands in the
393 spec string after this one will not.
394 %>S Similar to "%<S", but keep it in the GCC command line.
395 %<S* remove all occurrences of all switches beginning with -S from the
396 command line.
397 %:function(args)
398 Call the named function FUNCTION, passing it ARGS. ARGS is
399 first processed as a nested spec string, then split into an
400 argument vector in the usual fashion. The function returns
401 a string which is processed as if it had appeared literally
402 as part of the current spec.
403 %{S} substitutes the -S switch, if that switch was given to GCC.
404 If that switch was not specified, this substitutes nothing.
405 Here S is a metasyntactic variable.
406 %{S*} substitutes all the switches specified to GCC whose names start
407 with -S. This is used for -o, -I, etc; switches that take
408 arguments. GCC considers `-o foo' as being one switch whose
409 name starts with `o'. %{o*} would substitute this text,
410 including the space; thus, two arguments would be generated.
411 %{S*&T*} likewise, but preserve order of S and T options (the order
412 of S and T in the spec is not significant). Can be any number
413 of ampersand-separated variables; for each the wild card is
414 optional. Useful for CPP as %{D*&U*&A*}.
416 %{S:X} substitutes X, if the -S switch was given to GCC.
417 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
418 %{S*:X} substitutes X if one or more switches whose names start
419 with -S was given to GCC. Normally X is substituted only
420 once, no matter how many such switches appeared. However,
421 if %* appears somewhere in X, then X will be substituted
422 once for each matching switch, with the %* replaced by the
423 part of that switch that matched the '*'.
424 %{.S:X} substitutes X, if processing a file with suffix S.
425 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
426 %{,S:X} substitutes X, if processing a file which will use spec S.
427 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
429 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
430 combined with '!', '.', ',', and '*' as above binding stronger
431 than the OR.
432 If %* appears in X, all of the alternatives must be starred, and
433 only the first matching alternative is substituted.
434 %{S:X; if S was given to GCC, substitutes X;
435 T:Y; else if T was given to GCC, substitutes Y;
436 :D} else substitutes D. There can be as many clauses as you need.
437 This may be combined with '.', '!', ',', '|', and '*' as above.
439 %(Spec) processes a specification defined in a specs file as *Spec:
441 The conditional text X in a %{S:X} or similar construct may contain
442 other nested % constructs or spaces, or even newlines. They are
443 processed as usual, as described above. Trailing white space in X is
444 ignored. White space may also appear anywhere on the left side of the
445 colon in these constructs, except between . or * and the corresponding
446 word.
448 The -O, -f, -g, -m, and -W switches are handled specifically in these
449 constructs. If another value of -O or the negated form of a -f, -m, or
450 -W switch is found later in the command line, the earlier switch
451 value is ignored, except with {S*} where S is just one letter; this
452 passes all matching options.
454 The character | at the beginning of the predicate text is used to indicate
455 that a command should be piped to the following command, but only if -pipe
456 is specified.
458 Note that it is built into GCC which switches take arguments and which
459 do not. You might think it would be useful to generalize this to
460 allow each compiler's spec to say which switches take arguments. But
461 this cannot be done in a consistent fashion. GCC cannot even decide
462 which input files have been specified without knowing which switches
463 take arguments, and it must know which input files to compile in order
464 to tell which compilers to run.
466 GCC also knows implicitly that arguments starting in `-l' are to be
467 treated as compiler output files, and passed to the linker in their
468 proper position among the other output files. */
470 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
472 /* config.h can define ASM_SPEC to provide extra args to the assembler
473 or extra switch-translations. */
474 #ifndef ASM_SPEC
475 #define ASM_SPEC ""
476 #endif
478 /* config.h can define ASM_FINAL_SPEC to run a post processor after
479 the assembler has run. */
480 #ifndef ASM_FINAL_SPEC
481 #define ASM_FINAL_SPEC \
482 "%{gsplit-dwarf: \n\
483 objcopy --extract-dwo \
484 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
485 %{c:%{o*:%:replace-extension(%{o*:%*} .dwo)}%{!o*:%b.dwo}}%{!c:%b.dwo} \n\
486 objcopy --strip-dwo \
487 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
489 #endif
491 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
492 or extra switch-translations. */
493 #ifndef CPP_SPEC
494 #define CPP_SPEC ""
495 #endif
497 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
498 or extra switch-translations. */
499 #ifndef CC1_SPEC
500 #define CC1_SPEC ""
501 #endif
503 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
504 or extra switch-translations. */
505 #ifndef CC1PLUS_SPEC
506 #define CC1PLUS_SPEC ""
507 #endif
509 /* config.h can define LINK_SPEC to provide extra args to the linker
510 or extra switch-translations. */
511 #ifndef LINK_SPEC
512 #define LINK_SPEC ""
513 #endif
515 /* config.h can define LIB_SPEC to override the default libraries. */
516 #ifndef LIB_SPEC
517 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
518 #endif
520 /* mudflap specs */
521 #ifndef MFWRAP_SPEC
522 /* XXX: valid only for GNU ld */
523 /* XXX: should exactly match hooks provided by libmudflap.a */
524 #define MFWRAP_SPEC " %{static: %{fmudflap|fmudflapth: \
525 --wrap=malloc --wrap=free --wrap=calloc --wrap=realloc\
526 --wrap=mmap --wrap=mmap64 --wrap=munmap --wrap=alloca\
527 } %{fmudflapth: --wrap=pthread_create\
528 }} %{fmudflap|fmudflapth: --wrap=main}"
529 #endif
530 #ifndef MFLIB_SPEC
531 #define MFLIB_SPEC "%{fmudflap|fmudflapth: -export-dynamic}"
532 #endif
534 /* When using -fsplit-stack we need to wrap pthread_create, in order
535 to initialize the stack guard. We always use wrapping, rather than
536 shared library ordering, and we keep the wrapper function in
537 libgcc. This is not yet a real spec, though it could become one;
538 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
539 only works with GNU ld and gold. FIXME: This is incompatible with
540 -fmudflap when linking statically, which wants to do its own
541 wrapping. */
542 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
544 #ifndef LIBASAN_SPEC
545 #ifdef STATIC_LIBASAN_LIBS
546 #define ADD_STATIC_LIBASAN_LIBS \
547 " %{static-libasan:" STATIC_LIBASAN_LIBS "}"
548 #else
549 #define ADD_STATIC_LIBASAN_LIBS
550 #endif
551 #ifdef LIBASAN_EARLY_SPEC
552 #define LIBASAN_SPEC ADD_STATIC_LIBASAN_LIBS
553 #elif defined(HAVE_LD_STATIC_DYNAMIC)
554 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
555 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
556 ADD_STATIC_LIBASAN_LIBS
557 #else
558 #define LIBASAN_SPEC "-lasan" ADD_STATIC_LIBASAN_LIBS
559 #endif
560 #endif
562 #ifndef LIBASAN_EARLY_SPEC
563 #define LIBASAN_EARLY_SPEC ""
564 #endif
566 #ifndef LIBTSAN_SPEC
567 #ifdef STATIC_LIBTSAN_LIBS
568 #define ADD_STATIC_LIBTSAN_LIBS \
569 " %{static-libtsan:" STATIC_LIBTSAN_LIBS "}"
570 #else
571 #define ADD_STATIC_LIBTSAN_LIBS
572 #endif
573 #ifdef LIBTSAN_EARLY_SPEC
574 #define LIBTSAN_SPEC ADD_STATIC_LIBTSAN_LIBS
575 #elif defined(HAVE_LD_STATIC_DYNAMIC)
576 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
577 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
578 ADD_STATIC_LIBTSAN_LIBS
579 #else
580 #define LIBTSAN_SPEC "-ltsan" ADD_STATIC_LIBTSAN_LIBS
581 #endif
582 #endif
584 #ifndef LIBTSAN_EARLY_SPEC
585 #define LIBTSAN_EARLY_SPEC ""
586 #endif
588 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
589 included. */
590 #ifndef LIBGCC_SPEC
591 #if defined(REAL_LIBGCC_SPEC)
592 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
593 #elif defined(LINK_LIBGCC_SPECIAL_1)
594 /* Have gcc do the search for libgcc.a. */
595 #define LIBGCC_SPEC "libgcc.a%s"
596 #else
597 #define LIBGCC_SPEC "-lgcc"
598 #endif
599 #endif
601 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
602 #ifndef STARTFILE_SPEC
603 #define STARTFILE_SPEC \
604 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
605 #endif
607 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
608 #ifndef ENDFILE_SPEC
609 #define ENDFILE_SPEC ""
610 #endif
612 #ifndef LINKER_NAME
613 #define LINKER_NAME "collect2"
614 #endif
616 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
617 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
618 #else
619 #define ASM_MAP ""
620 #endif
622 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
623 to the assembler. */
624 #ifndef ASM_DEBUG_SPEC
625 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
626 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
627 # define ASM_DEBUG_SPEC \
628 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
629 ? "%{!g0:%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}}" ASM_MAP \
630 : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
631 # else
632 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
633 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
634 # endif
635 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
636 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
637 # endif
638 # endif
639 #endif
640 #ifndef ASM_DEBUG_SPEC
641 # define ASM_DEBUG_SPEC ""
642 #endif
644 /* Here is the spec for running the linker, after compiling all files. */
646 /* This is overridable by the target in case they need to specify the
647 -lgcc and -lc order specially, yet not require them to override all
648 of LINK_COMMAND_SPEC. */
649 #ifndef LINK_GCC_C_SEQUENCE_SPEC
650 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
651 #endif
653 #ifndef LINK_SSP_SPEC
654 #ifdef TARGET_LIBC_PROVIDES_SSP
655 #define LINK_SSP_SPEC "%{fstack-protector:}"
656 #else
657 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all:-lssp_nonshared -lssp}"
658 #endif
659 #endif
661 #ifndef LINK_PIE_SPEC
662 #ifdef HAVE_LD_PIE
663 #define LINK_PIE_SPEC "%{pie:-pie} "
664 #else
665 #define LINK_PIE_SPEC "%{pie:} "
666 #endif
667 #endif
669 #ifndef LINK_BUILDID_SPEC
670 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
671 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
672 # endif
673 #endif
675 /* Conditional to test whether the LTO plugin is used or not.
676 FIXME: For slim LTO we will need to enable plugin unconditionally. This
677 still cause problems with PLUGIN_LD != LD and when plugin is built but
678 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
679 plugin only when LTO is enabled. We still honor explicit
680 -fuse-linker-plugin if the linker used understands -plugin. */
682 /* The linker has some plugin support. */
683 #if HAVE_LTO_PLUGIN > 0
684 /* The linker used has full plugin support, use LTO plugin by default. */
685 #if HAVE_LTO_PLUGIN == 2
686 #define PLUGIN_COND "!fno-use-linker-plugin:%{flto|flto=*|fuse-linker-plugin"
687 #define PLUGIN_COND_CLOSE "}"
688 #else
689 /* The linker used has limited plugin support, use LTO plugin with explicit
690 -fuse-linker-plugin. */
691 #define PLUGIN_COND "fuse-linker-plugin"
692 #define PLUGIN_COND_CLOSE ""
693 #endif
694 #define LINK_PLUGIN_SPEC \
695 "%{"PLUGIN_COND": \
696 -plugin %(linker_plugin_file) \
697 -plugin-opt=%(lto_wrapper) \
698 -plugin-opt=-fresolution=%u.res \
699 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
700 }"PLUGIN_COND_CLOSE
701 #else
702 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
703 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
704 %e-fuse-linker-plugin is not supported in this configuration}"
705 #endif
707 /* Linker command line options for -fsanitize= early on the command line. */
708 #ifndef SANITIZER_EARLY_SPEC
709 #define SANITIZER_EARLY_SPEC "\
710 %{!nostdlib:%{!nodefaultlibs:%{fsanitize=address:" LIBASAN_EARLY_SPEC "} \
711 %{fsanitize=thread:" LIBTSAN_EARLY_SPEC "}}}"
712 #endif
714 /* Linker command line options for -fsanitize= late on the command line. */
715 #ifndef SANITIZER_SPEC
716 #define SANITIZER_SPEC "\
717 %{!nostdlib:%{!nodefaultlibs:%{fsanitize=address:" LIBASAN_SPEC "\
718 %{static:%ecannot specify -static with -fsanitize=address}}\
719 %{fsanitize=thread:" LIBTSAN_SPEC "\
720 %{!pie:%{!shared:%e-fsanitize=thread linking must be done with -pie or -shared}}}}}"
721 #endif
723 /* -u* was put back because both BSD and SysV seem to support it. */
724 /* %{static:} simply prevents an error message if the target machine
725 doesn't handle -static. */
726 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
727 scripts which exist in user specified directories, or in standard
728 directories. */
729 /* We pass any -flto flags on to the linker, which is expected
730 to understand them. In practice, this means it had better be collect2. */
731 /* %{e*} includes -export-dynamic; see comment in common.opt. */
732 #ifndef LINK_COMMAND_SPEC
733 #define LINK_COMMAND_SPEC "\
734 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
735 %(linker) " \
736 LINK_PLUGIN_SPEC \
737 "%{flto|flto=*:%<fcompare-debug*} \
738 %{flto} %{flto=*} %l " LINK_PIE_SPEC \
739 "%{fuse-ld=*:-fuse-ld=%*}\
740 %X %{o*} %{e*} %{N} %{n} %{r}\
741 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}}\
742 %{static:} %{L*} %(mfwrap) %(link_libgcc) " SANITIZER_EARLY_SPEC " %o\
743 %{fopenmp|ftree-parallelize-loops=*:%:include(libgomp.spec)%(link_gomp)}\
744 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
745 %(mflib) " STACK_SPLIT_SPEC "\
746 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
747 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
748 %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
749 #endif
751 #ifndef LINK_LIBGCC_SPEC
752 /* Generate -L options for startfile prefix list. */
753 # define LINK_LIBGCC_SPEC "%D"
754 #endif
756 #ifndef STARTFILE_PREFIX_SPEC
757 # define STARTFILE_PREFIX_SPEC ""
758 #endif
760 #ifndef SYSROOT_SPEC
761 # define SYSROOT_SPEC "--sysroot=%R"
762 #endif
764 #ifndef SYSROOT_SUFFIX_SPEC
765 # define SYSROOT_SUFFIX_SPEC ""
766 #endif
768 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
769 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
770 #endif
772 static const char *asm_debug = ASM_DEBUG_SPEC;
773 static const char *cpp_spec = CPP_SPEC;
774 static const char *cc1_spec = CC1_SPEC;
775 static const char *cc1plus_spec = CC1PLUS_SPEC;
776 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
777 static const char *link_ssp_spec = LINK_SSP_SPEC;
778 static const char *asm_spec = ASM_SPEC;
779 static const char *asm_final_spec = ASM_FINAL_SPEC;
780 static const char *link_spec = LINK_SPEC;
781 static const char *lib_spec = LIB_SPEC;
782 static const char *mfwrap_spec = MFWRAP_SPEC;
783 static const char *mflib_spec = MFLIB_SPEC;
784 static const char *link_gomp_spec = "";
785 static const char *libgcc_spec = LIBGCC_SPEC;
786 static const char *endfile_spec = ENDFILE_SPEC;
787 static const char *startfile_spec = STARTFILE_SPEC;
788 static const char *linker_name_spec = LINKER_NAME;
789 static const char *linker_plugin_file_spec = "";
790 static const char *lto_wrapper_spec = "";
791 static const char *lto_gcc_spec = "";
792 static const char *link_command_spec = LINK_COMMAND_SPEC;
793 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
794 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
795 static const char *sysroot_spec = SYSROOT_SPEC;
796 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
797 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
798 static const char *self_spec = "";
800 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
801 There should be no need to override these in target dependent files,
802 but we need to copy them to the specs file so that newer versions
803 of the GCC driver can correctly drive older tool chains with the
804 appropriate -B options. */
806 /* When cpplib handles traditional preprocessing, get rid of this, and
807 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
808 that we default the front end language better. */
809 static const char *trad_capable_cpp =
810 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
812 /* We don't wrap .d files in %W{} since a missing .d file, and
813 therefore no dependency entry, confuses make into thinking a .o
814 file that happens to exist is up-to-date. */
815 static const char *cpp_unique_options =
816 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
817 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
818 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
819 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
820 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
821 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
822 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
823 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
824 %{fmudflap:-D_MUDFLAP -include mf-runtime.h}\
825 %{fmudflapth:-D_MUDFLAP -D_MUDFLAPTH -include mf-runtime.h}\
826 %{E|M|MM:%W{o*}}";
828 /* This contains cpp options which are common with cc1_options and are passed
829 only when preprocessing only to avoid duplication. We pass the cc1 spec
830 options to the preprocessor so that it the cc1 spec may manipulate
831 options used to set target flags. Those special target flags settings may
832 in turn cause preprocessor symbols to be defined specially. */
833 static const char *cpp_options =
834 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
835 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
836 %{undef} %{save-temps*:-fpch-preprocess}";
838 /* This contains cpp options which are not passed when the preprocessor
839 output will be used by another program. */
840 static const char *cpp_debug_options = "%{d*}";
842 /* NB: This is shared amongst all front-ends, except for Ada. */
843 static const char *cc1_options =
844 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
845 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
846 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
847 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
848 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
849 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
850 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
851 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
852 %{-target-help:--target-help}\
853 %{-version:--version}\
854 %{-help=*:--help=%*}\
855 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
856 %{fsyntax-only:-o %j} %{-param*}\
857 %{fmudflap|fmudflapth:-fno-builtin -fno-merge-constants}\
858 %{coverage:-fprofile-arcs -ftest-coverage}";
860 static const char *asm_options =
861 "%{-target-help:%:print-asm-header()} "
862 #if HAVE_GNU_AS
863 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
864 to the assembler equivalents. */
865 "%{v} %{w:-W} %{I*} "
866 #endif
867 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
869 static const char *invoke_as =
870 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
871 "%{!fwpa:\
872 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
873 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
875 #else
876 "%{!fwpa:\
877 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
878 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
880 #endif
882 /* Some compilers have limits on line lengths, and the multilib_select
883 and/or multilib_matches strings can be very long, so we build them at
884 run time. */
885 static struct obstack multilib_obstack;
886 static const char *multilib_select;
887 static const char *multilib_matches;
888 static const char *multilib_defaults;
889 static const char *multilib_exclusions;
890 static const char *multilib_reuse;
892 /* Check whether a particular argument is a default argument. */
894 #ifndef MULTILIB_DEFAULTS
895 #define MULTILIB_DEFAULTS { "" }
896 #endif
898 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
900 #ifndef DRIVER_SELF_SPECS
901 #define DRIVER_SELF_SPECS ""
902 #endif
904 /* Adding -fopenmp should imply pthreads. This is particularly important
905 for targets that use different start files and suchlike. */
906 #ifndef GOMP_SELF_SPECS
907 #define GOMP_SELF_SPECS "%{fopenmp|ftree-parallelize-loops=*: -pthread}"
908 #endif
910 /* Likewise for -fgnu-tm. */
911 #ifndef GTM_SELF_SPECS
912 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
913 #endif
915 static const char *const driver_self_specs[] = {
916 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
917 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS
920 #ifndef OPTION_DEFAULT_SPECS
921 #define OPTION_DEFAULT_SPECS { "", "" }
922 #endif
924 struct default_spec
926 const char *name;
927 const char *spec;
930 static const struct default_spec
931 option_default_specs[] = { OPTION_DEFAULT_SPECS };
933 struct user_specs
935 struct user_specs *next;
936 const char *filename;
939 static struct user_specs *user_specs_head, *user_specs_tail;
942 /* Record the mapping from file suffixes for compilation specs. */
944 struct compiler
946 const char *suffix; /* Use this compiler for input files
947 whose names end in this suffix. */
949 const char *spec; /* To use this compiler, run this spec. */
951 const char *cpp_spec; /* If non-NULL, substitute this spec
952 for `%C', rather than the usual
953 cpp_spec. */
954 const int combinable; /* If nonzero, compiler can deal with
955 multiple source files at once (IMA). */
956 const int needs_preprocessing; /* If nonzero, source files need to
957 be run through a preprocessor. */
960 /* Pointer to a vector of `struct compiler' that gives the spec for
961 compiling a file, based on its suffix.
962 A file that does not end in any of these suffixes will be passed
963 unchanged to the loader and nothing else will be done to it.
965 An entry containing two 0s is used to terminate the vector.
967 If multiple entries match a file, the last matching one is used. */
969 static struct compiler *compilers;
971 /* Number of entries in `compilers', not counting the null terminator. */
973 static int n_compilers;
975 /* The default list of file name suffixes and their compilation specs. */
977 static const struct compiler default_compilers[] =
979 /* Add lists of suffixes of known languages here. If those languages
980 were not present when we built the driver, we will hit these copies
981 and be given a more meaningful error than "file not used since
982 linking is not done". */
983 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
984 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
985 {".mii", "#Objective-C++", 0, 0, 0},
986 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
987 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
988 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
989 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
990 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
991 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
992 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
993 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
994 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
995 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
996 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
997 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
998 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
999 {".r", "#Ratfor", 0, 0, 0},
1000 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
1001 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
1002 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
1003 {".go", "#Go", 0, 1, 0},
1004 /* Next come the entries for C. */
1005 {".c", "@c", 0, 0, 1},
1006 {"@c",
1007 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1008 external preprocessor if -save-temps is given. */
1009 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1010 %{!E:%{!M:%{!MM:\
1011 %{traditional:\
1012 %eGNU C no longer supports -traditional without -E}\
1013 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1014 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1015 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1016 %(cc1_options)}\
1017 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1018 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1019 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1020 {"-",
1021 "%{!E:%e-E or -x required when input is from standard input}\
1022 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1023 {".h", "@c-header", 0, 0, 0},
1024 {"@c-header",
1025 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1026 external preprocessor if -save-temps is given. */
1027 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1028 %{!E:%{!M:%{!MM:\
1029 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1030 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1031 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1032 %(cc1_options)\
1033 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1034 %W{o*:--output-pch=%*}}%V}\
1035 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1036 cc1 %(cpp_unique_options) %(cc1_options)\
1037 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1038 %W{o*:--output-pch=%*}}%V}}}}}}", 0, 0, 0},
1039 {".i", "@cpp-output", 0, 0, 0},
1040 {"@cpp-output",
1041 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1042 {".s", "@assembler", 0, 0, 0},
1043 {"@assembler",
1044 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1045 {".sx", "@assembler-with-cpp", 0, 0, 0},
1046 {".S", "@assembler-with-cpp", 0, 0, 0},
1047 {"@assembler-with-cpp",
1048 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1049 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1050 %{E|M|MM:%(cpp_debug_options)}\
1051 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1052 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1053 #else
1054 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1055 %{E|M|MM:%(cpp_debug_options)}\
1056 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1057 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1058 #endif
1059 , 0, 0, 0},
1061 #include "specs.h"
1062 /* Mark end of table. */
1063 {0, 0, 0, 0, 0}
1066 /* Number of elements in default_compilers, not counting the terminator. */
1068 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1070 typedef char *char_p; /* For DEF_VEC_P. */
1072 /* A vector of options to give to the linker.
1073 These options are accumulated by %x,
1074 and substituted into the linker command with %X. */
1075 static vec<char_p> linker_options;
1077 /* A vector of options to give to the assembler.
1078 These options are accumulated by -Wa,
1079 and substituted into the assembler command with %Y. */
1080 static vec<char_p> assembler_options;
1082 /* A vector of options to give to the preprocessor.
1083 These options are accumulated by -Wp,
1084 and substituted into the preprocessor command with %Z. */
1085 static vec<char_p> preprocessor_options;
1087 static char *
1088 skip_whitespace (char *p)
1090 while (1)
1092 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1093 be considered whitespace. */
1094 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1095 return p + 1;
1096 else if (*p == '\n' || *p == ' ' || *p == '\t')
1097 p++;
1098 else if (*p == '#')
1100 while (*p != '\n')
1101 p++;
1102 p++;
1104 else
1105 break;
1108 return p;
1110 /* Structures to keep track of prefixes to try when looking for files. */
1112 struct prefix_list
1114 const char *prefix; /* String to prepend to the path. */
1115 struct prefix_list *next; /* Next in linked list. */
1116 int require_machine_suffix; /* Don't use without machine_suffix. */
1117 /* 2 means try both machine_suffix and just_machine_suffix. */
1118 int priority; /* Sort key - priority within list. */
1119 int os_multilib; /* 1 if OS multilib scheme should be used,
1120 0 for GCC multilib scheme. */
1123 struct path_prefix
1125 struct prefix_list *plist; /* List of prefixes to try */
1126 int max_len; /* Max length of a prefix in PLIST */
1127 const char *name; /* Name of this list (used in config stuff) */
1130 /* List of prefixes to try when looking for executables. */
1132 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1134 /* List of prefixes to try when looking for startup (crt0) files. */
1136 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1138 /* List of prefixes to try when looking for include files. */
1140 static struct path_prefix include_prefixes = { 0, 0, "include" };
1142 /* Suffix to attach to directories searched for commands.
1143 This looks like `MACHINE/VERSION/'. */
1145 static const char *machine_suffix = 0;
1147 /* Suffix to attach to directories searched for commands.
1148 This is just `MACHINE/'. */
1150 static const char *just_machine_suffix = 0;
1152 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1154 static const char *gcc_exec_prefix;
1156 /* Adjusted value of standard_libexec_prefix. */
1158 static const char *gcc_libexec_prefix;
1160 /* Default prefixes to attach to command names. */
1162 #ifndef STANDARD_STARTFILE_PREFIX_1
1163 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1164 #endif
1165 #ifndef STANDARD_STARTFILE_PREFIX_2
1166 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1167 #endif
1169 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1170 #undef MD_EXEC_PREFIX
1171 #undef MD_STARTFILE_PREFIX
1172 #undef MD_STARTFILE_PREFIX_1
1173 #endif
1175 /* If no prefixes defined, use the null string, which will disable them. */
1176 #ifndef MD_EXEC_PREFIX
1177 #define MD_EXEC_PREFIX ""
1178 #endif
1179 #ifndef MD_STARTFILE_PREFIX
1180 #define MD_STARTFILE_PREFIX ""
1181 #endif
1182 #ifndef MD_STARTFILE_PREFIX_1
1183 #define MD_STARTFILE_PREFIX_1 ""
1184 #endif
1186 /* These directories are locations set at configure-time based on the
1187 --prefix option provided to configure. Their initializers are
1188 defined in Makefile.in. These paths are not *directly* used when
1189 gcc_exec_prefix is set because, in that case, we know where the
1190 compiler has been installed, and use paths relative to that
1191 location instead. */
1192 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1193 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1194 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1195 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1197 /* For native compilers, these are well-known paths containing
1198 components that may be provided by the system. For cross
1199 compilers, these paths are not used. */
1200 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1201 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1202 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1203 static const char *const standard_startfile_prefix_1
1204 = STANDARD_STARTFILE_PREFIX_1;
1205 static const char *const standard_startfile_prefix_2
1206 = STANDARD_STARTFILE_PREFIX_2;
1208 /* A relative path to be used in finding the location of tools
1209 relative to the driver. */
1210 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1212 /* Subdirectory to use for locating libraries. Set by
1213 set_multilib_dir based on the compilation options. */
1215 static const char *multilib_dir;
1217 /* Subdirectory to use for locating libraries in OS conventions. Set by
1218 set_multilib_dir based on the compilation options. */
1220 static const char *multilib_os_dir;
1222 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1223 set_multilib_dir based on the compilation options. */
1225 static const char *multiarch_dir;
1227 /* Structure to keep track of the specs that have been defined so far.
1228 These are accessed using %(specname) in a compiler or link
1229 spec. */
1231 struct spec_list
1233 /* The following 2 fields must be first */
1234 /* to allow EXTRA_SPECS to be initialized */
1235 const char *name; /* name of the spec. */
1236 const char *ptr; /* available ptr if no static pointer */
1238 /* The following fields are not initialized */
1239 /* by EXTRA_SPECS */
1240 const char **ptr_spec; /* pointer to the spec itself. */
1241 struct spec_list *next; /* Next spec in linked list. */
1242 int name_len; /* length of the name */
1243 bool user_p; /* whether string come from file spec. */
1244 bool alloc_p; /* whether string was allocated */
1247 #define INIT_STATIC_SPEC(NAME,PTR) \
1248 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false }
1250 /* List of statically defined specs. */
1251 static struct spec_list static_specs[] =
1253 INIT_STATIC_SPEC ("asm", &asm_spec),
1254 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1255 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1256 INIT_STATIC_SPEC ("asm_options", &asm_options),
1257 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1258 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1259 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1260 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1261 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1262 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1263 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1264 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1265 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1266 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1267 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1268 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1269 INIT_STATIC_SPEC ("link", &link_spec),
1270 INIT_STATIC_SPEC ("lib", &lib_spec),
1271 INIT_STATIC_SPEC ("mfwrap", &mfwrap_spec),
1272 INIT_STATIC_SPEC ("mflib", &mflib_spec),
1273 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1274 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1275 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1276 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1277 INIT_STATIC_SPEC ("version", &compiler_version),
1278 INIT_STATIC_SPEC ("multilib", &multilib_select),
1279 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1280 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1281 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1282 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1283 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1284 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1285 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1286 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1287 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1288 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1289 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1290 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1291 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1292 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1293 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1294 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1295 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1296 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1297 INIT_STATIC_SPEC ("self_spec", &self_spec),
1300 #ifdef EXTRA_SPECS /* additional specs needed */
1301 /* Structure to keep track of just the first two args of a spec_list.
1302 That is all that the EXTRA_SPECS macro gives us. */
1303 struct spec_list_1
1305 const char *const name;
1306 const char *const ptr;
1309 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1310 static struct spec_list *extra_specs = (struct spec_list *) 0;
1311 #endif
1313 /* List of dynamically allocates specs that have been defined so far. */
1315 static struct spec_list *specs = (struct spec_list *) 0;
1317 /* List of static spec functions. */
1319 static const struct spec_function static_spec_functions[] =
1321 { "getenv", getenv_spec_function },
1322 { "if-exists", if_exists_spec_function },
1323 { "if-exists-else", if_exists_else_spec_function },
1324 { "replace-outfile", replace_outfile_spec_function },
1325 { "remove-outfile", remove_outfile_spec_function },
1326 { "version-compare", version_compare_spec_function },
1327 { "include", include_spec_function },
1328 { "find-file", find_file_spec_function },
1329 { "find-plugindir", find_plugindir_spec_function },
1330 { "print-asm-header", print_asm_header_spec_function },
1331 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1332 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1333 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1334 { "pass-through-libs", pass_through_libs_spec_func },
1335 { "replace-extension", replace_extension_spec_func },
1336 #ifdef EXTRA_SPEC_FUNCTIONS
1337 EXTRA_SPEC_FUNCTIONS
1338 #endif
1339 { 0, 0 }
1342 static int processing_spec_function;
1344 /* Add appropriate libgcc specs to OBSTACK, taking into account
1345 various permutations of -shared-libgcc, -shared, and such. */
1347 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1349 #ifndef USE_LD_AS_NEEDED
1350 #define USE_LD_AS_NEEDED 0
1351 #endif
1353 static void
1354 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1355 const char *static_name, const char *eh_name)
1357 char *buf;
1359 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1360 "%{!static:%{!static-libgcc:"
1361 #if USE_LD_AS_NEEDED
1362 "%{!shared-libgcc:",
1363 static_name, " --as-needed ", shared_name, " --no-as-needed"
1365 "%{shared-libgcc:",
1366 shared_name, "%{!shared: ", static_name, "}"
1368 #else
1369 "%{!shared:"
1370 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1371 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1373 #ifdef LINK_EH_SPEC
1374 "%{shared:"
1375 "%{shared-libgcc:", shared_name, "}"
1376 "%{!shared-libgcc:", static_name, "}"
1378 #else
1379 "%{shared:", shared_name, "}"
1380 #endif
1381 #endif
1382 "}}", NULL);
1384 obstack_grow (obstack, buf, strlen (buf));
1385 free (buf);
1387 #endif /* ENABLE_SHARED_LIBGCC */
1389 /* Initialize the specs lookup routines. */
1391 static void
1392 init_spec (void)
1394 struct spec_list *next = (struct spec_list *) 0;
1395 struct spec_list *sl = (struct spec_list *) 0;
1396 int i;
1398 if (specs)
1399 return; /* Already initialized. */
1401 if (verbose_flag)
1402 fnotice (stderr, "Using built-in specs.\n");
1404 #ifdef EXTRA_SPECS
1405 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1407 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1409 sl = &extra_specs[i];
1410 sl->name = extra_specs_1[i].name;
1411 sl->ptr = extra_specs_1[i].ptr;
1412 sl->next = next;
1413 sl->name_len = strlen (sl->name);
1414 sl->ptr_spec = &sl->ptr;
1415 next = sl;
1417 #endif
1419 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1421 sl = &static_specs[i];
1422 sl->next = next;
1423 next = sl;
1426 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1427 /* ??? If neither -shared-libgcc nor --static-libgcc was
1428 seen, then we should be making an educated guess. Some proposed
1429 heuristics for ELF include:
1431 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1432 program will be doing dynamic loading, which will likely
1433 need the shared libgcc.
1435 (2) If "-ldl", then it's also a fair bet that we're doing
1436 dynamic loading.
1438 (3) For each ET_DYN we're linking against (either through -lfoo
1439 or /some/path/foo.so), check to see whether it or one of
1440 its dependencies depends on a shared libgcc.
1442 (4) If "-shared"
1444 If the runtime is fixed to look for program headers instead
1445 of calling __register_frame_info at all, for each object,
1446 use the shared libgcc if any EH symbol referenced.
1448 If crtstuff is fixed to not invoke __register_frame_info
1449 automatically, for each object, use the shared libgcc if
1450 any non-empty unwind section found.
1452 Doing any of this probably requires invoking an external program to
1453 do the actual object file scanning. */
1455 const char *p = libgcc_spec;
1456 int in_sep = 1;
1458 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1459 when given the proper command line arguments. */
1460 while (*p)
1462 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1464 init_gcc_specs (&obstack,
1465 "-lgcc_s"
1466 #ifdef USE_LIBUNWIND_EXCEPTIONS
1467 " -lunwind"
1468 #endif
1470 "-lgcc",
1471 "-lgcc_eh"
1472 #ifdef USE_LIBUNWIND_EXCEPTIONS
1473 # ifdef HAVE_LD_STATIC_DYNAMIC
1474 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1475 " %{!static:" LD_DYNAMIC_OPTION "}"
1476 # else
1477 " -lunwind"
1478 # endif
1479 #endif
1482 p += 5;
1483 in_sep = 0;
1485 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1487 /* Ug. We don't know shared library extensions. Hope that
1488 systems that use this form don't do shared libraries. */
1489 init_gcc_specs (&obstack,
1490 "-lgcc_s",
1491 "libgcc.a%s",
1492 "libgcc_eh.a%s"
1493 #ifdef USE_LIBUNWIND_EXCEPTIONS
1494 " -lunwind"
1495 #endif
1497 p += 10;
1498 in_sep = 0;
1500 else
1502 obstack_1grow (&obstack, *p);
1503 in_sep = (*p == ' ');
1504 p += 1;
1508 obstack_1grow (&obstack, '\0');
1509 libgcc_spec = XOBFINISH (&obstack, const char *);
1511 #endif
1512 #ifdef USE_AS_TRADITIONAL_FORMAT
1513 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1515 static const char tf[] = "--traditional-format ";
1516 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1517 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1518 asm_spec = XOBFINISH (&obstack, const char *);
1520 #endif
1522 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1523 defined LINKER_HASH_STYLE
1524 # ifdef LINK_BUILDID_SPEC
1525 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1526 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof(LINK_BUILDID_SPEC) - 1);
1527 # endif
1528 # ifdef LINK_EH_SPEC
1529 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1530 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1531 # endif
1532 # ifdef LINKER_HASH_STYLE
1533 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1534 before. */
1536 static const char hash_style[] = "--hash-style=";
1537 obstack_grow (&obstack, hash_style, sizeof(hash_style) - 1);
1538 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof(LINKER_HASH_STYLE) - 1);
1539 obstack_1grow (&obstack, ' ');
1541 # endif
1542 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1543 link_spec = XOBFINISH (&obstack, const char *);
1544 #endif
1546 specs = sl;
1549 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1550 removed; If the spec starts with a + then SPEC is added to the end of the
1551 current spec. */
1553 static void
1554 set_spec (const char *name, const char *spec, bool user_p)
1556 struct spec_list *sl;
1557 const char *old_spec;
1558 int name_len = strlen (name);
1559 int i;
1561 /* If this is the first call, initialize the statically allocated specs. */
1562 if (!specs)
1564 struct spec_list *next = (struct spec_list *) 0;
1565 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1567 sl = &static_specs[i];
1568 sl->next = next;
1569 next = sl;
1571 specs = sl;
1574 /* See if the spec already exists. */
1575 for (sl = specs; sl; sl = sl->next)
1576 if (name_len == sl->name_len && !strcmp (sl->name, name))
1577 break;
1579 if (!sl)
1581 /* Not found - make it. */
1582 sl = XNEW (struct spec_list);
1583 sl->name = xstrdup (name);
1584 sl->name_len = name_len;
1585 sl->ptr_spec = &sl->ptr;
1586 sl->alloc_p = 0;
1587 *(sl->ptr_spec) = "";
1588 sl->next = specs;
1589 specs = sl;
1592 old_spec = *(sl->ptr_spec);
1593 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1594 ? concat (old_spec, spec + 1, NULL)
1595 : xstrdup (spec));
1597 #ifdef DEBUG_SPECS
1598 if (verbose_flag)
1599 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1600 #endif
1602 /* Free the old spec. */
1603 if (old_spec && sl->alloc_p)
1604 free (CONST_CAST(char *, old_spec));
1606 sl->user_p = user_p;
1607 sl->alloc_p = true;
1610 /* Accumulate a command (program name and args), and run it. */
1612 typedef const char *const_char_p; /* For DEF_VEC_P. */
1614 /* Vector of pointers to arguments in the current line of specifications. */
1616 static vec<const_char_p> argbuf;
1618 /* Position in the argbuf vector containing the name of the output file
1619 (the value associated with the "-o" flag). */
1621 static int have_o_argbuf_index = 0;
1623 /* Were the options -c, -S or -E passed. */
1624 static int have_c = 0;
1626 /* Was the option -o passed. */
1627 static int have_o = 0;
1629 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1630 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1631 it here. */
1633 static struct temp_name {
1634 const char *suffix; /* suffix associated with the code. */
1635 int length; /* strlen (suffix). */
1636 int unique; /* Indicates whether %g or %u/%U was used. */
1637 const char *filename; /* associated filename. */
1638 int filename_length; /* strlen (filename). */
1639 struct temp_name *next;
1640 } *temp_names;
1642 /* Number of commands executed so far. */
1644 static int execution_count;
1646 /* Number of commands that exited with a signal. */
1648 static int signal_count;
1650 /* Allocate the argument vector. */
1652 static void
1653 alloc_args (void)
1655 argbuf.create (10);
1658 /* Clear out the vector of arguments (after a command is executed). */
1660 static void
1661 clear_args (void)
1663 argbuf.truncate (0);
1666 /* Add one argument to the vector at the end.
1667 This is done when a space is seen or at the end of the line.
1668 If DELETE_ALWAYS is nonzero, the arg is a filename
1669 and the file should be deleted eventually.
1670 If DELETE_FAILURE is nonzero, the arg is a filename
1671 and the file should be deleted if this compilation fails. */
1673 static void
1674 store_arg (const char *arg, int delete_always, int delete_failure)
1676 argbuf.safe_push (arg);
1678 if (strcmp (arg, "-o") == 0)
1679 have_o_argbuf_index = argbuf.length ();
1680 if (delete_always || delete_failure)
1682 const char *p;
1683 /* If the temporary file we should delete is specified as
1684 part of a joined argument extract the filename. */
1685 if (arg[0] == '-'
1686 && (p = strrchr (arg, '=')))
1687 arg = p + 1;
1688 record_temp_file (arg, delete_always, delete_failure);
1692 /* Load specs from a file name named FILENAME, replacing occurrences of
1693 various different types of line-endings, \r\n, \n\r and just \r, with
1694 a single \n. */
1696 static char *
1697 load_specs (const char *filename)
1699 int desc;
1700 int readlen;
1701 struct stat statbuf;
1702 char *buffer;
1703 char *buffer_p;
1704 char *specs;
1705 char *specs_p;
1707 if (verbose_flag)
1708 fnotice (stderr, "Reading specs from %s\n", filename);
1710 /* Open and stat the file. */
1711 desc = open (filename, O_RDONLY, 0);
1712 if (desc < 0)
1713 pfatal_with_name (filename);
1714 if (stat (filename, &statbuf) < 0)
1715 pfatal_with_name (filename);
1717 /* Read contents of file into BUFFER. */
1718 buffer = XNEWVEC (char, statbuf.st_size + 1);
1719 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1720 if (readlen < 0)
1721 pfatal_with_name (filename);
1722 buffer[readlen] = 0;
1723 close (desc);
1725 specs = XNEWVEC (char, readlen + 1);
1726 specs_p = specs;
1727 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1729 int skip = 0;
1730 char c = *buffer_p;
1731 if (c == '\r')
1733 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1734 skip = 1;
1735 else if (*(buffer_p + 1) == '\n') /* \r\n */
1736 skip = 1;
1737 else /* \r */
1738 c = '\n';
1740 if (! skip)
1741 *specs_p++ = c;
1743 *specs_p = '\0';
1745 free (buffer);
1746 return (specs);
1749 /* Read compilation specs from a file named FILENAME,
1750 replacing the default ones.
1752 A suffix which starts with `*' is a definition for
1753 one of the machine-specific sub-specs. The "suffix" should be
1754 *asm, *cc1, *cpp, *link, *startfile, etc.
1755 The corresponding spec is stored in asm_spec, etc.,
1756 rather than in the `compilers' vector.
1758 Anything invalid in the file is a fatal error. */
1760 static void
1761 read_specs (const char *filename, bool main_p, bool user_p)
1763 char *buffer;
1764 char *p;
1766 buffer = load_specs (filename);
1768 /* Scan BUFFER for specs, putting them in the vector. */
1769 p = buffer;
1770 while (1)
1772 char *suffix;
1773 char *spec;
1774 char *in, *out, *p1, *p2, *p3;
1776 /* Advance P in BUFFER to the next nonblank nocomment line. */
1777 p = skip_whitespace (p);
1778 if (*p == 0)
1779 break;
1781 /* Is this a special command that starts with '%'? */
1782 /* Don't allow this for the main specs file, since it would
1783 encourage people to overwrite it. */
1784 if (*p == '%' && !main_p)
1786 p1 = p;
1787 while (*p && *p != '\n')
1788 p++;
1790 /* Skip '\n'. */
1791 p++;
1793 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1794 && (p1[sizeof "%include" - 1] == ' '
1795 || p1[sizeof "%include" - 1] == '\t'))
1797 char *new_filename;
1799 p1 += sizeof ("%include");
1800 while (*p1 == ' ' || *p1 == '\t')
1801 p1++;
1803 if (*p1++ != '<' || p[-2] != '>')
1804 fatal_error ("specs %%include syntax malformed after "
1805 "%ld characters",
1806 (long) (p1 - buffer + 1));
1808 p[-2] = '\0';
1809 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1810 read_specs (new_filename ? new_filename : p1, false, user_p);
1811 continue;
1813 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1814 && (p1[sizeof "%include_noerr" - 1] == ' '
1815 || p1[sizeof "%include_noerr" - 1] == '\t'))
1817 char *new_filename;
1819 p1 += sizeof "%include_noerr";
1820 while (*p1 == ' ' || *p1 == '\t')
1821 p1++;
1823 if (*p1++ != '<' || p[-2] != '>')
1824 fatal_error ("specs %%include syntax malformed after "
1825 "%ld characters",
1826 (long) (p1 - buffer + 1));
1828 p[-2] = '\0';
1829 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1830 if (new_filename)
1831 read_specs (new_filename, false, user_p);
1832 else if (verbose_flag)
1833 fnotice (stderr, "could not find specs file %s\n", p1);
1834 continue;
1836 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1837 && (p1[sizeof "%rename" - 1] == ' '
1838 || p1[sizeof "%rename" - 1] == '\t'))
1840 int name_len;
1841 struct spec_list *sl;
1842 struct spec_list *newsl;
1844 /* Get original name. */
1845 p1 += sizeof "%rename";
1846 while (*p1 == ' ' || *p1 == '\t')
1847 p1++;
1849 if (! ISALPHA ((unsigned char) *p1))
1850 fatal_error ("specs %%rename syntax malformed after "
1851 "%ld characters",
1852 (long) (p1 - buffer));
1854 p2 = p1;
1855 while (*p2 && !ISSPACE ((unsigned char) *p2))
1856 p2++;
1858 if (*p2 != ' ' && *p2 != '\t')
1859 fatal_error ("specs %%rename syntax malformed after "
1860 "%ld characters",
1861 (long) (p2 - buffer));
1863 name_len = p2 - p1;
1864 *p2++ = '\0';
1865 while (*p2 == ' ' || *p2 == '\t')
1866 p2++;
1868 if (! ISALPHA ((unsigned char) *p2))
1869 fatal_error ("specs %%rename syntax malformed after "
1870 "%ld characters",
1871 (long) (p2 - buffer));
1873 /* Get new spec name. */
1874 p3 = p2;
1875 while (*p3 && !ISSPACE ((unsigned char) *p3))
1876 p3++;
1878 if (p3 != p - 1)
1879 fatal_error ("specs %%rename syntax malformed after "
1880 "%ld characters",
1881 (long) (p3 - buffer));
1882 *p3 = '\0';
1884 for (sl = specs; sl; sl = sl->next)
1885 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1886 break;
1888 if (!sl)
1889 fatal_error ("specs %s spec was not found to be renamed", p1);
1891 if (strcmp (p1, p2) == 0)
1892 continue;
1894 for (newsl = specs; newsl; newsl = newsl->next)
1895 if (strcmp (newsl->name, p2) == 0)
1896 fatal_error ("%s: attempt to rename spec %qs to "
1897 "already defined spec %qs",
1898 filename, p1, p2);
1900 if (verbose_flag)
1902 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
1903 #ifdef DEBUG_SPECS
1904 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
1905 #endif
1908 set_spec (p2, *(sl->ptr_spec), user_p);
1909 if (sl->alloc_p)
1910 free (CONST_CAST (char *, *(sl->ptr_spec)));
1912 *(sl->ptr_spec) = "";
1913 sl->alloc_p = 0;
1914 continue;
1916 else
1917 fatal_error ("specs unknown %% command after %ld characters",
1918 (long) (p1 - buffer));
1921 /* Find the colon that should end the suffix. */
1922 p1 = p;
1923 while (*p1 && *p1 != ':' && *p1 != '\n')
1924 p1++;
1926 /* The colon shouldn't be missing. */
1927 if (*p1 != ':')
1928 fatal_error ("specs file malformed after %ld characters",
1929 (long) (p1 - buffer));
1931 /* Skip back over trailing whitespace. */
1932 p2 = p1;
1933 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
1934 p2--;
1936 /* Copy the suffix to a string. */
1937 suffix = save_string (p, p2 - p);
1938 /* Find the next line. */
1939 p = skip_whitespace (p1 + 1);
1940 if (p[1] == 0)
1941 fatal_error ("specs file malformed after %ld characters",
1942 (long) (p - buffer));
1944 p1 = p;
1945 /* Find next blank line or end of string. */
1946 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
1947 p1++;
1949 /* Specs end at the blank line and do not include the newline. */
1950 spec = save_string (p, p1 - p);
1951 p = p1;
1953 /* Delete backslash-newline sequences from the spec. */
1954 in = spec;
1955 out = spec;
1956 while (*in != 0)
1958 if (in[0] == '\\' && in[1] == '\n')
1959 in += 2;
1960 else if (in[0] == '#')
1961 while (*in && *in != '\n')
1962 in++;
1964 else
1965 *out++ = *in++;
1967 *out = 0;
1969 if (suffix[0] == '*')
1971 if (! strcmp (suffix, "*link_command"))
1972 link_command_spec = spec;
1973 else
1974 set_spec (suffix + 1, spec, user_p);
1976 else
1978 /* Add this pair to the vector. */
1979 compilers
1980 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
1982 compilers[n_compilers].suffix = suffix;
1983 compilers[n_compilers].spec = spec;
1984 n_compilers++;
1985 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
1988 if (*suffix == 0)
1989 link_command_spec = spec;
1992 if (link_command_spec == 0)
1993 fatal_error ("spec file has no spec for linking");
1996 /* Record the names of temporary files we tell compilers to write,
1997 and delete them at the end of the run. */
1999 /* This is the common prefix we use to make temp file names.
2000 It is chosen once for each run of this program.
2001 It is substituted into a spec by %g or %j.
2002 Thus, all temp file names contain this prefix.
2003 In practice, all temp file names start with this prefix.
2005 This prefix comes from the envvar TMPDIR if it is defined;
2006 otherwise, from the P_tmpdir macro if that is defined;
2007 otherwise, in /usr/tmp or /tmp;
2008 or finally the current directory if all else fails. */
2010 static const char *temp_filename;
2012 /* Length of the prefix. */
2014 static int temp_filename_length;
2016 /* Define the list of temporary files to delete. */
2018 struct temp_file
2020 const char *name;
2021 struct temp_file *next;
2024 /* Queue of files to delete on success or failure of compilation. */
2025 static struct temp_file *always_delete_queue;
2026 /* Queue of files to delete on failure of compilation. */
2027 static struct temp_file *failure_delete_queue;
2029 /* Record FILENAME as a file to be deleted automatically.
2030 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2031 otherwise delete it in any case.
2032 FAIL_DELETE nonzero means delete it if a compilation step fails;
2033 otherwise delete it in any case. */
2035 void
2036 record_temp_file (const char *filename, int always_delete, int fail_delete)
2038 char *const name = xstrdup (filename);
2040 if (always_delete)
2042 struct temp_file *temp;
2043 for (temp = always_delete_queue; temp; temp = temp->next)
2044 if (! filename_cmp (name, temp->name))
2045 goto already1;
2047 temp = XNEW (struct temp_file);
2048 temp->next = always_delete_queue;
2049 temp->name = name;
2050 always_delete_queue = temp;
2052 already1:;
2055 if (fail_delete)
2057 struct temp_file *temp;
2058 for (temp = failure_delete_queue; temp; temp = temp->next)
2059 if (! filename_cmp (name, temp->name))
2061 free (name);
2062 goto already2;
2065 temp = XNEW (struct temp_file);
2066 temp->next = failure_delete_queue;
2067 temp->name = name;
2068 failure_delete_queue = temp;
2070 already2:;
2074 /* Delete all the temporary files whose names we previously recorded. */
2076 #ifndef DELETE_IF_ORDINARY
2077 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2078 do \
2080 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2081 if (unlink (NAME) < 0) \
2082 if (VERBOSE_FLAG) \
2083 perror_with_name (NAME); \
2084 } while (0)
2085 #endif
2087 static void
2088 delete_if_ordinary (const char *name)
2090 struct stat st;
2091 #ifdef DEBUG
2092 int i, c;
2094 printf ("Delete %s? (y or n) ", name);
2095 fflush (stdout);
2096 i = getchar ();
2097 if (i != '\n')
2098 while ((c = getchar ()) != '\n' && c != EOF)
2101 if (i == 'y' || i == 'Y')
2102 #endif /* DEBUG */
2103 DELETE_IF_ORDINARY (name, st, verbose_flag);
2106 static void
2107 delete_temp_files (void)
2109 struct temp_file *temp;
2111 for (temp = always_delete_queue; temp; temp = temp->next)
2112 delete_if_ordinary (temp->name);
2113 always_delete_queue = 0;
2116 /* Delete all the files to be deleted on error. */
2118 static void
2119 delete_failure_queue (void)
2121 struct temp_file *temp;
2123 for (temp = failure_delete_queue; temp; temp = temp->next)
2124 delete_if_ordinary (temp->name);
2127 static void
2128 clear_failure_queue (void)
2130 failure_delete_queue = 0;
2133 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2134 returns non-NULL.
2135 If DO_MULTI is true iterate over the paths twice, first with multilib
2136 suffix then without, otherwise iterate over the paths once without
2137 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2138 to avoid visiting the same path twice, but we could do better. For
2139 instance, /usr/lib/../lib is considered different from /usr/lib.
2140 At least EXTRA_SPACE chars past the end of the path passed to
2141 CALLBACK are available for use by the callback.
2142 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2144 Returns the value returned by CALLBACK. */
2146 static void *
2147 for_each_path (const struct path_prefix *paths,
2148 bool do_multi,
2149 size_t extra_space,
2150 void *(*callback) (char *, void *),
2151 void *callback_info)
2153 struct prefix_list *pl;
2154 const char *multi_dir = NULL;
2155 const char *multi_os_dir = NULL;
2156 const char *multiarch_suffix = NULL;
2157 const char *multi_suffix;
2158 const char *just_multi_suffix;
2159 char *path = NULL;
2160 void *ret = NULL;
2161 bool skip_multi_dir = false;
2162 bool skip_multi_os_dir = false;
2164 multi_suffix = machine_suffix;
2165 just_multi_suffix = just_machine_suffix;
2166 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2168 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2169 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2170 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2172 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2173 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2174 if (multiarch_dir)
2175 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2177 while (1)
2179 size_t multi_dir_len = 0;
2180 size_t multi_os_dir_len = 0;
2181 size_t multiarch_len = 0;
2182 size_t suffix_len;
2183 size_t just_suffix_len;
2184 size_t len;
2186 if (multi_dir)
2187 multi_dir_len = strlen (multi_dir);
2188 if (multi_os_dir)
2189 multi_os_dir_len = strlen (multi_os_dir);
2190 if (multiarch_suffix)
2191 multiarch_len = strlen (multiarch_suffix);
2192 suffix_len = strlen (multi_suffix);
2193 just_suffix_len = strlen (just_multi_suffix);
2195 if (path == NULL)
2197 len = paths->max_len + extra_space + 1;
2198 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2199 path = XNEWVEC (char, len);
2202 for (pl = paths->plist; pl != 0; pl = pl->next)
2204 len = strlen (pl->prefix);
2205 memcpy (path, pl->prefix, len);
2207 /* Look first in MACHINE/VERSION subdirectory. */
2208 if (!skip_multi_dir)
2210 memcpy (path + len, multi_suffix, suffix_len + 1);
2211 ret = callback (path, callback_info);
2212 if (ret)
2213 break;
2216 /* Some paths are tried with just the machine (ie. target)
2217 subdir. This is used for finding as, ld, etc. */
2218 if (!skip_multi_dir
2219 && pl->require_machine_suffix == 2)
2221 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2222 ret = callback (path, callback_info);
2223 if (ret)
2224 break;
2227 /* Now try the multiarch path. */
2228 if (!skip_multi_dir
2229 && !pl->require_machine_suffix && multiarch_dir)
2231 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2232 ret = callback (path, callback_info);
2233 if (ret)
2234 break;
2237 /* Now try the base path. */
2238 if (!pl->require_machine_suffix
2239 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2241 const char *this_multi;
2242 size_t this_multi_len;
2244 if (pl->os_multilib)
2246 this_multi = multi_os_dir;
2247 this_multi_len = multi_os_dir_len;
2249 else
2251 this_multi = multi_dir;
2252 this_multi_len = multi_dir_len;
2255 if (this_multi_len)
2256 memcpy (path + len, this_multi, this_multi_len + 1);
2257 else
2258 path[len] = '\0';
2260 ret = callback (path, callback_info);
2261 if (ret)
2262 break;
2265 if (pl)
2266 break;
2268 if (multi_dir == NULL && multi_os_dir == NULL)
2269 break;
2271 /* Run through the paths again, this time without multilibs.
2272 Don't repeat any we have already seen. */
2273 if (multi_dir)
2275 free (CONST_CAST (char *, multi_dir));
2276 multi_dir = NULL;
2277 free (CONST_CAST (char *, multi_suffix));
2278 multi_suffix = machine_suffix;
2279 free (CONST_CAST (char *, just_multi_suffix));
2280 just_multi_suffix = just_machine_suffix;
2282 else
2283 skip_multi_dir = true;
2284 if (multi_os_dir)
2286 free (CONST_CAST (char *, multi_os_dir));
2287 multi_os_dir = NULL;
2289 else
2290 skip_multi_os_dir = true;
2293 if (multi_dir)
2295 free (CONST_CAST (char *, multi_dir));
2296 free (CONST_CAST (char *, multi_suffix));
2297 free (CONST_CAST (char *, just_multi_suffix));
2299 if (multi_os_dir)
2300 free (CONST_CAST (char *, multi_os_dir));
2301 if (ret != path)
2302 free (path);
2303 return ret;
2306 /* Callback for build_search_list. Adds path to obstack being built. */
2308 struct add_to_obstack_info {
2309 struct obstack *ob;
2310 bool check_dir;
2311 bool first_time;
2314 static void *
2315 add_to_obstack (char *path, void *data)
2317 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2319 if (info->check_dir && !is_directory (path, false))
2320 return NULL;
2322 if (!info->first_time)
2323 obstack_1grow (info->ob, PATH_SEPARATOR);
2325 obstack_grow (info->ob, path, strlen (path));
2327 info->first_time = false;
2328 return NULL;
2331 /* Add or change the value of an environment variable, outputting the
2332 change to standard error if in verbose mode. */
2333 static void
2334 xputenv (const char *string)
2336 if (verbose_flag)
2337 fnotice (stderr, "%s\n", string);
2338 putenv (CONST_CAST (char *, string));
2341 /* Build a list of search directories from PATHS.
2342 PREFIX is a string to prepend to the list.
2343 If CHECK_DIR_P is true we ensure the directory exists.
2344 If DO_MULTI is true, multilib paths are output first, then
2345 non-multilib paths.
2346 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2347 It is also used by the --print-search-dirs flag. */
2349 static char *
2350 build_search_list (const struct path_prefix *paths, const char *prefix,
2351 bool check_dir, bool do_multi)
2353 struct add_to_obstack_info info;
2355 info.ob = &collect_obstack;
2356 info.check_dir = check_dir;
2357 info.first_time = true;
2359 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2360 obstack_1grow (&collect_obstack, '=');
2362 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2364 obstack_1grow (&collect_obstack, '\0');
2365 return XOBFINISH (&collect_obstack, char *);
2368 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2369 for collect. */
2371 static void
2372 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2373 bool do_multi)
2375 xputenv (build_search_list (paths, env_var, true, do_multi));
2378 /* Check whether NAME can be accessed in MODE. This is like access,
2379 except that it never considers directories to be executable. */
2381 static int
2382 access_check (const char *name, int mode)
2384 if (mode == X_OK)
2386 struct stat st;
2388 if (stat (name, &st) < 0
2389 || S_ISDIR (st.st_mode))
2390 return -1;
2393 return access (name, mode);
2396 /* Callback for find_a_file. Appends the file name to the directory
2397 path. If the resulting file exists in the right mode, return the
2398 full pathname to the file. */
2400 struct file_at_path_info {
2401 const char *name;
2402 const char *suffix;
2403 int name_len;
2404 int suffix_len;
2405 int mode;
2408 static void *
2409 file_at_path (char *path, void *data)
2411 struct file_at_path_info *info = (struct file_at_path_info *) data;
2412 size_t len = strlen (path);
2414 memcpy (path + len, info->name, info->name_len);
2415 len += info->name_len;
2417 /* Some systems have a suffix for executable files.
2418 So try appending that first. */
2419 if (info->suffix_len)
2421 memcpy (path + len, info->suffix, info->suffix_len + 1);
2422 if (access_check (path, info->mode) == 0)
2423 return path;
2426 path[len] = '\0';
2427 if (access_check (path, info->mode) == 0)
2428 return path;
2430 return NULL;
2433 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2434 access to check permissions. If DO_MULTI is true, search multilib
2435 paths then non-multilib paths, otherwise do not search multilib paths.
2436 Return 0 if not found, otherwise return its name, allocated with malloc. */
2438 static char *
2439 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2440 bool do_multi)
2442 struct file_at_path_info info;
2444 #ifdef DEFAULT_ASSEMBLER
2445 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2446 return xstrdup (DEFAULT_ASSEMBLER);
2447 #endif
2449 #ifdef DEFAULT_LINKER
2450 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2451 return xstrdup (DEFAULT_LINKER);
2452 #endif
2454 /* Determine the filename to execute (special case for absolute paths). */
2456 if (IS_ABSOLUTE_PATH (name))
2458 if (access (name, mode) == 0)
2459 return xstrdup (name);
2461 return NULL;
2464 info.name = name;
2465 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2466 info.name_len = strlen (info.name);
2467 info.suffix_len = strlen (info.suffix);
2468 info.mode = mode;
2470 return (char*) for_each_path (pprefix, do_multi,
2471 info.name_len + info.suffix_len,
2472 file_at_path, &info);
2475 /* Ranking of prefixes in the sort list. -B prefixes are put before
2476 all others. */
2478 enum path_prefix_priority
2480 PREFIX_PRIORITY_B_OPT,
2481 PREFIX_PRIORITY_LAST
2484 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2485 order according to PRIORITY. Within each PRIORITY, new entries are
2486 appended.
2488 If WARN is nonzero, we will warn if no file is found
2489 through this prefix. WARN should point to an int
2490 which will be set to 1 if this entry is used.
2492 COMPONENT is the value to be passed to update_path.
2494 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2495 the complete value of machine_suffix.
2496 2 means try both machine_suffix and just_machine_suffix. */
2498 static void
2499 add_prefix (struct path_prefix *pprefix, const char *prefix,
2500 const char *component, /* enum prefix_priority */ int priority,
2501 int require_machine_suffix, int os_multilib)
2503 struct prefix_list *pl, **prev;
2504 int len;
2506 for (prev = &pprefix->plist;
2507 (*prev) != NULL && (*prev)->priority <= priority;
2508 prev = &(*prev)->next)
2511 /* Keep track of the longest prefix. */
2513 prefix = update_path (prefix, component);
2514 len = strlen (prefix);
2515 if (len > pprefix->max_len)
2516 pprefix->max_len = len;
2518 pl = XNEW (struct prefix_list);
2519 pl->prefix = prefix;
2520 pl->require_machine_suffix = require_machine_suffix;
2521 pl->priority = priority;
2522 pl->os_multilib = os_multilib;
2524 /* Insert after PREV. */
2525 pl->next = (*prev);
2526 (*prev) = pl;
2529 /* Same as add_prefix, but prepending target_system_root to prefix. */
2530 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2531 static void
2532 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2533 const char *component,
2534 /* enum prefix_priority */ int priority,
2535 int require_machine_suffix, int os_multilib)
2537 if (!IS_ABSOLUTE_PATH (prefix))
2538 fatal_error ("system path %qs is not absolute", prefix);
2540 if (target_system_root)
2542 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2543 size_t sysroot_len = strlen (target_system_root);
2545 if (sysroot_len > 0
2546 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2547 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2549 if (target_sysroot_suffix)
2550 prefix = concat (sysroot_no_trailing_dir_separator,
2551 target_sysroot_suffix, prefix, NULL);
2552 else
2553 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2555 free (sysroot_no_trailing_dir_separator);
2557 /* We have to override this because GCC's notion of sysroot
2558 moves along with GCC. */
2559 component = "GCC";
2562 add_prefix (pprefix, prefix, component, priority,
2563 require_machine_suffix, os_multilib);
2566 /* Execute the command specified by the arguments on the current line of spec.
2567 When using pipes, this includes several piped-together commands
2568 with `|' between them.
2570 Return 0 if successful, -1 if failed. */
2572 static int
2573 execute (void)
2575 int i;
2576 int n_commands; /* # of command. */
2577 char *string;
2578 struct pex_obj *pex;
2579 struct command
2581 const char *prog; /* program name. */
2582 const char **argv; /* vector of args. */
2584 const char *arg;
2586 struct command *commands; /* each command buffer with above info. */
2588 gcc_assert (!processing_spec_function);
2590 if (wrapper_string)
2592 string = find_a_file (&exec_prefixes,
2593 argbuf[0], X_OK, false);
2594 if (string)
2595 argbuf[0] = string;
2596 insert_wrapper (wrapper_string);
2599 /* Count # of piped commands. */
2600 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2601 if (strcmp (arg, "|") == 0)
2602 n_commands++;
2604 /* Get storage for each command. */
2605 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2607 /* Split argbuf into its separate piped processes,
2608 and record info about each one.
2609 Also search for the programs that are to be run. */
2611 argbuf.safe_push (0);
2613 commands[0].prog = argbuf[0]; /* first command. */
2614 commands[0].argv = argbuf.address ();
2616 if (!wrapper_string)
2618 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2619 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2622 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2623 if (arg && strcmp (arg, "|") == 0)
2624 { /* each command. */
2625 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2626 fatal_error ("-pipe not supported");
2627 #endif
2628 argbuf[i] = 0; /* Termination of
2629 command args. */
2630 commands[n_commands].prog = argbuf[i + 1];
2631 commands[n_commands].argv
2632 = &(argbuf.address ())[i + 1];
2633 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2634 X_OK, false);
2635 if (string)
2636 commands[n_commands].argv[0] = string;
2637 n_commands++;
2640 /* If -v, print what we are about to do, and maybe query. */
2642 if (verbose_flag)
2644 /* For help listings, put a blank line between sub-processes. */
2645 if (print_help_list)
2646 fputc ('\n', stderr);
2648 /* Print each piped command as a separate line. */
2649 for (i = 0; i < n_commands; i++)
2651 const char *const *j;
2653 if (verbose_only_flag)
2655 for (j = commands[i].argv; *j; j++)
2657 const char *p;
2658 for (p = *j; *p; ++p)
2659 if (!ISALNUM ((unsigned char) *p)
2660 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2661 break;
2662 if (*p || !*j)
2664 fprintf (stderr, " \"");
2665 for (p = *j; *p; ++p)
2667 if (*p == '"' || *p == '\\' || *p == '$')
2668 fputc ('\\', stderr);
2669 fputc (*p, stderr);
2671 fputc ('"', stderr);
2673 /* If it's empty, print "". */
2674 else if (!**j)
2675 fprintf (stderr, " \"\"");
2676 else
2677 fprintf (stderr, " %s", *j);
2680 else
2681 for (j = commands[i].argv; *j; j++)
2682 /* If it's empty, print "". */
2683 if (!**j)
2684 fprintf (stderr, " \"\"");
2685 else
2686 fprintf (stderr, " %s", *j);
2688 /* Print a pipe symbol after all but the last command. */
2689 if (i + 1 != n_commands)
2690 fprintf (stderr, " |");
2691 fprintf (stderr, "\n");
2693 fflush (stderr);
2694 if (verbose_only_flag != 0)
2696 /* verbose_only_flag should act as if the spec was
2697 executed, so increment execution_count before
2698 returning. This prevents spurious warnings about
2699 unused linker input files, etc. */
2700 execution_count++;
2701 return 0;
2703 #ifdef DEBUG
2704 fnotice (stderr, "\nGo ahead? (y or n) ");
2705 fflush (stderr);
2706 i = getchar ();
2707 if (i != '\n')
2708 while (getchar () != '\n')
2711 if (i != 'y' && i != 'Y')
2712 return 0;
2713 #endif /* DEBUG */
2716 #ifdef ENABLE_VALGRIND_CHECKING
2717 /* Run the each command through valgrind. To simplify prepending the
2718 path to valgrind and the option "-q" (for quiet operation unless
2719 something triggers), we allocate a separate argv array. */
2721 for (i = 0; i < n_commands; i++)
2723 const char **argv;
2724 int argc;
2725 int j;
2727 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2730 argv = XALLOCAVEC (const char *, argc + 3);
2732 argv[0] = VALGRIND_PATH;
2733 argv[1] = "-q";
2734 for (j = 2; j < argc + 2; j++)
2735 argv[j] = commands[i].argv[j - 2];
2736 argv[j] = NULL;
2738 commands[i].argv = argv;
2739 commands[i].prog = argv[0];
2741 #endif
2743 /* Run each piped subprocess. */
2745 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2746 ? PEX_RECORD_TIMES : 0),
2747 progname, temp_filename);
2748 if (pex == NULL)
2749 fatal_error ("pex_init failed: %m");
2751 for (i = 0; i < n_commands; i++)
2753 const char *errmsg;
2754 int err;
2755 const char *string = commands[i].argv[0];
2757 errmsg = pex_run (pex,
2758 ((i + 1 == n_commands ? PEX_LAST : 0)
2759 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2760 string, CONST_CAST (char **, commands[i].argv),
2761 NULL, NULL, &err);
2762 if (errmsg != NULL)
2764 if (err == 0)
2765 fatal_error (errmsg);
2766 else
2768 errno = err;
2769 pfatal_with_name (errmsg);
2773 if (string != commands[i].prog)
2774 free (CONST_CAST (char *, string));
2777 execution_count++;
2779 /* Wait for all the subprocesses to finish. */
2782 int *statuses;
2783 struct pex_time *times = NULL;
2784 int ret_code = 0;
2786 statuses = (int *) alloca (n_commands * sizeof (int));
2787 if (!pex_get_status (pex, n_commands, statuses))
2788 fatal_error ("failed to get exit status: %m");
2790 if (report_times || report_times_to_file)
2792 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2793 if (!pex_get_times (pex, n_commands, times))
2794 fatal_error ("failed to get process times: %m");
2797 pex_free (pex);
2799 for (i = 0; i < n_commands; ++i)
2801 int status = statuses[i];
2803 if (WIFSIGNALED (status))
2805 #ifdef SIGPIPE
2806 /* SIGPIPE is a special case. It happens in -pipe mode
2807 when the compiler dies before the preprocessor is done,
2808 or the assembler dies before the compiler is done.
2809 There's generally been an error already, and this is
2810 just fallout. So don't generate another error unless
2811 we would otherwise have succeeded. */
2812 if (WTERMSIG (status) == SIGPIPE
2813 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2815 signal_count++;
2816 ret_code = -1;
2818 else
2819 #endif
2820 internal_error ("%s (program %s)",
2821 strsignal (WTERMSIG (status)), commands[i].prog);
2823 else if (WIFEXITED (status)
2824 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2826 if (WEXITSTATUS (status) > greatest_status)
2827 greatest_status = WEXITSTATUS (status);
2828 ret_code = -1;
2831 if (report_times || report_times_to_file)
2833 struct pex_time *pt = &times[i];
2834 double ut, st;
2836 ut = ((double) pt->user_seconds
2837 + (double) pt->user_microseconds / 1.0e6);
2838 st = ((double) pt->system_seconds
2839 + (double) pt->system_microseconds / 1.0e6);
2841 if (ut + st != 0)
2843 if (report_times)
2844 fnotice (stderr, "# %s %.2f %.2f\n",
2845 commands[i].prog, ut, st);
2847 if (report_times_to_file)
2849 int c = 0;
2850 const char *const *j;
2852 fprintf (report_times_to_file, "%g %g", ut, st);
2854 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
2856 const char *p;
2857 for (p = *j; *p; ++p)
2858 if (*p == '"' || *p == '\\' || *p == '$'
2859 || ISSPACE (*p))
2860 break;
2862 if (*p)
2864 fprintf (report_times_to_file, " \"");
2865 for (p = *j; *p; ++p)
2867 if (*p == '"' || *p == '\\' || *p == '$')
2868 fputc ('\\', report_times_to_file);
2869 fputc (*p, report_times_to_file);
2871 fputc ('"', report_times_to_file);
2873 else
2874 fprintf (report_times_to_file, " %s", *j);
2877 fputc ('\n', report_times_to_file);
2883 return ret_code;
2887 /* Find all the switches given to us
2888 and make a vector describing them.
2889 The elements of the vector are strings, one per switch given.
2890 If a switch uses following arguments, then the `part1' field
2891 is the switch itself and the `args' field
2892 is a null-terminated vector containing the following arguments.
2893 Bits in the `live_cond' field are:
2894 SWITCH_LIVE to indicate this switch is true in a conditional spec.
2895 SWITCH_FALSE to indicate this switch is overridden by a later switch.
2896 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
2897 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
2898 in all do_spec calls afterwards. Used for %<S from self specs.
2899 The `validated' field is nonzero if any spec has looked at this switch;
2900 if it remains zero at the end of the run, it must be meaningless. */
2902 #define SWITCH_LIVE (1 << 0)
2903 #define SWITCH_FALSE (1 << 1)
2904 #define SWITCH_IGNORE (1 << 2)
2905 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
2906 #define SWITCH_KEEP_FOR_GCC (1 << 4)
2908 struct switchstr
2910 const char *part1;
2911 const char **args;
2912 unsigned int live_cond;
2913 bool known;
2914 bool validated;
2915 bool ordering;
2918 static struct switchstr *switches;
2920 static int n_switches;
2922 static int n_switches_alloc;
2924 /* Set to zero if -fcompare-debug is disabled, positive if it's
2925 enabled and we're running the first compilation, negative if it's
2926 enabled and we're running the second compilation. For most of the
2927 time, it's in the range -1..1, but it can be temporarily set to 2
2928 or 3 to indicate that the -fcompare-debug flags didn't come from
2929 the command-line, but rather from the GCC_COMPARE_DEBUG environment
2930 variable, until a synthesized -fcompare-debug flag is added to the
2931 command line. */
2932 int compare_debug;
2934 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
2935 int compare_debug_second;
2937 /* Set to the flags that should be passed to the second compilation in
2938 a -fcompare-debug compilation. */
2939 const char *compare_debug_opt;
2941 static struct switchstr *switches_debug_check[2];
2943 static int n_switches_debug_check[2];
2945 static int n_switches_alloc_debug_check[2];
2947 static char *debug_check_temp_file[2];
2949 /* Language is one of three things:
2951 1) The name of a real programming language.
2952 2) NULL, indicating that no one has figured out
2953 what it is yet.
2954 3) '*', indicating that the file should be passed
2955 to the linker. */
2956 struct infile
2958 const char *name;
2959 const char *language;
2960 struct compiler *incompiler;
2961 bool compiled;
2962 bool preprocessed;
2965 /* Also a vector of input files specified. */
2967 static struct infile *infiles;
2969 int n_infiles;
2971 static int n_infiles_alloc;
2973 /* True if multiple input files are being compiled to a single
2974 assembly file. */
2976 static bool combine_inputs;
2978 /* This counts the number of libraries added by lang_specific_driver, so that
2979 we can tell if there were any user supplied any files or libraries. */
2981 static int added_libraries;
2983 /* And a vector of corresponding output files is made up later. */
2985 const char **outfiles;
2987 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2989 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2990 is true if we should look for an executable suffix. DO_OBJ
2991 is true if we should look for an object suffix. */
2993 static const char *
2994 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
2995 int do_obj ATTRIBUTE_UNUSED)
2997 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2998 int i;
2999 #endif
3000 int len;
3002 if (name == NULL)
3003 return NULL;
3005 len = strlen (name);
3007 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3008 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3009 if (do_obj && len > 2
3010 && name[len - 2] == '.'
3011 && name[len - 1] == 'o')
3013 obstack_grow (&obstack, name, len - 2);
3014 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3015 name = XOBFINISH (&obstack, const char *);
3017 #endif
3019 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3020 /* If there is no filetype, make it the executable suffix (which includes
3021 the "."). But don't get confused if we have just "-o". */
3022 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3023 return name;
3025 for (i = len - 1; i >= 0; i--)
3026 if (IS_DIR_SEPARATOR (name[i]))
3027 break;
3029 for (i++; i < len; i++)
3030 if (name[i] == '.')
3031 return name;
3033 obstack_grow (&obstack, name, len);
3034 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3035 strlen (TARGET_EXECUTABLE_SUFFIX));
3036 name = XOBFINISH (&obstack, const char *);
3037 #endif
3039 return name;
3041 #endif
3043 /* Display the command line switches accepted by gcc. */
3044 static void
3045 display_help (void)
3047 printf (_("Usage: %s [options] file...\n"), progname);
3048 fputs (_("Options:\n"), stdout);
3050 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3051 fputs (_(" --help Display this information\n"), stdout);
3052 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3053 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
3054 fputs (_(" Display specific types of command line options\n"), stdout);
3055 if (! verbose_flag)
3056 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3057 fputs (_(" --version Display compiler version information\n"), stdout);
3058 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3059 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3060 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3061 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3062 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3063 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3064 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3065 fputs (_("\
3066 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3067 a component in the library path\n"), stdout);
3068 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3069 fputs (_("\
3070 -print-multi-lib Display the mapping between command line options and\n\
3071 multiple library search directories\n"), stdout);
3072 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3073 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
3074 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
3075 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3076 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3077 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3078 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3079 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3080 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3081 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3082 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
3083 fputs (_("\
3084 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3085 prefixes to other gcc components\n"), stdout);
3086 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3087 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3088 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3089 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3090 fputs (_("\
3091 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3092 and libraries\n"), stdout);
3093 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3094 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3095 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3096 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3097 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3098 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3099 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3100 fputs (_(" -pie Create a position independent executable\n"), stdout);
3101 fputs (_(" -shared Create a shared library\n"), stdout);
3102 fputs (_("\
3103 -x <language> Specify the language of the following input files\n\
3104 Permissible languages include: c c++ assembler none\n\
3105 'none' means revert to the default behavior of\n\
3106 guessing the language based on the file's extension\n\
3107 "), stdout);
3109 printf (_("\
3110 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3111 passed on to the various sub-processes invoked by %s. In order to pass\n\
3112 other options on to these processes the -W<letter> options must be used.\n\
3113 "), progname);
3115 /* The rest of the options are displayed by invocations of the various
3116 sub-processes. */
3119 static void
3120 add_preprocessor_option (const char *option, int len)
3122 preprocessor_options.safe_push (save_string (option, len));
3125 static void
3126 add_assembler_option (const char *option, int len)
3128 assembler_options.safe_push (save_string (option, len));
3131 static void
3132 add_linker_option (const char *option, int len)
3134 linker_options.safe_push (save_string (option, len));
3137 /* Allocate space for an input file in infiles. */
3139 static void
3140 alloc_infile (void)
3142 if (n_infiles_alloc == 0)
3144 n_infiles_alloc = 16;
3145 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3147 else if (n_infiles_alloc == n_infiles)
3149 n_infiles_alloc *= 2;
3150 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3154 /* Store an input file with the given NAME and LANGUAGE in
3155 infiles. */
3157 static void
3158 add_infile (const char *name, const char *language)
3160 alloc_infile ();
3161 infiles[n_infiles].name = name;
3162 infiles[n_infiles++].language = language;
3165 /* Allocate space for a switch in switches. */
3167 static void
3168 alloc_switch (void)
3170 if (n_switches_alloc == 0)
3172 n_switches_alloc = 16;
3173 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3175 else if (n_switches_alloc == n_switches)
3177 n_switches_alloc *= 2;
3178 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3182 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3183 as validated if VALIDATED and KNOWN if it is an internal switch. */
3185 static void
3186 save_switch (const char *opt, size_t n_args, const char *const *args,
3187 bool validated, bool known)
3189 alloc_switch ();
3190 switches[n_switches].part1 = opt + 1;
3191 if (n_args == 0)
3192 switches[n_switches].args = 0;
3193 else
3195 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3196 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3197 switches[n_switches].args[n_args] = NULL;
3200 switches[n_switches].live_cond = 0;
3201 switches[n_switches].validated = validated;
3202 switches[n_switches].known = known;
3203 switches[n_switches].ordering = 0;
3204 n_switches++;
3207 /* Handle an option DECODED that is unknown to the option-processing
3208 machinery. */
3210 static bool
3211 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3213 const char *opt = decoded->arg;
3214 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3215 && !(decoded->errors & CL_ERR_NEGATIVE))
3217 /* Leave unknown -Wno-* options for the compiler proper, to be
3218 diagnosed only if there are warnings. */
3219 save_switch (decoded->canonical_option[0],
3220 decoded->canonical_option_num_elements - 1,
3221 &decoded->canonical_option[1], false, true);
3222 return false;
3224 if (decoded->opt_index == OPT_SPECIAL_unknown)
3226 /* Give it a chance to define it a a spec file. */
3227 save_switch (decoded->canonical_option[0],
3228 decoded->canonical_option_num_elements - 1,
3229 &decoded->canonical_option[1], false, false);
3230 return false;
3232 else
3233 return true;
3236 /* Handle an option DECODED that is not marked as CL_DRIVER.
3237 LANG_MASK will always be CL_DRIVER. */
3239 static void
3240 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3241 unsigned int lang_mask ATTRIBUTE_UNUSED)
3243 /* At this point, non-driver options are accepted (and expected to
3244 be passed down by specs) unless marked to be rejected by the
3245 driver. Options to be rejected by the driver but accepted by the
3246 compilers proper are treated just like completely unknown
3247 options. */
3248 const struct cl_option *option = &cl_options[decoded->opt_index];
3250 if (option->cl_reject_driver)
3251 error ("unrecognized command line option %qs",
3252 decoded->orig_option_with_args_text);
3253 else
3254 save_switch (decoded->canonical_option[0],
3255 decoded->canonical_option_num_elements - 1,
3256 &decoded->canonical_option[1], false, true);
3259 static const char *spec_lang = 0;
3260 static int last_language_n_infiles;
3262 /* Handle a driver option; arguments and return value as for
3263 handle_option. */
3265 static bool
3266 driver_handle_option (struct gcc_options *opts,
3267 struct gcc_options *opts_set,
3268 const struct cl_decoded_option *decoded,
3269 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3270 location_t loc,
3271 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3272 diagnostic_context *dc)
3274 size_t opt_index = decoded->opt_index;
3275 const char *arg = decoded->arg;
3276 const char *compare_debug_replacement_opt;
3277 int value = decoded->value;
3278 bool validated = false;
3279 bool do_save = true;
3281 gcc_assert (opts == &global_options);
3282 gcc_assert (opts_set == &global_options_set);
3283 gcc_assert (kind == DK_UNSPECIFIED);
3284 gcc_assert (loc == UNKNOWN_LOCATION);
3285 gcc_assert (dc == global_dc);
3287 switch (opt_index)
3289 case OPT_dumpspecs:
3291 struct spec_list *sl;
3292 init_spec ();
3293 for (sl = specs; sl; sl = sl->next)
3294 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3295 if (link_command_spec)
3296 printf ("*link_command:\n%s\n\n", link_command_spec);
3297 exit (0);
3300 case OPT_dumpversion:
3301 printf ("%s\n", spec_version);
3302 exit (0);
3304 case OPT_dumpmachine:
3305 printf ("%s\n", spec_machine);
3306 exit (0);
3308 case OPT__version:
3309 print_version = 1;
3311 /* CPP driver cannot obtain switch from cc1_options. */
3312 if (is_cpp_driver)
3313 add_preprocessor_option ("--version", strlen ("--version"));
3314 add_assembler_option ("--version", strlen ("--version"));
3315 add_linker_option ("--version", strlen ("--version"));
3316 break;
3318 case OPT__help:
3319 print_help_list = 1;
3321 /* CPP driver cannot obtain switch from cc1_options. */
3322 if (is_cpp_driver)
3323 add_preprocessor_option ("--help", 6);
3324 add_assembler_option ("--help", 6);
3325 add_linker_option ("--help", 6);
3326 break;
3328 case OPT__help_:
3329 print_subprocess_help = 2;
3330 break;
3332 case OPT__target_help:
3333 print_subprocess_help = 1;
3335 /* CPP driver cannot obtain switch from cc1_options. */
3336 if (is_cpp_driver)
3337 add_preprocessor_option ("--target-help", 13);
3338 add_assembler_option ("--target-help", 13);
3339 add_linker_option ("--target-help", 13);
3340 break;
3342 case OPT__no_sysroot_suffix:
3343 case OPT_pass_exit_codes:
3344 case OPT_print_search_dirs:
3345 case OPT_print_file_name_:
3346 case OPT_print_prog_name_:
3347 case OPT_print_multi_lib:
3348 case OPT_print_multi_directory:
3349 case OPT_print_sysroot:
3350 case OPT_print_multi_os_directory:
3351 case OPT_print_multiarch:
3352 case OPT_print_sysroot_headers_suffix:
3353 case OPT_time:
3354 case OPT_wrapper:
3355 /* These options set the variables specified in common.opt
3356 automatically, and do not need to be saved for spec
3357 processing. */
3358 do_save = false;
3359 break;
3361 case OPT_print_libgcc_file_name:
3362 print_file_name = "libgcc.a";
3363 do_save = false;
3364 break;
3366 case OPT_fcompare_debug_second:
3367 compare_debug_second = 1;
3368 break;
3370 case OPT_fcompare_debug:
3371 switch (value)
3373 case 0:
3374 compare_debug_replacement_opt = "-fcompare-debug=";
3375 arg = "";
3376 goto compare_debug_with_arg;
3378 case 1:
3379 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3380 arg = "-gtoggle";
3381 goto compare_debug_with_arg;
3383 default:
3384 gcc_unreachable ();
3386 break;
3388 case OPT_fcompare_debug_:
3389 compare_debug_replacement_opt = decoded->canonical_option[0];
3390 compare_debug_with_arg:
3391 gcc_assert (decoded->canonical_option_num_elements == 1);
3392 gcc_assert (arg != NULL);
3393 if (*arg)
3394 compare_debug = 1;
3395 else
3396 compare_debug = -1;
3397 if (compare_debug < 0)
3398 compare_debug_opt = NULL;
3399 else
3400 compare_debug_opt = arg;
3401 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3402 return true;
3404 case OPT_Wa_:
3406 int prev, j;
3407 /* Pass the rest of this option to the assembler. */
3409 /* Split the argument at commas. */
3410 prev = 0;
3411 for (j = 0; arg[j]; j++)
3412 if (arg[j] == ',')
3414 add_assembler_option (arg + prev, j - prev);
3415 prev = j + 1;
3418 /* Record the part after the last comma. */
3419 add_assembler_option (arg + prev, j - prev);
3421 do_save = false;
3422 break;
3424 case OPT_Wp_:
3426 int prev, j;
3427 /* Pass the rest of this option to the preprocessor. */
3429 /* Split the argument at commas. */
3430 prev = 0;
3431 for (j = 0; arg[j]; j++)
3432 if (arg[j] == ',')
3434 add_preprocessor_option (arg + prev, j - prev);
3435 prev = j + 1;
3438 /* Record the part after the last comma. */
3439 add_preprocessor_option (arg + prev, j - prev);
3441 do_save = false;
3442 break;
3444 case OPT_Wl_:
3446 int prev, j;
3447 /* Split the argument at commas. */
3448 prev = 0;
3449 for (j = 0; arg[j]; j++)
3450 if (arg[j] == ',')
3452 add_infile (save_string (arg + prev, j - prev), "*");
3453 prev = j + 1;
3455 /* Record the part after the last comma. */
3456 add_infile (arg + prev, "*");
3458 do_save = false;
3459 break;
3461 case OPT_Xlinker:
3462 add_infile (arg, "*");
3463 do_save = false;
3464 break;
3466 case OPT_Xpreprocessor:
3467 add_preprocessor_option (arg, strlen (arg));
3468 do_save = false;
3469 break;
3471 case OPT_Xassembler:
3472 add_assembler_option (arg, strlen (arg));
3473 do_save = false;
3474 break;
3476 case OPT_l:
3477 /* POSIX allows separation of -l and the lib arg; canonicalize
3478 by concatenating -l with its arg */
3479 add_infile (concat ("-l", arg, NULL), "*");
3480 do_save = false;
3481 break;
3483 case OPT_L:
3484 /* Similarly, canonicalize -L for linkers that may not accept
3485 separate arguments. */
3486 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3487 return true;
3489 case OPT_F:
3490 /* Likewise -F. */
3491 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3492 return true;
3494 case OPT_save_temps:
3495 save_temps_flag = SAVE_TEMPS_CWD;
3496 validated = true;
3497 break;
3499 case OPT_save_temps_:
3500 if (strcmp (arg, "cwd") == 0)
3501 save_temps_flag = SAVE_TEMPS_CWD;
3502 else if (strcmp (arg, "obj") == 0
3503 || strcmp (arg, "object") == 0)
3504 save_temps_flag = SAVE_TEMPS_OBJ;
3505 else
3506 fatal_error ("%qs is an unknown -save-temps option",
3507 decoded->orig_option_with_args_text);
3508 break;
3510 case OPT_no_canonical_prefixes:
3511 /* Already handled as a special case, so ignored here. */
3512 do_save = false;
3513 break;
3515 case OPT_pipe:
3516 validated = true;
3517 /* These options set the variables specified in common.opt
3518 automatically, but do need to be saved for spec
3519 processing. */
3520 break;
3522 case OPT_specs_:
3524 struct user_specs *user = XNEW (struct user_specs);
3526 user->next = (struct user_specs *) 0;
3527 user->filename = arg;
3528 if (user_specs_tail)
3529 user_specs_tail->next = user;
3530 else
3531 user_specs_head = user;
3532 user_specs_tail = user;
3534 validated = true;
3535 break;
3537 case OPT__sysroot_:
3538 target_system_root = arg;
3539 target_system_root_changed = 1;
3540 do_save = false;
3541 break;
3543 case OPT_time_:
3544 if (report_times_to_file)
3545 fclose (report_times_to_file);
3546 report_times_to_file = fopen (arg, "a");
3547 do_save = false;
3548 break;
3550 case OPT____:
3551 /* "-###"
3552 This is similar to -v except that there is no execution
3553 of the commands and the echoed arguments are quoted. It
3554 is intended for use in shell scripts to capture the
3555 driver-generated command line. */
3556 verbose_only_flag++;
3557 verbose_flag = 1;
3558 do_save = false;
3559 break;
3561 case OPT_B:
3563 size_t len = strlen (arg);
3565 /* Catch the case where the user has forgotten to append a
3566 directory separator to the path. Note, they may be using
3567 -B to add an executable name prefix, eg "i386-elf-", in
3568 order to distinguish between multiple installations of
3569 GCC in the same directory. Hence we must check to see
3570 if appending a directory separator actually makes a
3571 valid directory name. */
3572 if (!IS_DIR_SEPARATOR (arg[len - 1])
3573 && is_directory (arg, false))
3575 char *tmp = XNEWVEC (char, len + 2);
3576 strcpy (tmp, arg);
3577 tmp[len] = DIR_SEPARATOR;
3578 tmp[++len] = 0;
3579 arg = tmp;
3582 add_prefix (&exec_prefixes, arg, NULL,
3583 PREFIX_PRIORITY_B_OPT, 0, 0);
3584 add_prefix (&startfile_prefixes, arg, NULL,
3585 PREFIX_PRIORITY_B_OPT, 0, 0);
3586 add_prefix (&include_prefixes, arg, NULL,
3587 PREFIX_PRIORITY_B_OPT, 0, 0);
3589 validated = true;
3590 break;
3592 case OPT_x:
3593 spec_lang = arg;
3594 if (!strcmp (spec_lang, "none"))
3595 /* Suppress the warning if -xnone comes after the last input
3596 file, because alternate command interfaces like g++ might
3597 find it useful to place -xnone after each input file. */
3598 spec_lang = 0;
3599 else
3600 last_language_n_infiles = n_infiles;
3601 do_save = false;
3602 break;
3604 case OPT_o:
3605 have_o = 1;
3606 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3607 arg = convert_filename (arg, ! have_c, 0);
3608 #endif
3609 /* Save the output name in case -save-temps=obj was used. */
3610 save_temps_prefix = xstrdup (arg);
3611 /* On some systems, ld cannot handle "-o" without a space. So
3612 split the option from its argument. */
3613 save_switch ("-o", 1, &arg, validated, true);
3614 return true;
3616 case OPT_static_libgcc:
3617 case OPT_shared_libgcc:
3618 case OPT_static_libgfortran:
3619 case OPT_static_libstdc__:
3620 /* These are always valid, since gcc.c itself understands the
3621 first two, gfortranspec.c understands -static-libgfortran and
3622 g++spec.c understands -static-libstdc++ */
3623 validated = true;
3624 break;
3626 default:
3627 /* Various driver options need no special processing at this
3628 point, having been handled in a prescan above or being
3629 handled by specs. */
3630 break;
3633 if (do_save)
3634 save_switch (decoded->canonical_option[0],
3635 decoded->canonical_option_num_elements - 1,
3636 &decoded->canonical_option[1], validated, true);
3637 return true;
3640 /* Put the driver's standard set of option handlers in *HANDLERS. */
3642 static void
3643 set_option_handlers (struct cl_option_handlers *handlers)
3645 handlers->unknown_option_callback = driver_unknown_option_callback;
3646 handlers->wrong_lang_callback = driver_wrong_lang_callback;
3647 handlers->num_handlers = 3;
3648 handlers->handlers[0].handler = driver_handle_option;
3649 handlers->handlers[0].mask = CL_DRIVER;
3650 handlers->handlers[1].handler = common_handle_option;
3651 handlers->handlers[1].mask = CL_COMMON;
3652 handlers->handlers[2].handler = target_handle_option;
3653 handlers->handlers[2].mask = CL_TARGET;
3656 /* Create the vector `switches' and its contents.
3657 Store its length in `n_switches'. */
3659 static void
3660 process_command (unsigned int decoded_options_count,
3661 struct cl_decoded_option *decoded_options)
3663 const char *temp;
3664 char *temp1;
3665 char *tooldir_prefix, *tooldir_prefix2;
3666 char *(*get_relative_prefix) (const char *, const char *,
3667 const char *) = NULL;
3668 struct cl_option_handlers handlers;
3669 unsigned int j;
3671 gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
3673 n_switches = 0;
3674 n_infiles = 0;
3675 added_libraries = 0;
3677 /* Figure compiler version from version string. */
3679 compiler_version = temp1 = xstrdup (version_string);
3681 for (; *temp1; ++temp1)
3683 if (*temp1 == ' ')
3685 *temp1 = '\0';
3686 break;
3690 /* Handle any -no-canonical-prefixes flag early, to assign the function
3691 that builds relative prefixes. This function creates default search
3692 paths that are needed later in normal option handling. */
3694 for (j = 1; j < decoded_options_count; j++)
3696 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3698 get_relative_prefix = make_relative_prefix_ignore_links;
3699 break;
3702 if (! get_relative_prefix)
3703 get_relative_prefix = make_relative_prefix;
3705 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3706 see if we can create it from the pathname specified in
3707 decoded_options[0].arg. */
3709 gcc_libexec_prefix = standard_libexec_prefix;
3710 #ifndef VMS
3711 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3712 if (!gcc_exec_prefix)
3714 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
3715 standard_bindir_prefix,
3716 standard_exec_prefix);
3717 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
3718 standard_bindir_prefix,
3719 standard_libexec_prefix);
3720 if (gcc_exec_prefix)
3721 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3723 else
3725 /* make_relative_prefix requires a program name, but
3726 GCC_EXEC_PREFIX is typically a directory name with a trailing
3727 / (which is ignored by make_relative_prefix), so append a
3728 program name. */
3729 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3730 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
3731 standard_exec_prefix,
3732 standard_libexec_prefix);
3734 /* The path is unrelocated, so fallback to the original setting. */
3735 if (!gcc_libexec_prefix)
3736 gcc_libexec_prefix = standard_libexec_prefix;
3738 free (tmp_prefix);
3740 #else
3741 #endif
3742 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3743 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3744 or an automatically created GCC_EXEC_PREFIX from
3745 decoded_options[0].arg. */
3747 /* Do language-specific adjustment/addition of flags. */
3748 lang_specific_driver (&decoded_options, &decoded_options_count,
3749 &added_libraries);
3751 if (gcc_exec_prefix)
3753 int len = strlen (gcc_exec_prefix);
3755 if (len > (int) sizeof ("/lib/gcc/") - 1
3756 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3758 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3759 if (IS_DIR_SEPARATOR (*temp)
3760 && filename_ncmp (temp + 1, "lib", 3) == 0
3761 && IS_DIR_SEPARATOR (temp[4])
3762 && filename_ncmp (temp + 5, "gcc", 3) == 0)
3763 len -= sizeof ("/lib/gcc/") - 1;
3766 set_std_prefix (gcc_exec_prefix, len);
3767 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3768 PREFIX_PRIORITY_LAST, 0, 0);
3769 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3770 PREFIX_PRIORITY_LAST, 0, 0);
3773 /* COMPILER_PATH and LIBRARY_PATH have values
3774 that are lists of directory names with colons. */
3776 temp = getenv ("COMPILER_PATH");
3777 if (temp)
3779 const char *startp, *endp;
3780 char *nstore = (char *) alloca (strlen (temp) + 3);
3782 startp = endp = temp;
3783 while (1)
3785 if (*endp == PATH_SEPARATOR || *endp == 0)
3787 strncpy (nstore, startp, endp - startp);
3788 if (endp == startp)
3789 strcpy (nstore, concat (".", dir_separator_str, NULL));
3790 else if (!IS_DIR_SEPARATOR (endp[-1]))
3792 nstore[endp - startp] = DIR_SEPARATOR;
3793 nstore[endp - startp + 1] = 0;
3795 else
3796 nstore[endp - startp] = 0;
3797 add_prefix (&exec_prefixes, nstore, 0,
3798 PREFIX_PRIORITY_LAST, 0, 0);
3799 add_prefix (&include_prefixes, nstore, 0,
3800 PREFIX_PRIORITY_LAST, 0, 0);
3801 if (*endp == 0)
3802 break;
3803 endp = startp = endp + 1;
3805 else
3806 endp++;
3810 temp = getenv (LIBRARY_PATH_ENV);
3811 if (temp && *cross_compile == '0')
3813 const char *startp, *endp;
3814 char *nstore = (char *) alloca (strlen (temp) + 3);
3816 startp = endp = temp;
3817 while (1)
3819 if (*endp == PATH_SEPARATOR || *endp == 0)
3821 strncpy (nstore, startp, endp - startp);
3822 if (endp == startp)
3823 strcpy (nstore, concat (".", dir_separator_str, NULL));
3824 else if (!IS_DIR_SEPARATOR (endp[-1]))
3826 nstore[endp - startp] = DIR_SEPARATOR;
3827 nstore[endp - startp + 1] = 0;
3829 else
3830 nstore[endp - startp] = 0;
3831 add_prefix (&startfile_prefixes, nstore, NULL,
3832 PREFIX_PRIORITY_LAST, 0, 1);
3833 if (*endp == 0)
3834 break;
3835 endp = startp = endp + 1;
3837 else
3838 endp++;
3842 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3843 temp = getenv ("LPATH");
3844 if (temp && *cross_compile == '0')
3846 const char *startp, *endp;
3847 char *nstore = (char *) alloca (strlen (temp) + 3);
3849 startp = endp = temp;
3850 while (1)
3852 if (*endp == PATH_SEPARATOR || *endp == 0)
3854 strncpy (nstore, startp, endp - startp);
3855 if (endp == startp)
3856 strcpy (nstore, concat (".", dir_separator_str, NULL));
3857 else if (!IS_DIR_SEPARATOR (endp[-1]))
3859 nstore[endp - startp] = DIR_SEPARATOR;
3860 nstore[endp - startp + 1] = 0;
3862 else
3863 nstore[endp - startp] = 0;
3864 add_prefix (&startfile_prefixes, nstore, NULL,
3865 PREFIX_PRIORITY_LAST, 0, 1);
3866 if (*endp == 0)
3867 break;
3868 endp = startp = endp + 1;
3870 else
3871 endp++;
3875 /* Process the options and store input files and switches in their
3876 vectors. */
3878 last_language_n_infiles = -1;
3880 set_option_handlers (&handlers);
3882 for (j = 1; j < decoded_options_count; j++)
3884 switch (decoded_options[j].opt_index)
3886 case OPT_S:
3887 case OPT_c:
3888 case OPT_E:
3889 have_c = 1;
3890 break;
3892 if (have_c)
3893 break;
3896 for (j = 1; j < decoded_options_count; j++)
3898 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
3900 const char *arg = decoded_options[j].arg;
3901 const char *p = strrchr (arg, '@');
3902 char *fname;
3903 long offset;
3904 int consumed;
3905 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3906 arg = convert_filename (arg, 0, access (arg, F_OK));
3907 #endif
3908 /* For LTO static archive support we handle input file
3909 specifications that are composed of a filename and
3910 an offset like FNAME@OFFSET. */
3911 if (p
3912 && p != arg
3913 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
3914 && strlen (p) == (unsigned int)consumed)
3916 fname = (char *)xmalloc (p - arg + 1);
3917 memcpy (fname, arg, p - arg);
3918 fname[p - arg] = '\0';
3919 /* Only accept non-stdin and existing FNAME parts, otherwise
3920 try with the full name. */
3921 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
3923 free (fname);
3924 fname = xstrdup (arg);
3927 else
3928 fname = xstrdup (arg);
3930 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
3931 perror_with_name (fname);
3932 else
3933 add_infile (arg, spec_lang);
3935 free (fname);
3936 continue;
3939 read_cmdline_option (&global_options, &global_options_set,
3940 decoded_options + j, UNKNOWN_LOCATION,
3941 CL_DRIVER, &handlers, global_dc);
3944 /* If -save-temps=obj and -o name, create the prefix to use for %b.
3945 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
3946 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
3948 save_temps_length = strlen (save_temps_prefix);
3949 temp = strrchr (lbasename (save_temps_prefix), '.');
3950 if (temp)
3952 save_temps_length -= strlen (temp);
3953 save_temps_prefix[save_temps_length] = '\0';
3957 else if (save_temps_prefix != NULL)
3959 free (save_temps_prefix);
3960 save_temps_prefix = NULL;
3963 if (save_temps_flag && use_pipes)
3965 /* -save-temps overrides -pipe, so that temp files are produced */
3966 if (save_temps_flag)
3967 warning (0, "-pipe ignored because -save-temps specified");
3968 use_pipes = 0;
3971 if (!compare_debug)
3973 const char *gcd = getenv ("GCC_COMPARE_DEBUG");
3975 if (gcd && gcd[0] == '-')
3977 compare_debug = 2;
3978 compare_debug_opt = gcd;
3980 else if (gcd && *gcd && strcmp (gcd, "0"))
3982 compare_debug = 3;
3983 compare_debug_opt = "-gtoggle";
3986 else if (compare_debug < 0)
3988 compare_debug = 0;
3989 gcc_assert (!compare_debug_opt);
3992 /* Set up the search paths. We add directories that we expect to
3993 contain GNU Toolchain components before directories specified by
3994 the machine description so that we will find GNU components (like
3995 the GNU assembler) before those of the host system. */
3997 /* If we don't know where the toolchain has been installed, use the
3998 configured-in locations. */
3999 if (!gcc_exec_prefix)
4001 #ifndef OS2
4002 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4003 PREFIX_PRIORITY_LAST, 1, 0);
4004 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4005 PREFIX_PRIORITY_LAST, 2, 0);
4006 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4007 PREFIX_PRIORITY_LAST, 2, 0);
4008 #endif
4009 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4010 PREFIX_PRIORITY_LAST, 1, 0);
4013 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4014 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
4015 dir_separator_str, NULL);
4017 /* Look for tools relative to the location from which the driver is
4018 running, or, if that is not available, the configured prefix. */
4019 tooldir_prefix
4020 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4021 spec_machine, dir_separator_str,
4022 spec_version, dir_separator_str, tooldir_prefix2, NULL);
4023 free (tooldir_prefix2);
4025 add_prefix (&exec_prefixes,
4026 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4027 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4028 add_prefix (&startfile_prefixes,
4029 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4030 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4031 free (tooldir_prefix);
4033 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4034 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4035 then consider it to relocate with the rest of the GCC installation
4036 if GCC_EXEC_PREFIX is set.
4037 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4038 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4040 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4041 standard_bindir_prefix,
4042 target_system_root);
4043 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4045 target_system_root = tmp_prefix;
4046 target_system_root_changed = 1;
4049 #endif
4051 /* More prefixes are enabled in main, after we read the specs file
4052 and determine whether this is cross-compilation or not. */
4054 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4055 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4057 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4058 environment variable. */
4059 if (compare_debug == 2 || compare_debug == 3)
4061 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4062 save_switch (opt, 0, NULL, false, true);
4063 compare_debug = 1;
4066 /* Ensure we only invoke each subprocess once. */
4067 if (print_subprocess_help || print_help_list || print_version)
4069 n_infiles = 0;
4071 /* Create a dummy input file, so that we can pass
4072 the help option on to the various sub-processes. */
4073 add_infile ("help-dummy", "c");
4076 alloc_switch ();
4077 switches[n_switches].part1 = 0;
4078 alloc_infile ();
4079 infiles[n_infiles].name = 0;
4082 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4083 and place that in the environment. */
4085 static void
4086 set_collect_gcc_options (void)
4088 int i;
4089 int first_time;
4091 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4092 the compiler. */
4093 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4094 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4096 first_time = TRUE;
4097 for (i = 0; (int) i < n_switches; i++)
4099 const char *const *args;
4100 const char *p, *q;
4101 if (!first_time)
4102 obstack_grow (&collect_obstack, " ", 1);
4104 first_time = FALSE;
4106 /* Ignore elided switches. */
4107 if ((switches[i].live_cond
4108 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4109 == SWITCH_IGNORE)
4110 continue;
4112 obstack_grow (&collect_obstack, "'-", 2);
4113 q = switches[i].part1;
4114 while ((p = strchr (q, '\'')))
4116 obstack_grow (&collect_obstack, q, p - q);
4117 obstack_grow (&collect_obstack, "'\\''", 4);
4118 q = ++p;
4120 obstack_grow (&collect_obstack, q, strlen (q));
4121 obstack_grow (&collect_obstack, "'", 1);
4123 for (args = switches[i].args; args && *args; args++)
4125 obstack_grow (&collect_obstack, " '", 2);
4126 q = *args;
4127 while ((p = strchr (q, '\'')))
4129 obstack_grow (&collect_obstack, q, p - q);
4130 obstack_grow (&collect_obstack, "'\\''", 4);
4131 q = ++p;
4133 obstack_grow (&collect_obstack, q, strlen (q));
4134 obstack_grow (&collect_obstack, "'", 1);
4137 obstack_grow (&collect_obstack, "\0", 1);
4138 xputenv (XOBFINISH (&collect_obstack, char *));
4141 /* Process a spec string, accumulating and running commands. */
4143 /* These variables describe the input file name.
4144 input_file_number is the index on outfiles of this file,
4145 so that the output file name can be stored for later use by %o.
4146 input_basename is the start of the part of the input file
4147 sans all directory names, and basename_length is the number
4148 of characters starting there excluding the suffix .c or whatever. */
4150 static const char *gcc_input_filename;
4151 static int input_file_number;
4152 size_t input_filename_length;
4153 static int basename_length;
4154 static int suffixed_basename_length;
4155 static const char *input_basename;
4156 static const char *input_suffix;
4157 #ifndef HOST_LACKS_INODE_NUMBERS
4158 static struct stat input_stat;
4159 #endif
4160 static int input_stat_set;
4162 /* The compiler used to process the current input file. */
4163 static struct compiler *input_file_compiler;
4165 /* These are variables used within do_spec and do_spec_1. */
4167 /* Nonzero if an arg has been started and not yet terminated
4168 (with space, tab or newline). */
4169 static int arg_going;
4171 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4172 is a temporary file name. */
4173 static int delete_this_arg;
4175 /* Nonzero means %w has been seen; the next arg to be terminated
4176 is the output file name of this compilation. */
4177 static int this_is_output_file;
4179 /* Nonzero means %s has been seen; the next arg to be terminated
4180 is the name of a library file and we should try the standard
4181 search dirs for it. */
4182 static int this_is_library_file;
4184 /* Nonzero means %T has been seen; the next arg to be terminated
4185 is the name of a linker script and we should try all of the
4186 standard search dirs for it. If it is found insert a --script
4187 command line switch and then substitute the full path in place,
4188 otherwise generate an error message. */
4189 static int this_is_linker_script;
4191 /* Nonzero means that the input of this command is coming from a pipe. */
4192 static int input_from_pipe;
4194 /* Nonnull means substitute this for any suffix when outputting a switches
4195 arguments. */
4196 static const char *suffix_subst;
4198 /* If there is an argument being accumulated, terminate it and store it. */
4200 static void
4201 end_going_arg (void)
4203 if (arg_going)
4205 const char *string;
4207 obstack_1grow (&obstack, 0);
4208 string = XOBFINISH (&obstack, const char *);
4209 if (this_is_library_file)
4210 string = find_file (string);
4211 if (this_is_linker_script)
4213 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4215 if (full_script_path == NULL)
4217 error ("unable to locate default linker script %qs in the library search paths", string);
4218 /* Script was not found on search path. */
4219 return;
4221 store_arg ("--script", false, false);
4222 string = full_script_path;
4224 store_arg (string, delete_this_arg, this_is_output_file);
4225 if (this_is_output_file)
4226 outfiles[input_file_number] = string;
4227 arg_going = 0;
4232 /* Parse the WRAPPER string which is a comma separated list of the command line
4233 and insert them into the beginning of argbuf. */
4235 static void
4236 insert_wrapper (const char *wrapper)
4238 int n = 0;
4239 int i;
4240 char *buf = xstrdup (wrapper);
4241 char *p = buf;
4242 unsigned int old_length = argbuf.length ();
4246 n++;
4247 while (*p == ',')
4248 p++;
4250 while ((p = strchr (p, ',')) != NULL);
4252 argbuf.safe_grow (old_length + n);
4253 memmove (argbuf.address () + n,
4254 argbuf.address (),
4255 old_length * sizeof (const_char_p));
4257 i = 0;
4258 p = buf;
4261 while (*p == ',')
4263 *p = 0;
4264 p++;
4266 argbuf[i] = p;
4267 i++;
4269 while ((p = strchr (p, ',')) != NULL);
4270 gcc_assert (i == n);
4273 /* Process the spec SPEC and run the commands specified therein.
4274 Returns 0 if the spec is successfully processed; -1 if failed. */
4277 do_spec (const char *spec)
4279 int value;
4281 value = do_spec_2 (spec);
4283 /* Force out any unfinished command.
4284 If -pipe, this forces out the last command if it ended in `|'. */
4285 if (value == 0)
4287 if (argbuf.length () > 0
4288 && !strcmp (argbuf.last (), "|"))
4289 argbuf.pop ();
4291 set_collect_gcc_options ();
4293 if (argbuf.length () > 0)
4294 value = execute ();
4297 return value;
4300 static int
4301 do_spec_2 (const char *spec)
4303 int result;
4305 clear_args ();
4306 arg_going = 0;
4307 delete_this_arg = 0;
4308 this_is_output_file = 0;
4309 this_is_library_file = 0;
4310 this_is_linker_script = 0;
4311 input_from_pipe = 0;
4312 suffix_subst = NULL;
4314 result = do_spec_1 (spec, 0, NULL);
4316 end_going_arg ();
4318 return result;
4322 /* Process the given spec string and add any new options to the end
4323 of the switches/n_switches array. */
4325 static void
4326 do_option_spec (const char *name, const char *spec)
4328 unsigned int i, value_count, value_len;
4329 const char *p, *q, *value;
4330 char *tmp_spec, *tmp_spec_p;
4332 if (configure_default_options[0].name == NULL)
4333 return;
4335 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4336 if (strcmp (configure_default_options[i].name, name) == 0)
4337 break;
4338 if (i == ARRAY_SIZE (configure_default_options))
4339 return;
4341 value = configure_default_options[i].value;
4342 value_len = strlen (value);
4344 /* Compute the size of the final spec. */
4345 value_count = 0;
4346 p = spec;
4347 while ((p = strstr (p, "%(VALUE)")) != NULL)
4349 p ++;
4350 value_count ++;
4353 /* Replace each %(VALUE) by the specified value. */
4354 tmp_spec = (char *) alloca (strlen (spec) + 1
4355 + value_count * (value_len - strlen ("%(VALUE)")));
4356 tmp_spec_p = tmp_spec;
4357 q = spec;
4358 while ((p = strstr (q, "%(VALUE)")) != NULL)
4360 memcpy (tmp_spec_p, q, p - q);
4361 tmp_spec_p = tmp_spec_p + (p - q);
4362 memcpy (tmp_spec_p, value, value_len);
4363 tmp_spec_p += value_len;
4364 q = p + strlen ("%(VALUE)");
4366 strcpy (tmp_spec_p, q);
4368 do_self_spec (tmp_spec);
4371 /* Process the given spec string and add any new options to the end
4372 of the switches/n_switches array. */
4374 static void
4375 do_self_spec (const char *spec)
4377 int i;
4379 do_spec_2 (spec);
4380 do_spec_1 (" ", 0, NULL);
4382 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4383 do_self_specs adds the replacements to switches array, so it shouldn't
4384 be processed afterwards. */
4385 for (i = 0; i < n_switches; i++)
4386 if ((switches[i].live_cond & SWITCH_IGNORE))
4387 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4389 if (argbuf.length () > 0)
4391 const char **argbuf_copy;
4392 struct cl_decoded_option *decoded_options;
4393 struct cl_option_handlers handlers;
4394 unsigned int decoded_options_count;
4395 unsigned int j;
4397 /* Create a copy of argbuf with a dummy argv[0] entry for
4398 decode_cmdline_options_to_array. */
4399 argbuf_copy = XNEWVEC (const char *,
4400 argbuf.length () + 1);
4401 argbuf_copy[0] = "";
4402 memcpy (argbuf_copy + 1, argbuf.address (),
4403 argbuf.length () * sizeof (const char *));
4405 decode_cmdline_options_to_array (argbuf.length () + 1,
4406 argbuf_copy,
4407 CL_DRIVER, &decoded_options,
4408 &decoded_options_count);
4409 free (argbuf_copy);
4411 set_option_handlers (&handlers);
4413 for (j = 1; j < decoded_options_count; j++)
4415 switch (decoded_options[j].opt_index)
4417 case OPT_SPECIAL_input_file:
4418 /* Specs should only generate options, not input
4419 files. */
4420 if (strcmp (decoded_options[j].arg, "-") != 0)
4421 fatal_error ("switch %qs does not start with %<-%>",
4422 decoded_options[j].arg);
4423 else
4424 fatal_error ("spec-generated switch is just %<-%>");
4425 break;
4427 case OPT_fcompare_debug_second:
4428 case OPT_fcompare_debug:
4429 case OPT_fcompare_debug_:
4430 case OPT_o:
4431 /* Avoid duplicate processing of some options from
4432 compare-debug specs; just save them here. */
4433 save_switch (decoded_options[j].canonical_option[0],
4434 (decoded_options[j].canonical_option_num_elements
4435 - 1),
4436 &decoded_options[j].canonical_option[1], false, true);
4437 break;
4439 default:
4440 read_cmdline_option (&global_options, &global_options_set,
4441 decoded_options + j, UNKNOWN_LOCATION,
4442 CL_DRIVER, &handlers, global_dc);
4443 break;
4447 alloc_switch ();
4448 switches[n_switches].part1 = 0;
4452 /* Callback for processing %D and %I specs. */
4454 struct spec_path_info {
4455 const char *option;
4456 const char *append;
4457 size_t append_len;
4458 bool omit_relative;
4459 bool separate_options;
4462 static void *
4463 spec_path (char *path, void *data)
4465 struct spec_path_info *info = (struct spec_path_info *) data;
4466 size_t len = 0;
4467 char save = 0;
4469 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4470 return NULL;
4472 if (info->append_len != 0)
4474 len = strlen (path);
4475 memcpy (path + len, info->append, info->append_len + 1);
4478 if (!is_directory (path, true))
4479 return NULL;
4481 do_spec_1 (info->option, 1, NULL);
4482 if (info->separate_options)
4483 do_spec_1 (" ", 0, NULL);
4485 if (info->append_len == 0)
4487 len = strlen (path);
4488 save = path[len - 1];
4489 if (IS_DIR_SEPARATOR (path[len - 1]))
4490 path[len - 1] = '\0';
4493 do_spec_1 (path, 1, NULL);
4494 do_spec_1 (" ", 0, NULL);
4496 /* Must not damage the original path. */
4497 if (info->append_len == 0)
4498 path[len - 1] = save;
4500 return NULL;
4503 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4504 argument list. */
4506 static void
4507 create_at_file (char **argv)
4509 char *temp_file = make_temp_file ("");
4510 char *at_argument = concat ("@", temp_file, NULL);
4511 FILE *f = fopen (temp_file, "w");
4512 int status;
4514 if (f == NULL)
4515 fatal_error ("could not open temporary response file %s",
4516 temp_file);
4518 status = writeargv (argv, f);
4520 if (status)
4521 fatal_error ("could not write to temporary response file %s",
4522 temp_file);
4524 status = fclose (f);
4526 if (EOF == status)
4527 fatal_error ("could not close temporary response file %s",
4528 temp_file);
4530 store_arg (at_argument, 0, 0);
4532 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4535 /* True if we should compile INFILE. */
4537 static bool
4538 compile_input_file_p (struct infile *infile)
4540 if ((!infile->language) || (infile->language[0] != '*'))
4541 if (infile->incompiler == input_file_compiler)
4542 return true;
4543 return false;
4546 /* Process each member of VEC as a spec. */
4548 static void
4549 do_specs_vec (vec<char_p> vec)
4551 unsigned ix;
4552 char *opt;
4554 FOR_EACH_VEC_ELT (vec, ix, opt)
4556 do_spec_1 (opt, 1, NULL);
4557 /* Make each accumulated option a separate argument. */
4558 do_spec_1 (" ", 0, NULL);
4562 /* Process the sub-spec SPEC as a portion of a larger spec.
4563 This is like processing a whole spec except that we do
4564 not initialize at the beginning and we do not supply a
4565 newline by default at the end.
4566 INSWITCH nonzero means don't process %-sequences in SPEC;
4567 in this case, % is treated as an ordinary character.
4568 This is used while substituting switches.
4569 INSWITCH nonzero also causes SPC not to terminate an argument.
4571 Value is zero unless a line was finished
4572 and the command on that line reported an error. */
4574 static int
4575 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4577 const char *p = spec;
4578 int c;
4579 int i;
4580 int value;
4582 /* If it's an empty string argument to a switch, keep it as is. */
4583 if (inswitch && !*p)
4584 arg_going = 1;
4586 while ((c = *p++))
4587 /* If substituting a switch, treat all chars like letters.
4588 Otherwise, NL, SPC, TAB and % are special. */
4589 switch (inswitch ? 'a' : c)
4591 case '\n':
4592 end_going_arg ();
4594 if (argbuf.length () > 0
4595 && !strcmp (argbuf.last (), "|"))
4597 /* A `|' before the newline means use a pipe here,
4598 but only if -pipe was specified.
4599 Otherwise, execute now and don't pass the `|' as an arg. */
4600 if (use_pipes)
4602 input_from_pipe = 1;
4603 break;
4605 else
4606 argbuf.pop ();
4609 set_collect_gcc_options ();
4611 if (argbuf.length () > 0)
4613 value = execute ();
4614 if (value)
4615 return value;
4617 /* Reinitialize for a new command, and for a new argument. */
4618 clear_args ();
4619 arg_going = 0;
4620 delete_this_arg = 0;
4621 this_is_output_file = 0;
4622 this_is_library_file = 0;
4623 this_is_linker_script = 0;
4624 input_from_pipe = 0;
4625 break;
4627 case '|':
4628 end_going_arg ();
4630 /* Use pipe */
4631 obstack_1grow (&obstack, c);
4632 arg_going = 1;
4633 break;
4635 case '\t':
4636 case ' ':
4637 end_going_arg ();
4639 /* Reinitialize for a new argument. */
4640 delete_this_arg = 0;
4641 this_is_output_file = 0;
4642 this_is_library_file = 0;
4643 this_is_linker_script = 0;
4644 break;
4646 case '%':
4647 switch (c = *p++)
4649 case 0:
4650 fatal_error ("spec %qs invalid", spec);
4652 case 'b':
4653 if (save_temps_length)
4654 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4655 else
4656 obstack_grow (&obstack, input_basename, basename_length);
4657 if (compare_debug < 0)
4658 obstack_grow (&obstack, ".gk", 3);
4659 arg_going = 1;
4660 break;
4662 case 'B':
4663 if (save_temps_length)
4664 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4665 else
4666 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4667 if (compare_debug < 0)
4668 obstack_grow (&obstack, ".gk", 3);
4669 arg_going = 1;
4670 break;
4672 case 'd':
4673 delete_this_arg = 2;
4674 break;
4676 /* Dump out the directories specified with LIBRARY_PATH,
4677 followed by the absolute directories
4678 that we search for startfiles. */
4679 case 'D':
4681 struct spec_path_info info;
4683 info.option = "-L";
4684 info.append_len = 0;
4685 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4686 /* Used on systems which record the specified -L dirs
4687 and use them to search for dynamic linking.
4688 Relative directories always come from -B,
4689 and it is better not to use them for searching
4690 at run time. In particular, stage1 loses. */
4691 info.omit_relative = true;
4692 #else
4693 info.omit_relative = false;
4694 #endif
4695 info.separate_options = false;
4697 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4699 break;
4701 case 'e':
4702 /* %efoo means report an error with `foo' as error message
4703 and don't execute any more commands for this file. */
4705 const char *q = p;
4706 char *buf;
4707 while (*p != 0 && *p != '\n')
4708 p++;
4709 buf = (char *) alloca (p - q + 1);
4710 strncpy (buf, q, p - q);
4711 buf[p - q] = 0;
4712 error ("%s", _(buf));
4713 return -1;
4715 break;
4716 case 'n':
4717 /* %nfoo means report a notice with `foo' on stderr. */
4719 const char *q = p;
4720 char *buf;
4721 while (*p != 0 && *p != '\n')
4722 p++;
4723 buf = (char *) alloca (p - q + 1);
4724 strncpy (buf, q, p - q);
4725 buf[p - q] = 0;
4726 inform (0, "%s", _(buf));
4727 if (*p)
4728 p++;
4730 break;
4732 case 'j':
4734 struct stat st;
4736 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4737 defined, and it is not a directory, and it is
4738 writable, use it. Otherwise, treat this like any
4739 other temporary file. */
4741 if ((!save_temps_flag)
4742 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4743 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4745 obstack_grow (&obstack, HOST_BIT_BUCKET,
4746 strlen (HOST_BIT_BUCKET));
4747 delete_this_arg = 0;
4748 arg_going = 1;
4749 break;
4752 goto create_temp_file;
4753 case '|':
4754 if (use_pipes)
4756 obstack_1grow (&obstack, '-');
4757 delete_this_arg = 0;
4758 arg_going = 1;
4760 /* consume suffix */
4761 while (*p == '.' || ISALNUM ((unsigned char) *p))
4762 p++;
4763 if (p[0] == '%' && p[1] == 'O')
4764 p += 2;
4766 break;
4768 goto create_temp_file;
4769 case 'm':
4770 if (use_pipes)
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 'g':
4782 case 'u':
4783 case 'U':
4784 create_temp_file:
4786 struct temp_name *t;
4787 int suffix_length;
4788 const char *suffix = p;
4789 char *saved_suffix = NULL;
4791 while (*p == '.' || ISALNUM ((unsigned char) *p))
4792 p++;
4793 suffix_length = p - suffix;
4794 if (p[0] == '%' && p[1] == 'O')
4796 p += 2;
4797 /* We don't support extra suffix characters after %O. */
4798 if (*p == '.' || ISALNUM ((unsigned char) *p))
4799 fatal_error ("spec %qs has invalid %<%%0%c%>", spec, *p);
4800 if (suffix_length == 0)
4801 suffix = TARGET_OBJECT_SUFFIX;
4802 else
4804 saved_suffix
4805 = XNEWVEC (char, suffix_length
4806 + strlen (TARGET_OBJECT_SUFFIX));
4807 strncpy (saved_suffix, suffix, suffix_length);
4808 strcpy (saved_suffix + suffix_length,
4809 TARGET_OBJECT_SUFFIX);
4811 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4814 if (compare_debug < 0)
4816 suffix = concat (".gk", suffix, NULL);
4817 suffix_length += 3;
4820 /* If -save-temps=obj and -o were specified, use that for the
4821 temp file. */
4822 if (save_temps_length)
4824 char *tmp;
4825 temp_filename_length
4826 = save_temps_length + suffix_length + 1;
4827 tmp = (char *) alloca (temp_filename_length);
4828 memcpy (tmp, save_temps_prefix, save_temps_length);
4829 memcpy (tmp + save_temps_length, suffix, suffix_length);
4830 tmp[save_temps_length + suffix_length] = '\0';
4831 temp_filename = save_string (tmp, save_temps_length
4832 + suffix_length);
4833 obstack_grow (&obstack, temp_filename,
4834 temp_filename_length);
4835 arg_going = 1;
4836 delete_this_arg = 0;
4837 break;
4840 /* If the gcc_input_filename has the same suffix specified
4841 for the %g, %u, or %U, and -save-temps is specified,
4842 we could end up using that file as an intermediate
4843 thus clobbering the user's source file (.e.g.,
4844 gcc -save-temps foo.s would clobber foo.s with the
4845 output of cpp0). So check for this condition and
4846 generate a temp file as the intermediate. */
4848 if (save_temps_flag)
4850 char *tmp;
4851 temp_filename_length = basename_length + suffix_length + 1;
4852 tmp = (char *) alloca (temp_filename_length);
4853 memcpy (tmp, input_basename, basename_length);
4854 memcpy (tmp + basename_length, suffix, suffix_length);
4855 tmp[basename_length + suffix_length] = '\0';
4856 temp_filename = tmp;
4858 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
4860 #ifndef HOST_LACKS_INODE_NUMBERS
4861 struct stat st_temp;
4863 /* Note, set_input() resets input_stat_set to 0. */
4864 if (input_stat_set == 0)
4866 input_stat_set = stat (gcc_input_filename,
4867 &input_stat);
4868 if (input_stat_set >= 0)
4869 input_stat_set = 1;
4872 /* If we have the stat for the gcc_input_filename
4873 and we can do the stat for the temp_filename
4874 then the they could still refer to the same
4875 file if st_dev/st_ino's are the same. */
4876 if (input_stat_set != 1
4877 || stat (temp_filename, &st_temp) < 0
4878 || input_stat.st_dev != st_temp.st_dev
4879 || input_stat.st_ino != st_temp.st_ino)
4880 #else
4881 /* Just compare canonical pathnames. */
4882 char* input_realname = lrealpath (gcc_input_filename);
4883 char* temp_realname = lrealpath (temp_filename);
4884 bool files_differ = filename_cmp (input_realname, temp_realname);
4885 free (input_realname);
4886 free (temp_realname);
4887 if (files_differ)
4888 #endif
4890 temp_filename = save_string (temp_filename,
4891 temp_filename_length + 1);
4892 obstack_grow (&obstack, temp_filename,
4893 temp_filename_length);
4894 arg_going = 1;
4895 delete_this_arg = 0;
4896 break;
4901 /* See if we already have an association of %g/%u/%U and
4902 suffix. */
4903 for (t = temp_names; t; t = t->next)
4904 if (t->length == suffix_length
4905 && strncmp (t->suffix, suffix, suffix_length) == 0
4906 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4907 break;
4909 /* Make a new association if needed. %u and %j
4910 require one. */
4911 if (t == 0 || c == 'u' || c == 'j')
4913 if (t == 0)
4915 t = XNEW (struct temp_name);
4916 t->next = temp_names;
4917 temp_names = t;
4919 t->length = suffix_length;
4920 if (saved_suffix)
4922 t->suffix = saved_suffix;
4923 saved_suffix = NULL;
4925 else
4926 t->suffix = save_string (suffix, suffix_length);
4927 t->unique = (c == 'u' || c == 'U' || c == 'j');
4928 temp_filename = make_temp_file (t->suffix);
4929 temp_filename_length = strlen (temp_filename);
4930 t->filename = temp_filename;
4931 t->filename_length = temp_filename_length;
4934 free (saved_suffix);
4936 obstack_grow (&obstack, t->filename, t->filename_length);
4937 delete_this_arg = 1;
4939 arg_going = 1;
4940 break;
4942 case 'i':
4943 if (combine_inputs)
4945 if (at_file_supplied)
4947 /* We are going to expand `%i' to `@FILE', where FILE
4948 is a newly-created temporary filename. The filenames
4949 that would usually be expanded in place of %o will be
4950 written to the temporary file. */
4951 char **argv;
4952 int n_files = 0;
4953 int j;
4955 for (i = 0; i < n_infiles; i++)
4956 if (compile_input_file_p (&infiles[i]))
4957 n_files++;
4959 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
4961 /* Copy the strings over. */
4962 for (i = 0, j = 0; i < n_infiles; i++)
4963 if (compile_input_file_p (&infiles[i]))
4965 argv[j] = CONST_CAST (char *, infiles[i].name);
4966 infiles[i].compiled = true;
4967 j++;
4969 argv[j] = NULL;
4971 create_at_file (argv);
4973 else
4974 for (i = 0; (int) i < n_infiles; i++)
4975 if (compile_input_file_p (&infiles[i]))
4977 store_arg (infiles[i].name, 0, 0);
4978 infiles[i].compiled = true;
4981 else
4983 obstack_grow (&obstack, gcc_input_filename,
4984 input_filename_length);
4985 arg_going = 1;
4987 break;
4989 case 'I':
4991 struct spec_path_info info;
4993 if (multilib_dir)
4995 do_spec_1 ("-imultilib", 1, NULL);
4996 /* Make this a separate argument. */
4997 do_spec_1 (" ", 0, NULL);
4998 do_spec_1 (multilib_dir, 1, NULL);
4999 do_spec_1 (" ", 0, NULL);
5002 if (multiarch_dir)
5004 do_spec_1 ("-imultiarch", 1, NULL);
5005 /* Make this a separate argument. */
5006 do_spec_1 (" ", 0, NULL);
5007 do_spec_1 (multiarch_dir, 1, NULL);
5008 do_spec_1 (" ", 0, NULL);
5011 if (gcc_exec_prefix)
5013 do_spec_1 ("-iprefix", 1, NULL);
5014 /* Make this a separate argument. */
5015 do_spec_1 (" ", 0, NULL);
5016 do_spec_1 (gcc_exec_prefix, 1, NULL);
5017 do_spec_1 (" ", 0, NULL);
5020 if (target_system_root_changed ||
5021 (target_system_root && target_sysroot_hdrs_suffix))
5023 do_spec_1 ("-isysroot", 1, NULL);
5024 /* Make this a separate argument. */
5025 do_spec_1 (" ", 0, NULL);
5026 do_spec_1 (target_system_root, 1, NULL);
5027 if (target_sysroot_hdrs_suffix)
5028 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5029 do_spec_1 (" ", 0, NULL);
5032 info.option = "-isystem";
5033 info.append = "include";
5034 info.append_len = strlen (info.append);
5035 info.omit_relative = false;
5036 info.separate_options = true;
5038 for_each_path (&include_prefixes, false, info.append_len,
5039 spec_path, &info);
5041 info.append = "include-fixed";
5042 if (*sysroot_hdrs_suffix_spec)
5043 info.append = concat (info.append, dir_separator_str,
5044 multilib_dir, NULL);
5045 info.append_len = strlen (info.append);
5046 for_each_path (&include_prefixes, false, info.append_len,
5047 spec_path, &info);
5049 break;
5051 case 'o':
5053 int max = n_infiles;
5054 max += lang_specific_extra_outfiles;
5056 if (HAVE_GNU_LD && at_file_supplied)
5058 /* We are going to expand `%o' to `@FILE', where FILE
5059 is a newly-created temporary filename. The filenames
5060 that would usually be expanded in place of %o will be
5061 written to the temporary file. */
5063 char **argv;
5064 int n_files, j;
5066 /* Convert OUTFILES into a form suitable for writeargv. */
5068 /* Determine how many are non-NULL. */
5069 for (n_files = 0, i = 0; i < max; i++)
5070 n_files += outfiles[i] != NULL;
5072 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5074 /* Copy the strings over. */
5075 for (i = 0, j = 0; i < max; i++)
5076 if (outfiles[i])
5078 argv[j] = CONST_CAST (char *, outfiles[i]);
5079 j++;
5081 argv[j] = NULL;
5083 create_at_file (argv);
5085 else
5086 for (i = 0; i < max; i++)
5087 if (outfiles[i])
5088 store_arg (outfiles[i], 0, 0);
5089 break;
5092 case 'O':
5093 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5094 arg_going = 1;
5095 break;
5097 case 's':
5098 this_is_library_file = 1;
5099 break;
5101 case 'T':
5102 this_is_linker_script = 1;
5103 break;
5105 case 'V':
5106 outfiles[input_file_number] = NULL;
5107 break;
5109 case 'w':
5110 this_is_output_file = 1;
5111 break;
5113 case 'W':
5115 unsigned int cur_index = argbuf.length ();
5116 /* Handle the {...} following the %W. */
5117 if (*p != '{')
5118 fatal_error ("spec %qs has invalid %<%%W%c%>", spec, *p);
5119 p = handle_braces (p + 1);
5120 if (p == 0)
5121 return -1;
5122 end_going_arg ();
5123 /* If any args were output, mark the last one for deletion
5124 on failure. */
5125 if (argbuf.length () != cur_index)
5126 record_temp_file (argbuf.last (), 0, 1);
5127 break;
5130 /* %x{OPTION} records OPTION for %X to output. */
5131 case 'x':
5133 const char *p1 = p;
5134 char *string;
5135 char *opt;
5136 unsigned ix;
5138 /* Skip past the option value and make a copy. */
5139 if (*p != '{')
5140 fatal_error ("spec %qs has invalid %<%%x%c%>", spec, *p);
5141 while (*p++ != '}')
5143 string = save_string (p1 + 1, p - p1 - 2);
5145 /* See if we already recorded this option. */
5146 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5147 if (! strcmp (string, opt))
5149 free (string);
5150 return 0;
5153 /* This option is new; add it. */
5154 add_linker_option (string, strlen (string));
5155 free (string);
5157 break;
5159 /* Dump out the options accumulated previously using %x. */
5160 case 'X':
5161 do_specs_vec (linker_options);
5162 break;
5164 /* Dump out the options accumulated previously using -Wa,. */
5165 case 'Y':
5166 do_specs_vec (assembler_options);
5167 break;
5169 /* Dump out the options accumulated previously using -Wp,. */
5170 case 'Z':
5171 do_specs_vec (preprocessor_options);
5172 break;
5174 /* Here are digits and numbers that just process
5175 a certain constant string as a spec. */
5177 case '1':
5178 value = do_spec_1 (cc1_spec, 0, NULL);
5179 if (value != 0)
5180 return value;
5181 break;
5183 case '2':
5184 value = do_spec_1 (cc1plus_spec, 0, NULL);
5185 if (value != 0)
5186 return value;
5187 break;
5189 case 'a':
5190 value = do_spec_1 (asm_spec, 0, NULL);
5191 if (value != 0)
5192 return value;
5193 break;
5195 case 'A':
5196 value = do_spec_1 (asm_final_spec, 0, NULL);
5197 if (value != 0)
5198 return value;
5199 break;
5201 case 'C':
5203 const char *const spec
5204 = (input_file_compiler->cpp_spec
5205 ? input_file_compiler->cpp_spec
5206 : cpp_spec);
5207 value = do_spec_1 (spec, 0, NULL);
5208 if (value != 0)
5209 return value;
5211 break;
5213 case 'E':
5214 value = do_spec_1 (endfile_spec, 0, NULL);
5215 if (value != 0)
5216 return value;
5217 break;
5219 case 'l':
5220 value = do_spec_1 (link_spec, 0, NULL);
5221 if (value != 0)
5222 return value;
5223 break;
5225 case 'L':
5226 value = do_spec_1 (lib_spec, 0, NULL);
5227 if (value != 0)
5228 return value;
5229 break;
5231 case 'M':
5232 if (multilib_os_dir == NULL)
5233 obstack_1grow (&obstack, '.');
5234 else
5235 obstack_grow (&obstack, multilib_os_dir,
5236 strlen (multilib_os_dir));
5237 break;
5239 case 'G':
5240 value = do_spec_1 (libgcc_spec, 0, NULL);
5241 if (value != 0)
5242 return value;
5243 break;
5245 case 'R':
5246 /* We assume there is a directory
5247 separator at the end of this string. */
5248 if (target_system_root)
5250 obstack_grow (&obstack, target_system_root,
5251 strlen (target_system_root));
5252 if (target_sysroot_suffix)
5253 obstack_grow (&obstack, target_sysroot_suffix,
5254 strlen (target_sysroot_suffix));
5256 break;
5258 case 'S':
5259 value = do_spec_1 (startfile_spec, 0, NULL);
5260 if (value != 0)
5261 return value;
5262 break;
5264 /* Here we define characters other than letters and digits. */
5266 case '{':
5267 p = handle_braces (p);
5268 if (p == 0)
5269 return -1;
5270 break;
5272 case ':':
5273 p = handle_spec_function (p);
5274 if (p == 0)
5275 return -1;
5276 break;
5278 case '%':
5279 obstack_1grow (&obstack, '%');
5280 break;
5282 case '.':
5284 unsigned len = 0;
5286 while (p[len] && p[len] != ' ' && p[len] != '%')
5287 len++;
5288 suffix_subst = save_string (p - 1, len + 1);
5289 p += len;
5291 break;
5293 /* Henceforth ignore the option(s) matching the pattern
5294 after the %<. */
5295 case '<':
5296 case '>':
5298 unsigned len = 0;
5299 int have_wildcard = 0;
5300 int i;
5301 int switch_option;
5303 if (c == '>')
5304 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5305 else
5306 switch_option = SWITCH_IGNORE;
5308 while (p[len] && p[len] != ' ' && p[len] != '\t')
5309 len++;
5311 if (p[len-1] == '*')
5312 have_wildcard = 1;
5314 for (i = 0; i < n_switches; i++)
5315 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5316 && (have_wildcard || switches[i].part1[len] == '\0'))
5318 switches[i].live_cond |= switch_option;
5319 /* User switch be validated from validate_all_switches.
5320 when the definition is seen from the spec file.
5321 If not defined anywhere, will be rejected. */
5322 if (switches[i].known)
5323 switches[i].validated = true;
5326 p += len;
5328 break;
5330 case '*':
5331 if (soft_matched_part)
5333 if (soft_matched_part[0])
5334 do_spec_1 (soft_matched_part, 1, NULL);
5335 do_spec_1 (" ", 0, NULL);
5337 else
5338 /* Catch the case where a spec string contains something like
5339 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5340 hand side of the :. */
5341 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5342 break;
5344 /* Process a string found as the value of a spec given by name.
5345 This feature allows individual machine descriptions
5346 to add and use their own specs. */
5347 case '(':
5349 const char *name = p;
5350 struct spec_list *sl;
5351 int len;
5353 /* The string after the S/P is the name of a spec that is to be
5354 processed. */
5355 while (*p && *p != ')')
5356 p++;
5358 /* See if it's in the list. */
5359 for (len = p - name, sl = specs; sl; sl = sl->next)
5360 if (sl->name_len == len && !strncmp (sl->name, name, len))
5362 name = *(sl->ptr_spec);
5363 #ifdef DEBUG_SPECS
5364 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5365 sl->name, name);
5366 #endif
5367 break;
5370 if (sl)
5372 value = do_spec_1 (name, 0, NULL);
5373 if (value != 0)
5374 return value;
5377 /* Discard the closing paren. */
5378 if (*p)
5379 p++;
5381 break;
5383 default:
5384 error ("spec failure: unrecognized spec option %qc", c);
5385 break;
5387 break;
5389 case '\\':
5390 /* Backslash: treat next character as ordinary. */
5391 c = *p++;
5393 /* Fall through. */
5394 default:
5395 /* Ordinary character: put it into the current argument. */
5396 obstack_1grow (&obstack, c);
5397 arg_going = 1;
5400 /* End of string. If we are processing a spec function, we need to
5401 end any pending argument. */
5402 if (processing_spec_function)
5403 end_going_arg ();
5405 return 0;
5408 /* Look up a spec function. */
5410 static const struct spec_function *
5411 lookup_spec_function (const char *name)
5413 const struct spec_function *sf;
5415 for (sf = static_spec_functions; sf->name != NULL; sf++)
5416 if (strcmp (sf->name, name) == 0)
5417 return sf;
5419 return NULL;
5422 /* Evaluate a spec function. */
5424 static const char *
5425 eval_spec_function (const char *func, const char *args)
5427 const struct spec_function *sf;
5428 const char *funcval;
5430 /* Saved spec processing context. */
5431 vec<const_char_p> save_argbuf;
5433 int save_arg_going;
5434 int save_delete_this_arg;
5435 int save_this_is_output_file;
5436 int save_this_is_library_file;
5437 int save_input_from_pipe;
5438 int save_this_is_linker_script;
5439 const char *save_suffix_subst;
5441 int save_growing_size;
5442 void *save_growing_value;
5444 sf = lookup_spec_function (func);
5445 if (sf == NULL)
5446 fatal_error ("unknown spec function %qs", func);
5448 /* Push the spec processing context. */
5449 save_argbuf = argbuf;
5451 save_arg_going = arg_going;
5452 save_delete_this_arg = delete_this_arg;
5453 save_this_is_output_file = this_is_output_file;
5454 save_this_is_library_file = this_is_library_file;
5455 save_this_is_linker_script = this_is_linker_script;
5456 save_input_from_pipe = input_from_pipe;
5457 save_suffix_subst = suffix_subst;
5459 /* If we have some object growing now, finalize it so the args and function
5460 eval proceed from a cleared context. This is needed to prevent the first
5461 constructed arg from mistakenly including the growing value. We'll push
5462 this value back on the obstack once the function evaluation is done, to
5463 restore a consistent processing context for our caller. This is fine as
5464 the address of growing objects isn't guaranteed to remain stable until
5465 they are finalized, and we expect this situation to be rare enough for
5466 the extra copy not to be an issue. */
5467 save_growing_size = obstack_object_size (&obstack);
5468 if (save_growing_size > 0)
5469 save_growing_value = obstack_finish (&obstack);
5471 /* Create a new spec processing context, and build the function
5472 arguments. */
5474 alloc_args ();
5475 if (do_spec_2 (args) < 0)
5476 fatal_error ("error in args to spec function %qs", func);
5478 /* argbuf_index is an index for the next argument to be inserted, and
5479 so contains the count of the args already inserted. */
5481 funcval = (*sf->func) (argbuf.length (),
5482 argbuf.address ());
5484 /* Pop the spec processing context. */
5485 argbuf.release ();
5486 argbuf = save_argbuf;
5488 arg_going = save_arg_going;
5489 delete_this_arg = save_delete_this_arg;
5490 this_is_output_file = save_this_is_output_file;
5491 this_is_library_file = save_this_is_library_file;
5492 this_is_linker_script = save_this_is_linker_script;
5493 input_from_pipe = save_input_from_pipe;
5494 suffix_subst = save_suffix_subst;
5496 if (save_growing_size > 0)
5497 obstack_grow (&obstack, save_growing_value, save_growing_size);
5499 return funcval;
5502 /* Handle a spec function call of the form:
5504 %:function(args)
5506 ARGS is processed as a spec in a separate context and split into an
5507 argument vector in the normal fashion. The function returns a string
5508 containing a spec which we then process in the caller's context, or
5509 NULL if no processing is required. */
5511 static const char *
5512 handle_spec_function (const char *p)
5514 char *func, *args;
5515 const char *endp, *funcval;
5516 int count;
5518 processing_spec_function++;
5520 /* Get the function name. */
5521 for (endp = p; *endp != '\0'; endp++)
5523 if (*endp == '(') /* ) */
5524 break;
5525 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5526 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5527 fatal_error ("malformed spec function name");
5529 if (*endp != '(') /* ) */
5530 fatal_error ("no arguments for spec function");
5531 func = save_string (p, endp - p);
5532 p = ++endp;
5534 /* Get the arguments. */
5535 for (count = 0; *endp != '\0'; endp++)
5537 /* ( */
5538 if (*endp == ')')
5540 if (count == 0)
5541 break;
5542 count--;
5544 else if (*endp == '(') /* ) */
5545 count++;
5547 /* ( */
5548 if (*endp != ')')
5549 fatal_error ("malformed spec function arguments");
5550 args = save_string (p, endp - p);
5551 p = ++endp;
5553 /* p now points to just past the end of the spec function expression. */
5555 funcval = eval_spec_function (func, args);
5556 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5557 p = NULL;
5559 free (func);
5560 free (args);
5562 processing_spec_function--;
5564 return p;
5567 /* Inline subroutine of handle_braces. Returns true if the current
5568 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5569 static inline bool
5570 input_suffix_matches (const char *atom, const char *end_atom)
5572 return (input_suffix
5573 && !strncmp (input_suffix, atom, end_atom - atom)
5574 && input_suffix[end_atom - atom] == '\0');
5577 /* Subroutine of handle_braces. Returns true if the current
5578 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
5579 static bool
5580 input_spec_matches (const char *atom, const char *end_atom)
5582 return (input_file_compiler
5583 && input_file_compiler->suffix
5584 && input_file_compiler->suffix[0] != '\0'
5585 && !strncmp (input_file_compiler->suffix + 1, atom,
5586 end_atom - atom)
5587 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5590 /* Subroutine of handle_braces. Returns true if a switch
5591 matching the atom bracketed by ATOM and END_ATOM appeared on the
5592 command line. */
5593 static bool
5594 switch_matches (const char *atom, const char *end_atom, int starred)
5596 int i;
5597 int len = end_atom - atom;
5598 int plen = starred ? len : -1;
5600 for (i = 0; i < n_switches; i++)
5601 if (!strncmp (switches[i].part1, atom, len)
5602 && (starred || switches[i].part1[len] == '\0')
5603 && check_live_switch (i, plen))
5604 return true;
5606 /* Check if a switch with separated form matching the atom.
5607 We check -D and -U switches. */
5608 else if (switches[i].args != 0)
5610 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
5611 && *switches[i].part1 == atom[0])
5613 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
5614 && (starred || (switches[i].part1[1] == '\0'
5615 && switches[i].args[0][len - 1] == '\0'))
5616 && check_live_switch (i, (starred ? 1 : -1)))
5617 return true;
5621 return false;
5624 /* Inline subroutine of handle_braces. Mark all of the switches which
5625 match ATOM (extends to END_ATOM; STARRED indicates whether there
5626 was a star after the atom) for later processing. */
5627 static inline void
5628 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5630 int i;
5631 int len = end_atom - atom;
5632 int plen = starred ? len : -1;
5634 for (i = 0; i < n_switches; i++)
5635 if (!strncmp (switches[i].part1, atom, len)
5636 && (starred || switches[i].part1[len] == '\0')
5637 && check_live_switch (i, plen))
5638 switches[i].ordering = 1;
5641 /* Inline subroutine of handle_braces. Process all the currently
5642 marked switches through give_switch, and clear the marks. */
5643 static inline void
5644 process_marked_switches (void)
5646 int i;
5648 for (i = 0; i < n_switches; i++)
5649 if (switches[i].ordering == 1)
5651 switches[i].ordering = 0;
5652 give_switch (i, 0);
5656 /* Handle a %{ ... } construct. P points just inside the leading {.
5657 Returns a pointer one past the end of the brace block, or 0
5658 if we call do_spec_1 and that returns -1. */
5660 static const char *
5661 handle_braces (const char *p)
5663 const char *atom, *end_atom;
5664 const char *d_atom = NULL, *d_end_atom = NULL;
5665 const char *orig = p;
5667 bool a_is_suffix;
5668 bool a_is_spectype;
5669 bool a_is_starred;
5670 bool a_is_negated;
5671 bool a_matched;
5673 bool a_must_be_last = false;
5674 bool ordered_set = false;
5675 bool disjunct_set = false;
5676 bool disj_matched = false;
5677 bool disj_starred = true;
5678 bool n_way_choice = false;
5679 bool n_way_matched = false;
5681 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5685 if (a_must_be_last)
5686 goto invalid;
5688 /* Scan one "atom" (S in the description above of %{}, possibly
5689 with '!', '.', '@', ',', or '*' modifiers). */
5690 a_matched = false;
5691 a_is_suffix = false;
5692 a_is_starred = false;
5693 a_is_negated = false;
5694 a_is_spectype = false;
5696 SKIP_WHITE();
5697 if (*p == '!')
5698 p++, a_is_negated = true;
5700 SKIP_WHITE();
5701 if (*p == '.')
5702 p++, a_is_suffix = true;
5703 else if (*p == ',')
5704 p++, a_is_spectype = true;
5706 atom = p;
5707 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5708 || *p == ',' || *p == '.' || *p == '@')
5709 p++;
5710 end_atom = p;
5712 if (*p == '*')
5713 p++, a_is_starred = 1;
5715 SKIP_WHITE();
5716 switch (*p)
5718 case '&': case '}':
5719 /* Substitute the switch(es) indicated by the current atom. */
5720 ordered_set = true;
5721 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5722 || a_is_spectype || atom == end_atom)
5723 goto invalid;
5725 mark_matching_switches (atom, end_atom, a_is_starred);
5727 if (*p == '}')
5728 process_marked_switches ();
5729 break;
5731 case '|': case ':':
5732 /* Substitute some text if the current atom appears as a switch
5733 or suffix. */
5734 disjunct_set = true;
5735 if (ordered_set)
5736 goto invalid;
5738 if (atom == end_atom)
5740 if (!n_way_choice || disj_matched || *p == '|'
5741 || a_is_negated || a_is_suffix || a_is_spectype
5742 || a_is_starred)
5743 goto invalid;
5745 /* An empty term may appear as the last choice of an
5746 N-way choice set; it means "otherwise". */
5747 a_must_be_last = true;
5748 disj_matched = !n_way_matched;
5749 disj_starred = false;
5751 else
5753 if ((a_is_suffix || a_is_spectype) && a_is_starred)
5754 goto invalid;
5756 if (!a_is_starred)
5757 disj_starred = false;
5759 /* Don't bother testing this atom if we already have a
5760 match. */
5761 if (!disj_matched && !n_way_matched)
5763 if (a_is_suffix)
5764 a_matched = input_suffix_matches (atom, end_atom);
5765 else if (a_is_spectype)
5766 a_matched = input_spec_matches (atom, end_atom);
5767 else
5768 a_matched = switch_matches (atom, end_atom, a_is_starred);
5770 if (a_matched != a_is_negated)
5772 disj_matched = true;
5773 d_atom = atom;
5774 d_end_atom = end_atom;
5779 if (*p == ':')
5781 /* Found the body, that is, the text to substitute if the
5782 current disjunction matches. */
5783 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5784 disj_matched && !n_way_matched);
5785 if (p == 0)
5786 return 0;
5788 /* If we have an N-way choice, reset state for the next
5789 disjunction. */
5790 if (*p == ';')
5792 n_way_choice = true;
5793 n_way_matched |= disj_matched;
5794 disj_matched = false;
5795 disj_starred = true;
5796 d_atom = d_end_atom = NULL;
5799 break;
5801 default:
5802 goto invalid;
5805 while (*p++ != '}');
5807 return p;
5809 invalid:
5810 fatal_error ("braced spec %qs is invalid at %qc", orig, *p);
5812 #undef SKIP_WHITE
5815 /* Subroutine of handle_braces. Scan and process a brace substitution body
5816 (X in the description of %{} syntax). P points one past the colon;
5817 ATOM and END_ATOM bracket the first atom which was found to be true
5818 (present) in the current disjunction; STARRED indicates whether all
5819 the atoms in the current disjunction were starred (for syntax validation);
5820 MATCHED indicates whether the disjunction matched or not, and therefore
5821 whether or not the body is to be processed through do_spec_1 or just
5822 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5823 returns -1. */
5825 static const char *
5826 process_brace_body (const char *p, const char *atom, const char *end_atom,
5827 int starred, int matched)
5829 const char *body, *end_body;
5830 unsigned int nesting_level;
5831 bool have_subst = false;
5833 /* Locate the closing } or ;, honoring nested braces.
5834 Trim trailing whitespace. */
5835 body = p;
5836 nesting_level = 1;
5837 for (;;)
5839 if (*p == '{')
5840 nesting_level++;
5841 else if (*p == '}')
5843 if (!--nesting_level)
5844 break;
5846 else if (*p == ';' && nesting_level == 1)
5847 break;
5848 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5849 have_subst = true;
5850 else if (*p == '\0')
5851 goto invalid;
5852 p++;
5855 end_body = p;
5856 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5857 end_body--;
5859 if (have_subst && !starred)
5860 goto invalid;
5862 if (matched)
5864 /* Copy the substitution body to permanent storage and execute it.
5865 If have_subst is false, this is a simple matter of running the
5866 body through do_spec_1... */
5867 char *string = save_string (body, end_body - body);
5868 if (!have_subst)
5870 if (do_spec_1 (string, 0, NULL) < 0)
5871 return 0;
5873 else
5875 /* ... but if have_subst is true, we have to process the
5876 body once for each matching switch, with %* set to the
5877 variant part of the switch. */
5878 unsigned int hard_match_len = end_atom - atom;
5879 int i;
5881 for (i = 0; i < n_switches; i++)
5882 if (!strncmp (switches[i].part1, atom, hard_match_len)
5883 && check_live_switch (i, hard_match_len))
5885 if (do_spec_1 (string, 0,
5886 &switches[i].part1[hard_match_len]) < 0)
5887 return 0;
5888 /* Pass any arguments this switch has. */
5889 give_switch (i, 1);
5890 suffix_subst = NULL;
5895 return p;
5897 invalid:
5898 fatal_error ("braced spec body %qs is invalid", body);
5901 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5902 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5903 spec, or -1 if either exact match or %* is used.
5905 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
5906 whose value does not begin with "no-" is obsoleted by the same value
5907 with the "no-", similarly for a switch with the "no-" prefix. */
5909 static int
5910 check_live_switch (int switchnum, int prefix_length)
5912 const char *name = switches[switchnum].part1;
5913 int i;
5915 /* If we already processed this switch and determined if it was
5916 live or not, return our past determination. */
5917 if (switches[switchnum].live_cond != 0)
5918 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
5919 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
5920 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
5921 == 0);
5923 /* In the common case of {<at-most-one-letter>*}, a negating
5924 switch would always match, so ignore that case. We will just
5925 send the conflicting switches to the compiler phase. */
5926 if (prefix_length >= 0 && prefix_length <= 1)
5927 return 1;
5929 /* Now search for duplicate in a manner that depends on the name. */
5930 switch (*name)
5932 case 'O':
5933 for (i = switchnum + 1; i < n_switches; i++)
5934 if (switches[i].part1[0] == 'O')
5936 switches[switchnum].validated = true;
5937 switches[switchnum].live_cond = SWITCH_FALSE;
5938 return 0;
5940 break;
5942 case 'W': case 'f': case 'm': case 'g':
5943 if (! strncmp (name + 1, "no-", 3))
5945 /* We have Xno-YYY, search for XYYY. */
5946 for (i = switchnum + 1; i < n_switches; i++)
5947 if (switches[i].part1[0] == name[0]
5948 && ! strcmp (&switches[i].part1[1], &name[4]))
5950 /* --specs are validated with the validate_switches mechanism. */
5951 if (switches[switchnum].known)
5952 switches[switchnum].validated = true;
5953 switches[switchnum].live_cond = SWITCH_FALSE;
5954 return 0;
5957 else
5959 /* We have XYYY, search for Xno-YYY. */
5960 for (i = switchnum + 1; i < n_switches; i++)
5961 if (switches[i].part1[0] == name[0]
5962 && switches[i].part1[1] == 'n'
5963 && switches[i].part1[2] == 'o'
5964 && switches[i].part1[3] == '-'
5965 && !strcmp (&switches[i].part1[4], &name[1]))
5967 /* --specs are validated with the validate_switches mechanism. */
5968 if (switches[switchnum].known)
5969 switches[switchnum].validated = true;
5970 switches[switchnum].live_cond = SWITCH_FALSE;
5971 return 0;
5974 break;
5977 /* Otherwise the switch is live. */
5978 switches[switchnum].live_cond |= SWITCH_LIVE;
5979 return 1;
5982 /* Pass a switch to the current accumulating command
5983 in the same form that we received it.
5984 SWITCHNUM identifies the switch; it is an index into
5985 the vector of switches gcc received, which is `switches'.
5986 This cannot fail since it never finishes a command line.
5988 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5990 static void
5991 give_switch (int switchnum, int omit_first_word)
5993 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
5994 return;
5996 if (!omit_first_word)
5998 do_spec_1 ("-", 0, NULL);
5999 do_spec_1 (switches[switchnum].part1, 1, NULL);
6002 if (switches[switchnum].args != 0)
6004 const char **p;
6005 for (p = switches[switchnum].args; *p; p++)
6007 const char *arg = *p;
6009 do_spec_1 (" ", 0, NULL);
6010 if (suffix_subst)
6012 unsigned length = strlen (arg);
6013 int dot = 0;
6015 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6016 if (arg[length] == '.')
6018 (CONST_CAST(char *, arg))[length] = 0;
6019 dot = 1;
6020 break;
6022 do_spec_1 (arg, 1, NULL);
6023 if (dot)
6024 (CONST_CAST(char *, arg))[length] = '.';
6025 do_spec_1 (suffix_subst, 1, NULL);
6027 else
6028 do_spec_1 (arg, 1, NULL);
6032 do_spec_1 (" ", 0, NULL);
6033 switches[switchnum].validated = true;
6036 /* Search for a file named NAME trying various prefixes including the
6037 user's -B prefix and some standard ones.
6038 Return the absolute file name found. If nothing is found, return NAME. */
6040 static const char *
6041 find_file (const char *name)
6043 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6044 return newname ? newname : name;
6047 /* Determine whether a directory exists. If LINKER, return 0 for
6048 certain fixed names not needed by the linker. */
6050 static int
6051 is_directory (const char *path1, bool linker)
6053 int len1;
6054 char *path;
6055 char *cp;
6056 struct stat st;
6058 /* Ensure the string ends with "/.". The resulting path will be a
6059 directory even if the given path is a symbolic link. */
6060 len1 = strlen (path1);
6061 path = (char *) alloca (3 + len1);
6062 memcpy (path, path1, len1);
6063 cp = path + len1;
6064 if (!IS_DIR_SEPARATOR (cp[-1]))
6065 *cp++ = DIR_SEPARATOR;
6066 *cp++ = '.';
6067 *cp = '\0';
6069 /* Exclude directories that the linker is known to search. */
6070 if (linker
6071 && IS_DIR_SEPARATOR (path[0])
6072 && ((cp - path == 6
6073 && filename_ncmp (path + 1, "lib", 3) == 0)
6074 || (cp - path == 10
6075 && filename_ncmp (path + 1, "usr", 3) == 0
6076 && IS_DIR_SEPARATOR (path[4])
6077 && filename_ncmp (path + 5, "lib", 3) == 0)))
6078 return 0;
6080 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6083 /* Set up the various global variables to indicate that we're processing
6084 the input file named FILENAME. */
6086 void
6087 set_input (const char *filename)
6089 const char *p;
6091 gcc_input_filename = filename;
6092 input_filename_length = strlen (gcc_input_filename);
6093 input_basename = lbasename (gcc_input_filename);
6095 /* Find a suffix starting with the last period,
6096 and set basename_length to exclude that suffix. */
6097 basename_length = strlen (input_basename);
6098 suffixed_basename_length = basename_length;
6099 p = input_basename + basename_length;
6100 while (p != input_basename && *p != '.')
6101 --p;
6102 if (*p == '.' && p != input_basename)
6104 basename_length = p - input_basename;
6105 input_suffix = p + 1;
6107 else
6108 input_suffix = "";
6110 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6111 we will need to do a stat on the gcc_input_filename. The
6112 INPUT_STAT_SET signals that the stat is needed. */
6113 input_stat_set = 0;
6116 /* On fatal signals, delete all the temporary files. */
6118 static void
6119 fatal_signal (int signum)
6121 signal (signum, SIG_DFL);
6122 delete_failure_queue ();
6123 delete_temp_files ();
6124 /* Get the same signal again, this time not handled,
6125 so its normal effect occurs. */
6126 kill (getpid (), signum);
6129 /* Compare the contents of the two files named CMPFILE[0] and
6130 CMPFILE[1]. Return zero if they're identical, nonzero
6131 otherwise. */
6133 static int
6134 compare_files (char *cmpfile[])
6136 int ret = 0;
6137 FILE *temp[2] = { NULL, NULL };
6138 int i;
6140 #if HAVE_MMAP_FILE
6142 size_t length[2];
6143 void *map[2] = { NULL, NULL };
6145 for (i = 0; i < 2; i++)
6147 struct stat st;
6149 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6151 error ("%s: could not determine length of compare-debug file %s",
6152 gcc_input_filename, cmpfile[i]);
6153 ret = 1;
6154 break;
6157 length[i] = st.st_size;
6160 if (!ret && length[0] != length[1])
6162 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
6163 ret = 1;
6166 if (!ret)
6167 for (i = 0; i < 2; i++)
6169 int fd = open (cmpfile[i], O_RDONLY);
6170 if (fd < 0)
6172 error ("%s: could not open compare-debug file %s",
6173 gcc_input_filename, cmpfile[i]);
6174 ret = 1;
6175 break;
6178 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
6179 close (fd);
6181 if (map[i] == (void *) MAP_FAILED)
6183 ret = -1;
6184 break;
6188 if (!ret)
6190 if (memcmp (map[0], map[1], length[0]) != 0)
6192 error ("%s: -fcompare-debug failure", gcc_input_filename);
6193 ret = 1;
6197 for (i = 0; i < 2; i++)
6198 if (map[i])
6199 munmap ((caddr_t) map[i], length[i]);
6201 if (ret >= 0)
6202 return ret;
6204 ret = 0;
6206 #endif
6208 for (i = 0; i < 2; i++)
6210 temp[i] = fopen (cmpfile[i], "r");
6211 if (!temp[i])
6213 error ("%s: could not open compare-debug file %s",
6214 gcc_input_filename, cmpfile[i]);
6215 ret = 1;
6216 break;
6220 if (!ret && temp[0] && temp[1])
6221 for (;;)
6223 int c0, c1;
6224 c0 = fgetc (temp[0]);
6225 c1 = fgetc (temp[1]);
6227 if (c0 != c1)
6229 error ("%s: -fcompare-debug failure",
6230 gcc_input_filename);
6231 ret = 1;
6232 break;
6235 if (c0 == EOF)
6236 break;
6239 for (i = 1; i >= 0; i--)
6241 if (temp[i])
6242 fclose (temp[i]);
6245 return ret;
6248 extern int main (int, char **);
6251 main (int argc, char **argv)
6253 size_t i;
6254 int value;
6255 int linker_was_run = 0;
6256 int lang_n_infiles = 0;
6257 int num_linker_inputs = 0;
6258 char *explicit_link_files;
6259 char *specs_file;
6260 char *lto_wrapper_file;
6261 const char *p;
6262 struct user_specs *uptr;
6263 char **old_argv = argv;
6264 struct cl_decoded_option *decoded_options;
6265 unsigned int decoded_options_count;
6267 p = argv[0] + strlen (argv[0]);
6268 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6269 --p;
6270 progname = p;
6272 xmalloc_set_program_name (progname);
6274 expandargv (&argc, &argv);
6276 /* Determine if any expansions were made. */
6277 if (argv != old_argv)
6278 at_file_supplied = true;
6280 /* Register the language-independent parameters. */
6281 global_init_params ();
6282 finish_params ();
6284 init_options_struct (&global_options, &global_options_set);
6286 decode_cmdline_options_to_array (argc, CONST_CAST2 (const char **, char **,
6287 argv),
6288 CL_DRIVER,
6289 &decoded_options, &decoded_options_count);
6291 /* Unlock the stdio streams. */
6292 unlock_std_streams ();
6294 gcc_init_libintl ();
6296 diagnostic_initialize (global_dc, 0);
6298 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6299 /* Perform host dependent initialization when needed. */
6300 GCC_DRIVER_HOST_INITIALIZATION;
6301 #endif
6303 if (atexit (delete_temp_files) != 0)
6304 fatal_error ("atexit failed");
6306 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6307 signal (SIGINT, fatal_signal);
6308 #ifdef SIGHUP
6309 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6310 signal (SIGHUP, fatal_signal);
6311 #endif
6312 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6313 signal (SIGTERM, fatal_signal);
6314 #ifdef SIGPIPE
6315 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6316 signal (SIGPIPE, fatal_signal);
6317 #endif
6318 #ifdef SIGCHLD
6319 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6320 receive the signal. A different setting is inheritable */
6321 signal (SIGCHLD, SIG_DFL);
6322 #endif
6324 /* Parsing and gimplification sometimes need quite large stack.
6325 Increase stack size limits if possible. */
6326 stack_limit_increase (64 * 1024 * 1024);
6328 /* Allocate the argument vector. */
6329 alloc_args ();
6331 obstack_init (&obstack);
6333 /* Build multilib_select, et. al from the separate lines that make up each
6334 multilib selection. */
6336 const char *const *q = multilib_raw;
6337 int need_space;
6339 obstack_init (&multilib_obstack);
6340 while ((p = *q++) != (char *) 0)
6341 obstack_grow (&multilib_obstack, p, strlen (p));
6343 obstack_1grow (&multilib_obstack, 0);
6344 multilib_select = XOBFINISH (&multilib_obstack, const char *);
6346 q = multilib_matches_raw;
6347 while ((p = *q++) != (char *) 0)
6348 obstack_grow (&multilib_obstack, p, strlen (p));
6350 obstack_1grow (&multilib_obstack, 0);
6351 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6353 q = multilib_exclusions_raw;
6354 while ((p = *q++) != (char *) 0)
6355 obstack_grow (&multilib_obstack, p, strlen (p));
6357 obstack_1grow (&multilib_obstack, 0);
6358 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6360 q = multilib_reuse_raw;
6361 while ((p = *q++) != (char *) 0)
6362 obstack_grow (&multilib_obstack, p, strlen (p));
6364 obstack_1grow (&multilib_obstack, 0);
6365 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
6367 need_space = FALSE;
6368 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6370 if (need_space)
6371 obstack_1grow (&multilib_obstack, ' ');
6372 obstack_grow (&multilib_obstack,
6373 multilib_defaults_raw[i],
6374 strlen (multilib_defaults_raw[i]));
6375 need_space = TRUE;
6378 obstack_1grow (&multilib_obstack, 0);
6379 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6382 #ifdef INIT_ENVIRONMENT
6383 /* Set up any other necessary machine specific environment variables. */
6384 xputenv (INIT_ENVIRONMENT);
6385 #endif
6387 /* Make a table of what switches there are (switches, n_switches).
6388 Make a table of specified input files (infiles, n_infiles).
6389 Decode switches that are handled locally. */
6391 process_command (decoded_options_count, decoded_options);
6393 /* Initialize the vector of specs to just the default.
6394 This means one element containing 0s, as a terminator. */
6396 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
6397 memcpy (compilers, default_compilers, sizeof default_compilers);
6398 n_compilers = n_default_compilers;
6400 /* Read specs from a file if there is one. */
6402 machine_suffix = concat (spec_machine, dir_separator_str,
6403 spec_version, dir_separator_str, NULL);
6404 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6406 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
6407 /* Read the specs file unless it is a default one. */
6408 if (specs_file != 0 && strcmp (specs_file, "specs"))
6409 read_specs (specs_file, true, false);
6410 else
6411 init_spec ();
6413 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6414 for any override of as, ld and libraries. */
6415 specs_file = (char *) alloca (strlen (standard_exec_prefix)
6416 + strlen (just_machine_suffix) + sizeof ("specs"));
6418 strcpy (specs_file, standard_exec_prefix);
6419 strcat (specs_file, just_machine_suffix);
6420 strcat (specs_file, "specs");
6421 if (access (specs_file, R_OK) == 0)
6422 read_specs (specs_file, true, false);
6424 /* Process any configure-time defaults specified for the command line
6425 options, via OPTION_DEFAULT_SPECS. */
6426 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6427 do_option_spec (option_default_specs[i].name,
6428 option_default_specs[i].spec);
6430 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6431 of the command line. */
6433 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6434 do_self_spec (driver_self_specs[i]);
6436 /* If not cross-compiling, look for executables in the standard
6437 places. */
6438 if (*cross_compile == '0')
6440 if (*md_exec_prefix)
6442 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6443 PREFIX_PRIORITY_LAST, 0, 0);
6447 /* Process sysroot_suffix_spec. */
6448 if (*sysroot_suffix_spec != 0
6449 && !no_sysroot_suffix
6450 && do_spec_2 (sysroot_suffix_spec) == 0)
6452 if (argbuf.length () > 1)
6453 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
6454 else if (argbuf.length () == 1)
6455 target_sysroot_suffix = xstrdup (argbuf.last ());
6458 #ifdef HAVE_LD_SYSROOT
6459 /* Pass the --sysroot option to the linker, if it supports that. If
6460 there is a sysroot_suffix_spec, it has already been processed by
6461 this point, so target_system_root really is the system root we
6462 should be using. */
6463 if (target_system_root)
6465 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6466 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6467 set_spec ("link", XOBFINISH (&obstack, const char *), false);
6469 #endif
6471 /* Process sysroot_hdrs_suffix_spec. */
6472 if (*sysroot_hdrs_suffix_spec != 0
6473 && !no_sysroot_suffix
6474 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6476 if (argbuf.length () > 1)
6477 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
6478 else if (argbuf.length () == 1)
6479 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
6482 /* Look for startfiles in the standard places. */
6483 if (*startfile_prefix_spec != 0
6484 && do_spec_2 (startfile_prefix_spec) == 0
6485 && do_spec_1 (" ", 0, NULL) == 0)
6487 const char *arg;
6488 int ndx;
6489 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
6490 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
6491 PREFIX_PRIORITY_LAST, 0, 1);
6493 /* We should eventually get rid of all these and stick to
6494 startfile_prefix_spec exclusively. */
6495 else if (*cross_compile == '0' || target_system_root)
6497 if (*md_startfile_prefix)
6498 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6499 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6501 if (*md_startfile_prefix_1)
6502 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6503 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6505 /* If standard_startfile_prefix is relative, base it on
6506 standard_exec_prefix. This lets us move the installed tree
6507 as a unit. If GCC_EXEC_PREFIX is defined, base
6508 standard_startfile_prefix on that as well.
6510 If the prefix is relative, only search it for native compilers;
6511 otherwise we will search a directory containing host libraries. */
6512 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6513 add_sysrooted_prefix (&startfile_prefixes,
6514 standard_startfile_prefix, "BINUTILS",
6515 PREFIX_PRIORITY_LAST, 0, 1);
6516 else if (*cross_compile == '0')
6518 add_prefix (&startfile_prefixes,
6519 concat (gcc_exec_prefix
6520 ? gcc_exec_prefix : standard_exec_prefix,
6521 machine_suffix,
6522 standard_startfile_prefix, NULL),
6523 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6526 /* Sysrooted prefixes are relocated because target_system_root is
6527 also relocated by gcc_exec_prefix. */
6528 if (*standard_startfile_prefix_1)
6529 add_sysrooted_prefix (&startfile_prefixes,
6530 standard_startfile_prefix_1, "BINUTILS",
6531 PREFIX_PRIORITY_LAST, 0, 1);
6532 if (*standard_startfile_prefix_2)
6533 add_sysrooted_prefix (&startfile_prefixes,
6534 standard_startfile_prefix_2, "BINUTILS",
6535 PREFIX_PRIORITY_LAST, 0, 1);
6538 /* Process any user specified specs in the order given on the command
6539 line. */
6540 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6542 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6543 R_OK, true);
6544 read_specs (filename ? filename : uptr->filename, false, true);
6547 /* Process any user self specs. */
6549 struct spec_list *sl;
6550 for (sl = specs; sl; sl = sl->next)
6551 if (sl->name_len == sizeof "self_spec" - 1
6552 && !strcmp (sl->name, "self_spec"))
6553 do_self_spec (*sl->ptr_spec);
6556 if (compare_debug)
6558 enum save_temps save;
6560 if (!compare_debug_second)
6562 n_switches_debug_check[1] = n_switches;
6563 n_switches_alloc_debug_check[1] = n_switches_alloc;
6564 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
6565 n_switches_alloc);
6567 do_self_spec ("%:compare-debug-self-opt()");
6568 n_switches_debug_check[0] = n_switches;
6569 n_switches_alloc_debug_check[0] = n_switches_alloc;
6570 switches_debug_check[0] = switches;
6572 n_switches = n_switches_debug_check[1];
6573 n_switches_alloc = n_switches_alloc_debug_check[1];
6574 switches = switches_debug_check[1];
6577 /* Avoid crash when computing %j in this early. */
6578 save = save_temps_flag;
6579 save_temps_flag = SAVE_TEMPS_NONE;
6581 compare_debug = -compare_debug;
6582 do_self_spec ("%:compare-debug-self-opt()");
6584 save_temps_flag = save;
6586 if (!compare_debug_second)
6588 n_switches_debug_check[1] = n_switches;
6589 n_switches_alloc_debug_check[1] = n_switches_alloc;
6590 switches_debug_check[1] = switches;
6591 compare_debug = -compare_debug;
6592 n_switches = n_switches_debug_check[0];
6593 n_switches_alloc = n_switches_debug_check[0];
6594 switches = switches_debug_check[0];
6599 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6600 if (gcc_exec_prefix)
6601 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6602 spec_version, dir_separator_str, NULL);
6604 /* Now we have the specs.
6605 Set the `valid' bits for switches that match anything in any spec. */
6607 validate_all_switches ();
6609 /* Now that we have the switches and the specs, set
6610 the subdirectory based on the options. */
6611 set_multilib_dir ();
6613 /* Set up to remember the pathname of gcc and any options
6614 needed for collect. We use argv[0] instead of progname because
6615 we need the complete pathname. */
6616 obstack_init (&collect_obstack);
6617 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6618 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6619 xputenv (XOBFINISH (&collect_obstack, char *));
6621 /* Set up to remember the pathname of the lto wrapper. */
6623 if (have_c)
6624 lto_wrapper_file = NULL;
6625 else
6626 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
6627 X_OK, false);
6628 if (lto_wrapper_file)
6630 lto_wrapper_spec = lto_wrapper_file;
6631 obstack_init (&collect_obstack);
6632 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
6633 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
6634 obstack_grow (&collect_obstack, lto_wrapper_spec,
6635 strlen (lto_wrapper_spec) + 1);
6636 xputenv (XOBFINISH (&collect_obstack, char *));
6639 /* Reject switches that no pass was interested in. */
6641 for (i = 0; (int) i < n_switches; i++)
6642 if (! switches[i].validated)
6643 error ("unrecognized command line option %<-%s%>", switches[i].part1);
6645 /* Obey some of the options. */
6647 if (print_search_dirs)
6649 printf (_("install: %s%s\n"),
6650 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
6651 gcc_exec_prefix ? "" : machine_suffix);
6652 printf (_("programs: %s\n"),
6653 build_search_list (&exec_prefixes, "", false, false));
6654 printf (_("libraries: %s\n"),
6655 build_search_list (&startfile_prefixes, "", false, true));
6656 return (0);
6659 if (print_file_name)
6661 printf ("%s\n", find_file (print_file_name));
6662 return (0);
6665 if (print_prog_name)
6667 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6668 printf ("%s\n", (newname ? newname : print_prog_name));
6669 return (0);
6672 if (print_multi_lib)
6674 print_multilib_info ();
6675 return (0);
6678 if (print_multi_directory)
6680 if (multilib_dir == NULL)
6681 printf (".\n");
6682 else
6683 printf ("%s\n", multilib_dir);
6684 return (0);
6687 if (print_multiarch)
6689 if (multiarch_dir == NULL)
6690 printf ("\n");
6691 else
6692 printf ("%s\n", multiarch_dir);
6693 return (0);
6696 if (print_sysroot)
6698 if (target_system_root)
6700 if (target_sysroot_suffix)
6701 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
6702 else
6703 printf ("%s\n", target_system_root);
6705 return (0);
6708 if (print_multi_os_directory)
6710 if (multilib_os_dir == NULL)
6711 printf (".\n");
6712 else
6713 printf ("%s\n", multilib_os_dir);
6714 return (0);
6717 if (print_sysroot_headers_suffix)
6719 if (*sysroot_hdrs_suffix_spec)
6721 printf("%s\n", (target_sysroot_hdrs_suffix
6722 ? target_sysroot_hdrs_suffix
6723 : ""));
6724 return (0);
6726 else
6727 /* The error status indicates that only one set of fixed
6728 headers should be built. */
6729 fatal_error ("not configured with sysroot headers suffix");
6732 if (print_help_list)
6734 display_help ();
6736 if (! verbose_flag)
6738 printf (_("\nFor bug reporting instructions, please see:\n"));
6739 printf ("%s.\n", bug_report_url);
6741 return (0);
6744 /* We do not exit here. Instead we have created a fake input file
6745 called 'help-dummy' which needs to be compiled, and we pass this
6746 on the various sub-processes, along with the --help switch.
6747 Ensure their output appears after ours. */
6748 fputc ('\n', stdout);
6749 fflush (stdout);
6752 if (print_version)
6754 printf (_("%s %s%s\n"), progname, pkgversion_string,
6755 version_string);
6756 printf ("Copyright %s 2013 Free Software Foundation, Inc.\n",
6757 _("(C)"));
6758 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
6759 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
6760 stdout);
6761 if (! verbose_flag)
6762 return 0;
6764 /* We do not exit here. We use the same mechanism of --help to print
6765 the version of the sub-processes. */
6766 fputc ('\n', stdout);
6767 fflush (stdout);
6770 if (verbose_flag)
6772 int n;
6773 const char *thrmod;
6775 fnotice (stderr, "Target: %s\n", spec_machine);
6776 fnotice (stderr, "Configured with: %s\n", configuration_arguments);
6778 #ifdef THREAD_MODEL_SPEC
6779 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6780 but there's no point in doing all this processing just to get
6781 thread_model back. */
6782 obstack_init (&obstack);
6783 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6784 obstack_1grow (&obstack, '\0');
6785 thrmod = XOBFINISH (&obstack, const char *);
6786 #else
6787 thrmod = thread_model;
6788 #endif
6790 fnotice (stderr, "Thread model: %s\n", thrmod);
6792 /* compiler_version is truncated at the first space when initialized
6793 from version string, so truncate version_string at the first space
6794 before comparing. */
6795 for (n = 0; version_string[n]; n++)
6796 if (version_string[n] == ' ')
6797 break;
6799 if (! strncmp (version_string, compiler_version, n)
6800 && compiler_version[n] == 0)
6801 fnotice (stderr, "gcc version %s %s\n", version_string,
6802 pkgversion_string);
6803 else
6804 fnotice (stderr, "gcc driver version %s %sexecuting gcc version %s\n",
6805 version_string, pkgversion_string, compiler_version);
6807 if (n_infiles == 0)
6808 return (0);
6811 if (n_infiles == added_libraries)
6812 fatal_error ("no input files");
6814 if (seen_error ())
6815 goto out;
6817 /* Make a place to record the compiler output file names
6818 that correspond to the input files. */
6820 i = n_infiles;
6821 i += lang_specific_extra_outfiles;
6822 outfiles = XCNEWVEC (const char *, i);
6824 /* Record which files were specified explicitly as link input. */
6826 explicit_link_files = XCNEWVEC (char, n_infiles);
6828 combine_inputs = have_o || flag_wpa;
6830 for (i = 0; (int) i < n_infiles; i++)
6832 const char *name = infiles[i].name;
6833 struct compiler *compiler = lookup_compiler (name,
6834 strlen (name),
6835 infiles[i].language);
6837 if (compiler && !(compiler->combinable))
6838 combine_inputs = false;
6840 if (lang_n_infiles > 0 && compiler != input_file_compiler
6841 && infiles[i].language && infiles[i].language[0] != '*')
6842 infiles[i].incompiler = compiler;
6843 else if (compiler)
6845 lang_n_infiles++;
6846 input_file_compiler = compiler;
6847 infiles[i].incompiler = compiler;
6849 else
6851 /* Since there is no compiler for this input file, assume it is a
6852 linker file. */
6853 explicit_link_files[i] = 1;
6854 infiles[i].incompiler = NULL;
6856 infiles[i].compiled = false;
6857 infiles[i].preprocessed = false;
6860 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
6861 fatal_error ("cannot specify -o with -c, -S or -E with multiple files");
6863 for (i = 0; (int) i < n_infiles; i++)
6865 int this_file_error = 0;
6867 /* Tell do_spec what to substitute for %i. */
6869 input_file_number = i;
6870 set_input (infiles[i].name);
6872 if (infiles[i].compiled)
6873 continue;
6875 /* Use the same thing in %o, unless cp->spec says otherwise. */
6877 outfiles[i] = gcc_input_filename;
6879 /* Figure out which compiler from the file's suffix. */
6881 input_file_compiler
6882 = lookup_compiler (infiles[i].name, input_filename_length,
6883 infiles[i].language);
6885 if (input_file_compiler)
6887 /* Ok, we found an applicable compiler. Run its spec. */
6889 if (input_file_compiler->spec[0] == '#')
6891 error ("%s: %s compiler not installed on this system",
6892 gcc_input_filename, &input_file_compiler->spec[1]);
6893 this_file_error = 1;
6895 else
6897 if (compare_debug)
6899 free (debug_check_temp_file[0]);
6900 debug_check_temp_file[0] = NULL;
6902 free (debug_check_temp_file[1]);
6903 debug_check_temp_file[1] = NULL;
6906 value = do_spec (input_file_compiler->spec);
6907 infiles[i].compiled = true;
6908 if (value < 0)
6909 this_file_error = 1;
6910 else if (compare_debug && debug_check_temp_file[0])
6912 if (verbose_flag)
6913 inform (0, "recompiling with -fcompare-debug");
6915 compare_debug = -compare_debug;
6916 n_switches = n_switches_debug_check[1];
6917 n_switches_alloc = n_switches_alloc_debug_check[1];
6918 switches = switches_debug_check[1];
6920 value = do_spec (input_file_compiler->spec);
6922 compare_debug = -compare_debug;
6923 n_switches = n_switches_debug_check[0];
6924 n_switches_alloc = n_switches_alloc_debug_check[0];
6925 switches = switches_debug_check[0];
6927 if (value < 0)
6929 error ("during -fcompare-debug recompilation");
6930 this_file_error = 1;
6933 gcc_assert (debug_check_temp_file[1]
6934 && filename_cmp (debug_check_temp_file[0],
6935 debug_check_temp_file[1]));
6937 if (verbose_flag)
6938 inform (0, "comparing final insns dumps");
6940 if (compare_files (debug_check_temp_file))
6941 this_file_error = 1;
6944 if (compare_debug)
6946 free (debug_check_temp_file[0]);
6947 debug_check_temp_file[0] = NULL;
6949 free (debug_check_temp_file[1]);
6950 debug_check_temp_file[1] = NULL;
6955 /* If this file's name does not contain a recognized suffix,
6956 record it as explicit linker input. */
6958 else
6959 explicit_link_files[i] = 1;
6961 /* Clear the delete-on-failure queue, deleting the files in it
6962 if this compilation failed. */
6964 if (this_file_error)
6966 delete_failure_queue ();
6967 errorcount++;
6969 /* If this compilation succeeded, don't delete those files later. */
6970 clear_failure_queue ();
6973 /* Reset the input file name to the first compile/object file name, for use
6974 with %b in LINK_SPEC. We use the first input file that we can find
6975 a compiler to compile it instead of using infiles.language since for
6976 languages other than C we use aliases that we then lookup later. */
6977 if (n_infiles > 0)
6979 int i;
6981 for (i = 0; i < n_infiles ; i++)
6982 if (infiles[i].incompiler
6983 || (infiles[i].language && infiles[i].language[0] != '*'))
6985 set_input (infiles[i].name);
6986 break;
6990 if (!seen_error ())
6992 /* Make sure INPUT_FILE_NUMBER points to first available open
6993 slot. */
6994 input_file_number = n_infiles;
6995 if (lang_specific_pre_link ())
6996 errorcount++;
6999 /* Determine if there are any linker input files. */
7000 num_linker_inputs = 0;
7001 for (i = 0; (int) i < n_infiles; i++)
7002 if (explicit_link_files[i] || outfiles[i] != NULL)
7003 num_linker_inputs++;
7005 /* Run ld to link all the compiler output files. */
7007 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
7009 int tmp = execution_count;
7011 if (! have_c)
7013 #if HAVE_LTO_PLUGIN > 0
7014 #if HAVE_LTO_PLUGIN == 2
7015 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
7016 #else
7017 const char *fuse_linker_plugin = "fuse-linker-plugin";
7018 #endif
7019 #endif
7021 /* We'll use ld if we can't find collect2. */
7022 if (! strcmp (linker_name_spec, "collect2"))
7024 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
7025 if (s == NULL)
7026 linker_name_spec = "ld";
7029 #if HAVE_LTO_PLUGIN > 0
7030 #if HAVE_LTO_PLUGIN == 2
7031 if (!switch_matches (fno_use_linker_plugin,
7032 fno_use_linker_plugin
7033 + strlen (fno_use_linker_plugin), 0))
7034 #else
7035 if (switch_matches (fuse_linker_plugin,
7036 fuse_linker_plugin
7037 + strlen (fuse_linker_plugin), 0))
7038 #endif
7040 linker_plugin_file_spec = find_a_file (&exec_prefixes,
7041 LTOPLUGINSONAME, R_OK,
7042 false);
7043 if (!linker_plugin_file_spec)
7044 fatal_error ("-fuse-linker-plugin, but %s not found",
7045 LTOPLUGINSONAME);
7047 #endif
7048 lto_gcc_spec = argv[0];
7051 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
7052 for collect. */
7053 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
7054 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
7056 if (print_subprocess_help == 1)
7058 printf (_("\nLinker options\n==============\n\n"));
7059 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
7060 " to the linker.\n\n"));
7061 fflush (stdout);
7063 value = do_spec (link_command_spec);
7064 if (value < 0)
7065 errorcount = 1;
7066 linker_was_run = (tmp != execution_count);
7069 /* If options said don't run linker,
7070 complain about input files to be given to the linker. */
7072 if (! linker_was_run && !seen_error ())
7073 for (i = 0; (int) i < n_infiles; i++)
7074 if (explicit_link_files[i]
7075 && !(infiles[i].language && infiles[i].language[0] == '*'))
7076 warning (0, "%s: linker input file unused because linking not done",
7077 outfiles[i]);
7079 /* Delete some or all of the temporary files we made. */
7081 if (seen_error ())
7082 delete_failure_queue ();
7083 delete_temp_files ();
7085 if (print_help_list)
7087 printf (("\nFor bug reporting instructions, please see:\n"));
7088 printf ("%s\n", bug_report_url);
7091 out:
7092 return (signal_count != 0 ? 2
7093 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
7094 : 0);
7097 /* Find the proper compilation spec for the file name NAME,
7098 whose length is LENGTH. LANGUAGE is the specified language,
7099 or 0 if this file is to be passed to the linker. */
7101 static struct compiler *
7102 lookup_compiler (const char *name, size_t length, const char *language)
7104 struct compiler *cp;
7106 /* If this was specified by the user to be a linker input, indicate that. */
7107 if (language != 0 && language[0] == '*')
7108 return 0;
7110 /* Otherwise, look for the language, if one is spec'd. */
7111 if (language != 0)
7113 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7114 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
7115 return cp;
7117 error ("language %s not recognized", language);
7118 return 0;
7121 /* Look for a suffix. */
7122 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7124 if (/* The suffix `-' matches only the file name `-'. */
7125 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7126 || (strlen (cp->suffix) < length
7127 /* See if the suffix matches the end of NAME. */
7128 && !strcmp (cp->suffix,
7129 name + length - strlen (cp->suffix))
7131 break;
7134 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
7135 /* Look again, but case-insensitively this time. */
7136 if (cp < compilers)
7137 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7139 if (/* The suffix `-' matches only the file name `-'. */
7140 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7141 || (strlen (cp->suffix) < length
7142 /* See if the suffix matches the end of NAME. */
7143 && ((!strcmp (cp->suffix,
7144 name + length - strlen (cp->suffix))
7145 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
7146 && !strcasecmp (cp->suffix,
7147 name + length - strlen (cp->suffix)))
7149 break;
7151 #endif
7153 if (cp >= compilers)
7155 if (cp->spec[0] != '@')
7156 /* A non-alias entry: return it. */
7157 return cp;
7159 /* An alias entry maps a suffix to a language.
7160 Search for the language; pass 0 for NAME and LENGTH
7161 to avoid infinite recursion if language not found. */
7162 return lookup_compiler (NULL, 0, cp->spec + 1);
7164 return 0;
7167 static char *
7168 save_string (const char *s, int len)
7170 char *result = XNEWVEC (char, len + 1);
7172 memcpy (result, s, len);
7173 result[len] = 0;
7174 return result;
7177 void
7178 pfatal_with_name (const char *name)
7180 perror_with_name (name);
7181 delete_temp_files ();
7182 exit (1);
7185 static void
7186 perror_with_name (const char *name)
7188 error ("%s: %m", name);
7191 static inline void
7192 validate_switches_from_spec (const char *spec, bool user)
7194 const char *p = spec;
7195 char c;
7196 while ((c = *p++))
7197 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
7198 /* We have a switch spec. */
7199 p = validate_switches (p + 1, user);
7202 static void
7203 validate_all_switches (void)
7205 struct compiler *comp;
7206 struct spec_list *spec;
7208 for (comp = compilers; comp->spec; comp++)
7209 validate_switches_from_spec (comp->spec, false);
7211 /* Look through the linked list of specs read from the specs file. */
7212 for (spec = specs; spec; spec = spec->next)
7213 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
7215 validate_switches_from_spec (link_command_spec, false);
7218 /* Look at the switch-name that comes after START
7219 and mark as valid all supplied switches that match it. */
7221 static const char *
7222 validate_switches (const char *start, bool user_spec)
7224 const char *p = start;
7225 const char *atom;
7226 size_t len;
7227 int i;
7228 bool suffix = false;
7229 bool starred = false;
7231 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7233 next_member:
7234 SKIP_WHITE ();
7236 if (*p == '!')
7237 p++;
7239 SKIP_WHITE ();
7240 if (*p == '.' || *p == ',')
7241 suffix = true, p++;
7243 atom = p;
7244 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7245 || *p == ',' || *p == '.' || *p == '@')
7246 p++;
7247 len = p - atom;
7249 if (*p == '*')
7250 starred = true, p++;
7252 SKIP_WHITE ();
7254 if (!suffix)
7256 /* Mark all matching switches as valid. */
7257 for (i = 0; i < n_switches; i++)
7258 if (!strncmp (switches[i].part1, atom, len)
7259 && (starred || switches[i].part1[len] == '\0')
7260 && (switches[i].known || user_spec))
7261 switches[i].validated = true;
7264 if (*p) p++;
7265 if (*p && (p[-1] == '|' || p[-1] == '&'))
7266 goto next_member;
7268 if (*p && p[-1] == ':')
7270 while (*p && *p != ';' && *p != '}')
7272 if (*p == '%')
7274 p++;
7275 if (*p == '{' || *p == '<')
7276 p = validate_switches (p+1, user_spec);
7277 else if (p[0] == 'W' && p[1] == '{')
7278 p = validate_switches (p+2, user_spec);
7280 else
7281 p++;
7284 if (*p) p++;
7285 if (*p && p[-1] == ';')
7286 goto next_member;
7289 return p;
7290 #undef SKIP_WHITE
7293 struct mdswitchstr
7295 const char *str;
7296 int len;
7299 static struct mdswitchstr *mdswitches;
7300 static int n_mdswitches;
7302 /* Check whether a particular argument was used. The first time we
7303 canonicalize the switches to keep only the ones we care about. */
7305 static int
7306 used_arg (const char *p, int len)
7308 struct mswitchstr
7310 const char *str;
7311 const char *replace;
7312 int len;
7313 int rep_len;
7316 static struct mswitchstr *mswitches;
7317 static int n_mswitches;
7318 int i, j;
7320 if (!mswitches)
7322 struct mswitchstr *matches;
7323 const char *q;
7324 int cnt = 0;
7326 /* Break multilib_matches into the component strings of string
7327 and replacement string. */
7328 for (q = multilib_matches; *q != '\0'; q++)
7329 if (*q == ';')
7330 cnt++;
7332 matches
7333 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
7334 i = 0;
7335 q = multilib_matches;
7336 while (*q != '\0')
7338 matches[i].str = q;
7339 while (*q != ' ')
7341 if (*q == '\0')
7343 invalid_matches:
7344 fatal_error ("multilib spec %qs is invalid",
7345 multilib_matches);
7347 q++;
7349 matches[i].len = q - matches[i].str;
7351 matches[i].replace = ++q;
7352 while (*q != ';' && *q != '\0')
7354 if (*q == ' ')
7355 goto invalid_matches;
7356 q++;
7358 matches[i].rep_len = q - matches[i].replace;
7359 i++;
7360 if (*q == ';')
7361 q++;
7364 /* Now build a list of the replacement string for switches that we care
7365 about. Make sure we allocate at least one entry. This prevents
7366 xmalloc from calling fatal, and prevents us from re-executing this
7367 block of code. */
7368 mswitches
7369 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
7370 for (i = 0; i < n_switches; i++)
7371 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
7373 int xlen = strlen (switches[i].part1);
7374 for (j = 0; j < cnt; j++)
7375 if (xlen == matches[j].len
7376 && ! strncmp (switches[i].part1, matches[j].str, xlen))
7378 mswitches[n_mswitches].str = matches[j].replace;
7379 mswitches[n_mswitches].len = matches[j].rep_len;
7380 mswitches[n_mswitches].replace = (char *) 0;
7381 mswitches[n_mswitches].rep_len = 0;
7382 n_mswitches++;
7383 break;
7387 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7388 on the command line nor any options mutually incompatible with
7389 them. */
7390 for (i = 0; i < n_mdswitches; i++)
7392 const char *r;
7394 for (q = multilib_options; *q != '\0'; q++)
7396 while (*q == ' ')
7397 q++;
7399 r = q;
7400 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7401 || strchr (" /", q[mdswitches[i].len]) == NULL)
7403 while (*q != ' ' && *q != '/' && *q != '\0')
7404 q++;
7405 if (*q != '/')
7406 break;
7407 q++;
7410 if (*q != ' ' && *q != '\0')
7412 while (*r != ' ' && *r != '\0')
7414 q = r;
7415 while (*q != ' ' && *q != '/' && *q != '\0')
7416 q++;
7418 if (used_arg (r, q - r))
7419 break;
7421 if (*q != '/')
7423 mswitches[n_mswitches].str = mdswitches[i].str;
7424 mswitches[n_mswitches].len = mdswitches[i].len;
7425 mswitches[n_mswitches].replace = (char *) 0;
7426 mswitches[n_mswitches].rep_len = 0;
7427 n_mswitches++;
7428 break;
7431 r = q + 1;
7433 break;
7439 for (i = 0; i < n_mswitches; i++)
7440 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7441 return 1;
7443 return 0;
7446 static int
7447 default_arg (const char *p, int len)
7449 int i;
7451 for (i = 0; i < n_mdswitches; i++)
7452 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7453 return 1;
7455 return 0;
7458 /* Work out the subdirectory to use based on the options. The format of
7459 multilib_select is a list of elements. Each element is a subdirectory
7460 name followed by a list of options followed by a semicolon. The format
7461 of multilib_exclusions is the same, but without the preceding
7462 directory. First gcc will check the exclusions, if none of the options
7463 beginning with an exclamation point are present, and all of the other
7464 options are present, then we will ignore this completely. Passing
7465 that, gcc will consider each multilib_select in turn using the same
7466 rules for matching the options. If a match is found, that subdirectory
7467 will be used.
7468 A subdirectory name is optionally followed by a colon and the corresponding
7469 multiarch name. */
7471 static void
7472 set_multilib_dir (void)
7474 const char *p;
7475 unsigned int this_path_len;
7476 const char *this_path, *this_arg;
7477 const char *start, *end;
7478 int not_arg;
7479 int ok, ndfltok, first;
7481 n_mdswitches = 0;
7482 start = multilib_defaults;
7483 while (*start == ' ' || *start == '\t')
7484 start++;
7485 while (*start != '\0')
7487 n_mdswitches++;
7488 while (*start != ' ' && *start != '\t' && *start != '\0')
7489 start++;
7490 while (*start == ' ' || *start == '\t')
7491 start++;
7494 if (n_mdswitches)
7496 int i = 0;
7498 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
7499 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7501 while (*start == ' ' || *start == '\t')
7502 start++;
7504 if (*start == '\0')
7505 break;
7507 for (end = start + 1;
7508 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7511 obstack_grow (&multilib_obstack, start, end - start);
7512 obstack_1grow (&multilib_obstack, 0);
7513 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7514 mdswitches[i++].len = end - start;
7516 if (*end == '\0')
7517 break;
7521 p = multilib_exclusions;
7522 while (*p != '\0')
7524 /* Ignore newlines. */
7525 if (*p == '\n')
7527 ++p;
7528 continue;
7531 /* Check the arguments. */
7532 ok = 1;
7533 while (*p != ';')
7535 if (*p == '\0')
7537 invalid_exclusions:
7538 fatal_error ("multilib exclusions %qs is invalid",
7539 multilib_exclusions);
7542 if (! ok)
7544 ++p;
7545 continue;
7548 this_arg = p;
7549 while (*p != ' ' && *p != ';')
7551 if (*p == '\0')
7552 goto invalid_exclusions;
7553 ++p;
7556 if (*this_arg != '!')
7557 not_arg = 0;
7558 else
7560 not_arg = 1;
7561 ++this_arg;
7564 ok = used_arg (this_arg, p - this_arg);
7565 if (not_arg)
7566 ok = ! ok;
7568 if (*p == ' ')
7569 ++p;
7572 if (ok)
7573 return;
7575 ++p;
7578 first = 1;
7579 p = multilib_select;
7581 /* Append multilib reuse rules if any. With those rules, we can reuse
7582 one multilib for certain different options sets. */
7583 if (strlen (multilib_reuse) > 0)
7584 p = concat (p, multilib_reuse, NULL);
7586 while (*p != '\0')
7588 /* Ignore newlines. */
7589 if (*p == '\n')
7591 ++p;
7592 continue;
7595 /* Get the initial path. */
7596 this_path = p;
7597 while (*p != ' ')
7599 if (*p == '\0')
7601 invalid_select:
7602 fatal_error ("multilib select %qs %qs is invalid",
7603 multilib_select, multilib_reuse);
7605 ++p;
7607 this_path_len = p - this_path;
7609 /* Check the arguments. */
7610 ok = 1;
7611 ndfltok = 1;
7612 ++p;
7613 while (*p != ';')
7615 if (*p == '\0')
7616 goto invalid_select;
7618 if (! ok)
7620 ++p;
7621 continue;
7624 this_arg = p;
7625 while (*p != ' ' && *p != ';')
7627 if (*p == '\0')
7628 goto invalid_select;
7629 ++p;
7632 if (*this_arg != '!')
7633 not_arg = 0;
7634 else
7636 not_arg = 1;
7637 ++this_arg;
7640 /* If this is a default argument, we can just ignore it.
7641 This is true even if this_arg begins with '!'. Beginning
7642 with '!' does not mean that this argument is necessarily
7643 inappropriate for this library: it merely means that
7644 there is a more specific library which uses this
7645 argument. If this argument is a default, we need not
7646 consider that more specific library. */
7647 ok = used_arg (this_arg, p - this_arg);
7648 if (not_arg)
7649 ok = ! ok;
7651 if (! ok)
7652 ndfltok = 0;
7654 if (default_arg (this_arg, p - this_arg))
7655 ok = 1;
7657 if (*p == ' ')
7658 ++p;
7661 if (ok && first)
7663 if (this_path_len != 1
7664 || this_path[0] != '.')
7666 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
7667 char *q;
7669 strncpy (new_multilib_dir, this_path, this_path_len);
7670 new_multilib_dir[this_path_len] = '\0';
7671 q = strchr (new_multilib_dir, ':');
7672 if (q != NULL)
7673 *q = '\0';
7674 multilib_dir = new_multilib_dir;
7676 first = 0;
7679 if (ndfltok)
7681 const char *q = this_path, *end = this_path + this_path_len;
7683 while (q < end && *q != ':')
7684 q++;
7685 if (q < end)
7687 const char *q2 = q + 1, *ml_end = end;
7688 char *new_multilib_os_dir;
7690 while (q2 < end && *q2 != ':')
7691 q2++;
7692 if (*q2 == ':')
7693 ml_end = q2;
7694 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
7695 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
7696 new_multilib_os_dir[ml_end - q - 1] = '\0';
7697 multilib_os_dir = *new_multilib_os_dir ? new_multilib_os_dir : ".";
7699 if (q2 < end && *q2 == ':')
7701 char *new_multiarch_dir = XNEWVEC (char, end - q2);
7702 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
7703 new_multiarch_dir[end - q2 - 1] = '\0';
7704 multiarch_dir = new_multiarch_dir;
7706 break;
7710 ++p;
7713 if (multilib_dir == NULL && multilib_os_dir != NULL
7714 && strcmp (multilib_os_dir, ".") == 0)
7716 free (CONST_CAST (char *, multilib_os_dir));
7717 multilib_os_dir = NULL;
7719 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7720 multilib_os_dir = multilib_dir;
7723 /* Print out the multiple library subdirectory selection
7724 information. This prints out a series of lines. Each line looks
7725 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7726 required. Only the desired options are printed out, the negative
7727 matches. The options are print without a leading dash. There are
7728 no spaces to make it easy to use the information in the shell.
7729 Each subdirectory is printed only once. This assumes the ordering
7730 generated by the genmultilib script. Also, we leave out ones that match
7731 the exclusions. */
7733 static void
7734 print_multilib_info (void)
7736 const char *p = multilib_select;
7737 const char *last_path = 0, *this_path;
7738 int skip;
7739 unsigned int last_path_len = 0;
7741 while (*p != '\0')
7743 skip = 0;
7744 /* Ignore newlines. */
7745 if (*p == '\n')
7747 ++p;
7748 continue;
7751 /* Get the initial path. */
7752 this_path = p;
7753 while (*p != ' ')
7755 if (*p == '\0')
7757 invalid_select:
7758 fatal_error ("multilib select %qs is invalid", multilib_select);
7761 ++p;
7764 /* When --disable-multilib was used but target defines
7765 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
7766 with .:: for multiarch configurations) are there just to find
7767 multilib_os_dir, so skip them from output. */
7768 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
7769 skip = 1;
7771 /* Check for matches with the multilib_exclusions. We don't bother
7772 with the '!' in either list. If any of the exclusion rules match
7773 all of its options with the select rule, we skip it. */
7775 const char *e = multilib_exclusions;
7776 const char *this_arg;
7778 while (*e != '\0')
7780 int m = 1;
7781 /* Ignore newlines. */
7782 if (*e == '\n')
7784 ++e;
7785 continue;
7788 /* Check the arguments. */
7789 while (*e != ';')
7791 const char *q;
7792 int mp = 0;
7794 if (*e == '\0')
7796 invalid_exclusion:
7797 fatal_error ("multilib exclusion %qs is invalid",
7798 multilib_exclusions);
7801 if (! m)
7803 ++e;
7804 continue;
7807 this_arg = e;
7809 while (*e != ' ' && *e != ';')
7811 if (*e == '\0')
7812 goto invalid_exclusion;
7813 ++e;
7816 q = p + 1;
7817 while (*q != ';')
7819 const char *arg;
7820 int len = e - this_arg;
7822 if (*q == '\0')
7823 goto invalid_select;
7825 arg = q;
7827 while (*q != ' ' && *q != ';')
7829 if (*q == '\0')
7830 goto invalid_select;
7831 ++q;
7834 if (! strncmp (arg, this_arg,
7835 (len < q - arg) ? q - arg : len)
7836 || default_arg (this_arg, e - this_arg))
7838 mp = 1;
7839 break;
7842 if (*q == ' ')
7843 ++q;
7846 if (! mp)
7847 m = 0;
7849 if (*e == ' ')
7850 ++e;
7853 if (m)
7855 skip = 1;
7856 break;
7859 if (*e != '\0')
7860 ++e;
7864 if (! skip)
7866 /* If this is a duplicate, skip it. */
7867 skip = (last_path != 0
7868 && (unsigned int) (p - this_path) == last_path_len
7869 && ! filename_ncmp (last_path, this_path, last_path_len));
7871 last_path = this_path;
7872 last_path_len = p - this_path;
7875 /* If this directory requires any default arguments, we can skip
7876 it. We will already have printed a directory identical to
7877 this one which does not require that default argument. */
7878 if (! skip)
7880 const char *q;
7882 q = p + 1;
7883 while (*q != ';')
7885 const char *arg;
7887 if (*q == '\0')
7888 goto invalid_select;
7890 if (*q == '!')
7891 arg = NULL;
7892 else
7893 arg = q;
7895 while (*q != ' ' && *q != ';')
7897 if (*q == '\0')
7898 goto invalid_select;
7899 ++q;
7902 if (arg != NULL
7903 && default_arg (arg, q - arg))
7905 skip = 1;
7906 break;
7909 if (*q == ' ')
7910 ++q;
7914 if (! skip)
7916 const char *p1;
7918 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7919 putchar (*p1);
7920 putchar (';');
7923 ++p;
7924 while (*p != ';')
7926 int use_arg;
7928 if (*p == '\0')
7929 goto invalid_select;
7931 if (skip)
7933 ++p;
7934 continue;
7937 use_arg = *p != '!';
7939 if (use_arg)
7940 putchar ('@');
7942 while (*p != ' ' && *p != ';')
7944 if (*p == '\0')
7945 goto invalid_select;
7946 if (use_arg)
7947 putchar (*p);
7948 ++p;
7951 if (*p == ' ')
7952 ++p;
7955 if (! skip)
7957 /* If there are extra options, print them now. */
7958 if (multilib_extra && *multilib_extra)
7960 int print_at = TRUE;
7961 const char *q;
7963 for (q = multilib_extra; *q != '\0'; q++)
7965 if (*q == ' ')
7966 print_at = TRUE;
7967 else
7969 if (print_at)
7970 putchar ('@');
7971 putchar (*q);
7972 print_at = FALSE;
7977 putchar ('\n');
7980 ++p;
7984 /* getenv built-in spec function.
7986 Returns the value of the environment variable given by its first
7987 argument, concatenated with the second argument. If the
7988 environment variable is not defined, a fatal error is issued. */
7990 static const char *
7991 getenv_spec_function (int argc, const char **argv)
7993 char *value;
7994 char *result;
7995 char *ptr;
7996 size_t len;
7998 if (argc != 2)
7999 return NULL;
8001 value = getenv (argv[0]);
8002 if (!value)
8003 fatal_error ("environment variable %qs not defined", argv[0]);
8005 /* We have to escape every character of the environment variable so
8006 they are not interpreted as active spec characters. A
8007 particularly painful case is when we are reading a variable
8008 holding a windows path complete with \ separators. */
8009 len = strlen (value) * 2 + strlen (argv[1]) + 1;
8010 result = XNEWVAR (char, len);
8011 for (ptr = result; *value; ptr += 2)
8013 ptr[0] = '\\';
8014 ptr[1] = *value++;
8017 strcpy (ptr, argv[1]);
8019 return result;
8022 /* if-exists built-in spec function.
8024 Checks to see if the file specified by the absolute pathname in
8025 ARGS exists. Returns that pathname if found.
8027 The usual use for this function is to check for a library file
8028 (whose name has been expanded with %s). */
8030 static const char *
8031 if_exists_spec_function (int argc, const char **argv)
8033 /* Must have only one argument. */
8034 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8035 return argv[0];
8037 return NULL;
8040 /* if-exists-else built-in spec function.
8042 This is like if-exists, but takes an additional argument which
8043 is returned if the first argument does not exist. */
8045 static const char *
8046 if_exists_else_spec_function (int argc, const char **argv)
8048 /* Must have exactly two arguments. */
8049 if (argc != 2)
8050 return NULL;
8052 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8053 return argv[0];
8055 return argv[1];
8058 /* replace-outfile built-in spec function.
8060 This looks for the first argument in the outfiles array's name and
8061 replaces it with the second argument. */
8063 static const char *
8064 replace_outfile_spec_function (int argc, const char **argv)
8066 int i;
8067 /* Must have exactly two arguments. */
8068 if (argc != 2)
8069 abort ();
8071 for (i = 0; i < n_infiles; i++)
8073 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8074 outfiles[i] = xstrdup (argv[1]);
8076 return NULL;
8079 /* remove-outfile built-in spec function.
8081 * This looks for the first argument in the outfiles array's name and
8082 * removes it. */
8084 static const char *
8085 remove_outfile_spec_function (int argc, const char **argv)
8087 int i;
8088 /* Must have exactly one argument. */
8089 if (argc != 1)
8090 abort ();
8092 for (i = 0; i < n_infiles; i++)
8094 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8095 outfiles[i] = NULL;
8097 return NULL;
8100 /* Given two version numbers, compares the two numbers.
8101 A version number must match the regular expression
8102 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
8104 static int
8105 compare_version_strings (const char *v1, const char *v2)
8107 int rresult;
8108 regex_t r;
8110 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
8111 REG_EXTENDED | REG_NOSUB) != 0)
8112 abort ();
8113 rresult = regexec (&r, v1, 0, NULL, 0);
8114 if (rresult == REG_NOMATCH)
8115 fatal_error ("invalid version number %qs", v1);
8116 else if (rresult != 0)
8117 abort ();
8118 rresult = regexec (&r, v2, 0, NULL, 0);
8119 if (rresult == REG_NOMATCH)
8120 fatal_error ("invalid version number %qs", v2);
8121 else if (rresult != 0)
8122 abort ();
8124 return strverscmp (v1, v2);
8128 /* version_compare built-in spec function.
8130 This takes an argument of the following form:
8132 <comparison-op> <arg1> [<arg2>] <switch> <result>
8134 and produces "result" if the comparison evaluates to true,
8135 and nothing if it doesn't.
8137 The supported <comparison-op> values are:
8139 >= true if switch is a later (or same) version than arg1
8140 !> opposite of >=
8141 < true if switch is an earlier version than arg1
8142 !< opposite of <
8143 >< true if switch is arg1 or later, and earlier than arg2
8144 <> true if switch is earlier than arg1 or is arg2 or later
8146 If the switch is not present, the condition is false unless
8147 the first character of the <comparison-op> is '!'.
8149 For example,
8150 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
8151 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
8153 static const char *
8154 version_compare_spec_function (int argc, const char **argv)
8156 int comp1, comp2;
8157 size_t switch_len;
8158 const char *switch_value = NULL;
8159 int nargs = 1, i;
8160 bool result;
8162 if (argc < 3)
8163 fatal_error ("too few arguments to %%:version-compare");
8164 if (argv[0][0] == '\0')
8165 abort ();
8166 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
8167 nargs = 2;
8168 if (argc != nargs + 3)
8169 fatal_error ("too many arguments to %%:version-compare");
8171 switch_len = strlen (argv[nargs + 1]);
8172 for (i = 0; i < n_switches; i++)
8173 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
8174 && check_live_switch (i, switch_len))
8175 switch_value = switches[i].part1 + switch_len;
8177 if (switch_value == NULL)
8178 comp1 = comp2 = -1;
8179 else
8181 comp1 = compare_version_strings (switch_value, argv[1]);
8182 if (nargs == 2)
8183 comp2 = compare_version_strings (switch_value, argv[2]);
8184 else
8185 comp2 = -1; /* This value unused. */
8188 switch (argv[0][0] << 8 | argv[0][1])
8190 case '>' << 8 | '=':
8191 result = comp1 >= 0;
8192 break;
8193 case '!' << 8 | '<':
8194 result = comp1 >= 0 || switch_value == NULL;
8195 break;
8196 case '<' << 8:
8197 result = comp1 < 0;
8198 break;
8199 case '!' << 8 | '>':
8200 result = comp1 < 0 || switch_value == NULL;
8201 break;
8202 case '>' << 8 | '<':
8203 result = comp1 >= 0 && comp2 < 0;
8204 break;
8205 case '<' << 8 | '>':
8206 result = comp1 < 0 || comp2 >= 0;
8207 break;
8209 default:
8210 fatal_error ("unknown operator %qs in %%:version-compare", argv[0]);
8212 if (! result)
8213 return NULL;
8215 return argv[nargs + 2];
8218 /* %:include builtin spec function. This differs from %include in that it
8219 can be nested inside a spec, and thus be conditionalized. It takes
8220 one argument, the filename, and looks for it in the startfile path.
8221 The result is always NULL, i.e. an empty expansion. */
8223 static const char *
8224 include_spec_function (int argc, const char **argv)
8226 char *file;
8228 if (argc != 1)
8229 abort ();
8231 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
8232 read_specs (file ? file : argv[0], false, false);
8234 return NULL;
8237 /* %:find-file spec function. This function replaces its argument by
8238 the file found through find_file, that is the -print-file-name gcc
8239 program option. */
8240 static const char *
8241 find_file_spec_function (int argc, const char **argv)
8243 const char *file;
8245 if (argc != 1)
8246 abort ();
8248 file = find_file (argv[0]);
8249 return file;
8253 /* %:find-plugindir spec function. This function replaces its argument
8254 by the -iplugindir=<dir> option. `dir' is found through find_file, that
8255 is the -print-file-name gcc program option. */
8256 static const char *
8257 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
8259 const char *option;
8261 if (argc != 0)
8262 abort ();
8264 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
8265 return option;
8269 /* %:print-asm-header spec function. Print a banner to say that the
8270 following output is from the assembler. */
8272 static const char *
8273 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
8274 const char **argv ATTRIBUTE_UNUSED)
8276 printf (_("Assembler options\n=================\n\n"));
8277 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
8278 fflush (stdout);
8279 return NULL;
8282 /* Get a random number for -frandom-seed */
8284 static unsigned HOST_WIDE_INT
8285 get_random_number (void)
8287 unsigned HOST_WIDE_INT ret = 0;
8288 int fd;
8290 fd = open ("/dev/urandom", O_RDONLY);
8291 if (fd >= 0)
8293 read (fd, &ret, sizeof (HOST_WIDE_INT));
8294 close (fd);
8295 if (ret)
8296 return ret;
8299 /* Get some more or less random data. */
8300 #ifdef HAVE_GETTIMEOFDAY
8302 struct timeval tv;
8304 gettimeofday (&tv, NULL);
8305 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
8307 #else
8309 time_t now = time (NULL);
8311 if (now != (time_t)-1)
8312 ret = (unsigned) now;
8314 #endif
8316 return ret ^ getpid();
8319 /* %:compare-debug-dump-opt spec function. Save the last argument,
8320 expected to be the last -fdump-final-insns option, or generate a
8321 temporary. */
8323 static const char *
8324 compare_debug_dump_opt_spec_function (int arg,
8325 const char **argv ATTRIBUTE_UNUSED)
8327 char *ret;
8328 char *name;
8329 int which;
8330 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
8332 if (arg != 0)
8333 fatal_error ("too many arguments to %%:compare-debug-dump-opt");
8335 do_spec_2 ("%{fdump-final-insns=*:%*}");
8336 do_spec_1 (" ", 0, NULL);
8338 if (argbuf.length () > 0
8339 && strcmp (argv[argbuf.length () - 1], "."))
8341 if (!compare_debug)
8342 return NULL;
8344 name = xstrdup (argv[argbuf.length () - 1]);
8345 ret = NULL;
8347 else
8349 const char *ext = NULL;
8351 if (argbuf.length () > 0)
8353 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
8354 ext = ".gkd";
8356 else if (!compare_debug)
8357 return NULL;
8358 else
8359 do_spec_2 ("%g.gkd");
8361 do_spec_1 (" ", 0, NULL);
8363 gcc_assert (argbuf.length () > 0);
8365 name = concat (argbuf.last (), ext, NULL);
8367 ret = concat ("-fdump-final-insns=", name, NULL);
8370 which = compare_debug < 0;
8371 debug_check_temp_file[which] = name;
8373 if (!which)
8375 unsigned HOST_WIDE_INT value = get_random_number ();
8377 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
8380 if (*random_seed)
8382 char *tmp = ret;
8383 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
8384 ret, NULL);
8385 free (tmp);
8388 if (which)
8389 *random_seed = 0;
8391 return ret;
8394 static const char *debug_auxbase_opt;
8396 /* %:compare-debug-self-opt spec function. Expands to the options
8397 that are to be passed in the second compilation of
8398 compare-debug. */
8400 static const char *
8401 compare_debug_self_opt_spec_function (int arg,
8402 const char **argv ATTRIBUTE_UNUSED)
8404 if (arg != 0)
8405 fatal_error ("too many arguments to %%:compare-debug-self-opt");
8407 if (compare_debug >= 0)
8408 return NULL;
8410 do_spec_2 ("%{c|S:%{o*:%*}}");
8411 do_spec_1 (" ", 0, NULL);
8413 if (argbuf.length () > 0)
8414 debug_auxbase_opt = concat ("-auxbase-strip ",
8415 argbuf.last (),
8416 NULL);
8417 else
8418 debug_auxbase_opt = NULL;
8420 return concat ("\
8421 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
8422 %<fdump-final-insns=* -w -S -o %j \
8423 %{!fcompare-debug-second:-fcompare-debug-second} \
8424 ", compare_debug_opt, NULL);
8427 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
8428 options that are to be passed in the second compilation of
8429 compare-debug. It expects, as an argument, the basename of the
8430 current input file name, with the .gk suffix appended to it. */
8432 static const char *
8433 compare_debug_auxbase_opt_spec_function (int arg,
8434 const char **argv)
8436 char *name;
8437 int len;
8439 if (arg == 0)
8440 fatal_error ("too few arguments to %%:compare-debug-auxbase-opt");
8442 if (arg != 1)
8443 fatal_error ("too many arguments to %%:compare-debug-auxbase-opt");
8445 if (compare_debug >= 0)
8446 return NULL;
8448 len = strlen (argv[0]);
8449 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
8450 fatal_error ("argument to %%:compare-debug-auxbase-opt "
8451 "does not end in .gk");
8453 if (debug_auxbase_opt)
8454 return debug_auxbase_opt;
8456 #define OPT "-auxbase "
8458 len -= 3;
8459 name = (char*) xmalloc (sizeof (OPT) + len);
8460 memcpy (name, OPT, sizeof (OPT) - 1);
8461 memcpy (name + sizeof (OPT) - 1, argv[0], len);
8462 name[sizeof (OPT) - 1 + len] = '\0';
8464 #undef OPT
8466 return name;
8469 /* %:pass-through-libs spec function. Finds all -l options and input
8470 file names in the lib spec passed to it, and makes a list of them
8471 prepended with the plugin option to cause them to be passed through
8472 to the final link after all the new object files have been added. */
8474 const char *
8475 pass_through_libs_spec_func (int argc, const char **argv)
8477 char *prepended = xstrdup (" ");
8478 int n;
8479 /* Shlemiel the painter's algorithm. Innately horrible, but at least
8480 we know that there will never be more than a handful of strings to
8481 concat, and it's only once per run, so it's not worth optimising. */
8482 for (n = 0; n < argc; n++)
8484 char *old = prepended;
8485 /* Anything that isn't an option is a full path to an output
8486 file; pass it through if it ends in '.a'. Among options,
8487 pass only -l. */
8488 if (argv[n][0] == '-' && argv[n][1] == 'l')
8490 const char *lopt = argv[n] + 2;
8491 /* Handle both joined and non-joined -l options. If for any
8492 reason there's a trailing -l with no joined or following
8493 arg just discard it. */
8494 if (!*lopt && ++n >= argc)
8495 break;
8496 else if (!*lopt)
8497 lopt = argv[n];
8498 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
8499 lopt, " ", NULL);
8501 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
8503 prepended = concat (prepended, "-plugin-opt=-pass-through=",
8504 argv[n], " ", NULL);
8506 if (prepended != old)
8507 free (old);
8509 return prepended;
8512 /* %:replace-extension spec function. Replaces the extension of the
8513 first argument with the second argument. */
8515 const char *
8516 replace_extension_spec_func (int argc, const char **argv)
8518 char *name;
8519 char *p;
8520 char *result;
8521 int i;
8523 if (argc != 2)
8524 fatal_error ("too few arguments to %%:replace-extension");
8526 name = xstrdup (argv[0]);
8528 for (i = strlen(name) - 1; i >= 0; i--)
8529 if (IS_DIR_SEPARATOR (name[i]))
8530 break;
8532 p = strrchr (name + i + 1, '.');
8533 if (p != NULL)
8534 *p = '\0';
8536 result = concat (name, argv[1], NULL);
8538 free (name);
8539 return result;