Mark ChangeLog
[official-gcc.git] / gcc / gcc.c
blob5e6e637b752dbb7e3b011b1c840407ee0dc54c84
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987-2013 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
9 version.
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 for more details.
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
20 /* This program is the user interface to the C compiler and possibly to
21 other compilers. It is used because compilation is a complicated procedure
22 which involves running several programs and passing temporary files between
23 them, forwarding the users switches to those programs selectively,
24 and deleting the temporary files at the end.
26 CC recognizes how to compile each input file by suffixes in the file names.
27 Once it knows which kind of compilation to perform, the procedure for
28 compilation is specified by a string called a "spec". */
30 #include "config.h"
31 #include "system.h"
32 #include "coretypes.h"
33 #include "multilib.h" /* before tm.h */
34 #include "tm.h"
35 #include "xregex.h"
36 #include "obstack.h"
37 #include "intl.h"
38 #include "prefix.h"
39 #include "gcc.h"
40 #include "diagnostic.h"
41 #include "flags.h"
42 #include "opts.h"
43 #include "params.h"
44 #include "vec.h"
45 #include "filenames.h"
47 /* By default there is no special suffix for target executables. */
48 /* FIXME: when autoconf is fixed, remove the host check - dj */
49 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
50 #define HAVE_TARGET_EXECUTABLE_SUFFIX
51 #endif
53 /* By default there is no special suffix for host executables. */
54 #ifdef HOST_EXECUTABLE_SUFFIX
55 #define HAVE_HOST_EXECUTABLE_SUFFIX
56 #else
57 #define HOST_EXECUTABLE_SUFFIX ""
58 #endif
60 /* By default, the suffix for target object files is ".o". */
61 #ifdef TARGET_OBJECT_SUFFIX
62 #define HAVE_TARGET_OBJECT_SUFFIX
63 #else
64 #define TARGET_OBJECT_SUFFIX ".o"
65 #endif
67 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
69 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
70 #ifndef LIBRARY_PATH_ENV
71 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
72 #endif
74 /* If a stage of compilation returns an exit status >= 1,
75 compilation of that file ceases. */
77 #define MIN_FATAL_STATUS 1
79 /* Flag set by cppspec.c to 1. */
80 int is_cpp_driver;
82 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
83 static bool at_file_supplied;
85 /* Definition of string containing the arguments given to configure. */
86 #include "configargs.h"
88 /* Flag saying to print the command line options understood by gcc and its
89 sub-processes. */
91 static int print_help_list;
93 /* Flag saying to print the version of gcc and its sub-processes. */
95 static int print_version;
97 /* Flag indicating whether we should ONLY print the command and
98 arguments (like verbose_flag) without executing the command.
99 Displayed arguments are quoted so that the generated command
100 line is suitable for execution. This is intended for use in
101 shell scripts to capture the driver-generated command line. */
102 static int verbose_only_flag;
104 /* Flag indicating how to print command line options of sub-processes. */
106 static int print_subprocess_help;
108 /* Whether we should report subprocess execution times to a file. */
110 FILE *report_times_to_file = NULL;
112 /* Nonzero means place this string before uses of /, so that include
113 and library files can be found in an alternate location. */
115 #ifdef TARGET_SYSTEM_ROOT
116 static const char *target_system_root = TARGET_SYSTEM_ROOT;
117 #else
118 static const char *target_system_root = 0;
119 #endif
121 /* Nonzero means pass the updated target_system_root to the compiler. */
123 static int target_system_root_changed;
125 /* Nonzero means append this string to target_system_root. */
127 static const char *target_sysroot_suffix = 0;
129 /* Nonzero means append this string to target_system_root for headers. */
131 static const char *target_sysroot_hdrs_suffix = 0;
133 /* Nonzero means write "temp" files in source directory
134 and use the source file's name in them, and don't delete them. */
136 static enum save_temps {
137 SAVE_TEMPS_NONE, /* no -save-temps */
138 SAVE_TEMPS_CWD, /* -save-temps in current directory */
139 SAVE_TEMPS_OBJ /* -save-temps in object directory */
140 } save_temps_flag;
142 /* Output file to use to get the object directory for -save-temps=obj */
143 static char *save_temps_prefix = 0;
144 static size_t save_temps_length = 0;
146 /* The compiler version. */
148 static const char *compiler_version;
150 /* The target version. */
152 static const char *const spec_version = DEFAULT_TARGET_VERSION;
154 /* The target machine. */
156 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
158 /* Nonzero if cross-compiling.
159 When -b is used, the value comes from the `specs' file. */
161 #ifdef CROSS_DIRECTORY_STRUCTURE
162 static const char *cross_compile = "1";
163 #else
164 static const char *cross_compile = "0";
165 #endif
167 /* Greatest exit code of sub-processes that has been encountered up to
168 now. */
169 static int greatest_status = 1;
171 /* This is the obstack which we use to allocate many strings. */
173 static struct obstack obstack;
175 /* This is the obstack to build an environment variable to pass to
176 collect2 that describes all of the relevant switches of what to
177 pass the compiler in building the list of pointers to constructors
178 and destructors. */
180 static struct obstack collect_obstack;
182 /* Forward declaration for prototypes. */
183 struct path_prefix;
184 struct prefix_list;
186 static void init_spec (void);
187 static void store_arg (const char *, int, int);
188 static void insert_wrapper (const char *);
189 static char *load_specs (const char *);
190 static void read_specs (const char *, bool, bool);
191 static void set_spec (const char *, const char *, bool);
192 static struct compiler *lookup_compiler (const char *, size_t, const char *);
193 static char *build_search_list (const struct path_prefix *, const char *,
194 bool, bool);
195 static void xputenv (const char *);
196 static void putenv_from_prefixes (const struct path_prefix *, const char *,
197 bool);
198 static int access_check (const char *, int);
199 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
200 static void add_prefix (struct path_prefix *, const char *, const char *,
201 int, int, int);
202 static void add_sysrooted_prefix (struct path_prefix *, const char *,
203 const char *, int, int, int);
204 static char *skip_whitespace (char *);
205 static void delete_if_ordinary (const char *);
206 static void delete_temp_files (void);
207 static void delete_failure_queue (void);
208 static void clear_failure_queue (void);
209 static int check_live_switch (int, int);
210 static const char *handle_braces (const char *);
211 static inline bool input_suffix_matches (const char *, const char *);
212 static inline bool switch_matches (const char *, const char *, int);
213 static inline void mark_matching_switches (const char *, const char *, int);
214 static inline void process_marked_switches (void);
215 static const char *process_brace_body (const char *, const char *, const char *, int, int);
216 static const struct spec_function *lookup_spec_function (const char *);
217 static const char *eval_spec_function (const char *, const char *);
218 static const char *handle_spec_function (const char *);
219 static char *save_string (const char *, int);
220 static void set_collect_gcc_options (void);
221 static int do_spec_1 (const char *, int, const char *);
222 static int do_spec_2 (const char *);
223 static void do_option_spec (const char *, const char *);
224 static void do_self_spec (const char *);
225 static const char *find_file (const char *);
226 static int is_directory (const char *, bool);
227 static const char *validate_switches (const char *, bool);
228 static void validate_all_switches (void);
229 static inline void validate_switches_from_spec (const char *, bool);
230 static void give_switch (int, int);
231 static int used_arg (const char *, int);
232 static int default_arg (const char *, int);
233 static void set_multilib_dir (void);
234 static void print_multilib_info (void);
235 static void perror_with_name (const char *);
236 static void display_help (void);
237 static void add_preprocessor_option (const char *, int);
238 static void add_assembler_option (const char *, int);
239 static void add_linker_option (const char *, int);
240 static void process_command (unsigned int, struct cl_decoded_option *);
241 static int execute (void);
242 static void alloc_args (void);
243 static void clear_args (void);
244 static void fatal_signal (int);
245 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
246 static void init_gcc_specs (struct obstack *, const char *, const char *,
247 const char *);
248 #endif
249 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
250 static const char *convert_filename (const char *, int, int);
251 #endif
253 static const char *getenv_spec_function (int, const char **);
254 static const char *if_exists_spec_function (int, const char **);
255 static const char *if_exists_else_spec_function (int, const char **);
256 static const char *replace_outfile_spec_function (int, const char **);
257 static const char *remove_outfile_spec_function (int, const char **);
258 static const char *version_compare_spec_function (int, const char **);
259 static const char *include_spec_function (int, const char **);
260 static const char *find_file_spec_function (int, const char **);
261 static const char *find_plugindir_spec_function (int, const char **);
262 static const char *print_asm_header_spec_function (int, const char **);
263 static const char *compare_debug_dump_opt_spec_function (int, const char **);
264 static const char *compare_debug_self_opt_spec_function (int, const char **);
265 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
266 static const char *pass_through_libs_spec_func (int, const char **);
267 static const char *replace_extension_spec_func (int, const char **);
268 static char *convert_white_space (char *);
270 /* The Specs Language
272 Specs are strings containing lines, each of which (if not blank)
273 is made up of a program name, and arguments separated by spaces.
274 The program name must be exact and start from root, since no path
275 is searched and it is unreliable to depend on the current working directory.
276 Redirection of input or output is not supported; the subprograms must
277 accept filenames saying what files to read and write.
279 In addition, the specs can contain %-sequences to substitute variable text
280 or for conditional text. Here is a table of all defined %-sequences.
281 Note that spaces are not generated automatically around the results of
282 expanding these sequences; therefore, you can concatenate them together
283 or with constant text in a single argument.
285 %% substitute one % into the program name or argument.
286 %i substitute the name of the input file being processed.
287 %b substitute the basename of the input file being processed.
288 This is the substring up to (and not including) the last period
289 and not including the directory unless -save-temps was specified
290 to put temporaries in a different location.
291 %B same as %b, but include the file suffix (text after the last period).
292 %gSUFFIX
293 substitute a file name that has suffix SUFFIX and is chosen
294 once per compilation, and mark the argument a la %d. To reduce
295 exposure to denial-of-service attacks, the file name is now
296 chosen in a way that is hard to predict even when previously
297 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
298 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
299 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
300 had been pre-processed. Previously, %g was simply substituted
301 with a file name chosen once per compilation, without regard
302 to any appended suffix (which was therefore treated just like
303 ordinary text), making such attacks more likely to succeed.
304 %|SUFFIX
305 like %g, but if -pipe is in effect, expands simply to "-".
306 %mSUFFIX
307 like %g, but if -pipe is in effect, expands to nothing. (We have both
308 %| and %m to accommodate differences between system assemblers; see
309 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
310 %uSUFFIX
311 like %g, but generates a new temporary file name even if %uSUFFIX
312 was already seen.
313 %USUFFIX
314 substitutes the last file name generated with %uSUFFIX, generating a
315 new one if there is no such last file name. In the absence of any
316 %uSUFFIX, this is just like %gSUFFIX, except they don't share
317 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
318 would involve the generation of two distinct file names, one
319 for each `%g.s' and another for each `%U.s'. Previously, %U was
320 simply substituted with a file name chosen for the previous %u,
321 without regard to any appended suffix.
322 %jSUFFIX
323 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
324 writable, and if save-temps is off; otherwise, substitute the name
325 of a temporary file, just like %u. This temporary file is not
326 meant for communication between processes, but rather as a junk
327 disposal mechanism.
328 %.SUFFIX
329 substitutes .SUFFIX for the suffixes of a matched switch's args when
330 it is subsequently output with %*. SUFFIX is terminated by the next
331 space or %.
332 %d marks the argument containing or following the %d as a
333 temporary file name, so that that file will be deleted if GCC exits
334 successfully. Unlike %g, this contributes no text to the argument.
335 %w marks the argument containing or following the %w as the
336 "output file" of this compilation. This puts the argument
337 into the sequence of arguments that %o will substitute later.
338 %V indicates that this compilation produces no "output file".
339 %W{...}
340 like %{...} but mark last argument supplied within
341 as a file to be deleted on failure.
342 %o substitutes the names of all the output files, with spaces
343 automatically placed around them. You should write spaces
344 around the %o as well or the results are undefined.
345 %o is for use in the specs for running the linker.
346 Input files whose names have no recognized suffix are not compiled
347 at all, but they are included among the output files, so they will
348 be linked.
349 %O substitutes the suffix for object files. Note that this is
350 handled specially when it immediately follows %g, %u, or %U
351 (with or without a suffix argument) because of the need for
352 those to form complete file names. The handling is such that
353 %O is treated exactly as if it had already been substituted,
354 except that %g, %u, and %U do not currently support additional
355 SUFFIX characters following %O as they would following, for
356 example, `.o'.
357 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
358 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
359 and -B options) and -imultilib as necessary.
360 %s current argument is the name of a library or startup file of some sort.
361 Search for that file in a standard list of directories
362 and substitute the full name found.
363 %eSTR Print STR as an error message. STR is terminated by a newline.
364 Use this when inconsistent options are detected.
365 %nSTR Print STR as a notice. STR is terminated by a newline.
366 %x{OPTION} Accumulate an option for %X.
367 %X Output the accumulated linker options specified by compilations.
368 %Y Output the accumulated assembler options specified by compilations.
369 %Z Output the accumulated preprocessor options specified by compilations.
370 %a process ASM_SPEC as a spec.
371 This allows config.h to specify part of the spec for running as.
372 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
373 used here. This can be used to run a post-processor after the
374 assembler has done its job.
375 %D Dump out a -L option for each directory in startfile_prefixes.
376 If multilib_dir is set, extra entries are generated with it affixed.
377 %l process LINK_SPEC as a spec.
378 %L process LIB_SPEC as a spec.
379 %M Output multilib_os_dir.
380 %G process LIBGCC_SPEC as a spec.
381 %R Output the concatenation of target_system_root and
382 target_sysroot_suffix.
383 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
384 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
385 %C process CPP_SPEC as a spec.
386 %1 process CC1_SPEC as a spec.
387 %2 process CC1PLUS_SPEC as a spec.
388 %* substitute the variable part of a matched option. (See below.)
389 Note that each comma in the substituted string is replaced by
390 a single space.
391 %<S remove all occurrences of -S from the command line.
392 Note - this command is position dependent. % commands in the
393 spec string before this one will see -S, % commands in the
394 spec string after this one will not.
395 %>S Similar to "%<S", but keep it in the GCC command line.
396 %<S* remove all occurrences of all switches beginning with -S from the
397 command line.
398 %:function(args)
399 Call the named function FUNCTION, passing it ARGS. ARGS is
400 first processed as a nested spec string, then split into an
401 argument vector in the usual fashion. The function returns
402 a string which is processed as if it had appeared literally
403 as part of the current spec.
404 %{S} substitutes the -S switch, if that switch was given to GCC.
405 If that switch was not specified, this substitutes nothing.
406 Here S is a metasyntactic variable.
407 %{S*} substitutes all the switches specified to GCC whose names start
408 with -S. This is used for -o, -I, etc; switches that take
409 arguments. GCC considers `-o foo' as being one switch whose
410 name starts with `o'. %{o*} would substitute this text,
411 including the space; thus, two arguments would be generated.
412 %{S*&T*} likewise, but preserve order of S and T options (the order
413 of S and T in the spec is not significant). Can be any number
414 of ampersand-separated variables; for each the wild card is
415 optional. Useful for CPP as %{D*&U*&A*}.
417 %{S:X} substitutes X, if the -S switch was given to GCC.
418 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
419 %{S*:X} substitutes X if one or more switches whose names start
420 with -S was given to GCC. Normally X is substituted only
421 once, no matter how many such switches appeared. However,
422 if %* appears somewhere in X, then X will be substituted
423 once for each matching switch, with the %* replaced by the
424 part of that switch that matched the '*'.
425 %{.S:X} substitutes X, if processing a file with suffix S.
426 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
427 %{,S:X} substitutes X, if processing a file which will use spec S.
428 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
430 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
431 combined with '!', '.', ',', and '*' as above binding stronger
432 than the OR.
433 If %* appears in X, all of the alternatives must be starred, and
434 only the first matching alternative is substituted.
435 %{S:X; if S was given to GCC, substitutes X;
436 T:Y; else if T was given to GCC, substitutes Y;
437 :D} else substitutes D. There can be as many clauses as you need.
438 This may be combined with '.', '!', ',', '|', and '*' as above.
440 %(Spec) processes a specification defined in a specs file as *Spec:
442 The conditional text X in a %{S:X} or similar construct may contain
443 other nested % constructs or spaces, or even newlines. They are
444 processed as usual, as described above. Trailing white space in X is
445 ignored. White space may also appear anywhere on the left side of the
446 colon in these constructs, except between . or * and the corresponding
447 word.
449 The -O, -f, -g, -m, and -W switches are handled specifically in these
450 constructs. If another value of -O or the negated form of a -f, -m, or
451 -W switch is found later in the command line, the earlier switch
452 value is ignored, except with {S*} where S is just one letter; this
453 passes all matching options.
455 The character | at the beginning of the predicate text is used to indicate
456 that a command should be piped to the following command, but only if -pipe
457 is specified.
459 Note that it is built into GCC which switches take arguments and which
460 do not. You might think it would be useful to generalize this to
461 allow each compiler's spec to say which switches take arguments. But
462 this cannot be done in a consistent fashion. GCC cannot even decide
463 which input files have been specified without knowing which switches
464 take arguments, and it must know which input files to compile in order
465 to tell which compilers to run.
467 GCC also knows implicitly that arguments starting in `-l' are to be
468 treated as compiler output files, and passed to the linker in their
469 proper position among the other output files. */
471 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
473 /* config.h can define ASM_SPEC to provide extra args to the assembler
474 or extra switch-translations. */
475 #ifndef ASM_SPEC
476 #define ASM_SPEC ""
477 #endif
479 /* config.h can define ASM_FINAL_SPEC to run a post processor after
480 the assembler has run. */
481 #ifndef ASM_FINAL_SPEC
482 #define ASM_FINAL_SPEC \
483 "%{gsplit-dwarf: \n\
484 objcopy --extract-dwo \
485 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
486 %{c:%{o*:%:replace-extension(%{o*:%*} .dwo)}%{!o*:%b.dwo}}%{!c:%b.dwo} \n\
487 objcopy --strip-dwo \
488 %{c:%{o*:%*}%{!o*:%b%O}}%{!c:%U%O} \
490 #endif
492 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
493 or extra switch-translations. */
494 #ifndef CPP_SPEC
495 #define CPP_SPEC ""
496 #endif
498 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
499 or extra switch-translations. */
500 #ifndef CC1_SPEC
501 #define CC1_SPEC ""
502 #endif
504 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
505 or extra switch-translations. */
506 #ifndef CC1PLUS_SPEC
507 #define CC1PLUS_SPEC ""
508 #endif
510 /* config.h can define LINK_SPEC to provide extra args to the linker
511 or extra switch-translations. */
512 #ifndef LINK_SPEC
513 #define LINK_SPEC ""
514 #endif
516 /* config.h can define LIB_SPEC to override the default libraries. */
517 #ifndef LIB_SPEC
518 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
519 #endif
521 /* mudflap specs */
522 #ifndef MFWRAP_SPEC
523 /* XXX: valid only for GNU ld */
524 /* XXX: should exactly match hooks provided by libmudflap.a */
525 #define MFWRAP_SPEC " %{static: %{fmudflap|fmudflapth: \
526 --wrap=malloc --wrap=free --wrap=calloc --wrap=realloc\
527 --wrap=mmap --wrap=mmap64 --wrap=munmap --wrap=alloca\
528 } %{fmudflapth: --wrap=pthread_create\
529 }} %{fmudflap|fmudflapth: --wrap=main}"
530 #endif
531 #ifndef MFLIB_SPEC
532 #define MFLIB_SPEC "%{fmudflap|fmudflapth: -export-dynamic}"
533 #endif
535 /* When using -fsplit-stack we need to wrap pthread_create, in order
536 to initialize the stack guard. We always use wrapping, rather than
537 shared library ordering, and we keep the wrapper function in
538 libgcc. This is not yet a real spec, though it could become one;
539 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
540 only works with GNU ld and gold. FIXME: This is incompatible with
541 -fmudflap when linking statically, which wants to do its own
542 wrapping. */
543 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
545 #ifndef LIBASAN_SPEC
546 #ifdef STATIC_LIBASAN_LIBS
547 #define ADD_STATIC_LIBASAN_LIBS \
548 " %{static-libasan:" STATIC_LIBASAN_LIBS "}"
549 #else
550 #define ADD_STATIC_LIBASAN_LIBS
551 #endif
552 #ifdef LIBASAN_EARLY_SPEC
553 #define LIBASAN_SPEC ADD_STATIC_LIBASAN_LIBS
554 #elif defined(HAVE_LD_STATIC_DYNAMIC)
555 #define LIBASAN_SPEC "%{static-libasan:" LD_STATIC_OPTION \
556 "} -lasan %{static-libasan:" LD_DYNAMIC_OPTION "}" \
557 ADD_STATIC_LIBASAN_LIBS
558 #else
559 #define LIBASAN_SPEC "-lasan" ADD_STATIC_LIBASAN_LIBS
560 #endif
561 #endif
563 #ifndef LIBASAN_EARLY_SPEC
564 #define LIBASAN_EARLY_SPEC ""
565 #endif
567 #ifndef LIBTSAN_SPEC
568 #ifdef STATIC_LIBTSAN_LIBS
569 #define ADD_STATIC_LIBTSAN_LIBS \
570 " %{static-libtsan:" STATIC_LIBTSAN_LIBS "}"
571 #else
572 #define ADD_STATIC_LIBTSAN_LIBS
573 #endif
574 #ifdef LIBTSAN_EARLY_SPEC
575 #define LIBTSAN_SPEC ADD_STATIC_LIBTSAN_LIBS
576 #elif defined(HAVE_LD_STATIC_DYNAMIC)
577 #define LIBTSAN_SPEC "%{static-libtsan:" LD_STATIC_OPTION \
578 "} -ltsan %{static-libtsan:" LD_DYNAMIC_OPTION "}" \
579 ADD_STATIC_LIBTSAN_LIBS
580 #else
581 #define LIBTSAN_SPEC "-ltsan" ADD_STATIC_LIBTSAN_LIBS
582 #endif
583 #endif
585 #ifndef LIBTSAN_EARLY_SPEC
586 #define LIBTSAN_EARLY_SPEC ""
587 #endif
589 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
590 included. */
591 #ifndef LIBGCC_SPEC
592 #if defined(REAL_LIBGCC_SPEC)
593 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
594 #elif defined(LINK_LIBGCC_SPECIAL_1)
595 /* Have gcc do the search for libgcc.a. */
596 #define LIBGCC_SPEC "libgcc.a%s"
597 #else
598 #define LIBGCC_SPEC "-lgcc"
599 #endif
600 #endif
602 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
603 #ifndef STARTFILE_SPEC
604 #define STARTFILE_SPEC \
605 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
606 #endif
608 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
609 #ifndef ENDFILE_SPEC
610 #define ENDFILE_SPEC ""
611 #endif
613 #ifndef LINKER_NAME
614 #define LINKER_NAME "collect2"
615 #endif
617 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
618 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
619 #else
620 #define ASM_MAP ""
621 #endif
623 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
624 to the assembler. */
625 #ifndef ASM_DEBUG_SPEC
626 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
627 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
628 # define ASM_DEBUG_SPEC \
629 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
630 ? "%{!g0:%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}}" ASM_MAP \
631 : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
632 # else
633 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
634 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
635 # endif
636 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
637 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
638 # endif
639 # endif
640 #endif
641 #ifndef ASM_DEBUG_SPEC
642 # define ASM_DEBUG_SPEC ""
643 #endif
645 /* Here is the spec for running the linker, after compiling all files. */
647 /* This is overridable by the target in case they need to specify the
648 -lgcc and -lc order specially, yet not require them to override all
649 of LINK_COMMAND_SPEC. */
650 #ifndef LINK_GCC_C_SEQUENCE_SPEC
651 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
652 #endif
654 #ifndef LINK_SSP_SPEC
655 #ifdef TARGET_LIBC_PROVIDES_SSP
656 #define LINK_SSP_SPEC "%{fstack-protector:}"
657 #else
658 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all:-lssp_nonshared -lssp}"
659 #endif
660 #endif
662 #ifndef LINK_PIE_SPEC
663 #ifdef HAVE_LD_PIE
664 #define LINK_PIE_SPEC "%{pie:-pie} "
665 #else
666 #define LINK_PIE_SPEC "%{pie:} "
667 #endif
668 #endif
670 #ifndef LINK_BUILDID_SPEC
671 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
672 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
673 # endif
674 #endif
676 /* Conditional to test whether the LTO plugin is used or not.
677 FIXME: For slim LTO we will need to enable plugin unconditionally. This
678 still cause problems with PLUGIN_LD != LD and when plugin is built but
679 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
680 plugin only when LTO is enabled. We still honor explicit
681 -fuse-linker-plugin if the linker used understands -plugin. */
683 /* The linker has some plugin support. */
684 #if HAVE_LTO_PLUGIN > 0
685 /* The linker used has full plugin support, use LTO plugin by default. */
686 #if HAVE_LTO_PLUGIN == 2
687 #define PLUGIN_COND "!fno-use-linker-plugin:%{flto|flto=*|fuse-linker-plugin"
688 #define PLUGIN_COND_CLOSE "}"
689 #else
690 /* The linker used has limited plugin support, use LTO plugin with explicit
691 -fuse-linker-plugin. */
692 #define PLUGIN_COND "fuse-linker-plugin"
693 #define PLUGIN_COND_CLOSE ""
694 #endif
695 #define LINK_PLUGIN_SPEC \
696 "%{"PLUGIN_COND": \
697 -plugin %(linker_plugin_file) \
698 -plugin-opt=%(lto_wrapper) \
699 -plugin-opt=-fresolution=%u.res \
700 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
701 }"PLUGIN_COND_CLOSE
702 #else
703 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
704 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
705 %e-fuse-linker-plugin is not supported in this configuration}"
706 #endif
708 /* Linker command line options for -fsanitize= early on the command line. */
709 #ifndef SANITIZER_EARLY_SPEC
710 #define SANITIZER_EARLY_SPEC "\
711 %{!nostdlib:%{!nodefaultlibs:%{fsanitize=address:" LIBASAN_EARLY_SPEC "} \
712 %{fsanitize=thread:" LIBTSAN_EARLY_SPEC "}}}"
713 #endif
715 /* Linker command line options for -fsanitize= late on the command line. */
716 #ifndef SANITIZER_SPEC
717 #define SANITIZER_SPEC "\
718 %{!nostdlib:%{!nodefaultlibs:%{fsanitize=address:" LIBASAN_SPEC "\
719 %{static:%ecannot specify -static with -fsanitize=address}\
720 %{fsanitize=thread:%e-fsanitize=address is incompatible with -fsanitize=thread}}\
721 %{fsanitize=thread:" LIBTSAN_SPEC "\
722 %{!pie:%{!shared:%e-fsanitize=thread linking must be done with -pie or -shared}}}}}"
723 #endif
725 /* -u* was put back because both BSD and SysV seem to support it. */
726 /* %{static:} simply prevents an error message if the target machine
727 doesn't handle -static. */
728 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
729 scripts which exist in user specified directories, or in standard
730 directories. */
731 /* We pass any -flto flags on to the linker, which is expected
732 to understand them. In practice, this means it had better be collect2. */
733 /* %{e*} includes -export-dynamic; see comment in common.opt. */
734 #ifndef LINK_COMMAND_SPEC
735 #define LINK_COMMAND_SPEC "\
736 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
737 %(linker) " \
738 LINK_PLUGIN_SPEC \
739 "%{flto|flto=*:%<fcompare-debug*} \
740 %{flto} %{flto=*} %l " LINK_PIE_SPEC \
741 "%{fuse-ld=*:-fuse-ld=%*}\
742 %X %{o*} %{e*} %{N} %{n} %{r}\
743 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}}\
744 %{static:} %{L*} %(mfwrap) %(link_libgcc) " SANITIZER_EARLY_SPEC " %o\
745 %{fopenmp|ftree-parallelize-loops=*:%:include(libgomp.spec)%(link_gomp)}\
746 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
747 %(mflib) " STACK_SPLIT_SPEC "\
748 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov} " SANITIZER_SPEC " \
749 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
750 %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
751 #endif
753 #ifndef LINK_LIBGCC_SPEC
754 /* Generate -L options for startfile prefix list. */
755 # define LINK_LIBGCC_SPEC "%D"
756 #endif
758 #ifndef STARTFILE_PREFIX_SPEC
759 # define STARTFILE_PREFIX_SPEC ""
760 #endif
762 #ifndef SYSROOT_SPEC
763 # define SYSROOT_SPEC "--sysroot=%R"
764 #endif
766 #ifndef SYSROOT_SUFFIX_SPEC
767 # define SYSROOT_SUFFIX_SPEC ""
768 #endif
770 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
771 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
772 #endif
774 static const char *asm_debug = ASM_DEBUG_SPEC;
775 static const char *cpp_spec = CPP_SPEC;
776 static const char *cc1_spec = CC1_SPEC;
777 static const char *cc1plus_spec = CC1PLUS_SPEC;
778 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
779 static const char *link_ssp_spec = LINK_SSP_SPEC;
780 static const char *asm_spec = ASM_SPEC;
781 static const char *asm_final_spec = ASM_FINAL_SPEC;
782 static const char *link_spec = LINK_SPEC;
783 static const char *lib_spec = LIB_SPEC;
784 static const char *mfwrap_spec = MFWRAP_SPEC;
785 static const char *mflib_spec = MFLIB_SPEC;
786 static const char *link_gomp_spec = "";
787 static const char *libgcc_spec = LIBGCC_SPEC;
788 static const char *endfile_spec = ENDFILE_SPEC;
789 static const char *startfile_spec = STARTFILE_SPEC;
790 static const char *linker_name_spec = LINKER_NAME;
791 static const char *linker_plugin_file_spec = "";
792 static const char *lto_wrapper_spec = "";
793 static const char *lto_gcc_spec = "";
794 static const char *link_command_spec = LINK_COMMAND_SPEC;
795 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
796 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
797 static const char *sysroot_spec = SYSROOT_SPEC;
798 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
799 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
800 static const char *self_spec = "";
802 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
803 There should be no need to override these in target dependent files,
804 but we need to copy them to the specs file so that newer versions
805 of the GCC driver can correctly drive older tool chains with the
806 appropriate -B options. */
808 /* When cpplib handles traditional preprocessing, get rid of this, and
809 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
810 that we default the front end language better. */
811 static const char *trad_capable_cpp =
812 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
814 /* We don't wrap .d files in %W{} since a missing .d file, and
815 therefore no dependency entry, confuses make into thinking a .o
816 file that happens to exist is up-to-date. */
817 static const char *cpp_unique_options =
818 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
819 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
820 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
821 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
822 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
823 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
824 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
825 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
826 %{fmudflap:-D_MUDFLAP -include mf-runtime.h}\
827 %{fmudflapth:-D_MUDFLAP -D_MUDFLAPTH -include mf-runtime.h}\
828 %{E|M|MM:%W{o*}}";
830 /* This contains cpp options which are common with cc1_options and are passed
831 only when preprocessing only to avoid duplication. We pass the cc1 spec
832 options to the preprocessor so that it the cc1 spec may manipulate
833 options used to set target flags. Those special target flags settings may
834 in turn cause preprocessor symbols to be defined specially. */
835 static const char *cpp_options =
836 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
837 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
838 %{undef} %{save-temps*:-fpch-preprocess}";
840 /* This contains cpp options which are not passed when the preprocessor
841 output will be used by another program. */
842 static const char *cpp_debug_options = "%{d*}";
844 /* NB: This is shared amongst all front-ends, except for Ada. */
845 static const char *cc1_options =
846 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
847 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
848 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
849 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
850 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
851 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
852 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
853 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
854 %{-target-help:--target-help}\
855 %{-version:--version}\
856 %{-help=*:--help=%*}\
857 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
858 %{fsyntax-only:-o %j} %{-param*}\
859 %{fmudflap|fmudflapth:-fno-builtin -fno-merge-constants}\
860 %{coverage:-fprofile-arcs -ftest-coverage}";
862 static const char *asm_options =
863 "%{-target-help:%:print-asm-header()} "
864 #if HAVE_GNU_AS
865 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
866 to the assembler equivalents. */
867 "%{v} %{w:-W} %{I*} "
868 #endif
869 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
871 static const char *invoke_as =
872 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
873 "%{!fwpa:\
874 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
875 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
877 #else
878 "%{!fwpa:\
879 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
880 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
882 #endif
884 /* Some compilers have limits on line lengths, and the multilib_select
885 and/or multilib_matches strings can be very long, so we build them at
886 run time. */
887 static struct obstack multilib_obstack;
888 static const char *multilib_select;
889 static const char *multilib_matches;
890 static const char *multilib_defaults;
891 static const char *multilib_exclusions;
892 static const char *multilib_reuse;
894 /* Check whether a particular argument is a default argument. */
896 #ifndef MULTILIB_DEFAULTS
897 #define MULTILIB_DEFAULTS { "" }
898 #endif
900 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
902 #ifndef DRIVER_SELF_SPECS
903 #define DRIVER_SELF_SPECS ""
904 #endif
906 /* Adding -fopenmp should imply pthreads. This is particularly important
907 for targets that use different start files and suchlike. */
908 #ifndef GOMP_SELF_SPECS
909 #define GOMP_SELF_SPECS "%{fopenmp|ftree-parallelize-loops=*: -pthread}"
910 #endif
912 /* Likewise for -fgnu-tm. */
913 #ifndef GTM_SELF_SPECS
914 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
915 #endif
917 static const char *const driver_self_specs[] = {
918 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
919 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS
922 #ifndef OPTION_DEFAULT_SPECS
923 #define OPTION_DEFAULT_SPECS { "", "" }
924 #endif
926 struct default_spec
928 const char *name;
929 const char *spec;
932 static const struct default_spec
933 option_default_specs[] = { OPTION_DEFAULT_SPECS };
935 struct user_specs
937 struct user_specs *next;
938 const char *filename;
941 static struct user_specs *user_specs_head, *user_specs_tail;
944 /* Record the mapping from file suffixes for compilation specs. */
946 struct compiler
948 const char *suffix; /* Use this compiler for input files
949 whose names end in this suffix. */
951 const char *spec; /* To use this compiler, run this spec. */
953 const char *cpp_spec; /* If non-NULL, substitute this spec
954 for `%C', rather than the usual
955 cpp_spec. */
956 const int combinable; /* If nonzero, compiler can deal with
957 multiple source files at once (IMA). */
958 const int needs_preprocessing; /* If nonzero, source files need to
959 be run through a preprocessor. */
962 /* Pointer to a vector of `struct compiler' that gives the spec for
963 compiling a file, based on its suffix.
964 A file that does not end in any of these suffixes will be passed
965 unchanged to the loader and nothing else will be done to it.
967 An entry containing two 0s is used to terminate the vector.
969 If multiple entries match a file, the last matching one is used. */
971 static struct compiler *compilers;
973 /* Number of entries in `compilers', not counting the null terminator. */
975 static int n_compilers;
977 /* The default list of file name suffixes and their compilation specs. */
979 static const struct compiler default_compilers[] =
981 /* Add lists of suffixes of known languages here. If those languages
982 were not present when we built the driver, we will hit these copies
983 and be given a more meaningful error than "file not used since
984 linking is not done". */
985 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
986 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
987 {".mii", "#Objective-C++", 0, 0, 0},
988 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
989 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
990 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
991 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
992 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
993 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
994 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
995 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
996 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
997 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
998 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
999 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
1000 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
1001 {".r", "#Ratfor", 0, 0, 0},
1002 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
1003 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
1004 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
1005 {".go", "#Go", 0, 1, 0},
1006 /* Next come the entries for C. */
1007 {".c", "@c", 0, 0, 1},
1008 {"@c",
1009 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1010 external preprocessor if -save-temps is given. */
1011 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1012 %{!E:%{!M:%{!MM:\
1013 %{traditional:\
1014 %eGNU C no longer supports -traditional without -E}\
1015 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1016 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1017 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1018 %(cc1_options)}\
1019 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1020 cc1 %(cpp_unique_options) %(cc1_options)}}}\
1021 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
1022 {"-",
1023 "%{!E:%e-E or -x required when input is from standard input}\
1024 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
1025 {".h", "@c-header", 0, 0, 0},
1026 {"@c-header",
1027 /* cc1 has an integrated ISO C preprocessor. We should invoke the
1028 external preprocessor if -save-temps is given. */
1029 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
1030 %{!E:%{!M:%{!MM:\
1031 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
1032 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
1033 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
1034 %(cc1_options)\
1035 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1036 %W{o*:--output-pch=%*}}%V}\
1037 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
1038 cc1 %(cpp_unique_options) %(cc1_options)\
1039 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
1040 %W{o*:--output-pch=%*}}%V}}}}}}", 0, 0, 0},
1041 {".i", "@cpp-output", 0, 0, 0},
1042 {"@cpp-output",
1043 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
1044 {".s", "@assembler", 0, 0, 0},
1045 {"@assembler",
1046 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
1047 {".sx", "@assembler-with-cpp", 0, 0, 0},
1048 {".S", "@assembler-with-cpp", 0, 0, 0},
1049 {"@assembler-with-cpp",
1050 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
1051 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1052 %{E|M|MM:%(cpp_debug_options)}\
1053 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1054 as %(asm_debug) %(asm_options) %|.s %A }}}}"
1055 #else
1056 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
1057 %{E|M|MM:%(cpp_debug_options)}\
1058 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
1059 as %(asm_debug) %(asm_options) %m.s %A }}}}"
1060 #endif
1061 , 0, 0, 0},
1063 #include "specs.h"
1064 /* Mark end of table. */
1065 {0, 0, 0, 0, 0}
1068 /* Number of elements in default_compilers, not counting the terminator. */
1070 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1072 typedef char *char_p; /* For DEF_VEC_P. */
1074 /* A vector of options to give to the linker.
1075 These options are accumulated by %x,
1076 and substituted into the linker command with %X. */
1077 static vec<char_p> linker_options;
1079 /* A vector of options to give to the assembler.
1080 These options are accumulated by -Wa,
1081 and substituted into the assembler command with %Y. */
1082 static vec<char_p> assembler_options;
1084 /* A vector of options to give to the preprocessor.
1085 These options are accumulated by -Wp,
1086 and substituted into the preprocessor command with %Z. */
1087 static vec<char_p> preprocessor_options;
1089 static char *
1090 skip_whitespace (char *p)
1092 while (1)
1094 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1095 be considered whitespace. */
1096 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1097 return p + 1;
1098 else if (*p == '\n' || *p == ' ' || *p == '\t')
1099 p++;
1100 else if (*p == '#')
1102 while (*p != '\n')
1103 p++;
1104 p++;
1106 else
1107 break;
1110 return p;
1112 /* Structures to keep track of prefixes to try when looking for files. */
1114 struct prefix_list
1116 const char *prefix; /* String to prepend to the path. */
1117 struct prefix_list *next; /* Next in linked list. */
1118 int require_machine_suffix; /* Don't use without machine_suffix. */
1119 /* 2 means try both machine_suffix and just_machine_suffix. */
1120 int priority; /* Sort key - priority within list. */
1121 int os_multilib; /* 1 if OS multilib scheme should be used,
1122 0 for GCC multilib scheme. */
1125 struct path_prefix
1127 struct prefix_list *plist; /* List of prefixes to try */
1128 int max_len; /* Max length of a prefix in PLIST */
1129 const char *name; /* Name of this list (used in config stuff) */
1132 /* List of prefixes to try when looking for executables. */
1134 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1136 /* List of prefixes to try when looking for startup (crt0) files. */
1138 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1140 /* List of prefixes to try when looking for include files. */
1142 static struct path_prefix include_prefixes = { 0, 0, "include" };
1144 /* Suffix to attach to directories searched for commands.
1145 This looks like `MACHINE/VERSION/'. */
1147 static const char *machine_suffix = 0;
1149 /* Suffix to attach to directories searched for commands.
1150 This is just `MACHINE/'. */
1152 static const char *just_machine_suffix = 0;
1154 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1156 static const char *gcc_exec_prefix;
1158 /* Adjusted value of standard_libexec_prefix. */
1160 static const char *gcc_libexec_prefix;
1162 /* Default prefixes to attach to command names. */
1164 #ifndef STANDARD_STARTFILE_PREFIX_1
1165 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1166 #endif
1167 #ifndef STANDARD_STARTFILE_PREFIX_2
1168 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1169 #endif
1171 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1172 #undef MD_EXEC_PREFIX
1173 #undef MD_STARTFILE_PREFIX
1174 #undef MD_STARTFILE_PREFIX_1
1175 #endif
1177 /* If no prefixes defined, use the null string, which will disable them. */
1178 #ifndef MD_EXEC_PREFIX
1179 #define MD_EXEC_PREFIX ""
1180 #endif
1181 #ifndef MD_STARTFILE_PREFIX
1182 #define MD_STARTFILE_PREFIX ""
1183 #endif
1184 #ifndef MD_STARTFILE_PREFIX_1
1185 #define MD_STARTFILE_PREFIX_1 ""
1186 #endif
1188 /* These directories are locations set at configure-time based on the
1189 --prefix option provided to configure. Their initializers are
1190 defined in Makefile.in. These paths are not *directly* used when
1191 gcc_exec_prefix is set because, in that case, we know where the
1192 compiler has been installed, and use paths relative to that
1193 location instead. */
1194 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1195 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1196 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1197 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1199 /* For native compilers, these are well-known paths containing
1200 components that may be provided by the system. For cross
1201 compilers, these paths are not used. */
1202 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1203 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1204 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1205 static const char *const standard_startfile_prefix_1
1206 = STANDARD_STARTFILE_PREFIX_1;
1207 static const char *const standard_startfile_prefix_2
1208 = STANDARD_STARTFILE_PREFIX_2;
1210 /* A relative path to be used in finding the location of tools
1211 relative to the driver. */
1212 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1214 /* Subdirectory to use for locating libraries. Set by
1215 set_multilib_dir based on the compilation options. */
1217 static const char *multilib_dir;
1219 /* Subdirectory to use for locating libraries in OS conventions. Set by
1220 set_multilib_dir based on the compilation options. */
1222 static const char *multilib_os_dir;
1224 /* Subdirectory to use for locating libraries in multiarch conventions. Set by
1225 set_multilib_dir based on the compilation options. */
1227 static const char *multiarch_dir;
1229 /* Structure to keep track of the specs that have been defined so far.
1230 These are accessed using %(specname) in a compiler or link
1231 spec. */
1233 struct spec_list
1235 /* The following 2 fields must be first */
1236 /* to allow EXTRA_SPECS to be initialized */
1237 const char *name; /* name of the spec. */
1238 const char *ptr; /* available ptr if no static pointer */
1240 /* The following fields are not initialized */
1241 /* by EXTRA_SPECS */
1242 const char **ptr_spec; /* pointer to the spec itself. */
1243 struct spec_list *next; /* Next spec in linked list. */
1244 int name_len; /* length of the name */
1245 bool user_p; /* whether string come from file spec. */
1246 bool alloc_p; /* whether string was allocated */
1249 #define INIT_STATIC_SPEC(NAME,PTR) \
1250 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false }
1252 /* List of statically defined specs. */
1253 static struct spec_list static_specs[] =
1255 INIT_STATIC_SPEC ("asm", &asm_spec),
1256 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1257 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1258 INIT_STATIC_SPEC ("asm_options", &asm_options),
1259 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1260 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1261 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1262 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1263 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1264 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1265 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1266 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1267 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1268 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1269 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1270 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1271 INIT_STATIC_SPEC ("link", &link_spec),
1272 INIT_STATIC_SPEC ("lib", &lib_spec),
1273 INIT_STATIC_SPEC ("mfwrap", &mfwrap_spec),
1274 INIT_STATIC_SPEC ("mflib", &mflib_spec),
1275 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1276 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1277 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1278 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1279 INIT_STATIC_SPEC ("version", &compiler_version),
1280 INIT_STATIC_SPEC ("multilib", &multilib_select),
1281 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1282 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1283 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1284 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1285 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1286 INIT_STATIC_SPEC ("multilib_reuse", &multilib_reuse),
1287 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1288 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1289 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1290 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1291 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1292 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1293 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1294 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1295 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1296 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1297 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1298 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1299 INIT_STATIC_SPEC ("self_spec", &self_spec),
1302 #ifdef EXTRA_SPECS /* additional specs needed */
1303 /* Structure to keep track of just the first two args of a spec_list.
1304 That is all that the EXTRA_SPECS macro gives us. */
1305 struct spec_list_1
1307 const char *const name;
1308 const char *const ptr;
1311 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1312 static struct spec_list *extra_specs = (struct spec_list *) 0;
1313 #endif
1315 /* List of dynamically allocates specs that have been defined so far. */
1317 static struct spec_list *specs = (struct spec_list *) 0;
1319 /* List of static spec functions. */
1321 static const struct spec_function static_spec_functions[] =
1323 { "getenv", getenv_spec_function },
1324 { "if-exists", if_exists_spec_function },
1325 { "if-exists-else", if_exists_else_spec_function },
1326 { "replace-outfile", replace_outfile_spec_function },
1327 { "remove-outfile", remove_outfile_spec_function },
1328 { "version-compare", version_compare_spec_function },
1329 { "include", include_spec_function },
1330 { "find-file", find_file_spec_function },
1331 { "find-plugindir", find_plugindir_spec_function },
1332 { "print-asm-header", print_asm_header_spec_function },
1333 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1334 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1335 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1336 { "pass-through-libs", pass_through_libs_spec_func },
1337 { "replace-extension", replace_extension_spec_func },
1338 #ifdef EXTRA_SPEC_FUNCTIONS
1339 EXTRA_SPEC_FUNCTIONS
1340 #endif
1341 { 0, 0 }
1344 static int processing_spec_function;
1346 /* Add appropriate libgcc specs to OBSTACK, taking into account
1347 various permutations of -shared-libgcc, -shared, and such. */
1349 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1351 #ifndef USE_LD_AS_NEEDED
1352 #define USE_LD_AS_NEEDED 0
1353 #endif
1355 static void
1356 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1357 const char *static_name, const char *eh_name)
1359 char *buf;
1361 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1362 "%{!static:%{!static-libgcc:"
1363 #if USE_LD_AS_NEEDED
1364 "%{!shared-libgcc:",
1365 static_name, " --as-needed ", shared_name, " --no-as-needed"
1367 "%{shared-libgcc:",
1368 shared_name, "%{!shared: ", static_name, "}"
1370 #else
1371 "%{!shared:"
1372 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1373 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1375 #ifdef LINK_EH_SPEC
1376 "%{shared:"
1377 "%{shared-libgcc:", shared_name, "}"
1378 "%{!shared-libgcc:", static_name, "}"
1380 #else
1381 "%{shared:", shared_name, "}"
1382 #endif
1383 #endif
1384 "}}", NULL);
1386 obstack_grow (obstack, buf, strlen (buf));
1387 free (buf);
1389 #endif /* ENABLE_SHARED_LIBGCC */
1391 /* Initialize the specs lookup routines. */
1393 static void
1394 init_spec (void)
1396 struct spec_list *next = (struct spec_list *) 0;
1397 struct spec_list *sl = (struct spec_list *) 0;
1398 int i;
1400 if (specs)
1401 return; /* Already initialized. */
1403 if (verbose_flag)
1404 fnotice (stderr, "Using built-in specs.\n");
1406 #ifdef EXTRA_SPECS
1407 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1409 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1411 sl = &extra_specs[i];
1412 sl->name = extra_specs_1[i].name;
1413 sl->ptr = extra_specs_1[i].ptr;
1414 sl->next = next;
1415 sl->name_len = strlen (sl->name);
1416 sl->ptr_spec = &sl->ptr;
1417 next = sl;
1419 #endif
1421 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1423 sl = &static_specs[i];
1424 sl->next = next;
1425 next = sl;
1428 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1429 /* ??? If neither -shared-libgcc nor --static-libgcc was
1430 seen, then we should be making an educated guess. Some proposed
1431 heuristics for ELF include:
1433 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1434 program will be doing dynamic loading, which will likely
1435 need the shared libgcc.
1437 (2) If "-ldl", then it's also a fair bet that we're doing
1438 dynamic loading.
1440 (3) For each ET_DYN we're linking against (either through -lfoo
1441 or /some/path/foo.so), check to see whether it or one of
1442 its dependencies depends on a shared libgcc.
1444 (4) If "-shared"
1446 If the runtime is fixed to look for program headers instead
1447 of calling __register_frame_info at all, for each object,
1448 use the shared libgcc if any EH symbol referenced.
1450 If crtstuff is fixed to not invoke __register_frame_info
1451 automatically, for each object, use the shared libgcc if
1452 any non-empty unwind section found.
1454 Doing any of this probably requires invoking an external program to
1455 do the actual object file scanning. */
1457 const char *p = libgcc_spec;
1458 int in_sep = 1;
1460 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1461 when given the proper command line arguments. */
1462 while (*p)
1464 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1466 init_gcc_specs (&obstack,
1467 "-lgcc_s"
1468 #ifdef USE_LIBUNWIND_EXCEPTIONS
1469 " -lunwind"
1470 #endif
1472 "-lgcc",
1473 "-lgcc_eh"
1474 #ifdef USE_LIBUNWIND_EXCEPTIONS
1475 # ifdef HAVE_LD_STATIC_DYNAMIC
1476 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1477 " %{!static:" LD_DYNAMIC_OPTION "}"
1478 # else
1479 " -lunwind"
1480 # endif
1481 #endif
1484 p += 5;
1485 in_sep = 0;
1487 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1489 /* Ug. We don't know shared library extensions. Hope that
1490 systems that use this form don't do shared libraries. */
1491 init_gcc_specs (&obstack,
1492 "-lgcc_s",
1493 "libgcc.a%s",
1494 "libgcc_eh.a%s"
1495 #ifdef USE_LIBUNWIND_EXCEPTIONS
1496 " -lunwind"
1497 #endif
1499 p += 10;
1500 in_sep = 0;
1502 else
1504 obstack_1grow (&obstack, *p);
1505 in_sep = (*p == ' ');
1506 p += 1;
1510 obstack_1grow (&obstack, '\0');
1511 libgcc_spec = XOBFINISH (&obstack, const char *);
1513 #endif
1514 #ifdef USE_AS_TRADITIONAL_FORMAT
1515 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1517 static const char tf[] = "--traditional-format ";
1518 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1519 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1520 asm_spec = XOBFINISH (&obstack, const char *);
1522 #endif
1524 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1525 defined LINKER_HASH_STYLE
1526 # ifdef LINK_BUILDID_SPEC
1527 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1528 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof(LINK_BUILDID_SPEC) - 1);
1529 # endif
1530 # ifdef LINK_EH_SPEC
1531 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1532 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1533 # endif
1534 # ifdef LINKER_HASH_STYLE
1535 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1536 before. */
1538 static const char hash_style[] = "--hash-style=";
1539 obstack_grow (&obstack, hash_style, sizeof(hash_style) - 1);
1540 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof(LINKER_HASH_STYLE) - 1);
1541 obstack_1grow (&obstack, ' ');
1543 # endif
1544 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1545 link_spec = XOBFINISH (&obstack, const char *);
1546 #endif
1548 specs = sl;
1551 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1552 removed; If the spec starts with a + then SPEC is added to the end of the
1553 current spec. */
1555 static void
1556 set_spec (const char *name, const char *spec, bool user_p)
1558 struct spec_list *sl;
1559 const char *old_spec;
1560 int name_len = strlen (name);
1561 int i;
1563 /* If this is the first call, initialize the statically allocated specs. */
1564 if (!specs)
1566 struct spec_list *next = (struct spec_list *) 0;
1567 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1569 sl = &static_specs[i];
1570 sl->next = next;
1571 next = sl;
1573 specs = sl;
1576 /* See if the spec already exists. */
1577 for (sl = specs; sl; sl = sl->next)
1578 if (name_len == sl->name_len && !strcmp (sl->name, name))
1579 break;
1581 if (!sl)
1583 /* Not found - make it. */
1584 sl = XNEW (struct spec_list);
1585 sl->name = xstrdup (name);
1586 sl->name_len = name_len;
1587 sl->ptr_spec = &sl->ptr;
1588 sl->alloc_p = 0;
1589 *(sl->ptr_spec) = "";
1590 sl->next = specs;
1591 specs = sl;
1594 old_spec = *(sl->ptr_spec);
1595 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1596 ? concat (old_spec, spec + 1, NULL)
1597 : xstrdup (spec));
1599 #ifdef DEBUG_SPECS
1600 if (verbose_flag)
1601 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1602 #endif
1604 /* Free the old spec. */
1605 if (old_spec && sl->alloc_p)
1606 free (CONST_CAST(char *, old_spec));
1608 sl->user_p = user_p;
1609 sl->alloc_p = true;
1612 /* Accumulate a command (program name and args), and run it. */
1614 typedef const char *const_char_p; /* For DEF_VEC_P. */
1616 /* Vector of pointers to arguments in the current line of specifications. */
1618 static vec<const_char_p> argbuf;
1620 /* Position in the argbuf vector containing the name of the output file
1621 (the value associated with the "-o" flag). */
1623 static int have_o_argbuf_index = 0;
1625 /* Were the options -c, -S or -E passed. */
1626 static int have_c = 0;
1628 /* Was the option -o passed. */
1629 static int have_o = 0;
1631 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1632 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1633 it here. */
1635 static struct temp_name {
1636 const char *suffix; /* suffix associated with the code. */
1637 int length; /* strlen (suffix). */
1638 int unique; /* Indicates whether %g or %u/%U was used. */
1639 const char *filename; /* associated filename. */
1640 int filename_length; /* strlen (filename). */
1641 struct temp_name *next;
1642 } *temp_names;
1644 /* Number of commands executed so far. */
1646 static int execution_count;
1648 /* Number of commands that exited with a signal. */
1650 static int signal_count;
1652 /* Allocate the argument vector. */
1654 static void
1655 alloc_args (void)
1657 argbuf.create (10);
1660 /* Clear out the vector of arguments (after a command is executed). */
1662 static void
1663 clear_args (void)
1665 argbuf.truncate (0);
1668 /* Add one argument to the vector at the end.
1669 This is done when a space is seen or at the end of the line.
1670 If DELETE_ALWAYS is nonzero, the arg is a filename
1671 and the file should be deleted eventually.
1672 If DELETE_FAILURE is nonzero, the arg is a filename
1673 and the file should be deleted if this compilation fails. */
1675 static void
1676 store_arg (const char *arg, int delete_always, int delete_failure)
1678 argbuf.safe_push (arg);
1680 if (strcmp (arg, "-o") == 0)
1681 have_o_argbuf_index = argbuf.length ();
1682 if (delete_always || delete_failure)
1684 const char *p;
1685 /* If the temporary file we should delete is specified as
1686 part of a joined argument extract the filename. */
1687 if (arg[0] == '-'
1688 && (p = strrchr (arg, '=')))
1689 arg = p + 1;
1690 record_temp_file (arg, delete_always, delete_failure);
1694 /* Load specs from a file name named FILENAME, replacing occurrences of
1695 various different types of line-endings, \r\n, \n\r and just \r, with
1696 a single \n. */
1698 static char *
1699 load_specs (const char *filename)
1701 int desc;
1702 int readlen;
1703 struct stat statbuf;
1704 char *buffer;
1705 char *buffer_p;
1706 char *specs;
1707 char *specs_p;
1709 if (verbose_flag)
1710 fnotice (stderr, "Reading specs from %s\n", filename);
1712 /* Open and stat the file. */
1713 desc = open (filename, O_RDONLY, 0);
1714 if (desc < 0)
1715 pfatal_with_name (filename);
1716 if (stat (filename, &statbuf) < 0)
1717 pfatal_with_name (filename);
1719 /* Read contents of file into BUFFER. */
1720 buffer = XNEWVEC (char, statbuf.st_size + 1);
1721 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1722 if (readlen < 0)
1723 pfatal_with_name (filename);
1724 buffer[readlen] = 0;
1725 close (desc);
1727 specs = XNEWVEC (char, readlen + 1);
1728 specs_p = specs;
1729 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1731 int skip = 0;
1732 char c = *buffer_p;
1733 if (c == '\r')
1735 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1736 skip = 1;
1737 else if (*(buffer_p + 1) == '\n') /* \r\n */
1738 skip = 1;
1739 else /* \r */
1740 c = '\n';
1742 if (! skip)
1743 *specs_p++ = c;
1745 *specs_p = '\0';
1747 free (buffer);
1748 return (specs);
1751 /* Read compilation specs from a file named FILENAME,
1752 replacing the default ones.
1754 A suffix which starts with `*' is a definition for
1755 one of the machine-specific sub-specs. The "suffix" should be
1756 *asm, *cc1, *cpp, *link, *startfile, etc.
1757 The corresponding spec is stored in asm_spec, etc.,
1758 rather than in the `compilers' vector.
1760 Anything invalid in the file is a fatal error. */
1762 static void
1763 read_specs (const char *filename, bool main_p, bool user_p)
1765 char *buffer;
1766 char *p;
1768 buffer = load_specs (filename);
1770 /* Scan BUFFER for specs, putting them in the vector. */
1771 p = buffer;
1772 while (1)
1774 char *suffix;
1775 char *spec;
1776 char *in, *out, *p1, *p2, *p3;
1778 /* Advance P in BUFFER to the next nonblank nocomment line. */
1779 p = skip_whitespace (p);
1780 if (*p == 0)
1781 break;
1783 /* Is this a special command that starts with '%'? */
1784 /* Don't allow this for the main specs file, since it would
1785 encourage people to overwrite it. */
1786 if (*p == '%' && !main_p)
1788 p1 = p;
1789 while (*p && *p != '\n')
1790 p++;
1792 /* Skip '\n'. */
1793 p++;
1795 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1796 && (p1[sizeof "%include" - 1] == ' '
1797 || p1[sizeof "%include" - 1] == '\t'))
1799 char *new_filename;
1801 p1 += sizeof ("%include");
1802 while (*p1 == ' ' || *p1 == '\t')
1803 p1++;
1805 if (*p1++ != '<' || p[-2] != '>')
1806 fatal_error ("specs %%include syntax malformed after "
1807 "%ld characters",
1808 (long) (p1 - buffer + 1));
1810 p[-2] = '\0';
1811 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1812 read_specs (new_filename ? new_filename : p1, false, user_p);
1813 continue;
1815 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1816 && (p1[sizeof "%include_noerr" - 1] == ' '
1817 || p1[sizeof "%include_noerr" - 1] == '\t'))
1819 char *new_filename;
1821 p1 += sizeof "%include_noerr";
1822 while (*p1 == ' ' || *p1 == '\t')
1823 p1++;
1825 if (*p1++ != '<' || p[-2] != '>')
1826 fatal_error ("specs %%include syntax malformed after "
1827 "%ld characters",
1828 (long) (p1 - buffer + 1));
1830 p[-2] = '\0';
1831 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1832 if (new_filename)
1833 read_specs (new_filename, false, user_p);
1834 else if (verbose_flag)
1835 fnotice (stderr, "could not find specs file %s\n", p1);
1836 continue;
1838 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1839 && (p1[sizeof "%rename" - 1] == ' '
1840 || p1[sizeof "%rename" - 1] == '\t'))
1842 int name_len;
1843 struct spec_list *sl;
1844 struct spec_list *newsl;
1846 /* Get original name. */
1847 p1 += sizeof "%rename";
1848 while (*p1 == ' ' || *p1 == '\t')
1849 p1++;
1851 if (! ISALPHA ((unsigned char) *p1))
1852 fatal_error ("specs %%rename syntax malformed after "
1853 "%ld characters",
1854 (long) (p1 - buffer));
1856 p2 = p1;
1857 while (*p2 && !ISSPACE ((unsigned char) *p2))
1858 p2++;
1860 if (*p2 != ' ' && *p2 != '\t')
1861 fatal_error ("specs %%rename syntax malformed after "
1862 "%ld characters",
1863 (long) (p2 - buffer));
1865 name_len = p2 - p1;
1866 *p2++ = '\0';
1867 while (*p2 == ' ' || *p2 == '\t')
1868 p2++;
1870 if (! ISALPHA ((unsigned char) *p2))
1871 fatal_error ("specs %%rename syntax malformed after "
1872 "%ld characters",
1873 (long) (p2 - buffer));
1875 /* Get new spec name. */
1876 p3 = p2;
1877 while (*p3 && !ISSPACE ((unsigned char) *p3))
1878 p3++;
1880 if (p3 != p - 1)
1881 fatal_error ("specs %%rename syntax malformed after "
1882 "%ld characters",
1883 (long) (p3 - buffer));
1884 *p3 = '\0';
1886 for (sl = specs; sl; sl = sl->next)
1887 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1888 break;
1890 if (!sl)
1891 fatal_error ("specs %s spec was not found to be renamed", p1);
1893 if (strcmp (p1, p2) == 0)
1894 continue;
1896 for (newsl = specs; newsl; newsl = newsl->next)
1897 if (strcmp (newsl->name, p2) == 0)
1898 fatal_error ("%s: attempt to rename spec %qs to "
1899 "already defined spec %qs",
1900 filename, p1, p2);
1902 if (verbose_flag)
1904 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
1905 #ifdef DEBUG_SPECS
1906 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
1907 #endif
1910 set_spec (p2, *(sl->ptr_spec), user_p);
1911 if (sl->alloc_p)
1912 free (CONST_CAST (char *, *(sl->ptr_spec)));
1914 *(sl->ptr_spec) = "";
1915 sl->alloc_p = 0;
1916 continue;
1918 else
1919 fatal_error ("specs unknown %% command after %ld characters",
1920 (long) (p1 - buffer));
1923 /* Find the colon that should end the suffix. */
1924 p1 = p;
1925 while (*p1 && *p1 != ':' && *p1 != '\n')
1926 p1++;
1928 /* The colon shouldn't be missing. */
1929 if (*p1 != ':')
1930 fatal_error ("specs file malformed after %ld characters",
1931 (long) (p1 - buffer));
1933 /* Skip back over trailing whitespace. */
1934 p2 = p1;
1935 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
1936 p2--;
1938 /* Copy the suffix to a string. */
1939 suffix = save_string (p, p2 - p);
1940 /* Find the next line. */
1941 p = skip_whitespace (p1 + 1);
1942 if (p[1] == 0)
1943 fatal_error ("specs file malformed after %ld characters",
1944 (long) (p - buffer));
1946 p1 = p;
1947 /* Find next blank line or end of string. */
1948 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
1949 p1++;
1951 /* Specs end at the blank line and do not include the newline. */
1952 spec = save_string (p, p1 - p);
1953 p = p1;
1955 /* Delete backslash-newline sequences from the spec. */
1956 in = spec;
1957 out = spec;
1958 while (*in != 0)
1960 if (in[0] == '\\' && in[1] == '\n')
1961 in += 2;
1962 else if (in[0] == '#')
1963 while (*in && *in != '\n')
1964 in++;
1966 else
1967 *out++ = *in++;
1969 *out = 0;
1971 if (suffix[0] == '*')
1973 if (! strcmp (suffix, "*link_command"))
1974 link_command_spec = spec;
1975 else
1976 set_spec (suffix + 1, spec, user_p);
1978 else
1980 /* Add this pair to the vector. */
1981 compilers
1982 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
1984 compilers[n_compilers].suffix = suffix;
1985 compilers[n_compilers].spec = spec;
1986 n_compilers++;
1987 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
1990 if (*suffix == 0)
1991 link_command_spec = spec;
1994 if (link_command_spec == 0)
1995 fatal_error ("spec file has no spec for linking");
1998 /* Record the names of temporary files we tell compilers to write,
1999 and delete them at the end of the run. */
2001 /* This is the common prefix we use to make temp file names.
2002 It is chosen once for each run of this program.
2003 It is substituted into a spec by %g or %j.
2004 Thus, all temp file names contain this prefix.
2005 In practice, all temp file names start with this prefix.
2007 This prefix comes from the envvar TMPDIR if it is defined;
2008 otherwise, from the P_tmpdir macro if that is defined;
2009 otherwise, in /usr/tmp or /tmp;
2010 or finally the current directory if all else fails. */
2012 static const char *temp_filename;
2014 /* Length of the prefix. */
2016 static int temp_filename_length;
2018 /* Define the list of temporary files to delete. */
2020 struct temp_file
2022 const char *name;
2023 struct temp_file *next;
2026 /* Queue of files to delete on success or failure of compilation. */
2027 static struct temp_file *always_delete_queue;
2028 /* Queue of files to delete on failure of compilation. */
2029 static struct temp_file *failure_delete_queue;
2031 /* Record FILENAME as a file to be deleted automatically.
2032 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
2033 otherwise delete it in any case.
2034 FAIL_DELETE nonzero means delete it if a compilation step fails;
2035 otherwise delete it in any case. */
2037 void
2038 record_temp_file (const char *filename, int always_delete, int fail_delete)
2040 char *const name = xstrdup (filename);
2042 if (always_delete)
2044 struct temp_file *temp;
2045 for (temp = always_delete_queue; temp; temp = temp->next)
2046 if (! filename_cmp (name, temp->name))
2047 goto already1;
2049 temp = XNEW (struct temp_file);
2050 temp->next = always_delete_queue;
2051 temp->name = name;
2052 always_delete_queue = temp;
2054 already1:;
2057 if (fail_delete)
2059 struct temp_file *temp;
2060 for (temp = failure_delete_queue; temp; temp = temp->next)
2061 if (! filename_cmp (name, temp->name))
2063 free (name);
2064 goto already2;
2067 temp = XNEW (struct temp_file);
2068 temp->next = failure_delete_queue;
2069 temp->name = name;
2070 failure_delete_queue = temp;
2072 already2:;
2076 /* Delete all the temporary files whose names we previously recorded. */
2078 #ifndef DELETE_IF_ORDINARY
2079 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2080 do \
2082 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2083 if (unlink (NAME) < 0) \
2084 if (VERBOSE_FLAG) \
2085 perror_with_name (NAME); \
2086 } while (0)
2087 #endif
2089 static void
2090 delete_if_ordinary (const char *name)
2092 struct stat st;
2093 #ifdef DEBUG
2094 int i, c;
2096 printf ("Delete %s? (y or n) ", name);
2097 fflush (stdout);
2098 i = getchar ();
2099 if (i != '\n')
2100 while ((c = getchar ()) != '\n' && c != EOF)
2103 if (i == 'y' || i == 'Y')
2104 #endif /* DEBUG */
2105 DELETE_IF_ORDINARY (name, st, verbose_flag);
2108 static void
2109 delete_temp_files (void)
2111 struct temp_file *temp;
2113 for (temp = always_delete_queue; temp; temp = temp->next)
2114 delete_if_ordinary (temp->name);
2115 always_delete_queue = 0;
2118 /* Delete all the files to be deleted on error. */
2120 static void
2121 delete_failure_queue (void)
2123 struct temp_file *temp;
2125 for (temp = failure_delete_queue; temp; temp = temp->next)
2126 delete_if_ordinary (temp->name);
2129 static void
2130 clear_failure_queue (void)
2132 failure_delete_queue = 0;
2135 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2136 returns non-NULL.
2137 If DO_MULTI is true iterate over the paths twice, first with multilib
2138 suffix then without, otherwise iterate over the paths once without
2139 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2140 to avoid visiting the same path twice, but we could do better. For
2141 instance, /usr/lib/../lib is considered different from /usr/lib.
2142 At least EXTRA_SPACE chars past the end of the path passed to
2143 CALLBACK are available for use by the callback.
2144 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2146 Returns the value returned by CALLBACK. */
2148 static void *
2149 for_each_path (const struct path_prefix *paths,
2150 bool do_multi,
2151 size_t extra_space,
2152 void *(*callback) (char *, void *),
2153 void *callback_info)
2155 struct prefix_list *pl;
2156 const char *multi_dir = NULL;
2157 const char *multi_os_dir = NULL;
2158 const char *multiarch_suffix = NULL;
2159 const char *multi_suffix;
2160 const char *just_multi_suffix;
2161 char *path = NULL;
2162 void *ret = NULL;
2163 bool skip_multi_dir = false;
2164 bool skip_multi_os_dir = false;
2166 multi_suffix = machine_suffix;
2167 just_multi_suffix = just_machine_suffix;
2168 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2170 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2171 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2172 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2174 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2175 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2176 if (multiarch_dir)
2177 multiarch_suffix = concat (multiarch_dir, dir_separator_str, NULL);
2179 while (1)
2181 size_t multi_dir_len = 0;
2182 size_t multi_os_dir_len = 0;
2183 size_t multiarch_len = 0;
2184 size_t suffix_len;
2185 size_t just_suffix_len;
2186 size_t len;
2188 if (multi_dir)
2189 multi_dir_len = strlen (multi_dir);
2190 if (multi_os_dir)
2191 multi_os_dir_len = strlen (multi_os_dir);
2192 if (multiarch_suffix)
2193 multiarch_len = strlen (multiarch_suffix);
2194 suffix_len = strlen (multi_suffix);
2195 just_suffix_len = strlen (just_multi_suffix);
2197 if (path == NULL)
2199 len = paths->max_len + extra_space + 1;
2200 len += MAX (MAX (suffix_len, multi_os_dir_len), multiarch_len);
2201 path = XNEWVEC (char, len);
2204 for (pl = paths->plist; pl != 0; pl = pl->next)
2206 len = strlen (pl->prefix);
2207 memcpy (path, pl->prefix, len);
2209 /* Look first in MACHINE/VERSION subdirectory. */
2210 if (!skip_multi_dir)
2212 memcpy (path + len, multi_suffix, suffix_len + 1);
2213 ret = callback (path, callback_info);
2214 if (ret)
2215 break;
2218 /* Some paths are tried with just the machine (ie. target)
2219 subdir. This is used for finding as, ld, etc. */
2220 if (!skip_multi_dir
2221 && pl->require_machine_suffix == 2)
2223 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2224 ret = callback (path, callback_info);
2225 if (ret)
2226 break;
2229 /* Now try the multiarch path. */
2230 if (!skip_multi_dir
2231 && !pl->require_machine_suffix && multiarch_dir)
2233 memcpy (path + len, multiarch_suffix, multiarch_len + 1);
2234 ret = callback (path, callback_info);
2235 if (ret)
2236 break;
2239 /* Now try the base path. */
2240 if (!pl->require_machine_suffix
2241 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2243 const char *this_multi;
2244 size_t this_multi_len;
2246 if (pl->os_multilib)
2248 this_multi = multi_os_dir;
2249 this_multi_len = multi_os_dir_len;
2251 else
2253 this_multi = multi_dir;
2254 this_multi_len = multi_dir_len;
2257 if (this_multi_len)
2258 memcpy (path + len, this_multi, this_multi_len + 1);
2259 else
2260 path[len] = '\0';
2262 ret = callback (path, callback_info);
2263 if (ret)
2264 break;
2267 if (pl)
2268 break;
2270 if (multi_dir == NULL && multi_os_dir == NULL)
2271 break;
2273 /* Run through the paths again, this time without multilibs.
2274 Don't repeat any we have already seen. */
2275 if (multi_dir)
2277 free (CONST_CAST (char *, multi_dir));
2278 multi_dir = NULL;
2279 free (CONST_CAST (char *, multi_suffix));
2280 multi_suffix = machine_suffix;
2281 free (CONST_CAST (char *, just_multi_suffix));
2282 just_multi_suffix = just_machine_suffix;
2284 else
2285 skip_multi_dir = true;
2286 if (multi_os_dir)
2288 free (CONST_CAST (char *, multi_os_dir));
2289 multi_os_dir = NULL;
2291 else
2292 skip_multi_os_dir = true;
2295 if (multi_dir)
2297 free (CONST_CAST (char *, multi_dir));
2298 free (CONST_CAST (char *, multi_suffix));
2299 free (CONST_CAST (char *, just_multi_suffix));
2301 if (multi_os_dir)
2302 free (CONST_CAST (char *, multi_os_dir));
2303 if (ret != path)
2304 free (path);
2305 return ret;
2308 /* Callback for build_search_list. Adds path to obstack being built. */
2310 struct add_to_obstack_info {
2311 struct obstack *ob;
2312 bool check_dir;
2313 bool first_time;
2316 static void *
2317 add_to_obstack (char *path, void *data)
2319 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2321 if (info->check_dir && !is_directory (path, false))
2322 return NULL;
2324 if (!info->first_time)
2325 obstack_1grow (info->ob, PATH_SEPARATOR);
2327 obstack_grow (info->ob, path, strlen (path));
2329 info->first_time = false;
2330 return NULL;
2333 /* Add or change the value of an environment variable, outputting the
2334 change to standard error if in verbose mode. */
2335 static void
2336 xputenv (const char *string)
2338 if (verbose_flag)
2339 fnotice (stderr, "%s\n", string);
2340 putenv (CONST_CAST (char *, string));
2343 /* Build a list of search directories from PATHS.
2344 PREFIX is a string to prepend to the list.
2345 If CHECK_DIR_P is true we ensure the directory exists.
2346 If DO_MULTI is true, multilib paths are output first, then
2347 non-multilib paths.
2348 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2349 It is also used by the --print-search-dirs flag. */
2351 static char *
2352 build_search_list (const struct path_prefix *paths, const char *prefix,
2353 bool check_dir, bool do_multi)
2355 struct add_to_obstack_info info;
2357 info.ob = &collect_obstack;
2358 info.check_dir = check_dir;
2359 info.first_time = true;
2361 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2362 obstack_1grow (&collect_obstack, '=');
2364 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2366 obstack_1grow (&collect_obstack, '\0');
2367 return XOBFINISH (&collect_obstack, char *);
2370 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2371 for collect. */
2373 static void
2374 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2375 bool do_multi)
2377 xputenv (build_search_list (paths, env_var, true, do_multi));
2380 /* Check whether NAME can be accessed in MODE. This is like access,
2381 except that it never considers directories to be executable. */
2383 static int
2384 access_check (const char *name, int mode)
2386 if (mode == X_OK)
2388 struct stat st;
2390 if (stat (name, &st) < 0
2391 || S_ISDIR (st.st_mode))
2392 return -1;
2395 return access (name, mode);
2398 /* Callback for find_a_file. Appends the file name to the directory
2399 path. If the resulting file exists in the right mode, return the
2400 full pathname to the file. */
2402 struct file_at_path_info {
2403 const char *name;
2404 const char *suffix;
2405 int name_len;
2406 int suffix_len;
2407 int mode;
2410 static void *
2411 file_at_path (char *path, void *data)
2413 struct file_at_path_info *info = (struct file_at_path_info *) data;
2414 size_t len = strlen (path);
2416 memcpy (path + len, info->name, info->name_len);
2417 len += info->name_len;
2419 /* Some systems have a suffix for executable files.
2420 So try appending that first. */
2421 if (info->suffix_len)
2423 memcpy (path + len, info->suffix, info->suffix_len + 1);
2424 if (access_check (path, info->mode) == 0)
2425 return path;
2428 path[len] = '\0';
2429 if (access_check (path, info->mode) == 0)
2430 return path;
2432 return NULL;
2435 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2436 access to check permissions. If DO_MULTI is true, search multilib
2437 paths then non-multilib paths, otherwise do not search multilib paths.
2438 Return 0 if not found, otherwise return its name, allocated with malloc. */
2440 static char *
2441 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2442 bool do_multi)
2444 struct file_at_path_info info;
2446 #ifdef DEFAULT_ASSEMBLER
2447 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2448 return xstrdup (DEFAULT_ASSEMBLER);
2449 #endif
2451 #ifdef DEFAULT_LINKER
2452 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2453 return xstrdup (DEFAULT_LINKER);
2454 #endif
2456 /* Determine the filename to execute (special case for absolute paths). */
2458 if (IS_ABSOLUTE_PATH (name))
2460 if (access (name, mode) == 0)
2461 return xstrdup (name);
2463 return NULL;
2466 info.name = name;
2467 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2468 info.name_len = strlen (info.name);
2469 info.suffix_len = strlen (info.suffix);
2470 info.mode = mode;
2472 return (char*) for_each_path (pprefix, do_multi,
2473 info.name_len + info.suffix_len,
2474 file_at_path, &info);
2477 /* Ranking of prefixes in the sort list. -B prefixes are put before
2478 all others. */
2480 enum path_prefix_priority
2482 PREFIX_PRIORITY_B_OPT,
2483 PREFIX_PRIORITY_LAST
2486 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2487 order according to PRIORITY. Within each PRIORITY, new entries are
2488 appended.
2490 If WARN is nonzero, we will warn if no file is found
2491 through this prefix. WARN should point to an int
2492 which will be set to 1 if this entry is used.
2494 COMPONENT is the value to be passed to update_path.
2496 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2497 the complete value of machine_suffix.
2498 2 means try both machine_suffix and just_machine_suffix. */
2500 static void
2501 add_prefix (struct path_prefix *pprefix, const char *prefix,
2502 const char *component, /* enum prefix_priority */ int priority,
2503 int require_machine_suffix, int os_multilib)
2505 struct prefix_list *pl, **prev;
2506 int len;
2508 for (prev = &pprefix->plist;
2509 (*prev) != NULL && (*prev)->priority <= priority;
2510 prev = &(*prev)->next)
2513 /* Keep track of the longest prefix. */
2515 prefix = update_path (prefix, component);
2516 len = strlen (prefix);
2517 if (len > pprefix->max_len)
2518 pprefix->max_len = len;
2520 pl = XNEW (struct prefix_list);
2521 pl->prefix = prefix;
2522 pl->require_machine_suffix = require_machine_suffix;
2523 pl->priority = priority;
2524 pl->os_multilib = os_multilib;
2526 /* Insert after PREV. */
2527 pl->next = (*prev);
2528 (*prev) = pl;
2531 /* Same as add_prefix, but prepending target_system_root to prefix. */
2532 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2533 static void
2534 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2535 const char *component,
2536 /* enum prefix_priority */ int priority,
2537 int require_machine_suffix, int os_multilib)
2539 if (!IS_ABSOLUTE_PATH (prefix))
2540 fatal_error ("system path %qs is not absolute", prefix);
2542 if (target_system_root)
2544 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2545 size_t sysroot_len = strlen (target_system_root);
2547 if (sysroot_len > 0
2548 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2549 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2551 if (target_sysroot_suffix)
2552 prefix = concat (sysroot_no_trailing_dir_separator,
2553 target_sysroot_suffix, prefix, NULL);
2554 else
2555 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2557 free (sysroot_no_trailing_dir_separator);
2559 /* We have to override this because GCC's notion of sysroot
2560 moves along with GCC. */
2561 component = "GCC";
2564 add_prefix (pprefix, prefix, component, priority,
2565 require_machine_suffix, os_multilib);
2568 /* Execute the command specified by the arguments on the current line of spec.
2569 When using pipes, this includes several piped-together commands
2570 with `|' between them.
2572 Return 0 if successful, -1 if failed. */
2574 static int
2575 execute (void)
2577 int i;
2578 int n_commands; /* # of command. */
2579 char *string;
2580 struct pex_obj *pex;
2581 struct command
2583 const char *prog; /* program name. */
2584 const char **argv; /* vector of args. */
2586 const char *arg;
2588 struct command *commands; /* each command buffer with above info. */
2590 gcc_assert (!processing_spec_function);
2592 if (wrapper_string)
2594 string = find_a_file (&exec_prefixes,
2595 argbuf[0], X_OK, false);
2596 if (string)
2597 argbuf[0] = string;
2598 insert_wrapper (wrapper_string);
2601 /* Count # of piped commands. */
2602 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2603 if (strcmp (arg, "|") == 0)
2604 n_commands++;
2606 /* Get storage for each command. */
2607 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2609 /* Split argbuf into its separate piped processes,
2610 and record info about each one.
2611 Also search for the programs that are to be run. */
2613 argbuf.safe_push (0);
2615 commands[0].prog = argbuf[0]; /* first command. */
2616 commands[0].argv = argbuf.address ();
2618 if (!wrapper_string)
2620 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2621 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2624 for (n_commands = 1, i = 0; argbuf.iterate (i, &arg); i++)
2625 if (arg && strcmp (arg, "|") == 0)
2626 { /* each command. */
2627 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2628 fatal_error ("-pipe not supported");
2629 #endif
2630 argbuf[i] = 0; /* Termination of
2631 command args. */
2632 commands[n_commands].prog = argbuf[i + 1];
2633 commands[n_commands].argv
2634 = &(argbuf.address ())[i + 1];
2635 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2636 X_OK, false);
2637 if (string)
2638 commands[n_commands].argv[0] = string;
2639 n_commands++;
2642 /* If -v, print what we are about to do, and maybe query. */
2644 if (verbose_flag)
2646 /* For help listings, put a blank line between sub-processes. */
2647 if (print_help_list)
2648 fputc ('\n', stderr);
2650 /* Print each piped command as a separate line. */
2651 for (i = 0; i < n_commands; i++)
2653 const char *const *j;
2655 if (verbose_only_flag)
2657 for (j = commands[i].argv; *j; j++)
2659 const char *p;
2660 for (p = *j; *p; ++p)
2661 if (!ISALNUM ((unsigned char) *p)
2662 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2663 break;
2664 if (*p || !*j)
2666 fprintf (stderr, " \"");
2667 for (p = *j; *p; ++p)
2669 if (*p == '"' || *p == '\\' || *p == '$')
2670 fputc ('\\', stderr);
2671 fputc (*p, stderr);
2673 fputc ('"', stderr);
2675 /* If it's empty, print "". */
2676 else if (!**j)
2677 fprintf (stderr, " \"\"");
2678 else
2679 fprintf (stderr, " %s", *j);
2682 else
2683 for (j = commands[i].argv; *j; j++)
2684 /* If it's empty, print "". */
2685 if (!**j)
2686 fprintf (stderr, " \"\"");
2687 else
2688 fprintf (stderr, " %s", *j);
2690 /* Print a pipe symbol after all but the last command. */
2691 if (i + 1 != n_commands)
2692 fprintf (stderr, " |");
2693 fprintf (stderr, "\n");
2695 fflush (stderr);
2696 if (verbose_only_flag != 0)
2698 /* verbose_only_flag should act as if the spec was
2699 executed, so increment execution_count before
2700 returning. This prevents spurious warnings about
2701 unused linker input files, etc. */
2702 execution_count++;
2703 return 0;
2705 #ifdef DEBUG
2706 fnotice (stderr, "\nGo ahead? (y or n) ");
2707 fflush (stderr);
2708 i = getchar ();
2709 if (i != '\n')
2710 while (getchar () != '\n')
2713 if (i != 'y' && i != 'Y')
2714 return 0;
2715 #endif /* DEBUG */
2718 #ifdef ENABLE_VALGRIND_CHECKING
2719 /* Run the each command through valgrind. To simplify prepending the
2720 path to valgrind and the option "-q" (for quiet operation unless
2721 something triggers), we allocate a separate argv array. */
2723 for (i = 0; i < n_commands; i++)
2725 const char **argv;
2726 int argc;
2727 int j;
2729 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2732 argv = XALLOCAVEC (const char *, argc + 3);
2734 argv[0] = VALGRIND_PATH;
2735 argv[1] = "-q";
2736 for (j = 2; j < argc + 2; j++)
2737 argv[j] = commands[i].argv[j - 2];
2738 argv[j] = NULL;
2740 commands[i].argv = argv;
2741 commands[i].prog = argv[0];
2743 #endif
2745 /* Run each piped subprocess. */
2747 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2748 ? PEX_RECORD_TIMES : 0),
2749 progname, temp_filename);
2750 if (pex == NULL)
2751 fatal_error ("pex_init failed: %m");
2753 for (i = 0; i < n_commands; i++)
2755 const char *errmsg;
2756 int err;
2757 const char *string = commands[i].argv[0];
2759 errmsg = pex_run (pex,
2760 ((i + 1 == n_commands ? PEX_LAST : 0)
2761 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2762 string, CONST_CAST (char **, commands[i].argv),
2763 NULL, NULL, &err);
2764 if (errmsg != NULL)
2766 if (err == 0)
2767 fatal_error (errmsg);
2768 else
2770 errno = err;
2771 pfatal_with_name (errmsg);
2775 if (string != commands[i].prog)
2776 free (CONST_CAST (char *, string));
2779 execution_count++;
2781 /* Wait for all the subprocesses to finish. */
2784 int *statuses;
2785 struct pex_time *times = NULL;
2786 int ret_code = 0;
2788 statuses = (int *) alloca (n_commands * sizeof (int));
2789 if (!pex_get_status (pex, n_commands, statuses))
2790 fatal_error ("failed to get exit status: %m");
2792 if (report_times || report_times_to_file)
2794 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2795 if (!pex_get_times (pex, n_commands, times))
2796 fatal_error ("failed to get process times: %m");
2799 pex_free (pex);
2801 for (i = 0; i < n_commands; ++i)
2803 int status = statuses[i];
2805 if (WIFSIGNALED (status))
2807 #ifdef SIGPIPE
2808 /* SIGPIPE is a special case. It happens in -pipe mode
2809 when the compiler dies before the preprocessor is done,
2810 or the assembler dies before the compiler is done.
2811 There's generally been an error already, and this is
2812 just fallout. So don't generate another error unless
2813 we would otherwise have succeeded. */
2814 if (WTERMSIG (status) == SIGPIPE
2815 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2817 signal_count++;
2818 ret_code = -1;
2820 else
2821 #endif
2822 internal_error ("%s (program %s)",
2823 strsignal (WTERMSIG (status)), commands[i].prog);
2825 else if (WIFEXITED (status)
2826 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2828 if (WEXITSTATUS (status) > greatest_status)
2829 greatest_status = WEXITSTATUS (status);
2830 ret_code = -1;
2833 if (report_times || report_times_to_file)
2835 struct pex_time *pt = &times[i];
2836 double ut, st;
2838 ut = ((double) pt->user_seconds
2839 + (double) pt->user_microseconds / 1.0e6);
2840 st = ((double) pt->system_seconds
2841 + (double) pt->system_microseconds / 1.0e6);
2843 if (ut + st != 0)
2845 if (report_times)
2846 fnotice (stderr, "# %s %.2f %.2f\n",
2847 commands[i].prog, ut, st);
2849 if (report_times_to_file)
2851 int c = 0;
2852 const char *const *j;
2854 fprintf (report_times_to_file, "%g %g", ut, st);
2856 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
2858 const char *p;
2859 for (p = *j; *p; ++p)
2860 if (*p == '"' || *p == '\\' || *p == '$'
2861 || ISSPACE (*p))
2862 break;
2864 if (*p)
2866 fprintf (report_times_to_file, " \"");
2867 for (p = *j; *p; ++p)
2869 if (*p == '"' || *p == '\\' || *p == '$')
2870 fputc ('\\', report_times_to_file);
2871 fputc (*p, report_times_to_file);
2873 fputc ('"', report_times_to_file);
2875 else
2876 fprintf (report_times_to_file, " %s", *j);
2879 fputc ('\n', report_times_to_file);
2885 return ret_code;
2889 /* Find all the switches given to us
2890 and make a vector describing them.
2891 The elements of the vector are strings, one per switch given.
2892 If a switch uses following arguments, then the `part1' field
2893 is the switch itself and the `args' field
2894 is a null-terminated vector containing the following arguments.
2895 Bits in the `live_cond' field are:
2896 SWITCH_LIVE to indicate this switch is true in a conditional spec.
2897 SWITCH_FALSE to indicate this switch is overridden by a later switch.
2898 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
2899 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
2900 in all do_spec calls afterwards. Used for %<S from self specs.
2901 The `validated' field is nonzero if any spec has looked at this switch;
2902 if it remains zero at the end of the run, it must be meaningless. */
2904 #define SWITCH_LIVE (1 << 0)
2905 #define SWITCH_FALSE (1 << 1)
2906 #define SWITCH_IGNORE (1 << 2)
2907 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
2908 #define SWITCH_KEEP_FOR_GCC (1 << 4)
2910 struct switchstr
2912 const char *part1;
2913 const char **args;
2914 unsigned int live_cond;
2915 bool known;
2916 bool validated;
2917 bool ordering;
2920 static struct switchstr *switches;
2922 static int n_switches;
2924 static int n_switches_alloc;
2926 /* Set to zero if -fcompare-debug is disabled, positive if it's
2927 enabled and we're running the first compilation, negative if it's
2928 enabled and we're running the second compilation. For most of the
2929 time, it's in the range -1..1, but it can be temporarily set to 2
2930 or 3 to indicate that the -fcompare-debug flags didn't come from
2931 the command-line, but rather from the GCC_COMPARE_DEBUG environment
2932 variable, until a synthesized -fcompare-debug flag is added to the
2933 command line. */
2934 int compare_debug;
2936 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
2937 int compare_debug_second;
2939 /* Set to the flags that should be passed to the second compilation in
2940 a -fcompare-debug compilation. */
2941 const char *compare_debug_opt;
2943 static struct switchstr *switches_debug_check[2];
2945 static int n_switches_debug_check[2];
2947 static int n_switches_alloc_debug_check[2];
2949 static char *debug_check_temp_file[2];
2951 /* Language is one of three things:
2953 1) The name of a real programming language.
2954 2) NULL, indicating that no one has figured out
2955 what it is yet.
2956 3) '*', indicating that the file should be passed
2957 to the linker. */
2958 struct infile
2960 const char *name;
2961 const char *language;
2962 struct compiler *incompiler;
2963 bool compiled;
2964 bool preprocessed;
2967 /* Also a vector of input files specified. */
2969 static struct infile *infiles;
2971 int n_infiles;
2973 static int n_infiles_alloc;
2975 /* True if multiple input files are being compiled to a single
2976 assembly file. */
2978 static bool combine_inputs;
2980 /* This counts the number of libraries added by lang_specific_driver, so that
2981 we can tell if there were any user supplied any files or libraries. */
2983 static int added_libraries;
2985 /* And a vector of corresponding output files is made up later. */
2987 const char **outfiles;
2989 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2991 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2992 is true if we should look for an executable suffix. DO_OBJ
2993 is true if we should look for an object suffix. */
2995 static const char *
2996 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
2997 int do_obj ATTRIBUTE_UNUSED)
2999 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3000 int i;
3001 #endif
3002 int len;
3004 if (name == NULL)
3005 return NULL;
3007 len = strlen (name);
3009 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3010 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
3011 if (do_obj && len > 2
3012 && name[len - 2] == '.'
3013 && name[len - 1] == 'o')
3015 obstack_grow (&obstack, name, len - 2);
3016 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
3017 name = XOBFINISH (&obstack, const char *);
3019 #endif
3021 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
3022 /* If there is no filetype, make it the executable suffix (which includes
3023 the "."). But don't get confused if we have just "-o". */
3024 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
3025 return name;
3027 for (i = len - 1; i >= 0; i--)
3028 if (IS_DIR_SEPARATOR (name[i]))
3029 break;
3031 for (i++; i < len; i++)
3032 if (name[i] == '.')
3033 return name;
3035 obstack_grow (&obstack, name, len);
3036 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
3037 strlen (TARGET_EXECUTABLE_SUFFIX));
3038 name = XOBFINISH (&obstack, const char *);
3039 #endif
3041 return name;
3043 #endif
3045 /* Display the command line switches accepted by gcc. */
3046 static void
3047 display_help (void)
3049 printf (_("Usage: %s [options] file...\n"), progname);
3050 fputs (_("Options:\n"), stdout);
3052 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
3053 fputs (_(" --help Display this information\n"), stdout);
3054 fputs (_(" --target-help Display target specific command line options\n"), stdout);
3055 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
3056 fputs (_(" Display specific types of command line options\n"), stdout);
3057 if (! verbose_flag)
3058 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
3059 fputs (_(" --version Display compiler version information\n"), stdout);
3060 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
3061 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
3062 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
3063 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
3064 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
3065 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
3066 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
3067 fputs (_("\
3068 -print-multiarch Display the target's normalized GNU triplet, used as\n\
3069 a component in the library path\n"), stdout);
3070 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
3071 fputs (_("\
3072 -print-multi-lib Display the mapping between command line options and\n\
3073 multiple library search directories\n"), stdout);
3074 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
3075 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
3076 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
3077 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
3078 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
3079 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
3080 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
3081 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
3082 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
3083 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
3084 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
3085 fputs (_("\
3086 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3087 prefixes to other gcc components\n"), stdout);
3088 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3089 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3090 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3091 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3092 fputs (_("\
3093 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3094 and libraries\n"), stdout);
3095 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3096 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3097 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3098 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3099 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3100 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3101 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3102 fputs (_(" -pie Create a position independent executable\n"), stdout);
3103 fputs (_(" -shared Create a shared library\n"), stdout);
3104 fputs (_("\
3105 -x <language> Specify the language of the following input files\n\
3106 Permissible languages include: c c++ assembler none\n\
3107 'none' means revert to the default behavior of\n\
3108 guessing the language based on the file's extension\n\
3109 "), stdout);
3111 printf (_("\
3112 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3113 passed on to the various sub-processes invoked by %s. In order to pass\n\
3114 other options on to these processes the -W<letter> options must be used.\n\
3115 "), progname);
3117 /* The rest of the options are displayed by invocations of the various
3118 sub-processes. */
3121 static void
3122 add_preprocessor_option (const char *option, int len)
3124 preprocessor_options.safe_push (save_string (option, len));
3127 static void
3128 add_assembler_option (const char *option, int len)
3130 assembler_options.safe_push (save_string (option, len));
3133 static void
3134 add_linker_option (const char *option, int len)
3136 linker_options.safe_push (save_string (option, len));
3139 /* Allocate space for an input file in infiles. */
3141 static void
3142 alloc_infile (void)
3144 if (n_infiles_alloc == 0)
3146 n_infiles_alloc = 16;
3147 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3149 else if (n_infiles_alloc == n_infiles)
3151 n_infiles_alloc *= 2;
3152 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3156 /* Store an input file with the given NAME and LANGUAGE in
3157 infiles. */
3159 static void
3160 add_infile (const char *name, const char *language)
3162 alloc_infile ();
3163 infiles[n_infiles].name = name;
3164 infiles[n_infiles++].language = language;
3167 /* Allocate space for a switch in switches. */
3169 static void
3170 alloc_switch (void)
3172 if (n_switches_alloc == 0)
3174 n_switches_alloc = 16;
3175 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3177 else if (n_switches_alloc == n_switches)
3179 n_switches_alloc *= 2;
3180 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3184 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3185 as validated if VALIDATED and KNOWN if it is an internal switch. */
3187 static void
3188 save_switch (const char *opt, size_t n_args, const char *const *args,
3189 bool validated, bool known)
3191 alloc_switch ();
3192 switches[n_switches].part1 = opt + 1;
3193 if (n_args == 0)
3194 switches[n_switches].args = 0;
3195 else
3197 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3198 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3199 switches[n_switches].args[n_args] = NULL;
3202 switches[n_switches].live_cond = 0;
3203 switches[n_switches].validated = validated;
3204 switches[n_switches].known = known;
3205 switches[n_switches].ordering = 0;
3206 n_switches++;
3209 /* Handle an option DECODED that is unknown to the option-processing
3210 machinery. */
3212 static bool
3213 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3215 const char *opt = decoded->arg;
3216 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3217 && !(decoded->errors & CL_ERR_NEGATIVE))
3219 /* Leave unknown -Wno-* options for the compiler proper, to be
3220 diagnosed only if there are warnings. */
3221 save_switch (decoded->canonical_option[0],
3222 decoded->canonical_option_num_elements - 1,
3223 &decoded->canonical_option[1], false, true);
3224 return false;
3226 if (decoded->opt_index == OPT_SPECIAL_unknown)
3228 /* Give it a chance to define it a a spec file. */
3229 save_switch (decoded->canonical_option[0],
3230 decoded->canonical_option_num_elements - 1,
3231 &decoded->canonical_option[1], false, false);
3232 return false;
3234 else
3235 return true;
3238 /* Handle an option DECODED that is not marked as CL_DRIVER.
3239 LANG_MASK will always be CL_DRIVER. */
3241 static void
3242 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3243 unsigned int lang_mask ATTRIBUTE_UNUSED)
3245 /* At this point, non-driver options are accepted (and expected to
3246 be passed down by specs) unless marked to be rejected by the
3247 driver. Options to be rejected by the driver but accepted by the
3248 compilers proper are treated just like completely unknown
3249 options. */
3250 const struct cl_option *option = &cl_options[decoded->opt_index];
3252 if (option->cl_reject_driver)
3253 error ("unrecognized command line option %qs",
3254 decoded->orig_option_with_args_text);
3255 else
3256 save_switch (decoded->canonical_option[0],
3257 decoded->canonical_option_num_elements - 1,
3258 &decoded->canonical_option[1], false, true);
3261 static const char *spec_lang = 0;
3262 static int last_language_n_infiles;
3264 /* Handle a driver option; arguments and return value as for
3265 handle_option. */
3267 static bool
3268 driver_handle_option (struct gcc_options *opts,
3269 struct gcc_options *opts_set,
3270 const struct cl_decoded_option *decoded,
3271 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3272 location_t loc,
3273 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3274 diagnostic_context *dc)
3276 size_t opt_index = decoded->opt_index;
3277 const char *arg = decoded->arg;
3278 const char *compare_debug_replacement_opt;
3279 int value = decoded->value;
3280 bool validated = false;
3281 bool do_save = true;
3283 gcc_assert (opts == &global_options);
3284 gcc_assert (opts_set == &global_options_set);
3285 gcc_assert (kind == DK_UNSPECIFIED);
3286 gcc_assert (loc == UNKNOWN_LOCATION);
3287 gcc_assert (dc == global_dc);
3289 switch (opt_index)
3291 case OPT_dumpspecs:
3293 struct spec_list *sl;
3294 init_spec ();
3295 for (sl = specs; sl; sl = sl->next)
3296 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3297 if (link_command_spec)
3298 printf ("*link_command:\n%s\n\n", link_command_spec);
3299 exit (0);
3302 case OPT_dumpversion:
3303 printf ("%s\n", spec_version);
3304 exit (0);
3306 case OPT_dumpmachine:
3307 printf ("%s\n", spec_machine);
3308 exit (0);
3310 case OPT__version:
3311 print_version = 1;
3313 /* CPP driver cannot obtain switch from cc1_options. */
3314 if (is_cpp_driver)
3315 add_preprocessor_option ("--version", strlen ("--version"));
3316 add_assembler_option ("--version", strlen ("--version"));
3317 add_linker_option ("--version", strlen ("--version"));
3318 break;
3320 case OPT__help:
3321 print_help_list = 1;
3323 /* CPP driver cannot obtain switch from cc1_options. */
3324 if (is_cpp_driver)
3325 add_preprocessor_option ("--help", 6);
3326 add_assembler_option ("--help", 6);
3327 add_linker_option ("--help", 6);
3328 break;
3330 case OPT__help_:
3331 print_subprocess_help = 2;
3332 break;
3334 case OPT__target_help:
3335 print_subprocess_help = 1;
3337 /* CPP driver cannot obtain switch from cc1_options. */
3338 if (is_cpp_driver)
3339 add_preprocessor_option ("--target-help", 13);
3340 add_assembler_option ("--target-help", 13);
3341 add_linker_option ("--target-help", 13);
3342 break;
3344 case OPT__no_sysroot_suffix:
3345 case OPT_pass_exit_codes:
3346 case OPT_print_search_dirs:
3347 case OPT_print_file_name_:
3348 case OPT_print_prog_name_:
3349 case OPT_print_multi_lib:
3350 case OPT_print_multi_directory:
3351 case OPT_print_sysroot:
3352 case OPT_print_multi_os_directory:
3353 case OPT_print_multiarch:
3354 case OPT_print_sysroot_headers_suffix:
3355 case OPT_time:
3356 case OPT_wrapper:
3357 /* These options set the variables specified in common.opt
3358 automatically, and do not need to be saved for spec
3359 processing. */
3360 do_save = false;
3361 break;
3363 case OPT_print_libgcc_file_name:
3364 print_file_name = "libgcc.a";
3365 do_save = false;
3366 break;
3368 case OPT_fcompare_debug_second:
3369 compare_debug_second = 1;
3370 break;
3372 case OPT_fcompare_debug:
3373 switch (value)
3375 case 0:
3376 compare_debug_replacement_opt = "-fcompare-debug=";
3377 arg = "";
3378 goto compare_debug_with_arg;
3380 case 1:
3381 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3382 arg = "-gtoggle";
3383 goto compare_debug_with_arg;
3385 default:
3386 gcc_unreachable ();
3388 break;
3390 case OPT_fcompare_debug_:
3391 compare_debug_replacement_opt = decoded->canonical_option[0];
3392 compare_debug_with_arg:
3393 gcc_assert (decoded->canonical_option_num_elements == 1);
3394 gcc_assert (arg != NULL);
3395 if (*arg)
3396 compare_debug = 1;
3397 else
3398 compare_debug = -1;
3399 if (compare_debug < 0)
3400 compare_debug_opt = NULL;
3401 else
3402 compare_debug_opt = arg;
3403 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3404 return true;
3406 case OPT_Wa_:
3408 int prev, j;
3409 /* Pass the rest of this option to the assembler. */
3411 /* Split the argument at commas. */
3412 prev = 0;
3413 for (j = 0; arg[j]; j++)
3414 if (arg[j] == ',')
3416 add_assembler_option (arg + prev, j - prev);
3417 prev = j + 1;
3420 /* Record the part after the last comma. */
3421 add_assembler_option (arg + prev, j - prev);
3423 do_save = false;
3424 break;
3426 case OPT_Wp_:
3428 int prev, j;
3429 /* Pass the rest of this option to the preprocessor. */
3431 /* Split the argument at commas. */
3432 prev = 0;
3433 for (j = 0; arg[j]; j++)
3434 if (arg[j] == ',')
3436 add_preprocessor_option (arg + prev, j - prev);
3437 prev = j + 1;
3440 /* Record the part after the last comma. */
3441 add_preprocessor_option (arg + prev, j - prev);
3443 do_save = false;
3444 break;
3446 case OPT_Wl_:
3448 int prev, j;
3449 /* Split the argument at commas. */
3450 prev = 0;
3451 for (j = 0; arg[j]; j++)
3452 if (arg[j] == ',')
3454 add_infile (save_string (arg + prev, j - prev), "*");
3455 prev = j + 1;
3457 /* Record the part after the last comma. */
3458 add_infile (arg + prev, "*");
3460 do_save = false;
3461 break;
3463 case OPT_Xlinker:
3464 add_infile (arg, "*");
3465 do_save = false;
3466 break;
3468 case OPT_Xpreprocessor:
3469 add_preprocessor_option (arg, strlen (arg));
3470 do_save = false;
3471 break;
3473 case OPT_Xassembler:
3474 add_assembler_option (arg, strlen (arg));
3475 do_save = false;
3476 break;
3478 case OPT_l:
3479 /* POSIX allows separation of -l and the lib arg; canonicalize
3480 by concatenating -l with its arg */
3481 add_infile (concat ("-l", arg, NULL), "*");
3482 do_save = false;
3483 break;
3485 case OPT_L:
3486 /* Similarly, canonicalize -L for linkers that may not accept
3487 separate arguments. */
3488 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3489 return true;
3491 case OPT_F:
3492 /* Likewise -F. */
3493 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3494 return true;
3496 case OPT_save_temps:
3497 save_temps_flag = SAVE_TEMPS_CWD;
3498 validated = true;
3499 break;
3501 case OPT_save_temps_:
3502 if (strcmp (arg, "cwd") == 0)
3503 save_temps_flag = SAVE_TEMPS_CWD;
3504 else if (strcmp (arg, "obj") == 0
3505 || strcmp (arg, "object") == 0)
3506 save_temps_flag = SAVE_TEMPS_OBJ;
3507 else
3508 fatal_error ("%qs is an unknown -save-temps option",
3509 decoded->orig_option_with_args_text);
3510 break;
3512 case OPT_no_canonical_prefixes:
3513 /* Already handled as a special case, so ignored here. */
3514 do_save = false;
3515 break;
3517 case OPT_pipe:
3518 validated = true;
3519 /* These options set the variables specified in common.opt
3520 automatically, but do need to be saved for spec
3521 processing. */
3522 break;
3524 case OPT_specs_:
3526 struct user_specs *user = XNEW (struct user_specs);
3528 user->next = (struct user_specs *) 0;
3529 user->filename = arg;
3530 if (user_specs_tail)
3531 user_specs_tail->next = user;
3532 else
3533 user_specs_head = user;
3534 user_specs_tail = user;
3536 validated = true;
3537 break;
3539 case OPT__sysroot_:
3540 target_system_root = arg;
3541 target_system_root_changed = 1;
3542 do_save = false;
3543 break;
3545 case OPT_time_:
3546 if (report_times_to_file)
3547 fclose (report_times_to_file);
3548 report_times_to_file = fopen (arg, "a");
3549 do_save = false;
3550 break;
3552 case OPT____:
3553 /* "-###"
3554 This is similar to -v except that there is no execution
3555 of the commands and the echoed arguments are quoted. It
3556 is intended for use in shell scripts to capture the
3557 driver-generated command line. */
3558 verbose_only_flag++;
3559 verbose_flag = 1;
3560 do_save = false;
3561 break;
3563 case OPT_B:
3565 size_t len = strlen (arg);
3567 /* Catch the case where the user has forgotten to append a
3568 directory separator to the path. Note, they may be using
3569 -B to add an executable name prefix, eg "i386-elf-", in
3570 order to distinguish between multiple installations of
3571 GCC in the same directory. Hence we must check to see
3572 if appending a directory separator actually makes a
3573 valid directory name. */
3574 if (!IS_DIR_SEPARATOR (arg[len - 1])
3575 && is_directory (arg, false))
3577 char *tmp = XNEWVEC (char, len + 2);
3578 strcpy (tmp, arg);
3579 tmp[len] = DIR_SEPARATOR;
3580 tmp[++len] = 0;
3581 arg = tmp;
3584 add_prefix (&exec_prefixes, arg, NULL,
3585 PREFIX_PRIORITY_B_OPT, 0, 0);
3586 add_prefix (&startfile_prefixes, arg, NULL,
3587 PREFIX_PRIORITY_B_OPT, 0, 0);
3588 add_prefix (&include_prefixes, arg, NULL,
3589 PREFIX_PRIORITY_B_OPT, 0, 0);
3591 validated = true;
3592 break;
3594 case OPT_x:
3595 spec_lang = arg;
3596 if (!strcmp (spec_lang, "none"))
3597 /* Suppress the warning if -xnone comes after the last input
3598 file, because alternate command interfaces like g++ might
3599 find it useful to place -xnone after each input file. */
3600 spec_lang = 0;
3601 else
3602 last_language_n_infiles = n_infiles;
3603 do_save = false;
3604 break;
3606 case OPT_o:
3607 have_o = 1;
3608 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3609 arg = convert_filename (arg, ! have_c, 0);
3610 #endif
3611 /* Save the output name in case -save-temps=obj was used. */
3612 save_temps_prefix = xstrdup (arg);
3613 /* On some systems, ld cannot handle "-o" without a space. So
3614 split the option from its argument. */
3615 save_switch ("-o", 1, &arg, validated, true);
3616 return true;
3618 case OPT_static_libgcc:
3619 case OPT_shared_libgcc:
3620 case OPT_static_libgfortran:
3621 case OPT_static_libstdc__:
3622 /* These are always valid, since gcc.c itself understands the
3623 first two, gfortranspec.c understands -static-libgfortran and
3624 g++spec.c understands -static-libstdc++ */
3625 validated = true;
3626 break;
3628 default:
3629 /* Various driver options need no special processing at this
3630 point, having been handled in a prescan above or being
3631 handled by specs. */
3632 break;
3635 if (do_save)
3636 save_switch (decoded->canonical_option[0],
3637 decoded->canonical_option_num_elements - 1,
3638 &decoded->canonical_option[1], validated, true);
3639 return true;
3642 /* Put the driver's standard set of option handlers in *HANDLERS. */
3644 static void
3645 set_option_handlers (struct cl_option_handlers *handlers)
3647 handlers->unknown_option_callback = driver_unknown_option_callback;
3648 handlers->wrong_lang_callback = driver_wrong_lang_callback;
3649 handlers->num_handlers = 3;
3650 handlers->handlers[0].handler = driver_handle_option;
3651 handlers->handlers[0].mask = CL_DRIVER;
3652 handlers->handlers[1].handler = common_handle_option;
3653 handlers->handlers[1].mask = CL_COMMON;
3654 handlers->handlers[2].handler = target_handle_option;
3655 handlers->handlers[2].mask = CL_TARGET;
3658 /* Create the vector `switches' and its contents.
3659 Store its length in `n_switches'. */
3661 static void
3662 process_command (unsigned int decoded_options_count,
3663 struct cl_decoded_option *decoded_options)
3665 const char *temp;
3666 char *temp1;
3667 char *tooldir_prefix, *tooldir_prefix2;
3668 char *(*get_relative_prefix) (const char *, const char *,
3669 const char *) = NULL;
3670 struct cl_option_handlers handlers;
3671 unsigned int j;
3673 gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
3675 n_switches = 0;
3676 n_infiles = 0;
3677 added_libraries = 0;
3679 /* Figure compiler version from version string. */
3681 compiler_version = temp1 = xstrdup (version_string);
3683 for (; *temp1; ++temp1)
3685 if (*temp1 == ' ')
3687 *temp1 = '\0';
3688 break;
3692 /* Handle any -no-canonical-prefixes flag early, to assign the function
3693 that builds relative prefixes. This function creates default search
3694 paths that are needed later in normal option handling. */
3696 for (j = 1; j < decoded_options_count; j++)
3698 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3700 get_relative_prefix = make_relative_prefix_ignore_links;
3701 break;
3704 if (! get_relative_prefix)
3705 get_relative_prefix = make_relative_prefix;
3707 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3708 see if we can create it from the pathname specified in
3709 decoded_options[0].arg. */
3711 gcc_libexec_prefix = standard_libexec_prefix;
3712 #ifndef VMS
3713 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3714 if (!gcc_exec_prefix)
3716 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
3717 standard_bindir_prefix,
3718 standard_exec_prefix);
3719 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
3720 standard_bindir_prefix,
3721 standard_libexec_prefix);
3722 if (gcc_exec_prefix)
3723 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3725 else
3727 /* make_relative_prefix requires a program name, but
3728 GCC_EXEC_PREFIX is typically a directory name with a trailing
3729 / (which is ignored by make_relative_prefix), so append a
3730 program name. */
3731 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3732 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
3733 standard_exec_prefix,
3734 standard_libexec_prefix);
3736 /* The path is unrelocated, so fallback to the original setting. */
3737 if (!gcc_libexec_prefix)
3738 gcc_libexec_prefix = standard_libexec_prefix;
3740 free (tmp_prefix);
3742 #else
3743 #endif
3744 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3745 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3746 or an automatically created GCC_EXEC_PREFIX from
3747 decoded_options[0].arg. */
3749 /* Do language-specific adjustment/addition of flags. */
3750 lang_specific_driver (&decoded_options, &decoded_options_count,
3751 &added_libraries);
3753 if (gcc_exec_prefix)
3755 int len = strlen (gcc_exec_prefix);
3757 if (len > (int) sizeof ("/lib/gcc/") - 1
3758 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3760 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3761 if (IS_DIR_SEPARATOR (*temp)
3762 && filename_ncmp (temp + 1, "lib", 3) == 0
3763 && IS_DIR_SEPARATOR (temp[4])
3764 && filename_ncmp (temp + 5, "gcc", 3) == 0)
3765 len -= sizeof ("/lib/gcc/") - 1;
3768 set_std_prefix (gcc_exec_prefix, len);
3769 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3770 PREFIX_PRIORITY_LAST, 0, 0);
3771 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3772 PREFIX_PRIORITY_LAST, 0, 0);
3775 /* COMPILER_PATH and LIBRARY_PATH have values
3776 that are lists of directory names with colons. */
3778 temp = getenv ("COMPILER_PATH");
3779 if (temp)
3781 const char *startp, *endp;
3782 char *nstore = (char *) alloca (strlen (temp) + 3);
3784 startp = endp = temp;
3785 while (1)
3787 if (*endp == PATH_SEPARATOR || *endp == 0)
3789 strncpy (nstore, startp, endp - startp);
3790 if (endp == startp)
3791 strcpy (nstore, concat (".", dir_separator_str, NULL));
3792 else if (!IS_DIR_SEPARATOR (endp[-1]))
3794 nstore[endp - startp] = DIR_SEPARATOR;
3795 nstore[endp - startp + 1] = 0;
3797 else
3798 nstore[endp - startp] = 0;
3799 add_prefix (&exec_prefixes, nstore, 0,
3800 PREFIX_PRIORITY_LAST, 0, 0);
3801 add_prefix (&include_prefixes, nstore, 0,
3802 PREFIX_PRIORITY_LAST, 0, 0);
3803 if (*endp == 0)
3804 break;
3805 endp = startp = endp + 1;
3807 else
3808 endp++;
3812 temp = getenv (LIBRARY_PATH_ENV);
3813 if (temp && *cross_compile == '0')
3815 const char *startp, *endp;
3816 char *nstore = (char *) alloca (strlen (temp) + 3);
3818 startp = endp = temp;
3819 while (1)
3821 if (*endp == PATH_SEPARATOR || *endp == 0)
3823 strncpy (nstore, startp, endp - startp);
3824 if (endp == startp)
3825 strcpy (nstore, concat (".", dir_separator_str, NULL));
3826 else if (!IS_DIR_SEPARATOR (endp[-1]))
3828 nstore[endp - startp] = DIR_SEPARATOR;
3829 nstore[endp - startp + 1] = 0;
3831 else
3832 nstore[endp - startp] = 0;
3833 add_prefix (&startfile_prefixes, nstore, NULL,
3834 PREFIX_PRIORITY_LAST, 0, 1);
3835 if (*endp == 0)
3836 break;
3837 endp = startp = endp + 1;
3839 else
3840 endp++;
3844 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3845 temp = getenv ("LPATH");
3846 if (temp && *cross_compile == '0')
3848 const char *startp, *endp;
3849 char *nstore = (char *) alloca (strlen (temp) + 3);
3851 startp = endp = temp;
3852 while (1)
3854 if (*endp == PATH_SEPARATOR || *endp == 0)
3856 strncpy (nstore, startp, endp - startp);
3857 if (endp == startp)
3858 strcpy (nstore, concat (".", dir_separator_str, NULL));
3859 else if (!IS_DIR_SEPARATOR (endp[-1]))
3861 nstore[endp - startp] = DIR_SEPARATOR;
3862 nstore[endp - startp + 1] = 0;
3864 else
3865 nstore[endp - startp] = 0;
3866 add_prefix (&startfile_prefixes, nstore, NULL,
3867 PREFIX_PRIORITY_LAST, 0, 1);
3868 if (*endp == 0)
3869 break;
3870 endp = startp = endp + 1;
3872 else
3873 endp++;
3877 /* Process the options and store input files and switches in their
3878 vectors. */
3880 last_language_n_infiles = -1;
3882 set_option_handlers (&handlers);
3884 for (j = 1; j < decoded_options_count; j++)
3886 switch (decoded_options[j].opt_index)
3888 case OPT_S:
3889 case OPT_c:
3890 case OPT_E:
3891 have_c = 1;
3892 break;
3894 if (have_c)
3895 break;
3898 for (j = 1; j < decoded_options_count; j++)
3900 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
3902 const char *arg = decoded_options[j].arg;
3903 const char *p = strrchr (arg, '@');
3904 char *fname;
3905 long offset;
3906 int consumed;
3907 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3908 arg = convert_filename (arg, 0, access (arg, F_OK));
3909 #endif
3910 /* For LTO static archive support we handle input file
3911 specifications that are composed of a filename and
3912 an offset like FNAME@OFFSET. */
3913 if (p
3914 && p != arg
3915 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
3916 && strlen (p) == (unsigned int)consumed)
3918 fname = (char *)xmalloc (p - arg + 1);
3919 memcpy (fname, arg, p - arg);
3920 fname[p - arg] = '\0';
3921 /* Only accept non-stdin and existing FNAME parts, otherwise
3922 try with the full name. */
3923 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
3925 free (fname);
3926 fname = xstrdup (arg);
3929 else
3930 fname = xstrdup (arg);
3932 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
3933 perror_with_name (fname);
3934 else
3935 add_infile (arg, spec_lang);
3937 free (fname);
3938 continue;
3941 read_cmdline_option (&global_options, &global_options_set,
3942 decoded_options + j, UNKNOWN_LOCATION,
3943 CL_DRIVER, &handlers, global_dc);
3946 /* If -save-temps=obj and -o name, create the prefix to use for %b.
3947 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
3948 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
3950 save_temps_length = strlen (save_temps_prefix);
3951 temp = strrchr (lbasename (save_temps_prefix), '.');
3952 if (temp)
3954 save_temps_length -= strlen (temp);
3955 save_temps_prefix[save_temps_length] = '\0';
3959 else if (save_temps_prefix != NULL)
3961 free (save_temps_prefix);
3962 save_temps_prefix = NULL;
3965 if (save_temps_flag && use_pipes)
3967 /* -save-temps overrides -pipe, so that temp files are produced */
3968 if (save_temps_flag)
3969 warning (0, "-pipe ignored because -save-temps specified");
3970 use_pipes = 0;
3973 if (!compare_debug)
3975 const char *gcd = getenv ("GCC_COMPARE_DEBUG");
3977 if (gcd && gcd[0] == '-')
3979 compare_debug = 2;
3980 compare_debug_opt = gcd;
3982 else if (gcd && *gcd && strcmp (gcd, "0"))
3984 compare_debug = 3;
3985 compare_debug_opt = "-gtoggle";
3988 else if (compare_debug < 0)
3990 compare_debug = 0;
3991 gcc_assert (!compare_debug_opt);
3994 /* Set up the search paths. We add directories that we expect to
3995 contain GNU Toolchain components before directories specified by
3996 the machine description so that we will find GNU components (like
3997 the GNU assembler) before those of the host system. */
3999 /* If we don't know where the toolchain has been installed, use the
4000 configured-in locations. */
4001 if (!gcc_exec_prefix)
4003 #ifndef OS2
4004 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
4005 PREFIX_PRIORITY_LAST, 1, 0);
4006 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
4007 PREFIX_PRIORITY_LAST, 2, 0);
4008 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
4009 PREFIX_PRIORITY_LAST, 2, 0);
4010 #endif
4011 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
4012 PREFIX_PRIORITY_LAST, 1, 0);
4015 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
4016 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
4017 dir_separator_str, NULL);
4019 /* Look for tools relative to the location from which the driver is
4020 running, or, if that is not available, the configured prefix. */
4021 tooldir_prefix
4022 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
4023 spec_machine, dir_separator_str,
4024 spec_version, dir_separator_str, tooldir_prefix2, NULL);
4025 free (tooldir_prefix2);
4027 add_prefix (&exec_prefixes,
4028 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
4029 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
4030 add_prefix (&startfile_prefixes,
4031 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
4032 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
4033 free (tooldir_prefix);
4035 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
4036 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
4037 then consider it to relocate with the rest of the GCC installation
4038 if GCC_EXEC_PREFIX is set.
4039 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
4040 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
4042 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
4043 standard_bindir_prefix,
4044 target_system_root);
4045 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
4047 target_system_root = tmp_prefix;
4048 target_system_root_changed = 1;
4051 #endif
4053 /* More prefixes are enabled in main, after we read the specs file
4054 and determine whether this is cross-compilation or not. */
4056 if (n_infiles == last_language_n_infiles && spec_lang != 0)
4057 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
4059 /* Synthesize -fcompare-debug flag from the GCC_COMPARE_DEBUG
4060 environment variable. */
4061 if (compare_debug == 2 || compare_debug == 3)
4063 const char *opt = concat ("-fcompare-debug=", compare_debug_opt, NULL);
4064 save_switch (opt, 0, NULL, false, true);
4065 compare_debug = 1;
4068 /* Ensure we only invoke each subprocess once. */
4069 if (print_subprocess_help || print_help_list || print_version)
4071 n_infiles = 0;
4073 /* Create a dummy input file, so that we can pass
4074 the help option on to the various sub-processes. */
4075 add_infile ("help-dummy", "c");
4078 alloc_switch ();
4079 switches[n_switches].part1 = 0;
4080 alloc_infile ();
4081 infiles[n_infiles].name = 0;
4084 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4085 and place that in the environment. */
4087 static void
4088 set_collect_gcc_options (void)
4090 int i;
4091 int first_time;
4093 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4094 the compiler. */
4095 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4096 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4098 first_time = TRUE;
4099 for (i = 0; (int) i < n_switches; i++)
4101 const char *const *args;
4102 const char *p, *q;
4103 if (!first_time)
4104 obstack_grow (&collect_obstack, " ", 1);
4106 first_time = FALSE;
4108 /* Ignore elided switches. */
4109 if ((switches[i].live_cond
4110 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4111 == SWITCH_IGNORE)
4112 continue;
4114 obstack_grow (&collect_obstack, "'-", 2);
4115 q = switches[i].part1;
4116 while ((p = strchr (q, '\'')))
4118 obstack_grow (&collect_obstack, q, p - q);
4119 obstack_grow (&collect_obstack, "'\\''", 4);
4120 q = ++p;
4122 obstack_grow (&collect_obstack, q, strlen (q));
4123 obstack_grow (&collect_obstack, "'", 1);
4125 for (args = switches[i].args; args && *args; args++)
4127 obstack_grow (&collect_obstack, " '", 2);
4128 q = *args;
4129 while ((p = strchr (q, '\'')))
4131 obstack_grow (&collect_obstack, q, p - q);
4132 obstack_grow (&collect_obstack, "'\\''", 4);
4133 q = ++p;
4135 obstack_grow (&collect_obstack, q, strlen (q));
4136 obstack_grow (&collect_obstack, "'", 1);
4139 obstack_grow (&collect_obstack, "\0", 1);
4140 xputenv (XOBFINISH (&collect_obstack, char *));
4143 /* Process a spec string, accumulating and running commands. */
4145 /* These variables describe the input file name.
4146 input_file_number is the index on outfiles of this file,
4147 so that the output file name can be stored for later use by %o.
4148 input_basename is the start of the part of the input file
4149 sans all directory names, and basename_length is the number
4150 of characters starting there excluding the suffix .c or whatever. */
4152 static const char *gcc_input_filename;
4153 static int input_file_number;
4154 size_t input_filename_length;
4155 static int basename_length;
4156 static int suffixed_basename_length;
4157 static const char *input_basename;
4158 static const char *input_suffix;
4159 #ifndef HOST_LACKS_INODE_NUMBERS
4160 static struct stat input_stat;
4161 #endif
4162 static int input_stat_set;
4164 /* The compiler used to process the current input file. */
4165 static struct compiler *input_file_compiler;
4167 /* These are variables used within do_spec and do_spec_1. */
4169 /* Nonzero if an arg has been started and not yet terminated
4170 (with space, tab or newline). */
4171 static int arg_going;
4173 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4174 is a temporary file name. */
4175 static int delete_this_arg;
4177 /* Nonzero means %w has been seen; the next arg to be terminated
4178 is the output file name of this compilation. */
4179 static int this_is_output_file;
4181 /* Nonzero means %s has been seen; the next arg to be terminated
4182 is the name of a library file and we should try the standard
4183 search dirs for it. */
4184 static int this_is_library_file;
4186 /* Nonzero means %T has been seen; the next arg to be terminated
4187 is the name of a linker script and we should try all of the
4188 standard search dirs for it. If it is found insert a --script
4189 command line switch and then substitute the full path in place,
4190 otherwise generate an error message. */
4191 static int this_is_linker_script;
4193 /* Nonzero means that the input of this command is coming from a pipe. */
4194 static int input_from_pipe;
4196 /* Nonnull means substitute this for any suffix when outputting a switches
4197 arguments. */
4198 static const char *suffix_subst;
4200 /* If there is an argument being accumulated, terminate it and store it. */
4202 static void
4203 end_going_arg (void)
4205 if (arg_going)
4207 const char *string;
4209 obstack_1grow (&obstack, 0);
4210 string = XOBFINISH (&obstack, const char *);
4211 if (this_is_library_file)
4212 string = find_file (string);
4213 if (this_is_linker_script)
4215 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4217 if (full_script_path == NULL)
4219 error ("unable to locate default linker script %qs in the library search paths", string);
4220 /* Script was not found on search path. */
4221 return;
4223 store_arg ("--script", false, false);
4224 string = full_script_path;
4226 store_arg (string, delete_this_arg, this_is_output_file);
4227 if (this_is_output_file)
4228 outfiles[input_file_number] = string;
4229 arg_going = 0;
4234 /* Parse the WRAPPER string which is a comma separated list of the command line
4235 and insert them into the beginning of argbuf. */
4237 static void
4238 insert_wrapper (const char *wrapper)
4240 int n = 0;
4241 int i;
4242 char *buf = xstrdup (wrapper);
4243 char *p = buf;
4244 unsigned int old_length = argbuf.length ();
4248 n++;
4249 while (*p == ',')
4250 p++;
4252 while ((p = strchr (p, ',')) != NULL);
4254 argbuf.safe_grow (old_length + n);
4255 memmove (argbuf.address () + n,
4256 argbuf.address (),
4257 old_length * sizeof (const_char_p));
4259 i = 0;
4260 p = buf;
4263 while (*p == ',')
4265 *p = 0;
4266 p++;
4268 argbuf[i] = p;
4269 i++;
4271 while ((p = strchr (p, ',')) != NULL);
4272 gcc_assert (i == n);
4275 /* Process the spec SPEC and run the commands specified therein.
4276 Returns 0 if the spec is successfully processed; -1 if failed. */
4279 do_spec (const char *spec)
4281 int value;
4283 value = do_spec_2 (spec);
4285 /* Force out any unfinished command.
4286 If -pipe, this forces out the last command if it ended in `|'. */
4287 if (value == 0)
4289 if (argbuf.length () > 0
4290 && !strcmp (argbuf.last (), "|"))
4291 argbuf.pop ();
4293 set_collect_gcc_options ();
4295 if (argbuf.length () > 0)
4296 value = execute ();
4299 return value;
4302 static int
4303 do_spec_2 (const char *spec)
4305 int result;
4307 clear_args ();
4308 arg_going = 0;
4309 delete_this_arg = 0;
4310 this_is_output_file = 0;
4311 this_is_library_file = 0;
4312 this_is_linker_script = 0;
4313 input_from_pipe = 0;
4314 suffix_subst = NULL;
4316 result = do_spec_1 (spec, 0, NULL);
4318 end_going_arg ();
4320 return result;
4324 /* Process the given spec string and add any new options to the end
4325 of the switches/n_switches array. */
4327 static void
4328 do_option_spec (const char *name, const char *spec)
4330 unsigned int i, value_count, value_len;
4331 const char *p, *q, *value;
4332 char *tmp_spec, *tmp_spec_p;
4334 if (configure_default_options[0].name == NULL)
4335 return;
4337 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4338 if (strcmp (configure_default_options[i].name, name) == 0)
4339 break;
4340 if (i == ARRAY_SIZE (configure_default_options))
4341 return;
4343 value = configure_default_options[i].value;
4344 value_len = strlen (value);
4346 /* Compute the size of the final spec. */
4347 value_count = 0;
4348 p = spec;
4349 while ((p = strstr (p, "%(VALUE)")) != NULL)
4351 p ++;
4352 value_count ++;
4355 /* Replace each %(VALUE) by the specified value. */
4356 tmp_spec = (char *) alloca (strlen (spec) + 1
4357 + value_count * (value_len - strlen ("%(VALUE)")));
4358 tmp_spec_p = tmp_spec;
4359 q = spec;
4360 while ((p = strstr (q, "%(VALUE)")) != NULL)
4362 memcpy (tmp_spec_p, q, p - q);
4363 tmp_spec_p = tmp_spec_p + (p - q);
4364 memcpy (tmp_spec_p, value, value_len);
4365 tmp_spec_p += value_len;
4366 q = p + strlen ("%(VALUE)");
4368 strcpy (tmp_spec_p, q);
4370 do_self_spec (tmp_spec);
4373 /* Process the given spec string and add any new options to the end
4374 of the switches/n_switches array. */
4376 static void
4377 do_self_spec (const char *spec)
4379 int i;
4381 do_spec_2 (spec);
4382 do_spec_1 (" ", 0, NULL);
4384 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4385 do_self_specs adds the replacements to switches array, so it shouldn't
4386 be processed afterwards. */
4387 for (i = 0; i < n_switches; i++)
4388 if ((switches[i].live_cond & SWITCH_IGNORE))
4389 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4391 if (argbuf.length () > 0)
4393 const char **argbuf_copy;
4394 struct cl_decoded_option *decoded_options;
4395 struct cl_option_handlers handlers;
4396 unsigned int decoded_options_count;
4397 unsigned int j;
4399 /* Create a copy of argbuf with a dummy argv[0] entry for
4400 decode_cmdline_options_to_array. */
4401 argbuf_copy = XNEWVEC (const char *,
4402 argbuf.length () + 1);
4403 argbuf_copy[0] = "";
4404 memcpy (argbuf_copy + 1, argbuf.address (),
4405 argbuf.length () * sizeof (const char *));
4407 decode_cmdline_options_to_array (argbuf.length () + 1,
4408 argbuf_copy,
4409 CL_DRIVER, &decoded_options,
4410 &decoded_options_count);
4411 free (argbuf_copy);
4413 set_option_handlers (&handlers);
4415 for (j = 1; j < decoded_options_count; j++)
4417 switch (decoded_options[j].opt_index)
4419 case OPT_SPECIAL_input_file:
4420 /* Specs should only generate options, not input
4421 files. */
4422 if (strcmp (decoded_options[j].arg, "-") != 0)
4423 fatal_error ("switch %qs does not start with %<-%>",
4424 decoded_options[j].arg);
4425 else
4426 fatal_error ("spec-generated switch is just %<-%>");
4427 break;
4429 case OPT_fcompare_debug_second:
4430 case OPT_fcompare_debug:
4431 case OPT_fcompare_debug_:
4432 case OPT_o:
4433 /* Avoid duplicate processing of some options from
4434 compare-debug specs; just save them here. */
4435 save_switch (decoded_options[j].canonical_option[0],
4436 (decoded_options[j].canonical_option_num_elements
4437 - 1),
4438 &decoded_options[j].canonical_option[1], false, true);
4439 break;
4441 default:
4442 read_cmdline_option (&global_options, &global_options_set,
4443 decoded_options + j, UNKNOWN_LOCATION,
4444 CL_DRIVER, &handlers, global_dc);
4445 break;
4449 alloc_switch ();
4450 switches[n_switches].part1 = 0;
4454 /* Callback for processing %D and %I specs. */
4456 struct spec_path_info {
4457 const char *option;
4458 const char *append;
4459 size_t append_len;
4460 bool omit_relative;
4461 bool separate_options;
4464 static void *
4465 spec_path (char *path, void *data)
4467 struct spec_path_info *info = (struct spec_path_info *) data;
4468 size_t len = 0;
4469 char save = 0;
4471 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4472 return NULL;
4474 if (info->append_len != 0)
4476 len = strlen (path);
4477 memcpy (path + len, info->append, info->append_len + 1);
4480 if (!is_directory (path, true))
4481 return NULL;
4483 do_spec_1 (info->option, 1, NULL);
4484 if (info->separate_options)
4485 do_spec_1 (" ", 0, NULL);
4487 if (info->append_len == 0)
4489 len = strlen (path);
4490 save = path[len - 1];
4491 if (IS_DIR_SEPARATOR (path[len - 1]))
4492 path[len - 1] = '\0';
4495 do_spec_1 (path, 1, NULL);
4496 do_spec_1 (" ", 0, NULL);
4498 /* Must not damage the original path. */
4499 if (info->append_len == 0)
4500 path[len - 1] = save;
4502 return NULL;
4505 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4506 argument list. */
4508 static void
4509 create_at_file (char **argv)
4511 char *temp_file = make_temp_file ("");
4512 char *at_argument = concat ("@", temp_file, NULL);
4513 FILE *f = fopen (temp_file, "w");
4514 int status;
4516 if (f == NULL)
4517 fatal_error ("could not open temporary response file %s",
4518 temp_file);
4520 status = writeargv (argv, f);
4522 if (status)
4523 fatal_error ("could not write to temporary response file %s",
4524 temp_file);
4526 status = fclose (f);
4528 if (EOF == status)
4529 fatal_error ("could not close temporary response file %s",
4530 temp_file);
4532 store_arg (at_argument, 0, 0);
4534 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4537 /* True if we should compile INFILE. */
4539 static bool
4540 compile_input_file_p (struct infile *infile)
4542 if ((!infile->language) || (infile->language[0] != '*'))
4543 if (infile->incompiler == input_file_compiler)
4544 return true;
4545 return false;
4548 /* Process each member of VEC as a spec. */
4550 static void
4551 do_specs_vec (vec<char_p> vec)
4553 unsigned ix;
4554 char *opt;
4556 FOR_EACH_VEC_ELT (vec, ix, opt)
4558 do_spec_1 (opt, 1, NULL);
4559 /* Make each accumulated option a separate argument. */
4560 do_spec_1 (" ", 0, NULL);
4564 /* Process the sub-spec SPEC as a portion of a larger spec.
4565 This is like processing a whole spec except that we do
4566 not initialize at the beginning and we do not supply a
4567 newline by default at the end.
4568 INSWITCH nonzero means don't process %-sequences in SPEC;
4569 in this case, % is treated as an ordinary character.
4570 This is used while substituting switches.
4571 INSWITCH nonzero also causes SPC not to terminate an argument.
4573 Value is zero unless a line was finished
4574 and the command on that line reported an error. */
4576 static int
4577 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4579 const char *p = spec;
4580 int c;
4581 int i;
4582 int value;
4584 /* If it's an empty string argument to a switch, keep it as is. */
4585 if (inswitch && !*p)
4586 arg_going = 1;
4588 while ((c = *p++))
4589 /* If substituting a switch, treat all chars like letters.
4590 Otherwise, NL, SPC, TAB and % are special. */
4591 switch (inswitch ? 'a' : c)
4593 case '\n':
4594 end_going_arg ();
4596 if (argbuf.length () > 0
4597 && !strcmp (argbuf.last (), "|"))
4599 /* A `|' before the newline means use a pipe here,
4600 but only if -pipe was specified.
4601 Otherwise, execute now and don't pass the `|' as an arg. */
4602 if (use_pipes)
4604 input_from_pipe = 1;
4605 break;
4607 else
4608 argbuf.pop ();
4611 set_collect_gcc_options ();
4613 if (argbuf.length () > 0)
4615 value = execute ();
4616 if (value)
4617 return value;
4619 /* Reinitialize for a new command, and for a new argument. */
4620 clear_args ();
4621 arg_going = 0;
4622 delete_this_arg = 0;
4623 this_is_output_file = 0;
4624 this_is_library_file = 0;
4625 this_is_linker_script = 0;
4626 input_from_pipe = 0;
4627 break;
4629 case '|':
4630 end_going_arg ();
4632 /* Use pipe */
4633 obstack_1grow (&obstack, c);
4634 arg_going = 1;
4635 break;
4637 case '\t':
4638 case ' ':
4639 end_going_arg ();
4641 /* Reinitialize for a new argument. */
4642 delete_this_arg = 0;
4643 this_is_output_file = 0;
4644 this_is_library_file = 0;
4645 this_is_linker_script = 0;
4646 break;
4648 case '%':
4649 switch (c = *p++)
4651 case 0:
4652 fatal_error ("spec %qs invalid", spec);
4654 case 'b':
4655 if (save_temps_length)
4656 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4657 else
4658 obstack_grow (&obstack, input_basename, basename_length);
4659 if (compare_debug < 0)
4660 obstack_grow (&obstack, ".gk", 3);
4661 arg_going = 1;
4662 break;
4664 case 'B':
4665 if (save_temps_length)
4666 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4667 else
4668 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4669 if (compare_debug < 0)
4670 obstack_grow (&obstack, ".gk", 3);
4671 arg_going = 1;
4672 break;
4674 case 'd':
4675 delete_this_arg = 2;
4676 break;
4678 /* Dump out the directories specified with LIBRARY_PATH,
4679 followed by the absolute directories
4680 that we search for startfiles. */
4681 case 'D':
4683 struct spec_path_info info;
4685 info.option = "-L";
4686 info.append_len = 0;
4687 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4688 /* Used on systems which record the specified -L dirs
4689 and use them to search for dynamic linking.
4690 Relative directories always come from -B,
4691 and it is better not to use them for searching
4692 at run time. In particular, stage1 loses. */
4693 info.omit_relative = true;
4694 #else
4695 info.omit_relative = false;
4696 #endif
4697 info.separate_options = false;
4699 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4701 break;
4703 case 'e':
4704 /* %efoo means report an error with `foo' as error message
4705 and don't execute any more commands for this file. */
4707 const char *q = p;
4708 char *buf;
4709 while (*p != 0 && *p != '\n')
4710 p++;
4711 buf = (char *) alloca (p - q + 1);
4712 strncpy (buf, q, p - q);
4713 buf[p - q] = 0;
4714 error ("%s", _(buf));
4715 return -1;
4717 break;
4718 case 'n':
4719 /* %nfoo means report a notice with `foo' on stderr. */
4721 const char *q = p;
4722 char *buf;
4723 while (*p != 0 && *p != '\n')
4724 p++;
4725 buf = (char *) alloca (p - q + 1);
4726 strncpy (buf, q, p - q);
4727 buf[p - q] = 0;
4728 inform (0, "%s", _(buf));
4729 if (*p)
4730 p++;
4732 break;
4734 case 'j':
4736 struct stat st;
4738 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4739 defined, and it is not a directory, and it is
4740 writable, use it. Otherwise, treat this like any
4741 other temporary file. */
4743 if ((!save_temps_flag)
4744 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4745 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4747 obstack_grow (&obstack, HOST_BIT_BUCKET,
4748 strlen (HOST_BIT_BUCKET));
4749 delete_this_arg = 0;
4750 arg_going = 1;
4751 break;
4754 goto create_temp_file;
4755 case '|':
4756 if (use_pipes)
4758 obstack_1grow (&obstack, '-');
4759 delete_this_arg = 0;
4760 arg_going = 1;
4762 /* consume suffix */
4763 while (*p == '.' || ISALNUM ((unsigned char) *p))
4764 p++;
4765 if (p[0] == '%' && p[1] == 'O')
4766 p += 2;
4768 break;
4770 goto create_temp_file;
4771 case 'm':
4772 if (use_pipes)
4774 /* consume suffix */
4775 while (*p == '.' || ISALNUM ((unsigned char) *p))
4776 p++;
4777 if (p[0] == '%' && p[1] == 'O')
4778 p += 2;
4780 break;
4782 goto create_temp_file;
4783 case 'g':
4784 case 'u':
4785 case 'U':
4786 create_temp_file:
4788 struct temp_name *t;
4789 int suffix_length;
4790 const char *suffix = p;
4791 char *saved_suffix = NULL;
4793 while (*p == '.' || ISALNUM ((unsigned char) *p))
4794 p++;
4795 suffix_length = p - suffix;
4796 if (p[0] == '%' && p[1] == 'O')
4798 p += 2;
4799 /* We don't support extra suffix characters after %O. */
4800 if (*p == '.' || ISALNUM ((unsigned char) *p))
4801 fatal_error ("spec %qs has invalid %<%%0%c%>", spec, *p);
4802 if (suffix_length == 0)
4803 suffix = TARGET_OBJECT_SUFFIX;
4804 else
4806 saved_suffix
4807 = XNEWVEC (char, suffix_length
4808 + strlen (TARGET_OBJECT_SUFFIX));
4809 strncpy (saved_suffix, suffix, suffix_length);
4810 strcpy (saved_suffix + suffix_length,
4811 TARGET_OBJECT_SUFFIX);
4813 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4816 if (compare_debug < 0)
4818 suffix = concat (".gk", suffix, NULL);
4819 suffix_length += 3;
4822 /* If -save-temps=obj and -o were specified, use that for the
4823 temp file. */
4824 if (save_temps_length)
4826 char *tmp;
4827 temp_filename_length
4828 = save_temps_length + suffix_length + 1;
4829 tmp = (char *) alloca (temp_filename_length);
4830 memcpy (tmp, save_temps_prefix, save_temps_length);
4831 memcpy (tmp + save_temps_length, suffix, suffix_length);
4832 tmp[save_temps_length + suffix_length] = '\0';
4833 temp_filename = save_string (tmp, save_temps_length
4834 + suffix_length);
4835 obstack_grow (&obstack, temp_filename,
4836 temp_filename_length);
4837 arg_going = 1;
4838 delete_this_arg = 0;
4839 break;
4842 /* If the gcc_input_filename has the same suffix specified
4843 for the %g, %u, or %U, and -save-temps is specified,
4844 we could end up using that file as an intermediate
4845 thus clobbering the user's source file (.e.g.,
4846 gcc -save-temps foo.s would clobber foo.s with the
4847 output of cpp0). So check for this condition and
4848 generate a temp file as the intermediate. */
4850 if (save_temps_flag)
4852 char *tmp;
4853 temp_filename_length = basename_length + suffix_length + 1;
4854 tmp = (char *) alloca (temp_filename_length);
4855 memcpy (tmp, input_basename, basename_length);
4856 memcpy (tmp + basename_length, suffix, suffix_length);
4857 tmp[basename_length + suffix_length] = '\0';
4858 temp_filename = tmp;
4860 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
4862 #ifndef HOST_LACKS_INODE_NUMBERS
4863 struct stat st_temp;
4865 /* Note, set_input() resets input_stat_set to 0. */
4866 if (input_stat_set == 0)
4868 input_stat_set = stat (gcc_input_filename,
4869 &input_stat);
4870 if (input_stat_set >= 0)
4871 input_stat_set = 1;
4874 /* If we have the stat for the gcc_input_filename
4875 and we can do the stat for the temp_filename
4876 then the they could still refer to the same
4877 file if st_dev/st_ino's are the same. */
4878 if (input_stat_set != 1
4879 || stat (temp_filename, &st_temp) < 0
4880 || input_stat.st_dev != st_temp.st_dev
4881 || input_stat.st_ino != st_temp.st_ino)
4882 #else
4883 /* Just compare canonical pathnames. */
4884 char* input_realname = lrealpath (gcc_input_filename);
4885 char* temp_realname = lrealpath (temp_filename);
4886 bool files_differ = filename_cmp (input_realname, temp_realname);
4887 free (input_realname);
4888 free (temp_realname);
4889 if (files_differ)
4890 #endif
4892 temp_filename = save_string (temp_filename,
4893 temp_filename_length + 1);
4894 obstack_grow (&obstack, temp_filename,
4895 temp_filename_length);
4896 arg_going = 1;
4897 delete_this_arg = 0;
4898 break;
4903 /* See if we already have an association of %g/%u/%U and
4904 suffix. */
4905 for (t = temp_names; t; t = t->next)
4906 if (t->length == suffix_length
4907 && strncmp (t->suffix, suffix, suffix_length) == 0
4908 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4909 break;
4911 /* Make a new association if needed. %u and %j
4912 require one. */
4913 if (t == 0 || c == 'u' || c == 'j')
4915 if (t == 0)
4917 t = XNEW (struct temp_name);
4918 t->next = temp_names;
4919 temp_names = t;
4921 t->length = suffix_length;
4922 if (saved_suffix)
4924 t->suffix = saved_suffix;
4925 saved_suffix = NULL;
4927 else
4928 t->suffix = save_string (suffix, suffix_length);
4929 t->unique = (c == 'u' || c == 'U' || c == 'j');
4930 temp_filename = make_temp_file (t->suffix);
4931 temp_filename_length = strlen (temp_filename);
4932 t->filename = temp_filename;
4933 t->filename_length = temp_filename_length;
4936 free (saved_suffix);
4938 obstack_grow (&obstack, t->filename, t->filename_length);
4939 delete_this_arg = 1;
4941 arg_going = 1;
4942 break;
4944 case 'i':
4945 if (combine_inputs)
4947 if (at_file_supplied)
4949 /* We are going to expand `%i' to `@FILE', where FILE
4950 is a newly-created temporary filename. The filenames
4951 that would usually be expanded in place of %o will be
4952 written to the temporary file. */
4953 char **argv;
4954 int n_files = 0;
4955 int j;
4957 for (i = 0; i < n_infiles; i++)
4958 if (compile_input_file_p (&infiles[i]))
4959 n_files++;
4961 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
4963 /* Copy the strings over. */
4964 for (i = 0, j = 0; i < n_infiles; i++)
4965 if (compile_input_file_p (&infiles[i]))
4967 argv[j] = CONST_CAST (char *, infiles[i].name);
4968 infiles[i].compiled = true;
4969 j++;
4971 argv[j] = NULL;
4973 create_at_file (argv);
4975 else
4976 for (i = 0; (int) i < n_infiles; i++)
4977 if (compile_input_file_p (&infiles[i]))
4979 store_arg (infiles[i].name, 0, 0);
4980 infiles[i].compiled = true;
4983 else
4985 obstack_grow (&obstack, gcc_input_filename,
4986 input_filename_length);
4987 arg_going = 1;
4989 break;
4991 case 'I':
4993 struct spec_path_info info;
4995 if (multilib_dir)
4997 do_spec_1 ("-imultilib", 1, NULL);
4998 /* Make this a separate argument. */
4999 do_spec_1 (" ", 0, NULL);
5000 do_spec_1 (multilib_dir, 1, NULL);
5001 do_spec_1 (" ", 0, NULL);
5004 if (multiarch_dir)
5006 do_spec_1 ("-imultiarch", 1, NULL);
5007 /* Make this a separate argument. */
5008 do_spec_1 (" ", 0, NULL);
5009 do_spec_1 (multiarch_dir, 1, NULL);
5010 do_spec_1 (" ", 0, NULL);
5013 if (gcc_exec_prefix)
5015 do_spec_1 ("-iprefix", 1, NULL);
5016 /* Make this a separate argument. */
5017 do_spec_1 (" ", 0, NULL);
5018 do_spec_1 (gcc_exec_prefix, 1, NULL);
5019 do_spec_1 (" ", 0, NULL);
5022 if (target_system_root_changed ||
5023 (target_system_root && target_sysroot_hdrs_suffix))
5025 do_spec_1 ("-isysroot", 1, NULL);
5026 /* Make this a separate argument. */
5027 do_spec_1 (" ", 0, NULL);
5028 do_spec_1 (target_system_root, 1, NULL);
5029 if (target_sysroot_hdrs_suffix)
5030 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
5031 do_spec_1 (" ", 0, NULL);
5034 info.option = "-isystem";
5035 info.append = "include";
5036 info.append_len = strlen (info.append);
5037 info.omit_relative = false;
5038 info.separate_options = true;
5040 for_each_path (&include_prefixes, false, info.append_len,
5041 spec_path, &info);
5043 info.append = "include-fixed";
5044 if (*sysroot_hdrs_suffix_spec)
5045 info.append = concat (info.append, dir_separator_str,
5046 multilib_dir, NULL);
5047 info.append_len = strlen (info.append);
5048 for_each_path (&include_prefixes, false, info.append_len,
5049 spec_path, &info);
5051 break;
5053 case 'o':
5055 int max = n_infiles;
5056 max += lang_specific_extra_outfiles;
5058 if (HAVE_GNU_LD && at_file_supplied)
5060 /* We are going to expand `%o' to `@FILE', where FILE
5061 is a newly-created temporary filename. The filenames
5062 that would usually be expanded in place of %o will be
5063 written to the temporary file. */
5065 char **argv;
5066 int n_files, j;
5068 /* Convert OUTFILES into a form suitable for writeargv. */
5070 /* Determine how many are non-NULL. */
5071 for (n_files = 0, i = 0; i < max; i++)
5072 n_files += outfiles[i] != NULL;
5074 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
5076 /* Copy the strings over. */
5077 for (i = 0, j = 0; i < max; i++)
5078 if (outfiles[i])
5080 argv[j] = CONST_CAST (char *, outfiles[i]);
5081 j++;
5083 argv[j] = NULL;
5085 create_at_file (argv);
5087 else
5088 for (i = 0; i < max; i++)
5089 if (outfiles[i])
5090 store_arg (outfiles[i], 0, 0);
5091 break;
5094 case 'O':
5095 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5096 arg_going = 1;
5097 break;
5099 case 's':
5100 this_is_library_file = 1;
5101 break;
5103 case 'T':
5104 this_is_linker_script = 1;
5105 break;
5107 case 'V':
5108 outfiles[input_file_number] = NULL;
5109 break;
5111 case 'w':
5112 this_is_output_file = 1;
5113 break;
5115 case 'W':
5117 unsigned int cur_index = argbuf.length ();
5118 /* Handle the {...} following the %W. */
5119 if (*p != '{')
5120 fatal_error ("spec %qs has invalid %<%%W%c%>", spec, *p);
5121 p = handle_braces (p + 1);
5122 if (p == 0)
5123 return -1;
5124 end_going_arg ();
5125 /* If any args were output, mark the last one for deletion
5126 on failure. */
5127 if (argbuf.length () != cur_index)
5128 record_temp_file (argbuf.last (), 0, 1);
5129 break;
5132 /* %x{OPTION} records OPTION for %X to output. */
5133 case 'x':
5135 const char *p1 = p;
5136 char *string;
5137 char *opt;
5138 unsigned ix;
5140 /* Skip past the option value and make a copy. */
5141 if (*p != '{')
5142 fatal_error ("spec %qs has invalid %<%%x%c%>", spec, *p);
5143 while (*p++ != '}')
5145 string = save_string (p1 + 1, p - p1 - 2);
5147 /* See if we already recorded this option. */
5148 FOR_EACH_VEC_ELT (linker_options, ix, opt)
5149 if (! strcmp (string, opt))
5151 free (string);
5152 return 0;
5155 /* This option is new; add it. */
5156 add_linker_option (string, strlen (string));
5157 free (string);
5159 break;
5161 /* Dump out the options accumulated previously using %x. */
5162 case 'X':
5163 do_specs_vec (linker_options);
5164 break;
5166 /* Dump out the options accumulated previously using -Wa,. */
5167 case 'Y':
5168 do_specs_vec (assembler_options);
5169 break;
5171 /* Dump out the options accumulated previously using -Wp,. */
5172 case 'Z':
5173 do_specs_vec (preprocessor_options);
5174 break;
5176 /* Here are digits and numbers that just process
5177 a certain constant string as a spec. */
5179 case '1':
5180 value = do_spec_1 (cc1_spec, 0, NULL);
5181 if (value != 0)
5182 return value;
5183 break;
5185 case '2':
5186 value = do_spec_1 (cc1plus_spec, 0, NULL);
5187 if (value != 0)
5188 return value;
5189 break;
5191 case 'a':
5192 value = do_spec_1 (asm_spec, 0, NULL);
5193 if (value != 0)
5194 return value;
5195 break;
5197 case 'A':
5198 value = do_spec_1 (asm_final_spec, 0, NULL);
5199 if (value != 0)
5200 return value;
5201 break;
5203 case 'C':
5205 const char *const spec
5206 = (input_file_compiler->cpp_spec
5207 ? input_file_compiler->cpp_spec
5208 : cpp_spec);
5209 value = do_spec_1 (spec, 0, NULL);
5210 if (value != 0)
5211 return value;
5213 break;
5215 case 'E':
5216 value = do_spec_1 (endfile_spec, 0, NULL);
5217 if (value != 0)
5218 return value;
5219 break;
5221 case 'l':
5222 value = do_spec_1 (link_spec, 0, NULL);
5223 if (value != 0)
5224 return value;
5225 break;
5227 case 'L':
5228 value = do_spec_1 (lib_spec, 0, NULL);
5229 if (value != 0)
5230 return value;
5231 break;
5233 case 'M':
5234 if (multilib_os_dir == NULL)
5235 obstack_1grow (&obstack, '.');
5236 else
5237 obstack_grow (&obstack, multilib_os_dir,
5238 strlen (multilib_os_dir));
5239 break;
5241 case 'G':
5242 value = do_spec_1 (libgcc_spec, 0, NULL);
5243 if (value != 0)
5244 return value;
5245 break;
5247 case 'R':
5248 /* We assume there is a directory
5249 separator at the end of this string. */
5250 if (target_system_root)
5252 obstack_grow (&obstack, target_system_root,
5253 strlen (target_system_root));
5254 if (target_sysroot_suffix)
5255 obstack_grow (&obstack, target_sysroot_suffix,
5256 strlen (target_sysroot_suffix));
5258 break;
5260 case 'S':
5261 value = do_spec_1 (startfile_spec, 0, NULL);
5262 if (value != 0)
5263 return value;
5264 break;
5266 /* Here we define characters other than letters and digits. */
5268 case '{':
5269 p = handle_braces (p);
5270 if (p == 0)
5271 return -1;
5272 break;
5274 case ':':
5275 p = handle_spec_function (p);
5276 if (p == 0)
5277 return -1;
5278 break;
5280 case '%':
5281 obstack_1grow (&obstack, '%');
5282 break;
5284 case '.':
5286 unsigned len = 0;
5288 while (p[len] && p[len] != ' ' && p[len] != '%')
5289 len++;
5290 suffix_subst = save_string (p - 1, len + 1);
5291 p += len;
5293 break;
5295 /* Henceforth ignore the option(s) matching the pattern
5296 after the %<. */
5297 case '<':
5298 case '>':
5300 unsigned len = 0;
5301 int have_wildcard = 0;
5302 int i;
5303 int switch_option;
5305 if (c == '>')
5306 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5307 else
5308 switch_option = SWITCH_IGNORE;
5310 while (p[len] && p[len] != ' ' && p[len] != '\t')
5311 len++;
5313 if (p[len-1] == '*')
5314 have_wildcard = 1;
5316 for (i = 0; i < n_switches; i++)
5317 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5318 && (have_wildcard || switches[i].part1[len] == '\0'))
5320 switches[i].live_cond |= switch_option;
5321 /* User switch be validated from validate_all_switches.
5322 when the definition is seen from the spec file.
5323 If not defined anywhere, will be rejected. */
5324 if (switches[i].known)
5325 switches[i].validated = true;
5328 p += len;
5330 break;
5332 case '*':
5333 if (soft_matched_part)
5335 if (soft_matched_part[0])
5336 do_spec_1 (soft_matched_part, 1, NULL);
5337 do_spec_1 (" ", 0, NULL);
5339 else
5340 /* Catch the case where a spec string contains something like
5341 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5342 hand side of the :. */
5343 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5344 break;
5346 /* Process a string found as the value of a spec given by name.
5347 This feature allows individual machine descriptions
5348 to add and use their own specs. */
5349 case '(':
5351 const char *name = p;
5352 struct spec_list *sl;
5353 int len;
5355 /* The string after the S/P is the name of a spec that is to be
5356 processed. */
5357 while (*p && *p != ')')
5358 p++;
5360 /* See if it's in the list. */
5361 for (len = p - name, sl = specs; sl; sl = sl->next)
5362 if (sl->name_len == len && !strncmp (sl->name, name, len))
5364 name = *(sl->ptr_spec);
5365 #ifdef DEBUG_SPECS
5366 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5367 sl->name, name);
5368 #endif
5369 break;
5372 if (sl)
5374 value = do_spec_1 (name, 0, NULL);
5375 if (value != 0)
5376 return value;
5379 /* Discard the closing paren. */
5380 if (*p)
5381 p++;
5383 break;
5385 default:
5386 error ("spec failure: unrecognized spec option %qc", c);
5387 break;
5389 break;
5391 case '\\':
5392 /* Backslash: treat next character as ordinary. */
5393 c = *p++;
5395 /* Fall through. */
5396 default:
5397 /* Ordinary character: put it into the current argument. */
5398 obstack_1grow (&obstack, c);
5399 arg_going = 1;
5402 /* End of string. If we are processing a spec function, we need to
5403 end any pending argument. */
5404 if (processing_spec_function)
5405 end_going_arg ();
5407 return 0;
5410 /* Look up a spec function. */
5412 static const struct spec_function *
5413 lookup_spec_function (const char *name)
5415 const struct spec_function *sf;
5417 for (sf = static_spec_functions; sf->name != NULL; sf++)
5418 if (strcmp (sf->name, name) == 0)
5419 return sf;
5421 return NULL;
5424 /* Evaluate a spec function. */
5426 static const char *
5427 eval_spec_function (const char *func, const char *args)
5429 const struct spec_function *sf;
5430 const char *funcval;
5432 /* Saved spec processing context. */
5433 vec<const_char_p> save_argbuf;
5435 int save_arg_going;
5436 int save_delete_this_arg;
5437 int save_this_is_output_file;
5438 int save_this_is_library_file;
5439 int save_input_from_pipe;
5440 int save_this_is_linker_script;
5441 const char *save_suffix_subst;
5443 int save_growing_size;
5444 void *save_growing_value = NULL;
5446 sf = lookup_spec_function (func);
5447 if (sf == NULL)
5448 fatal_error ("unknown spec function %qs", func);
5450 /* Push the spec processing context. */
5451 save_argbuf = argbuf;
5453 save_arg_going = arg_going;
5454 save_delete_this_arg = delete_this_arg;
5455 save_this_is_output_file = this_is_output_file;
5456 save_this_is_library_file = this_is_library_file;
5457 save_this_is_linker_script = this_is_linker_script;
5458 save_input_from_pipe = input_from_pipe;
5459 save_suffix_subst = suffix_subst;
5461 /* If we have some object growing now, finalize it so the args and function
5462 eval proceed from a cleared context. This is needed to prevent the first
5463 constructed arg from mistakenly including the growing value. We'll push
5464 this value back on the obstack once the function evaluation is done, to
5465 restore a consistent processing context for our caller. This is fine as
5466 the address of growing objects isn't guaranteed to remain stable until
5467 they are finalized, and we expect this situation to be rare enough for
5468 the extra copy not to be an issue. */
5469 save_growing_size = obstack_object_size (&obstack);
5470 if (save_growing_size > 0)
5471 save_growing_value = obstack_finish (&obstack);
5473 /* Create a new spec processing context, and build the function
5474 arguments. */
5476 alloc_args ();
5477 if (do_spec_2 (args) < 0)
5478 fatal_error ("error in args to spec function %qs", func);
5480 /* argbuf_index is an index for the next argument to be inserted, and
5481 so contains the count of the args already inserted. */
5483 funcval = (*sf->func) (argbuf.length (),
5484 argbuf.address ());
5486 /* Pop the spec processing context. */
5487 argbuf.release ();
5488 argbuf = save_argbuf;
5490 arg_going = save_arg_going;
5491 delete_this_arg = save_delete_this_arg;
5492 this_is_output_file = save_this_is_output_file;
5493 this_is_library_file = save_this_is_library_file;
5494 this_is_linker_script = save_this_is_linker_script;
5495 input_from_pipe = save_input_from_pipe;
5496 suffix_subst = save_suffix_subst;
5498 if (save_growing_size > 0)
5499 obstack_grow (&obstack, save_growing_value, save_growing_size);
5501 return funcval;
5504 /* Handle a spec function call of the form:
5506 %:function(args)
5508 ARGS is processed as a spec in a separate context and split into an
5509 argument vector in the normal fashion. The function returns a string
5510 containing a spec which we then process in the caller's context, or
5511 NULL if no processing is required. */
5513 static const char *
5514 handle_spec_function (const char *p)
5516 char *func, *args;
5517 const char *endp, *funcval;
5518 int count;
5520 processing_spec_function++;
5522 /* Get the function name. */
5523 for (endp = p; *endp != '\0'; endp++)
5525 if (*endp == '(') /* ) */
5526 break;
5527 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5528 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5529 fatal_error ("malformed spec function name");
5531 if (*endp != '(') /* ) */
5532 fatal_error ("no arguments for spec function");
5533 func = save_string (p, endp - p);
5534 p = ++endp;
5536 /* Get the arguments. */
5537 for (count = 0; *endp != '\0'; endp++)
5539 /* ( */
5540 if (*endp == ')')
5542 if (count == 0)
5543 break;
5544 count--;
5546 else if (*endp == '(') /* ) */
5547 count++;
5549 /* ( */
5550 if (*endp != ')')
5551 fatal_error ("malformed spec function arguments");
5552 args = save_string (p, endp - p);
5553 p = ++endp;
5555 /* p now points to just past the end of the spec function expression. */
5557 funcval = eval_spec_function (func, args);
5558 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5559 p = NULL;
5561 free (func);
5562 free (args);
5564 processing_spec_function--;
5566 return p;
5569 /* Inline subroutine of handle_braces. Returns true if the current
5570 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5571 static inline bool
5572 input_suffix_matches (const char *atom, const char *end_atom)
5574 return (input_suffix
5575 && !strncmp (input_suffix, atom, end_atom - atom)
5576 && input_suffix[end_atom - atom] == '\0');
5579 /* Subroutine of handle_braces. Returns true if the current
5580 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
5581 static bool
5582 input_spec_matches (const char *atom, const char *end_atom)
5584 return (input_file_compiler
5585 && input_file_compiler->suffix
5586 && input_file_compiler->suffix[0] != '\0'
5587 && !strncmp (input_file_compiler->suffix + 1, atom,
5588 end_atom - atom)
5589 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5592 /* Subroutine of handle_braces. Returns true if a switch
5593 matching the atom bracketed by ATOM and END_ATOM appeared on the
5594 command line. */
5595 static bool
5596 switch_matches (const char *atom, const char *end_atom, int starred)
5598 int i;
5599 int len = end_atom - atom;
5600 int plen = starred ? len : -1;
5602 for (i = 0; i < n_switches; i++)
5603 if (!strncmp (switches[i].part1, atom, len)
5604 && (starred || switches[i].part1[len] == '\0')
5605 && check_live_switch (i, plen))
5606 return true;
5608 /* Check if a switch with separated form matching the atom.
5609 We check -D and -U switches. */
5610 else if (switches[i].args != 0)
5612 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
5613 && *switches[i].part1 == atom[0])
5615 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
5616 && (starred || (switches[i].part1[1] == '\0'
5617 && switches[i].args[0][len - 1] == '\0'))
5618 && check_live_switch (i, (starred ? 1 : -1)))
5619 return true;
5623 return false;
5626 /* Inline subroutine of handle_braces. Mark all of the switches which
5627 match ATOM (extends to END_ATOM; STARRED indicates whether there
5628 was a star after the atom) for later processing. */
5629 static inline void
5630 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5632 int i;
5633 int len = end_atom - atom;
5634 int plen = starred ? len : -1;
5636 for (i = 0; i < n_switches; i++)
5637 if (!strncmp (switches[i].part1, atom, len)
5638 && (starred || switches[i].part1[len] == '\0')
5639 && check_live_switch (i, plen))
5640 switches[i].ordering = 1;
5643 /* Inline subroutine of handle_braces. Process all the currently
5644 marked switches through give_switch, and clear the marks. */
5645 static inline void
5646 process_marked_switches (void)
5648 int i;
5650 for (i = 0; i < n_switches; i++)
5651 if (switches[i].ordering == 1)
5653 switches[i].ordering = 0;
5654 give_switch (i, 0);
5658 /* Handle a %{ ... } construct. P points just inside the leading {.
5659 Returns a pointer one past the end of the brace block, or 0
5660 if we call do_spec_1 and that returns -1. */
5662 static const char *
5663 handle_braces (const char *p)
5665 const char *atom, *end_atom;
5666 const char *d_atom = NULL, *d_end_atom = NULL;
5667 const char *orig = p;
5669 bool a_is_suffix;
5670 bool a_is_spectype;
5671 bool a_is_starred;
5672 bool a_is_negated;
5673 bool a_matched;
5675 bool a_must_be_last = false;
5676 bool ordered_set = false;
5677 bool disjunct_set = false;
5678 bool disj_matched = false;
5679 bool disj_starred = true;
5680 bool n_way_choice = false;
5681 bool n_way_matched = false;
5683 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5687 if (a_must_be_last)
5688 goto invalid;
5690 /* Scan one "atom" (S in the description above of %{}, possibly
5691 with '!', '.', '@', ',', or '*' modifiers). */
5692 a_matched = false;
5693 a_is_suffix = false;
5694 a_is_starred = false;
5695 a_is_negated = false;
5696 a_is_spectype = false;
5698 SKIP_WHITE();
5699 if (*p == '!')
5700 p++, a_is_negated = true;
5702 SKIP_WHITE();
5703 if (*p == '.')
5704 p++, a_is_suffix = true;
5705 else if (*p == ',')
5706 p++, a_is_spectype = true;
5708 atom = p;
5709 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5710 || *p == ',' || *p == '.' || *p == '@')
5711 p++;
5712 end_atom = p;
5714 if (*p == '*')
5715 p++, a_is_starred = 1;
5717 SKIP_WHITE();
5718 switch (*p)
5720 case '&': case '}':
5721 /* Substitute the switch(es) indicated by the current atom. */
5722 ordered_set = true;
5723 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5724 || a_is_spectype || atom == end_atom)
5725 goto invalid;
5727 mark_matching_switches (atom, end_atom, a_is_starred);
5729 if (*p == '}')
5730 process_marked_switches ();
5731 break;
5733 case '|': case ':':
5734 /* Substitute some text if the current atom appears as a switch
5735 or suffix. */
5736 disjunct_set = true;
5737 if (ordered_set)
5738 goto invalid;
5740 if (atom == end_atom)
5742 if (!n_way_choice || disj_matched || *p == '|'
5743 || a_is_negated || a_is_suffix || a_is_spectype
5744 || a_is_starred)
5745 goto invalid;
5747 /* An empty term may appear as the last choice of an
5748 N-way choice set; it means "otherwise". */
5749 a_must_be_last = true;
5750 disj_matched = !n_way_matched;
5751 disj_starred = false;
5753 else
5755 if ((a_is_suffix || a_is_spectype) && a_is_starred)
5756 goto invalid;
5758 if (!a_is_starred)
5759 disj_starred = false;
5761 /* Don't bother testing this atom if we already have a
5762 match. */
5763 if (!disj_matched && !n_way_matched)
5765 if (a_is_suffix)
5766 a_matched = input_suffix_matches (atom, end_atom);
5767 else if (a_is_spectype)
5768 a_matched = input_spec_matches (atom, end_atom);
5769 else
5770 a_matched = switch_matches (atom, end_atom, a_is_starred);
5772 if (a_matched != a_is_negated)
5774 disj_matched = true;
5775 d_atom = atom;
5776 d_end_atom = end_atom;
5781 if (*p == ':')
5783 /* Found the body, that is, the text to substitute if the
5784 current disjunction matches. */
5785 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5786 disj_matched && !n_way_matched);
5787 if (p == 0)
5788 return 0;
5790 /* If we have an N-way choice, reset state for the next
5791 disjunction. */
5792 if (*p == ';')
5794 n_way_choice = true;
5795 n_way_matched |= disj_matched;
5796 disj_matched = false;
5797 disj_starred = true;
5798 d_atom = d_end_atom = NULL;
5801 break;
5803 default:
5804 goto invalid;
5807 while (*p++ != '}');
5809 return p;
5811 invalid:
5812 fatal_error ("braced spec %qs is invalid at %qc", orig, *p);
5814 #undef SKIP_WHITE
5817 /* Subroutine of handle_braces. Scan and process a brace substitution body
5818 (X in the description of %{} syntax). P points one past the colon;
5819 ATOM and END_ATOM bracket the first atom which was found to be true
5820 (present) in the current disjunction; STARRED indicates whether all
5821 the atoms in the current disjunction were starred (for syntax validation);
5822 MATCHED indicates whether the disjunction matched or not, and therefore
5823 whether or not the body is to be processed through do_spec_1 or just
5824 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5825 returns -1. */
5827 static const char *
5828 process_brace_body (const char *p, const char *atom, const char *end_atom,
5829 int starred, int matched)
5831 const char *body, *end_body;
5832 unsigned int nesting_level;
5833 bool have_subst = false;
5835 /* Locate the closing } or ;, honoring nested braces.
5836 Trim trailing whitespace. */
5837 body = p;
5838 nesting_level = 1;
5839 for (;;)
5841 if (*p == '{')
5842 nesting_level++;
5843 else if (*p == '}')
5845 if (!--nesting_level)
5846 break;
5848 else if (*p == ';' && nesting_level == 1)
5849 break;
5850 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5851 have_subst = true;
5852 else if (*p == '\0')
5853 goto invalid;
5854 p++;
5857 end_body = p;
5858 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5859 end_body--;
5861 if (have_subst && !starred)
5862 goto invalid;
5864 if (matched)
5866 /* Copy the substitution body to permanent storage and execute it.
5867 If have_subst is false, this is a simple matter of running the
5868 body through do_spec_1... */
5869 char *string = save_string (body, end_body - body);
5870 if (!have_subst)
5872 if (do_spec_1 (string, 0, NULL) < 0)
5873 return 0;
5875 else
5877 /* ... but if have_subst is true, we have to process the
5878 body once for each matching switch, with %* set to the
5879 variant part of the switch. */
5880 unsigned int hard_match_len = end_atom - atom;
5881 int i;
5883 for (i = 0; i < n_switches; i++)
5884 if (!strncmp (switches[i].part1, atom, hard_match_len)
5885 && check_live_switch (i, hard_match_len))
5887 if (do_spec_1 (string, 0,
5888 &switches[i].part1[hard_match_len]) < 0)
5889 return 0;
5890 /* Pass any arguments this switch has. */
5891 give_switch (i, 1);
5892 suffix_subst = NULL;
5897 return p;
5899 invalid:
5900 fatal_error ("braced spec body %qs is invalid", body);
5903 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5904 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5905 spec, or -1 if either exact match or %* is used.
5907 A -O switch is obsoleted by a later -O switch. A -f, -g, -m, or -W switch
5908 whose value does not begin with "no-" is obsoleted by the same value
5909 with the "no-", similarly for a switch with the "no-" prefix. */
5911 static int
5912 check_live_switch (int switchnum, int prefix_length)
5914 const char *name = switches[switchnum].part1;
5915 int i;
5917 /* If we already processed this switch and determined if it was
5918 live or not, return our past determination. */
5919 if (switches[switchnum].live_cond != 0)
5920 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
5921 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
5922 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
5923 == 0);
5925 /* In the common case of {<at-most-one-letter>*}, a negating
5926 switch would always match, so ignore that case. We will just
5927 send the conflicting switches to the compiler phase. */
5928 if (prefix_length >= 0 && prefix_length <= 1)
5929 return 1;
5931 /* Now search for duplicate in a manner that depends on the name. */
5932 switch (*name)
5934 case 'O':
5935 for (i = switchnum + 1; i < n_switches; i++)
5936 if (switches[i].part1[0] == 'O')
5938 switches[switchnum].validated = true;
5939 switches[switchnum].live_cond = SWITCH_FALSE;
5940 return 0;
5942 break;
5944 case 'W': case 'f': case 'm': case 'g':
5945 if (! strncmp (name + 1, "no-", 3))
5947 /* We have Xno-YYY, search for XYYY. */
5948 for (i = switchnum + 1; i < n_switches; i++)
5949 if (switches[i].part1[0] == name[0]
5950 && ! strcmp (&switches[i].part1[1], &name[4]))
5952 /* --specs are validated with the validate_switches mechanism. */
5953 if (switches[switchnum].known)
5954 switches[switchnum].validated = true;
5955 switches[switchnum].live_cond = SWITCH_FALSE;
5956 return 0;
5959 else
5961 /* We have XYYY, search for Xno-YYY. */
5962 for (i = switchnum + 1; i < n_switches; i++)
5963 if (switches[i].part1[0] == name[0]
5964 && switches[i].part1[1] == 'n'
5965 && switches[i].part1[2] == 'o'
5966 && switches[i].part1[3] == '-'
5967 && !strcmp (&switches[i].part1[4], &name[1]))
5969 /* --specs are validated with the validate_switches mechanism. */
5970 if (switches[switchnum].known)
5971 switches[switchnum].validated = true;
5972 switches[switchnum].live_cond = SWITCH_FALSE;
5973 return 0;
5976 break;
5979 /* Otherwise the switch is live. */
5980 switches[switchnum].live_cond |= SWITCH_LIVE;
5981 return 1;
5984 /* Pass a switch to the current accumulating command
5985 in the same form that we received it.
5986 SWITCHNUM identifies the switch; it is an index into
5987 the vector of switches gcc received, which is `switches'.
5988 This cannot fail since it never finishes a command line.
5990 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5992 static void
5993 give_switch (int switchnum, int omit_first_word)
5995 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
5996 return;
5998 if (!omit_first_word)
6000 do_spec_1 ("-", 0, NULL);
6001 do_spec_1 (switches[switchnum].part1, 1, NULL);
6004 if (switches[switchnum].args != 0)
6006 const char **p;
6007 for (p = switches[switchnum].args; *p; p++)
6009 const char *arg = *p;
6011 do_spec_1 (" ", 0, NULL);
6012 if (suffix_subst)
6014 unsigned length = strlen (arg);
6015 int dot = 0;
6017 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
6018 if (arg[length] == '.')
6020 (CONST_CAST(char *, arg))[length] = 0;
6021 dot = 1;
6022 break;
6024 do_spec_1 (arg, 1, NULL);
6025 if (dot)
6026 (CONST_CAST(char *, arg))[length] = '.';
6027 do_spec_1 (suffix_subst, 1, NULL);
6029 else
6030 do_spec_1 (arg, 1, NULL);
6034 do_spec_1 (" ", 0, NULL);
6035 switches[switchnum].validated = true;
6038 /* Search for a file named NAME trying various prefixes including the
6039 user's -B prefix and some standard ones.
6040 Return the absolute file name found. If nothing is found, return NAME. */
6042 static const char *
6043 find_file (const char *name)
6045 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
6046 return newname ? newname : name;
6049 /* Determine whether a directory exists. If LINKER, return 0 for
6050 certain fixed names not needed by the linker. */
6052 static int
6053 is_directory (const char *path1, bool linker)
6055 int len1;
6056 char *path;
6057 char *cp;
6058 struct stat st;
6060 /* Ensure the string ends with "/.". The resulting path will be a
6061 directory even if the given path is a symbolic link. */
6062 len1 = strlen (path1);
6063 path = (char *) alloca (3 + len1);
6064 memcpy (path, path1, len1);
6065 cp = path + len1;
6066 if (!IS_DIR_SEPARATOR (cp[-1]))
6067 *cp++ = DIR_SEPARATOR;
6068 *cp++ = '.';
6069 *cp = '\0';
6071 /* Exclude directories that the linker is known to search. */
6072 if (linker
6073 && IS_DIR_SEPARATOR (path[0])
6074 && ((cp - path == 6
6075 && filename_ncmp (path + 1, "lib", 3) == 0)
6076 || (cp - path == 10
6077 && filename_ncmp (path + 1, "usr", 3) == 0
6078 && IS_DIR_SEPARATOR (path[4])
6079 && filename_ncmp (path + 5, "lib", 3) == 0)))
6080 return 0;
6082 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
6085 /* Set up the various global variables to indicate that we're processing
6086 the input file named FILENAME. */
6088 void
6089 set_input (const char *filename)
6091 const char *p;
6093 gcc_input_filename = filename;
6094 input_filename_length = strlen (gcc_input_filename);
6095 input_basename = lbasename (gcc_input_filename);
6097 /* Find a suffix starting with the last period,
6098 and set basename_length to exclude that suffix. */
6099 basename_length = strlen (input_basename);
6100 suffixed_basename_length = basename_length;
6101 p = input_basename + basename_length;
6102 while (p != input_basename && *p != '.')
6103 --p;
6104 if (*p == '.' && p != input_basename)
6106 basename_length = p - input_basename;
6107 input_suffix = p + 1;
6109 else
6110 input_suffix = "";
6112 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6113 we will need to do a stat on the gcc_input_filename. The
6114 INPUT_STAT_SET signals that the stat is needed. */
6115 input_stat_set = 0;
6118 /* On fatal signals, delete all the temporary files. */
6120 static void
6121 fatal_signal (int signum)
6123 signal (signum, SIG_DFL);
6124 delete_failure_queue ();
6125 delete_temp_files ();
6126 /* Get the same signal again, this time not handled,
6127 so its normal effect occurs. */
6128 kill (getpid (), signum);
6131 /* Compare the contents of the two files named CMPFILE[0] and
6132 CMPFILE[1]. Return zero if they're identical, nonzero
6133 otherwise. */
6135 static int
6136 compare_files (char *cmpfile[])
6138 int ret = 0;
6139 FILE *temp[2] = { NULL, NULL };
6140 int i;
6142 #if HAVE_MMAP_FILE
6144 size_t length[2];
6145 void *map[2] = { NULL, NULL };
6147 for (i = 0; i < 2; i++)
6149 struct stat st;
6151 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6153 error ("%s: could not determine length of compare-debug file %s",
6154 gcc_input_filename, cmpfile[i]);
6155 ret = 1;
6156 break;
6159 length[i] = st.st_size;
6162 if (!ret && length[0] != length[1])
6164 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
6165 ret = 1;
6168 if (!ret)
6169 for (i = 0; i < 2; i++)
6171 int fd = open (cmpfile[i], O_RDONLY);
6172 if (fd < 0)
6174 error ("%s: could not open compare-debug file %s",
6175 gcc_input_filename, cmpfile[i]);
6176 ret = 1;
6177 break;
6180 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
6181 close (fd);
6183 if (map[i] == (void *) MAP_FAILED)
6185 ret = -1;
6186 break;
6190 if (!ret)
6192 if (memcmp (map[0], map[1], length[0]) != 0)
6194 error ("%s: -fcompare-debug failure", gcc_input_filename);
6195 ret = 1;
6199 for (i = 0; i < 2; i++)
6200 if (map[i])
6201 munmap ((caddr_t) map[i], length[i]);
6203 if (ret >= 0)
6204 return ret;
6206 ret = 0;
6208 #endif
6210 for (i = 0; i < 2; i++)
6212 temp[i] = fopen (cmpfile[i], "r");
6213 if (!temp[i])
6215 error ("%s: could not open compare-debug file %s",
6216 gcc_input_filename, cmpfile[i]);
6217 ret = 1;
6218 break;
6222 if (!ret && temp[0] && temp[1])
6223 for (;;)
6225 int c0, c1;
6226 c0 = fgetc (temp[0]);
6227 c1 = fgetc (temp[1]);
6229 if (c0 != c1)
6231 error ("%s: -fcompare-debug failure",
6232 gcc_input_filename);
6233 ret = 1;
6234 break;
6237 if (c0 == EOF)
6238 break;
6241 for (i = 1; i >= 0; i--)
6243 if (temp[i])
6244 fclose (temp[i]);
6247 return ret;
6250 extern int main (int, char **);
6253 main (int argc, char **argv)
6255 size_t i;
6256 int value;
6257 int linker_was_run = 0;
6258 int lang_n_infiles = 0;
6259 int num_linker_inputs = 0;
6260 char *explicit_link_files;
6261 char *specs_file;
6262 char *lto_wrapper_file;
6263 const char *p;
6264 struct user_specs *uptr;
6265 char **old_argv = argv;
6266 struct cl_decoded_option *decoded_options;
6267 unsigned int decoded_options_count;
6269 p = argv[0] + strlen (argv[0]);
6270 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6271 --p;
6272 progname = p;
6274 xmalloc_set_program_name (progname);
6276 expandargv (&argc, &argv);
6278 /* Determine if any expansions were made. */
6279 if (argv != old_argv)
6280 at_file_supplied = true;
6282 /* Register the language-independent parameters. */
6283 global_init_params ();
6284 finish_params ();
6286 init_options_struct (&global_options, &global_options_set);
6288 decode_cmdline_options_to_array (argc, CONST_CAST2 (const char **, char **,
6289 argv),
6290 CL_DRIVER,
6291 &decoded_options, &decoded_options_count);
6293 /* Unlock the stdio streams. */
6294 unlock_std_streams ();
6296 gcc_init_libintl ();
6298 diagnostic_initialize (global_dc, 0);
6300 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6301 /* Perform host dependent initialization when needed. */
6302 GCC_DRIVER_HOST_INITIALIZATION;
6303 #endif
6305 if (atexit (delete_temp_files) != 0)
6306 fatal_error ("atexit failed");
6308 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6309 signal (SIGINT, fatal_signal);
6310 #ifdef SIGHUP
6311 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6312 signal (SIGHUP, fatal_signal);
6313 #endif
6314 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6315 signal (SIGTERM, fatal_signal);
6316 #ifdef SIGPIPE
6317 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6318 signal (SIGPIPE, fatal_signal);
6319 #endif
6320 #ifdef SIGCHLD
6321 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6322 receive the signal. A different setting is inheritable */
6323 signal (SIGCHLD, SIG_DFL);
6324 #endif
6326 /* Parsing and gimplification sometimes need quite large stack.
6327 Increase stack size limits if possible. */
6328 stack_limit_increase (64 * 1024 * 1024);
6330 /* Allocate the argument vector. */
6331 alloc_args ();
6333 obstack_init (&obstack);
6335 /* Build multilib_select, et. al from the separate lines that make up each
6336 multilib selection. */
6338 const char *const *q = multilib_raw;
6339 int need_space;
6341 obstack_init (&multilib_obstack);
6342 while ((p = *q++) != (char *) 0)
6343 obstack_grow (&multilib_obstack, p, strlen (p));
6345 obstack_1grow (&multilib_obstack, 0);
6346 multilib_select = XOBFINISH (&multilib_obstack, const char *);
6348 q = multilib_matches_raw;
6349 while ((p = *q++) != (char *) 0)
6350 obstack_grow (&multilib_obstack, p, strlen (p));
6352 obstack_1grow (&multilib_obstack, 0);
6353 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6355 q = multilib_exclusions_raw;
6356 while ((p = *q++) != (char *) 0)
6357 obstack_grow (&multilib_obstack, p, strlen (p));
6359 obstack_1grow (&multilib_obstack, 0);
6360 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6362 q = multilib_reuse_raw;
6363 while ((p = *q++) != (char *) 0)
6364 obstack_grow (&multilib_obstack, p, strlen (p));
6366 obstack_1grow (&multilib_obstack, 0);
6367 multilib_reuse = XOBFINISH (&multilib_obstack, const char *);
6369 need_space = FALSE;
6370 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6372 if (need_space)
6373 obstack_1grow (&multilib_obstack, ' ');
6374 obstack_grow (&multilib_obstack,
6375 multilib_defaults_raw[i],
6376 strlen (multilib_defaults_raw[i]));
6377 need_space = TRUE;
6380 obstack_1grow (&multilib_obstack, 0);
6381 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6384 #ifdef INIT_ENVIRONMENT
6385 /* Set up any other necessary machine specific environment variables. */
6386 xputenv (INIT_ENVIRONMENT);
6387 #endif
6389 /* Make a table of what switches there are (switches, n_switches).
6390 Make a table of specified input files (infiles, n_infiles).
6391 Decode switches that are handled locally. */
6393 process_command (decoded_options_count, decoded_options);
6395 /* Initialize the vector of specs to just the default.
6396 This means one element containing 0s, as a terminator. */
6398 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
6399 memcpy (compilers, default_compilers, sizeof default_compilers);
6400 n_compilers = n_default_compilers;
6402 /* Read specs from a file if there is one. */
6404 machine_suffix = concat (spec_machine, dir_separator_str,
6405 spec_version, dir_separator_str, NULL);
6406 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6408 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
6409 /* Read the specs file unless it is a default one. */
6410 if (specs_file != 0 && strcmp (specs_file, "specs"))
6411 read_specs (specs_file, true, false);
6412 else
6413 init_spec ();
6415 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6416 for any override of as, ld and libraries. */
6417 specs_file = (char *) alloca (strlen (standard_exec_prefix)
6418 + strlen (just_machine_suffix) + sizeof ("specs"));
6420 strcpy (specs_file, standard_exec_prefix);
6421 strcat (specs_file, just_machine_suffix);
6422 strcat (specs_file, "specs");
6423 if (access (specs_file, R_OK) == 0)
6424 read_specs (specs_file, true, false);
6426 /* Process any configure-time defaults specified for the command line
6427 options, via OPTION_DEFAULT_SPECS. */
6428 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6429 do_option_spec (option_default_specs[i].name,
6430 option_default_specs[i].spec);
6432 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6433 of the command line. */
6435 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6436 do_self_spec (driver_self_specs[i]);
6438 /* If not cross-compiling, look for executables in the standard
6439 places. */
6440 if (*cross_compile == '0')
6442 if (*md_exec_prefix)
6444 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6445 PREFIX_PRIORITY_LAST, 0, 0);
6449 /* Process sysroot_suffix_spec. */
6450 if (*sysroot_suffix_spec != 0
6451 && !no_sysroot_suffix
6452 && do_spec_2 (sysroot_suffix_spec) == 0)
6454 if (argbuf.length () > 1)
6455 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
6456 else if (argbuf.length () == 1)
6457 target_sysroot_suffix = xstrdup (argbuf.last ());
6460 #ifdef HAVE_LD_SYSROOT
6461 /* Pass the --sysroot option to the linker, if it supports that. If
6462 there is a sysroot_suffix_spec, it has already been processed by
6463 this point, so target_system_root really is the system root we
6464 should be using. */
6465 if (target_system_root)
6467 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6468 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6469 set_spec ("link", XOBFINISH (&obstack, const char *), false);
6471 #endif
6473 /* Process sysroot_hdrs_suffix_spec. */
6474 if (*sysroot_hdrs_suffix_spec != 0
6475 && !no_sysroot_suffix
6476 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6478 if (argbuf.length () > 1)
6479 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
6480 else if (argbuf.length () == 1)
6481 target_sysroot_hdrs_suffix = xstrdup (argbuf.last ());
6484 /* Look for startfiles in the standard places. */
6485 if (*startfile_prefix_spec != 0
6486 && do_spec_2 (startfile_prefix_spec) == 0
6487 && do_spec_1 (" ", 0, NULL) == 0)
6489 const char *arg;
6490 int ndx;
6491 FOR_EACH_VEC_ELT (argbuf, ndx, arg)
6492 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
6493 PREFIX_PRIORITY_LAST, 0, 1);
6495 /* We should eventually get rid of all these and stick to
6496 startfile_prefix_spec exclusively. */
6497 else if (*cross_compile == '0' || target_system_root)
6499 if (*md_startfile_prefix)
6500 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6501 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6503 if (*md_startfile_prefix_1)
6504 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6505 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6507 /* If standard_startfile_prefix is relative, base it on
6508 standard_exec_prefix. This lets us move the installed tree
6509 as a unit. If GCC_EXEC_PREFIX is defined, base
6510 standard_startfile_prefix on that as well.
6512 If the prefix is relative, only search it for native compilers;
6513 otherwise we will search a directory containing host libraries. */
6514 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6515 add_sysrooted_prefix (&startfile_prefixes,
6516 standard_startfile_prefix, "BINUTILS",
6517 PREFIX_PRIORITY_LAST, 0, 1);
6518 else if (*cross_compile == '0')
6520 add_prefix (&startfile_prefixes,
6521 concat (gcc_exec_prefix
6522 ? gcc_exec_prefix : standard_exec_prefix,
6523 machine_suffix,
6524 standard_startfile_prefix, NULL),
6525 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6528 /* Sysrooted prefixes are relocated because target_system_root is
6529 also relocated by gcc_exec_prefix. */
6530 if (*standard_startfile_prefix_1)
6531 add_sysrooted_prefix (&startfile_prefixes,
6532 standard_startfile_prefix_1, "BINUTILS",
6533 PREFIX_PRIORITY_LAST, 0, 1);
6534 if (*standard_startfile_prefix_2)
6535 add_sysrooted_prefix (&startfile_prefixes,
6536 standard_startfile_prefix_2, "BINUTILS",
6537 PREFIX_PRIORITY_LAST, 0, 1);
6540 /* Process any user specified specs in the order given on the command
6541 line. */
6542 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6544 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6545 R_OK, true);
6546 read_specs (filename ? filename : uptr->filename, false, true);
6549 /* Process any user self specs. */
6551 struct spec_list *sl;
6552 for (sl = specs; sl; sl = sl->next)
6553 if (sl->name_len == sizeof "self_spec" - 1
6554 && !strcmp (sl->name, "self_spec"))
6555 do_self_spec (*sl->ptr_spec);
6558 if (compare_debug)
6560 enum save_temps save;
6562 if (!compare_debug_second)
6564 n_switches_debug_check[1] = n_switches;
6565 n_switches_alloc_debug_check[1] = n_switches_alloc;
6566 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
6567 n_switches_alloc);
6569 do_self_spec ("%:compare-debug-self-opt()");
6570 n_switches_debug_check[0] = n_switches;
6571 n_switches_alloc_debug_check[0] = n_switches_alloc;
6572 switches_debug_check[0] = switches;
6574 n_switches = n_switches_debug_check[1];
6575 n_switches_alloc = n_switches_alloc_debug_check[1];
6576 switches = switches_debug_check[1];
6579 /* Avoid crash when computing %j in this early. */
6580 save = save_temps_flag;
6581 save_temps_flag = SAVE_TEMPS_NONE;
6583 compare_debug = -compare_debug;
6584 do_self_spec ("%:compare-debug-self-opt()");
6586 save_temps_flag = save;
6588 if (!compare_debug_second)
6590 n_switches_debug_check[1] = n_switches;
6591 n_switches_alloc_debug_check[1] = n_switches_alloc;
6592 switches_debug_check[1] = switches;
6593 compare_debug = -compare_debug;
6594 n_switches = n_switches_debug_check[0];
6595 n_switches_alloc = n_switches_debug_check[0];
6596 switches = switches_debug_check[0];
6601 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6602 if (gcc_exec_prefix)
6603 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6604 spec_version, dir_separator_str, NULL);
6606 /* Now we have the specs.
6607 Set the `valid' bits for switches that match anything in any spec. */
6609 validate_all_switches ();
6611 /* Now that we have the switches and the specs, set
6612 the subdirectory based on the options. */
6613 set_multilib_dir ();
6615 /* Set up to remember the pathname of gcc and any options
6616 needed for collect. We use argv[0] instead of progname because
6617 we need the complete pathname. */
6618 obstack_init (&collect_obstack);
6619 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6620 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6621 xputenv (XOBFINISH (&collect_obstack, char *));
6623 /* Set up to remember the pathname of the lto wrapper. */
6625 if (have_c)
6626 lto_wrapper_file = NULL;
6627 else
6628 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
6629 X_OK, false);
6630 if (lto_wrapper_file)
6632 lto_wrapper_file = convert_white_space (lto_wrapper_file);
6633 lto_wrapper_spec = lto_wrapper_file;
6634 obstack_init (&collect_obstack);
6635 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
6636 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
6637 obstack_grow (&collect_obstack, lto_wrapper_spec,
6638 strlen (lto_wrapper_spec) + 1);
6639 xputenv (XOBFINISH (&collect_obstack, char *));
6642 /* Reject switches that no pass was interested in. */
6644 for (i = 0; (int) i < n_switches; i++)
6645 if (! switches[i].validated)
6646 error ("unrecognized command line option %<-%s%>", switches[i].part1);
6648 /* Obey some of the options. */
6650 if (print_search_dirs)
6652 printf (_("install: %s%s\n"),
6653 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
6654 gcc_exec_prefix ? "" : machine_suffix);
6655 printf (_("programs: %s\n"),
6656 build_search_list (&exec_prefixes, "", false, false));
6657 printf (_("libraries: %s\n"),
6658 build_search_list (&startfile_prefixes, "", false, true));
6659 return (0);
6662 if (print_file_name)
6664 printf ("%s\n", find_file (print_file_name));
6665 return (0);
6668 if (print_prog_name)
6670 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6671 printf ("%s\n", (newname ? newname : print_prog_name));
6672 return (0);
6675 if (print_multi_lib)
6677 print_multilib_info ();
6678 return (0);
6681 if (print_multi_directory)
6683 if (multilib_dir == NULL)
6684 printf (".\n");
6685 else
6686 printf ("%s\n", multilib_dir);
6687 return (0);
6690 if (print_multiarch)
6692 if (multiarch_dir == NULL)
6693 printf ("\n");
6694 else
6695 printf ("%s\n", multiarch_dir);
6696 return (0);
6699 if (print_sysroot)
6701 if (target_system_root)
6703 if (target_sysroot_suffix)
6704 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
6705 else
6706 printf ("%s\n", target_system_root);
6708 return (0);
6711 if (print_multi_os_directory)
6713 if (multilib_os_dir == NULL)
6714 printf (".\n");
6715 else
6716 printf ("%s\n", multilib_os_dir);
6717 return (0);
6720 if (print_sysroot_headers_suffix)
6722 if (*sysroot_hdrs_suffix_spec)
6724 printf("%s\n", (target_sysroot_hdrs_suffix
6725 ? target_sysroot_hdrs_suffix
6726 : ""));
6727 return (0);
6729 else
6730 /* The error status indicates that only one set of fixed
6731 headers should be built. */
6732 fatal_error ("not configured with sysroot headers suffix");
6735 if (print_help_list)
6737 display_help ();
6739 if (! verbose_flag)
6741 printf (_("\nFor bug reporting instructions, please see:\n"));
6742 printf ("%s.\n", bug_report_url);
6744 return (0);
6747 /* We do not exit here. Instead we have created a fake input file
6748 called 'help-dummy' which needs to be compiled, and we pass this
6749 on the various sub-processes, along with the --help switch.
6750 Ensure their output appears after ours. */
6751 fputc ('\n', stdout);
6752 fflush (stdout);
6755 if (print_version)
6757 printf (_("%s %s%s\n"), progname, pkgversion_string,
6758 version_string);
6759 printf ("Copyright %s 2013 Free Software Foundation, Inc.\n",
6760 _("(C)"));
6761 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
6762 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
6763 stdout);
6764 if (! verbose_flag)
6765 return 0;
6767 /* We do not exit here. We use the same mechanism of --help to print
6768 the version of the sub-processes. */
6769 fputc ('\n', stdout);
6770 fflush (stdout);
6773 if (verbose_flag)
6775 int n;
6776 const char *thrmod;
6778 fnotice (stderr, "Target: %s\n", spec_machine);
6779 fnotice (stderr, "Configured with: %s\n", configuration_arguments);
6781 #ifdef THREAD_MODEL_SPEC
6782 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6783 but there's no point in doing all this processing just to get
6784 thread_model back. */
6785 obstack_init (&obstack);
6786 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6787 obstack_1grow (&obstack, '\0');
6788 thrmod = XOBFINISH (&obstack, const char *);
6789 #else
6790 thrmod = thread_model;
6791 #endif
6793 fnotice (stderr, "Thread model: %s\n", thrmod);
6795 /* compiler_version is truncated at the first space when initialized
6796 from version string, so truncate version_string at the first space
6797 before comparing. */
6798 for (n = 0; version_string[n]; n++)
6799 if (version_string[n] == ' ')
6800 break;
6802 if (! strncmp (version_string, compiler_version, n)
6803 && compiler_version[n] == 0)
6804 fnotice (stderr, "gcc version %s %s\n", version_string,
6805 pkgversion_string);
6806 else
6807 fnotice (stderr, "gcc driver version %s %sexecuting gcc version %s\n",
6808 version_string, pkgversion_string, compiler_version);
6810 if (n_infiles == 0)
6811 return (0);
6814 if (n_infiles == added_libraries)
6815 fatal_error ("no input files");
6817 if (seen_error ())
6818 goto out;
6820 /* Make a place to record the compiler output file names
6821 that correspond to the input files. */
6823 i = n_infiles;
6824 i += lang_specific_extra_outfiles;
6825 outfiles = XCNEWVEC (const char *, i);
6827 /* Record which files were specified explicitly as link input. */
6829 explicit_link_files = XCNEWVEC (char, n_infiles);
6831 combine_inputs = have_o || flag_wpa;
6833 for (i = 0; (int) i < n_infiles; i++)
6835 const char *name = infiles[i].name;
6836 struct compiler *compiler = lookup_compiler (name,
6837 strlen (name),
6838 infiles[i].language);
6840 if (compiler && !(compiler->combinable))
6841 combine_inputs = false;
6843 if (lang_n_infiles > 0 && compiler != input_file_compiler
6844 && infiles[i].language && infiles[i].language[0] != '*')
6845 infiles[i].incompiler = compiler;
6846 else if (compiler)
6848 lang_n_infiles++;
6849 input_file_compiler = compiler;
6850 infiles[i].incompiler = compiler;
6852 else
6854 /* Since there is no compiler for this input file, assume it is a
6855 linker file. */
6856 explicit_link_files[i] = 1;
6857 infiles[i].incompiler = NULL;
6859 infiles[i].compiled = false;
6860 infiles[i].preprocessed = false;
6863 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
6864 fatal_error ("cannot specify -o with -c, -S or -E with multiple files");
6866 for (i = 0; (int) i < n_infiles; i++)
6868 int this_file_error = 0;
6870 /* Tell do_spec what to substitute for %i. */
6872 input_file_number = i;
6873 set_input (infiles[i].name);
6875 if (infiles[i].compiled)
6876 continue;
6878 /* Use the same thing in %o, unless cp->spec says otherwise. */
6880 outfiles[i] = gcc_input_filename;
6882 /* Figure out which compiler from the file's suffix. */
6884 input_file_compiler
6885 = lookup_compiler (infiles[i].name, input_filename_length,
6886 infiles[i].language);
6888 if (input_file_compiler)
6890 /* Ok, we found an applicable compiler. Run its spec. */
6892 if (input_file_compiler->spec[0] == '#')
6894 error ("%s: %s compiler not installed on this system",
6895 gcc_input_filename, &input_file_compiler->spec[1]);
6896 this_file_error = 1;
6898 else
6900 if (compare_debug)
6902 free (debug_check_temp_file[0]);
6903 debug_check_temp_file[0] = NULL;
6905 free (debug_check_temp_file[1]);
6906 debug_check_temp_file[1] = NULL;
6909 value = do_spec (input_file_compiler->spec);
6910 infiles[i].compiled = true;
6911 if (value < 0)
6912 this_file_error = 1;
6913 else if (compare_debug && debug_check_temp_file[0])
6915 if (verbose_flag)
6916 inform (0, "recompiling with -fcompare-debug");
6918 compare_debug = -compare_debug;
6919 n_switches = n_switches_debug_check[1];
6920 n_switches_alloc = n_switches_alloc_debug_check[1];
6921 switches = switches_debug_check[1];
6923 value = do_spec (input_file_compiler->spec);
6925 compare_debug = -compare_debug;
6926 n_switches = n_switches_debug_check[0];
6927 n_switches_alloc = n_switches_alloc_debug_check[0];
6928 switches = switches_debug_check[0];
6930 if (value < 0)
6932 error ("during -fcompare-debug recompilation");
6933 this_file_error = 1;
6936 gcc_assert (debug_check_temp_file[1]
6937 && filename_cmp (debug_check_temp_file[0],
6938 debug_check_temp_file[1]));
6940 if (verbose_flag)
6941 inform (0, "comparing final insns dumps");
6943 if (compare_files (debug_check_temp_file))
6944 this_file_error = 1;
6947 if (compare_debug)
6949 free (debug_check_temp_file[0]);
6950 debug_check_temp_file[0] = NULL;
6952 free (debug_check_temp_file[1]);
6953 debug_check_temp_file[1] = NULL;
6958 /* If this file's name does not contain a recognized suffix,
6959 record it as explicit linker input. */
6961 else
6962 explicit_link_files[i] = 1;
6964 /* Clear the delete-on-failure queue, deleting the files in it
6965 if this compilation failed. */
6967 if (this_file_error)
6969 delete_failure_queue ();
6970 errorcount++;
6972 /* If this compilation succeeded, don't delete those files later. */
6973 clear_failure_queue ();
6976 /* Reset the input file name to the first compile/object file name, for use
6977 with %b in LINK_SPEC. We use the first input file that we can find
6978 a compiler to compile it instead of using infiles.language since for
6979 languages other than C we use aliases that we then lookup later. */
6980 if (n_infiles > 0)
6982 int i;
6984 for (i = 0; i < n_infiles ; i++)
6985 if (infiles[i].incompiler
6986 || (infiles[i].language && infiles[i].language[0] != '*'))
6988 set_input (infiles[i].name);
6989 break;
6993 if (!seen_error ())
6995 /* Make sure INPUT_FILE_NUMBER points to first available open
6996 slot. */
6997 input_file_number = n_infiles;
6998 if (lang_specific_pre_link ())
6999 errorcount++;
7002 /* Determine if there are any linker input files. */
7003 num_linker_inputs = 0;
7004 for (i = 0; (int) i < n_infiles; i++)
7005 if (explicit_link_files[i] || outfiles[i] != NULL)
7006 num_linker_inputs++;
7008 /* Run ld to link all the compiler output files. */
7010 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
7012 int tmp = execution_count;
7014 if (! have_c)
7016 #if HAVE_LTO_PLUGIN > 0
7017 #if HAVE_LTO_PLUGIN == 2
7018 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
7019 #else
7020 const char *fuse_linker_plugin = "fuse-linker-plugin";
7021 #endif
7022 #endif
7024 /* We'll use ld if we can't find collect2. */
7025 if (! strcmp (linker_name_spec, "collect2"))
7027 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
7028 if (s == NULL)
7029 linker_name_spec = "ld";
7032 #if HAVE_LTO_PLUGIN > 0
7033 #if HAVE_LTO_PLUGIN == 2
7034 if (!switch_matches (fno_use_linker_plugin,
7035 fno_use_linker_plugin
7036 + strlen (fno_use_linker_plugin), 0))
7037 #else
7038 if (switch_matches (fuse_linker_plugin,
7039 fuse_linker_plugin
7040 + strlen (fuse_linker_plugin), 0))
7041 #endif
7043 char *temp_spec = find_a_file (&exec_prefixes,
7044 LTOPLUGINSONAME, R_OK,
7045 false);
7046 if (!temp_spec)
7047 fatal_error ("-fuse-linker-plugin, but %s not found",
7048 LTOPLUGINSONAME);
7049 linker_plugin_file_spec = convert_white_space (temp_spec);
7051 #endif
7052 lto_gcc_spec = argv[0];
7055 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
7056 for collect. */
7057 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
7058 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
7060 if (print_subprocess_help == 1)
7062 printf (_("\nLinker options\n==============\n\n"));
7063 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
7064 " to the linker.\n\n"));
7065 fflush (stdout);
7067 value = do_spec (link_command_spec);
7068 if (value < 0)
7069 errorcount = 1;
7070 linker_was_run = (tmp != execution_count);
7073 /* If options said don't run linker,
7074 complain about input files to be given to the linker. */
7076 if (! linker_was_run && !seen_error ())
7077 for (i = 0; (int) i < n_infiles; i++)
7078 if (explicit_link_files[i]
7079 && !(infiles[i].language && infiles[i].language[0] == '*'))
7080 warning (0, "%s: linker input file unused because linking not done",
7081 outfiles[i]);
7083 /* Delete some or all of the temporary files we made. */
7085 if (seen_error ())
7086 delete_failure_queue ();
7087 delete_temp_files ();
7089 if (print_help_list)
7091 printf (("\nFor bug reporting instructions, please see:\n"));
7092 printf ("%s\n", bug_report_url);
7095 out:
7096 return (signal_count != 0 ? 2
7097 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
7098 : 0);
7101 /* Find the proper compilation spec for the file name NAME,
7102 whose length is LENGTH. LANGUAGE is the specified language,
7103 or 0 if this file is to be passed to the linker. */
7105 static struct compiler *
7106 lookup_compiler (const char *name, size_t length, const char *language)
7108 struct compiler *cp;
7110 /* If this was specified by the user to be a linker input, indicate that. */
7111 if (language != 0 && language[0] == '*')
7112 return 0;
7114 /* Otherwise, look for the language, if one is spec'd. */
7115 if (language != 0)
7117 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7118 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
7119 return cp;
7121 error ("language %s not recognized", language);
7122 return 0;
7125 /* Look for a suffix. */
7126 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7128 if (/* The suffix `-' matches only the file name `-'. */
7129 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7130 || (strlen (cp->suffix) < length
7131 /* See if the suffix matches the end of NAME. */
7132 && !strcmp (cp->suffix,
7133 name + length - strlen (cp->suffix))
7135 break;
7138 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
7139 /* Look again, but case-insensitively this time. */
7140 if (cp < compilers)
7141 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7143 if (/* The suffix `-' matches only the file name `-'. */
7144 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7145 || (strlen (cp->suffix) < length
7146 /* See if the suffix matches the end of NAME. */
7147 && ((!strcmp (cp->suffix,
7148 name + length - strlen (cp->suffix))
7149 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
7150 && !strcasecmp (cp->suffix,
7151 name + length - strlen (cp->suffix)))
7153 break;
7155 #endif
7157 if (cp >= compilers)
7159 if (cp->spec[0] != '@')
7160 /* A non-alias entry: return it. */
7161 return cp;
7163 /* An alias entry maps a suffix to a language.
7164 Search for the language; pass 0 for NAME and LENGTH
7165 to avoid infinite recursion if language not found. */
7166 return lookup_compiler (NULL, 0, cp->spec + 1);
7168 return 0;
7171 static char *
7172 save_string (const char *s, int len)
7174 char *result = XNEWVEC (char, len + 1);
7176 memcpy (result, s, len);
7177 result[len] = 0;
7178 return result;
7181 void
7182 pfatal_with_name (const char *name)
7184 perror_with_name (name);
7185 delete_temp_files ();
7186 exit (1);
7189 static void
7190 perror_with_name (const char *name)
7192 error ("%s: %m", name);
7195 static inline void
7196 validate_switches_from_spec (const char *spec, bool user)
7198 const char *p = spec;
7199 char c;
7200 while ((c = *p++))
7201 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
7202 /* We have a switch spec. */
7203 p = validate_switches (p + 1, user);
7206 static void
7207 validate_all_switches (void)
7209 struct compiler *comp;
7210 struct spec_list *spec;
7212 for (comp = compilers; comp->spec; comp++)
7213 validate_switches_from_spec (comp->spec, false);
7215 /* Look through the linked list of specs read from the specs file. */
7216 for (spec = specs; spec; spec = spec->next)
7217 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
7219 validate_switches_from_spec (link_command_spec, false);
7222 /* Look at the switch-name that comes after START
7223 and mark as valid all supplied switches that match it. */
7225 static const char *
7226 validate_switches (const char *start, bool user_spec)
7228 const char *p = start;
7229 const char *atom;
7230 size_t len;
7231 int i;
7232 bool suffix = false;
7233 bool starred = false;
7235 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7237 next_member:
7238 SKIP_WHITE ();
7240 if (*p == '!')
7241 p++;
7243 SKIP_WHITE ();
7244 if (*p == '.' || *p == ',')
7245 suffix = true, p++;
7247 atom = p;
7248 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7249 || *p == ',' || *p == '.' || *p == '@')
7250 p++;
7251 len = p - atom;
7253 if (*p == '*')
7254 starred = true, p++;
7256 SKIP_WHITE ();
7258 if (!suffix)
7260 /* Mark all matching switches as valid. */
7261 for (i = 0; i < n_switches; i++)
7262 if (!strncmp (switches[i].part1, atom, len)
7263 && (starred || switches[i].part1[len] == '\0')
7264 && (switches[i].known || user_spec))
7265 switches[i].validated = true;
7268 if (*p) p++;
7269 if (*p && (p[-1] == '|' || p[-1] == '&'))
7270 goto next_member;
7272 if (*p && p[-1] == ':')
7274 while (*p && *p != ';' && *p != '}')
7276 if (*p == '%')
7278 p++;
7279 if (*p == '{' || *p == '<')
7280 p = validate_switches (p+1, user_spec);
7281 else if (p[0] == 'W' && p[1] == '{')
7282 p = validate_switches (p+2, user_spec);
7284 else
7285 p++;
7288 if (*p) p++;
7289 if (*p && p[-1] == ';')
7290 goto next_member;
7293 return p;
7294 #undef SKIP_WHITE
7297 struct mdswitchstr
7299 const char *str;
7300 int len;
7303 static struct mdswitchstr *mdswitches;
7304 static int n_mdswitches;
7306 /* Check whether a particular argument was used. The first time we
7307 canonicalize the switches to keep only the ones we care about. */
7309 static int
7310 used_arg (const char *p, int len)
7312 struct mswitchstr
7314 const char *str;
7315 const char *replace;
7316 int len;
7317 int rep_len;
7320 static struct mswitchstr *mswitches;
7321 static int n_mswitches;
7322 int i, j;
7324 if (!mswitches)
7326 struct mswitchstr *matches;
7327 const char *q;
7328 int cnt = 0;
7330 /* Break multilib_matches into the component strings of string
7331 and replacement string. */
7332 for (q = multilib_matches; *q != '\0'; q++)
7333 if (*q == ';')
7334 cnt++;
7336 matches
7337 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
7338 i = 0;
7339 q = multilib_matches;
7340 while (*q != '\0')
7342 matches[i].str = q;
7343 while (*q != ' ')
7345 if (*q == '\0')
7347 invalid_matches:
7348 fatal_error ("multilib spec %qs is invalid",
7349 multilib_matches);
7351 q++;
7353 matches[i].len = q - matches[i].str;
7355 matches[i].replace = ++q;
7356 while (*q != ';' && *q != '\0')
7358 if (*q == ' ')
7359 goto invalid_matches;
7360 q++;
7362 matches[i].rep_len = q - matches[i].replace;
7363 i++;
7364 if (*q == ';')
7365 q++;
7368 /* Now build a list of the replacement string for switches that we care
7369 about. Make sure we allocate at least one entry. This prevents
7370 xmalloc from calling fatal, and prevents us from re-executing this
7371 block of code. */
7372 mswitches
7373 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
7374 for (i = 0; i < n_switches; i++)
7375 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
7377 int xlen = strlen (switches[i].part1);
7378 for (j = 0; j < cnt; j++)
7379 if (xlen == matches[j].len
7380 && ! strncmp (switches[i].part1, matches[j].str, xlen))
7382 mswitches[n_mswitches].str = matches[j].replace;
7383 mswitches[n_mswitches].len = matches[j].rep_len;
7384 mswitches[n_mswitches].replace = (char *) 0;
7385 mswitches[n_mswitches].rep_len = 0;
7386 n_mswitches++;
7387 break;
7391 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7392 on the command line nor any options mutually incompatible with
7393 them. */
7394 for (i = 0; i < n_mdswitches; i++)
7396 const char *r;
7398 for (q = multilib_options; *q != '\0'; q++)
7400 while (*q == ' ')
7401 q++;
7403 r = q;
7404 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7405 || strchr (" /", q[mdswitches[i].len]) == NULL)
7407 while (*q != ' ' && *q != '/' && *q != '\0')
7408 q++;
7409 if (*q != '/')
7410 break;
7411 q++;
7414 if (*q != ' ' && *q != '\0')
7416 while (*r != ' ' && *r != '\0')
7418 q = r;
7419 while (*q != ' ' && *q != '/' && *q != '\0')
7420 q++;
7422 if (used_arg (r, q - r))
7423 break;
7425 if (*q != '/')
7427 mswitches[n_mswitches].str = mdswitches[i].str;
7428 mswitches[n_mswitches].len = mdswitches[i].len;
7429 mswitches[n_mswitches].replace = (char *) 0;
7430 mswitches[n_mswitches].rep_len = 0;
7431 n_mswitches++;
7432 break;
7435 r = q + 1;
7437 break;
7443 for (i = 0; i < n_mswitches; i++)
7444 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7445 return 1;
7447 return 0;
7450 static int
7451 default_arg (const char *p, int len)
7453 int i;
7455 for (i = 0; i < n_mdswitches; i++)
7456 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7457 return 1;
7459 return 0;
7462 /* Work out the subdirectory to use based on the options. The format of
7463 multilib_select is a list of elements. Each element is a subdirectory
7464 name followed by a list of options followed by a semicolon. The format
7465 of multilib_exclusions is the same, but without the preceding
7466 directory. First gcc will check the exclusions, if none of the options
7467 beginning with an exclamation point are present, and all of the other
7468 options are present, then we will ignore this completely. Passing
7469 that, gcc will consider each multilib_select in turn using the same
7470 rules for matching the options. If a match is found, that subdirectory
7471 will be used.
7472 A subdirectory name is optionally followed by a colon and the corresponding
7473 multiarch name. */
7475 static void
7476 set_multilib_dir (void)
7478 const char *p;
7479 unsigned int this_path_len;
7480 const char *this_path, *this_arg;
7481 const char *start, *end;
7482 int not_arg;
7483 int ok, ndfltok, first;
7485 n_mdswitches = 0;
7486 start = multilib_defaults;
7487 while (*start == ' ' || *start == '\t')
7488 start++;
7489 while (*start != '\0')
7491 n_mdswitches++;
7492 while (*start != ' ' && *start != '\t' && *start != '\0')
7493 start++;
7494 while (*start == ' ' || *start == '\t')
7495 start++;
7498 if (n_mdswitches)
7500 int i = 0;
7502 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
7503 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7505 while (*start == ' ' || *start == '\t')
7506 start++;
7508 if (*start == '\0')
7509 break;
7511 for (end = start + 1;
7512 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7515 obstack_grow (&multilib_obstack, start, end - start);
7516 obstack_1grow (&multilib_obstack, 0);
7517 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7518 mdswitches[i++].len = end - start;
7520 if (*end == '\0')
7521 break;
7525 p = multilib_exclusions;
7526 while (*p != '\0')
7528 /* Ignore newlines. */
7529 if (*p == '\n')
7531 ++p;
7532 continue;
7535 /* Check the arguments. */
7536 ok = 1;
7537 while (*p != ';')
7539 if (*p == '\0')
7541 invalid_exclusions:
7542 fatal_error ("multilib exclusions %qs is invalid",
7543 multilib_exclusions);
7546 if (! ok)
7548 ++p;
7549 continue;
7552 this_arg = p;
7553 while (*p != ' ' && *p != ';')
7555 if (*p == '\0')
7556 goto invalid_exclusions;
7557 ++p;
7560 if (*this_arg != '!')
7561 not_arg = 0;
7562 else
7564 not_arg = 1;
7565 ++this_arg;
7568 ok = used_arg (this_arg, p - this_arg);
7569 if (not_arg)
7570 ok = ! ok;
7572 if (*p == ' ')
7573 ++p;
7576 if (ok)
7577 return;
7579 ++p;
7582 first = 1;
7583 p = multilib_select;
7585 /* Append multilib reuse rules if any. With those rules, we can reuse
7586 one multilib for certain different options sets. */
7587 if (strlen (multilib_reuse) > 0)
7588 p = concat (p, multilib_reuse, NULL);
7590 while (*p != '\0')
7592 /* Ignore newlines. */
7593 if (*p == '\n')
7595 ++p;
7596 continue;
7599 /* Get the initial path. */
7600 this_path = p;
7601 while (*p != ' ')
7603 if (*p == '\0')
7605 invalid_select:
7606 fatal_error ("multilib select %qs %qs is invalid",
7607 multilib_select, multilib_reuse);
7609 ++p;
7611 this_path_len = p - this_path;
7613 /* Check the arguments. */
7614 ok = 1;
7615 ndfltok = 1;
7616 ++p;
7617 while (*p != ';')
7619 if (*p == '\0')
7620 goto invalid_select;
7622 if (! ok)
7624 ++p;
7625 continue;
7628 this_arg = p;
7629 while (*p != ' ' && *p != ';')
7631 if (*p == '\0')
7632 goto invalid_select;
7633 ++p;
7636 if (*this_arg != '!')
7637 not_arg = 0;
7638 else
7640 not_arg = 1;
7641 ++this_arg;
7644 /* If this is a default argument, we can just ignore it.
7645 This is true even if this_arg begins with '!'. Beginning
7646 with '!' does not mean that this argument is necessarily
7647 inappropriate for this library: it merely means that
7648 there is a more specific library which uses this
7649 argument. If this argument is a default, we need not
7650 consider that more specific library. */
7651 ok = used_arg (this_arg, p - this_arg);
7652 if (not_arg)
7653 ok = ! ok;
7655 if (! ok)
7656 ndfltok = 0;
7658 if (default_arg (this_arg, p - this_arg))
7659 ok = 1;
7661 if (*p == ' ')
7662 ++p;
7665 if (ok && first)
7667 if (this_path_len != 1
7668 || this_path[0] != '.')
7670 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
7671 char *q;
7673 strncpy (new_multilib_dir, this_path, this_path_len);
7674 new_multilib_dir[this_path_len] = '\0';
7675 q = strchr (new_multilib_dir, ':');
7676 if (q != NULL)
7677 *q = '\0';
7678 multilib_dir = new_multilib_dir;
7680 first = 0;
7683 if (ndfltok)
7685 const char *q = this_path, *end = this_path + this_path_len;
7687 while (q < end && *q != ':')
7688 q++;
7689 if (q < end)
7691 const char *q2 = q + 1, *ml_end = end;
7692 char *new_multilib_os_dir;
7694 while (q2 < end && *q2 != ':')
7695 q2++;
7696 if (*q2 == ':')
7697 ml_end = q2;
7698 new_multilib_os_dir = XNEWVEC (char, ml_end - q);
7699 memcpy (new_multilib_os_dir, q + 1, ml_end - q - 1);
7700 new_multilib_os_dir[ml_end - q - 1] = '\0';
7701 multilib_os_dir = *new_multilib_os_dir ? new_multilib_os_dir : ".";
7703 if (q2 < end && *q2 == ':')
7705 char *new_multiarch_dir = XNEWVEC (char, end - q2);
7706 memcpy (new_multiarch_dir, q2 + 1, end - q2 - 1);
7707 new_multiarch_dir[end - q2 - 1] = '\0';
7708 multiarch_dir = new_multiarch_dir;
7710 break;
7714 ++p;
7717 if (multilib_dir == NULL && multilib_os_dir != NULL
7718 && strcmp (multilib_os_dir, ".") == 0)
7720 free (CONST_CAST (char *, multilib_os_dir));
7721 multilib_os_dir = NULL;
7723 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7724 multilib_os_dir = multilib_dir;
7727 /* Print out the multiple library subdirectory selection
7728 information. This prints out a series of lines. Each line looks
7729 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7730 required. Only the desired options are printed out, the negative
7731 matches. The options are print without a leading dash. There are
7732 no spaces to make it easy to use the information in the shell.
7733 Each subdirectory is printed only once. This assumes the ordering
7734 generated by the genmultilib script. Also, we leave out ones that match
7735 the exclusions. */
7737 static void
7738 print_multilib_info (void)
7740 const char *p = multilib_select;
7741 const char *last_path = 0, *this_path;
7742 int skip;
7743 unsigned int last_path_len = 0;
7745 while (*p != '\0')
7747 skip = 0;
7748 /* Ignore newlines. */
7749 if (*p == '\n')
7751 ++p;
7752 continue;
7755 /* Get the initial path. */
7756 this_path = p;
7757 while (*p != ' ')
7759 if (*p == '\0')
7761 invalid_select:
7762 fatal_error ("multilib select %qs is invalid", multilib_select);
7765 ++p;
7768 /* When --disable-multilib was used but target defines
7769 MULTILIB_OSDIRNAMES, entries starting with .: (and not starting
7770 with .:: for multiarch configurations) are there just to find
7771 multilib_os_dir, so skip them from output. */
7772 if (this_path[0] == '.' && this_path[1] == ':' && this_path[2] != ':')
7773 skip = 1;
7775 /* Check for matches with the multilib_exclusions. We don't bother
7776 with the '!' in either list. If any of the exclusion rules match
7777 all of its options with the select rule, we skip it. */
7779 const char *e = multilib_exclusions;
7780 const char *this_arg;
7782 while (*e != '\0')
7784 int m = 1;
7785 /* Ignore newlines. */
7786 if (*e == '\n')
7788 ++e;
7789 continue;
7792 /* Check the arguments. */
7793 while (*e != ';')
7795 const char *q;
7796 int mp = 0;
7798 if (*e == '\0')
7800 invalid_exclusion:
7801 fatal_error ("multilib exclusion %qs is invalid",
7802 multilib_exclusions);
7805 if (! m)
7807 ++e;
7808 continue;
7811 this_arg = e;
7813 while (*e != ' ' && *e != ';')
7815 if (*e == '\0')
7816 goto invalid_exclusion;
7817 ++e;
7820 q = p + 1;
7821 while (*q != ';')
7823 const char *arg;
7824 int len = e - this_arg;
7826 if (*q == '\0')
7827 goto invalid_select;
7829 arg = q;
7831 while (*q != ' ' && *q != ';')
7833 if (*q == '\0')
7834 goto invalid_select;
7835 ++q;
7838 if (! strncmp (arg, this_arg,
7839 (len < q - arg) ? q - arg : len)
7840 || default_arg (this_arg, e - this_arg))
7842 mp = 1;
7843 break;
7846 if (*q == ' ')
7847 ++q;
7850 if (! mp)
7851 m = 0;
7853 if (*e == ' ')
7854 ++e;
7857 if (m)
7859 skip = 1;
7860 break;
7863 if (*e != '\0')
7864 ++e;
7868 if (! skip)
7870 /* If this is a duplicate, skip it. */
7871 skip = (last_path != 0
7872 && (unsigned int) (p - this_path) == last_path_len
7873 && ! filename_ncmp (last_path, this_path, last_path_len));
7875 last_path = this_path;
7876 last_path_len = p - this_path;
7879 /* If this directory requires any default arguments, we can skip
7880 it. We will already have printed a directory identical to
7881 this one which does not require that default argument. */
7882 if (! skip)
7884 const char *q;
7886 q = p + 1;
7887 while (*q != ';')
7889 const char *arg;
7891 if (*q == '\0')
7892 goto invalid_select;
7894 if (*q == '!')
7895 arg = NULL;
7896 else
7897 arg = q;
7899 while (*q != ' ' && *q != ';')
7901 if (*q == '\0')
7902 goto invalid_select;
7903 ++q;
7906 if (arg != NULL
7907 && default_arg (arg, q - arg))
7909 skip = 1;
7910 break;
7913 if (*q == ' ')
7914 ++q;
7918 if (! skip)
7920 const char *p1;
7922 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7923 putchar (*p1);
7924 putchar (';');
7927 ++p;
7928 while (*p != ';')
7930 int use_arg;
7932 if (*p == '\0')
7933 goto invalid_select;
7935 if (skip)
7937 ++p;
7938 continue;
7941 use_arg = *p != '!';
7943 if (use_arg)
7944 putchar ('@');
7946 while (*p != ' ' && *p != ';')
7948 if (*p == '\0')
7949 goto invalid_select;
7950 if (use_arg)
7951 putchar (*p);
7952 ++p;
7955 if (*p == ' ')
7956 ++p;
7959 if (! skip)
7961 /* If there are extra options, print them now. */
7962 if (multilib_extra && *multilib_extra)
7964 int print_at = TRUE;
7965 const char *q;
7967 for (q = multilib_extra; *q != '\0'; q++)
7969 if (*q == ' ')
7970 print_at = TRUE;
7971 else
7973 if (print_at)
7974 putchar ('@');
7975 putchar (*q);
7976 print_at = FALSE;
7981 putchar ('\n');
7984 ++p;
7988 /* getenv built-in spec function.
7990 Returns the value of the environment variable given by its first
7991 argument, concatenated with the second argument. If the
7992 environment variable is not defined, a fatal error is issued. */
7994 static const char *
7995 getenv_spec_function (int argc, const char **argv)
7997 char *value;
7998 char *result;
7999 char *ptr;
8000 size_t len;
8002 if (argc != 2)
8003 return NULL;
8005 value = getenv (argv[0]);
8006 if (!value)
8007 fatal_error ("environment variable %qs not defined", argv[0]);
8009 /* We have to escape every character of the environment variable so
8010 they are not interpreted as active spec characters. A
8011 particularly painful case is when we are reading a variable
8012 holding a windows path complete with \ separators. */
8013 len = strlen (value) * 2 + strlen (argv[1]) + 1;
8014 result = XNEWVAR (char, len);
8015 for (ptr = result; *value; ptr += 2)
8017 ptr[0] = '\\';
8018 ptr[1] = *value++;
8021 strcpy (ptr, argv[1]);
8023 return result;
8026 /* if-exists built-in spec function.
8028 Checks to see if the file specified by the absolute pathname in
8029 ARGS exists. Returns that pathname if found.
8031 The usual use for this function is to check for a library file
8032 (whose name has been expanded with %s). */
8034 static const char *
8035 if_exists_spec_function (int argc, const char **argv)
8037 /* Must have only one argument. */
8038 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8039 return argv[0];
8041 return NULL;
8044 /* if-exists-else built-in spec function.
8046 This is like if-exists, but takes an additional argument which
8047 is returned if the first argument does not exist. */
8049 static const char *
8050 if_exists_else_spec_function (int argc, const char **argv)
8052 /* Must have exactly two arguments. */
8053 if (argc != 2)
8054 return NULL;
8056 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
8057 return argv[0];
8059 return argv[1];
8062 /* replace-outfile built-in spec function.
8064 This looks for the first argument in the outfiles array's name and
8065 replaces it with the second argument. */
8067 static const char *
8068 replace_outfile_spec_function (int argc, const char **argv)
8070 int i;
8071 /* Must have exactly two arguments. */
8072 if (argc != 2)
8073 abort ();
8075 for (i = 0; i < n_infiles; i++)
8077 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8078 outfiles[i] = xstrdup (argv[1]);
8080 return NULL;
8083 /* remove-outfile built-in spec function.
8085 * This looks for the first argument in the outfiles array's name and
8086 * removes it. */
8088 static const char *
8089 remove_outfile_spec_function (int argc, const char **argv)
8091 int i;
8092 /* Must have exactly one argument. */
8093 if (argc != 1)
8094 abort ();
8096 for (i = 0; i < n_infiles; i++)
8098 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
8099 outfiles[i] = NULL;
8101 return NULL;
8104 /* Given two version numbers, compares the two numbers.
8105 A version number must match the regular expression
8106 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
8108 static int
8109 compare_version_strings (const char *v1, const char *v2)
8111 int rresult;
8112 regex_t r;
8114 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
8115 REG_EXTENDED | REG_NOSUB) != 0)
8116 abort ();
8117 rresult = regexec (&r, v1, 0, NULL, 0);
8118 if (rresult == REG_NOMATCH)
8119 fatal_error ("invalid version number %qs", v1);
8120 else if (rresult != 0)
8121 abort ();
8122 rresult = regexec (&r, v2, 0, NULL, 0);
8123 if (rresult == REG_NOMATCH)
8124 fatal_error ("invalid version number %qs", v2);
8125 else if (rresult != 0)
8126 abort ();
8128 return strverscmp (v1, v2);
8132 /* version_compare built-in spec function.
8134 This takes an argument of the following form:
8136 <comparison-op> <arg1> [<arg2>] <switch> <result>
8138 and produces "result" if the comparison evaluates to true,
8139 and nothing if it doesn't.
8141 The supported <comparison-op> values are:
8143 >= true if switch is a later (or same) version than arg1
8144 !> opposite of >=
8145 < true if switch is an earlier version than arg1
8146 !< opposite of <
8147 >< true if switch is arg1 or later, and earlier than arg2
8148 <> true if switch is earlier than arg1 or is arg2 or later
8150 If the switch is not present, the condition is false unless
8151 the first character of the <comparison-op> is '!'.
8153 For example,
8154 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
8155 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
8157 static const char *
8158 version_compare_spec_function (int argc, const char **argv)
8160 int comp1, comp2;
8161 size_t switch_len;
8162 const char *switch_value = NULL;
8163 int nargs = 1, i;
8164 bool result;
8166 if (argc < 3)
8167 fatal_error ("too few arguments to %%:version-compare");
8168 if (argv[0][0] == '\0')
8169 abort ();
8170 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
8171 nargs = 2;
8172 if (argc != nargs + 3)
8173 fatal_error ("too many arguments to %%:version-compare");
8175 switch_len = strlen (argv[nargs + 1]);
8176 for (i = 0; i < n_switches; i++)
8177 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
8178 && check_live_switch (i, switch_len))
8179 switch_value = switches[i].part1 + switch_len;
8181 if (switch_value == NULL)
8182 comp1 = comp2 = -1;
8183 else
8185 comp1 = compare_version_strings (switch_value, argv[1]);
8186 if (nargs == 2)
8187 comp2 = compare_version_strings (switch_value, argv[2]);
8188 else
8189 comp2 = -1; /* This value unused. */
8192 switch (argv[0][0] << 8 | argv[0][1])
8194 case '>' << 8 | '=':
8195 result = comp1 >= 0;
8196 break;
8197 case '!' << 8 | '<':
8198 result = comp1 >= 0 || switch_value == NULL;
8199 break;
8200 case '<' << 8:
8201 result = comp1 < 0;
8202 break;
8203 case '!' << 8 | '>':
8204 result = comp1 < 0 || switch_value == NULL;
8205 break;
8206 case '>' << 8 | '<':
8207 result = comp1 >= 0 && comp2 < 0;
8208 break;
8209 case '<' << 8 | '>':
8210 result = comp1 < 0 || comp2 >= 0;
8211 break;
8213 default:
8214 fatal_error ("unknown operator %qs in %%:version-compare", argv[0]);
8216 if (! result)
8217 return NULL;
8219 return argv[nargs + 2];
8222 /* %:include builtin spec function. This differs from %include in that it
8223 can be nested inside a spec, and thus be conditionalized. It takes
8224 one argument, the filename, and looks for it in the startfile path.
8225 The result is always NULL, i.e. an empty expansion. */
8227 static const char *
8228 include_spec_function (int argc, const char **argv)
8230 char *file;
8232 if (argc != 1)
8233 abort ();
8235 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
8236 read_specs (file ? file : argv[0], false, false);
8238 return NULL;
8241 /* %:find-file spec function. This function replaces its argument by
8242 the file found through find_file, that is the -print-file-name gcc
8243 program option. */
8244 static const char *
8245 find_file_spec_function (int argc, const char **argv)
8247 const char *file;
8249 if (argc != 1)
8250 abort ();
8252 file = find_file (argv[0]);
8253 return file;
8257 /* %:find-plugindir spec function. This function replaces its argument
8258 by the -iplugindir=<dir> option. `dir' is found through find_file, that
8259 is the -print-file-name gcc program option. */
8260 static const char *
8261 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
8263 const char *option;
8265 if (argc != 0)
8266 abort ();
8268 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
8269 return option;
8273 /* %:print-asm-header spec function. Print a banner to say that the
8274 following output is from the assembler. */
8276 static const char *
8277 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
8278 const char **argv ATTRIBUTE_UNUSED)
8280 printf (_("Assembler options\n=================\n\n"));
8281 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
8282 fflush (stdout);
8283 return NULL;
8286 /* Get a random number for -frandom-seed */
8288 static unsigned HOST_WIDE_INT
8289 get_random_number (void)
8291 unsigned HOST_WIDE_INT ret = 0;
8292 int fd;
8294 fd = open ("/dev/urandom", O_RDONLY);
8295 if (fd >= 0)
8297 read (fd, &ret, sizeof (HOST_WIDE_INT));
8298 close (fd);
8299 if (ret)
8300 return ret;
8303 /* Get some more or less random data. */
8304 #ifdef HAVE_GETTIMEOFDAY
8306 struct timeval tv;
8308 gettimeofday (&tv, NULL);
8309 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
8311 #else
8313 time_t now = time (NULL);
8315 if (now != (time_t)-1)
8316 ret = (unsigned) now;
8318 #endif
8320 return ret ^ getpid();
8323 /* %:compare-debug-dump-opt spec function. Save the last argument,
8324 expected to be the last -fdump-final-insns option, or generate a
8325 temporary. */
8327 static const char *
8328 compare_debug_dump_opt_spec_function (int arg,
8329 const char **argv ATTRIBUTE_UNUSED)
8331 char *ret;
8332 char *name;
8333 int which;
8334 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
8336 if (arg != 0)
8337 fatal_error ("too many arguments to %%:compare-debug-dump-opt");
8339 do_spec_2 ("%{fdump-final-insns=*:%*}");
8340 do_spec_1 (" ", 0, NULL);
8342 if (argbuf.length () > 0
8343 && strcmp (argv[argbuf.length () - 1], "."))
8345 if (!compare_debug)
8346 return NULL;
8348 name = xstrdup (argv[argbuf.length () - 1]);
8349 ret = NULL;
8351 else
8353 const char *ext = NULL;
8355 if (argbuf.length () > 0)
8357 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
8358 ext = ".gkd";
8360 else if (!compare_debug)
8361 return NULL;
8362 else
8363 do_spec_2 ("%g.gkd");
8365 do_spec_1 (" ", 0, NULL);
8367 gcc_assert (argbuf.length () > 0);
8369 name = concat (argbuf.last (), ext, NULL);
8371 ret = concat ("-fdump-final-insns=", name, NULL);
8374 which = compare_debug < 0;
8375 debug_check_temp_file[which] = name;
8377 if (!which)
8379 unsigned HOST_WIDE_INT value = get_random_number ();
8381 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
8384 if (*random_seed)
8386 char *tmp = ret;
8387 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
8388 ret, NULL);
8389 free (tmp);
8392 if (which)
8393 *random_seed = 0;
8395 return ret;
8398 static const char *debug_auxbase_opt;
8400 /* %:compare-debug-self-opt spec function. Expands to the options
8401 that are to be passed in the second compilation of
8402 compare-debug. */
8404 static const char *
8405 compare_debug_self_opt_spec_function (int arg,
8406 const char **argv ATTRIBUTE_UNUSED)
8408 if (arg != 0)
8409 fatal_error ("too many arguments to %%:compare-debug-self-opt");
8411 if (compare_debug >= 0)
8412 return NULL;
8414 do_spec_2 ("%{c|S:%{o*:%*}}");
8415 do_spec_1 (" ", 0, NULL);
8417 if (argbuf.length () > 0)
8418 debug_auxbase_opt = concat ("-auxbase-strip ",
8419 argbuf.last (),
8420 NULL);
8421 else
8422 debug_auxbase_opt = NULL;
8424 return concat ("\
8425 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
8426 %<fdump-final-insns=* -w -S -o %j \
8427 %{!fcompare-debug-second:-fcompare-debug-second} \
8428 ", compare_debug_opt, NULL);
8431 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
8432 options that are to be passed in the second compilation of
8433 compare-debug. It expects, as an argument, the basename of the
8434 current input file name, with the .gk suffix appended to it. */
8436 static const char *
8437 compare_debug_auxbase_opt_spec_function (int arg,
8438 const char **argv)
8440 char *name;
8441 int len;
8443 if (arg == 0)
8444 fatal_error ("too few arguments to %%:compare-debug-auxbase-opt");
8446 if (arg != 1)
8447 fatal_error ("too many arguments to %%:compare-debug-auxbase-opt");
8449 if (compare_debug >= 0)
8450 return NULL;
8452 len = strlen (argv[0]);
8453 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
8454 fatal_error ("argument to %%:compare-debug-auxbase-opt "
8455 "does not end in .gk");
8457 if (debug_auxbase_opt)
8458 return debug_auxbase_opt;
8460 #define OPT "-auxbase "
8462 len -= 3;
8463 name = (char*) xmalloc (sizeof (OPT) + len);
8464 memcpy (name, OPT, sizeof (OPT) - 1);
8465 memcpy (name + sizeof (OPT) - 1, argv[0], len);
8466 name[sizeof (OPT) - 1 + len] = '\0';
8468 #undef OPT
8470 return name;
8473 /* %:pass-through-libs spec function. Finds all -l options and input
8474 file names in the lib spec passed to it, and makes a list of them
8475 prepended with the plugin option to cause them to be passed through
8476 to the final link after all the new object files have been added. */
8478 const char *
8479 pass_through_libs_spec_func (int argc, const char **argv)
8481 char *prepended = xstrdup (" ");
8482 int n;
8483 /* Shlemiel the painter's algorithm. Innately horrible, but at least
8484 we know that there will never be more than a handful of strings to
8485 concat, and it's only once per run, so it's not worth optimising. */
8486 for (n = 0; n < argc; n++)
8488 char *old = prepended;
8489 /* Anything that isn't an option is a full path to an output
8490 file; pass it through if it ends in '.a'. Among options,
8491 pass only -l. */
8492 if (argv[n][0] == '-' && argv[n][1] == 'l')
8494 const char *lopt = argv[n] + 2;
8495 /* Handle both joined and non-joined -l options. If for any
8496 reason there's a trailing -l with no joined or following
8497 arg just discard it. */
8498 if (!*lopt && ++n >= argc)
8499 break;
8500 else if (!*lopt)
8501 lopt = argv[n];
8502 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
8503 lopt, " ", NULL);
8505 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
8507 prepended = concat (prepended, "-plugin-opt=-pass-through=",
8508 argv[n], " ", NULL);
8510 if (prepended != old)
8511 free (old);
8513 return prepended;
8516 /* %:replace-extension spec function. Replaces the extension of the
8517 first argument with the second argument. */
8519 const char *
8520 replace_extension_spec_func (int argc, const char **argv)
8522 char *name;
8523 char *p;
8524 char *result;
8525 int i;
8527 if (argc != 2)
8528 fatal_error ("too few arguments to %%:replace-extension");
8530 name = xstrdup (argv[0]);
8532 for (i = strlen(name) - 1; i >= 0; i--)
8533 if (IS_DIR_SEPARATOR (name[i]))
8534 break;
8536 p = strrchr (name + i + 1, '.');
8537 if (p != NULL)
8538 *p = '\0';
8540 result = concat (name, argv[1], NULL);
8542 free (name);
8543 return result;
8546 /* Insert backslash before spaces in ORIG (usually a file path), to
8547 avoid being broken by spec parser.
8549 This function is needed as do_spec_1 treats white space (' ' and '\t')
8550 as the end of an argument. But in case of -plugin /usr/gcc install/xxx.so,
8551 the file name should be treated as a single argument rather than being
8552 broken into multiple. Solution is to insert '\\' before the space in a
8553 file name.
8555 This function converts and only converts all occurrence of ' '
8556 to '\\' + ' ' and '\t' to '\\' + '\t'. For example:
8557 "a b" -> "a\\ b"
8558 "a b" -> "a\\ \\ b"
8559 "a\tb" -> "a\\\tb"
8560 "a\\ b" -> "a\\\\ b"
8562 orig: input null-terminating string that was allocated by xalloc. The
8563 memory it points to might be freed in this function. Behavior undefined
8564 if ORIG wasn't xalloced or was freed already at entry.
8566 Return: ORIG if no conversion needed. Otherwise a newly allocated string
8567 that was converted from ORIG. */
8569 static char *
8570 convert_white_space (char *orig)
8572 int len, number_of_space = 0;
8574 for (len = 0; orig[len]; len++)
8575 if (orig[len] == ' ' || orig[len] == '\t') number_of_space++;
8577 if (number_of_space)
8579 char *new_spec = (char *) xmalloc (len + number_of_space + 1);
8580 int j, k;
8581 for (j = 0, k = 0; j <= len; j++, k++)
8583 if (orig[j] == ' ' || orig[j] == '\t')
8584 new_spec[k++] = '\\';
8585 new_spec[k] = orig[j];
8587 free (orig);
8588 return new_spec;
8590 else
8591 return orig;