PR debug/54693
[official-gcc.git] / gcc / gcc.c
blobbbca6d84e33a0e904bbf78ab314849fa13d6bbec
1 /* Compiler driver program that can handle many languages.
2 Copyright (C) 1987, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
3 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009,
4 2010, 2011, 2012
5 Free Software Foundation, Inc.
7 This file is part of GCC.
9 GCC is free software; you can redistribute it and/or modify it under
10 the terms of the GNU General Public License as published by the Free
11 Software Foundation; either version 3, or (at your option) any later
12 version.
14 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
15 WARRANTY; without even the implied warranty of MERCHANTABILITY or
16 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
17 for more details.
19 You should have received a copy of the GNU General Public License
20 along with GCC; see the file COPYING3. If not see
21 <http://www.gnu.org/licenses/>. */
23 /* This program is the user interface to the C compiler and possibly to
24 other compilers. It is used because compilation is a complicated procedure
25 which involves running several programs and passing temporary files between
26 them, forwarding the users switches to those programs selectively,
27 and deleting the temporary files at the end.
29 CC recognizes how to compile each input file by suffixes in the file names.
30 Once it knows which kind of compilation to perform, the procedure for
31 compilation is specified by a string called a "spec". */
33 #include "config.h"
34 #include "system.h"
35 #include "coretypes.h"
36 #include "multilib.h" /* before tm.h */
37 #include "tm.h"
38 #include "xregex.h"
39 #include "obstack.h"
40 #include "intl.h"
41 #include "prefix.h"
42 #include "gcc.h"
43 #include "diagnostic.h"
44 #include "flags.h"
45 #include "opts.h"
46 #include "params.h"
47 #include "vec.h"
48 #include "filenames.h"
50 /* By default there is no special suffix for target executables. */
51 /* FIXME: when autoconf is fixed, remove the host check - dj */
52 #if defined(TARGET_EXECUTABLE_SUFFIX) && defined(HOST_EXECUTABLE_SUFFIX)
53 #define HAVE_TARGET_EXECUTABLE_SUFFIX
54 #endif
56 /* By default there is no special suffix for host executables. */
57 #ifdef HOST_EXECUTABLE_SUFFIX
58 #define HAVE_HOST_EXECUTABLE_SUFFIX
59 #else
60 #define HOST_EXECUTABLE_SUFFIX ""
61 #endif
63 /* By default, the suffix for target object files is ".o". */
64 #ifdef TARGET_OBJECT_SUFFIX
65 #define HAVE_TARGET_OBJECT_SUFFIX
66 #else
67 #define TARGET_OBJECT_SUFFIX ".o"
68 #endif
70 static const char dir_separator_str[] = { DIR_SEPARATOR, 0 };
72 /* Most every one is fine with LIBRARY_PATH. For some, it conflicts. */
73 #ifndef LIBRARY_PATH_ENV
74 #define LIBRARY_PATH_ENV "LIBRARY_PATH"
75 #endif
77 /* If a stage of compilation returns an exit status >= 1,
78 compilation of that file ceases. */
80 #define MIN_FATAL_STATUS 1
82 /* Flag set by cppspec.c to 1. */
83 int is_cpp_driver;
85 /* Flag set to nonzero if an @file argument has been supplied to gcc. */
86 static bool at_file_supplied;
88 /* Definition of string containing the arguments given to configure. */
89 #include "configargs.h"
91 /* Flag saying to print the command line options understood by gcc and its
92 sub-processes. */
94 static int print_help_list;
96 /* Flag saying to print the version of gcc and its sub-processes. */
98 static int print_version;
100 /* Flag indicating whether we should ONLY print the command and
101 arguments (like verbose_flag) without executing the command.
102 Displayed arguments are quoted so that the generated command
103 line is suitable for execution. This is intended for use in
104 shell scripts to capture the driver-generated command line. */
105 static int verbose_only_flag;
107 /* Flag indicating how to print command line options of sub-processes. */
109 static int print_subprocess_help;
111 /* Whether we should report subprocess execution times to a file. */
113 FILE *report_times_to_file = NULL;
115 /* Nonzero means place this string before uses of /, so that include
116 and library files can be found in an alternate location. */
118 #ifdef TARGET_SYSTEM_ROOT
119 static const char *target_system_root = TARGET_SYSTEM_ROOT;
120 #else
121 static const char *target_system_root = 0;
122 #endif
124 /* Nonzero means pass the updated target_system_root to the compiler. */
126 static int target_system_root_changed;
128 /* Nonzero means append this string to target_system_root. */
130 static const char *target_sysroot_suffix = 0;
132 /* Nonzero means append this string to target_system_root for headers. */
134 static const char *target_sysroot_hdrs_suffix = 0;
136 /* Nonzero means write "temp" files in source directory
137 and use the source file's name in them, and don't delete them. */
139 static enum save_temps {
140 SAVE_TEMPS_NONE, /* no -save-temps */
141 SAVE_TEMPS_CWD, /* -save-temps in current directory */
142 SAVE_TEMPS_OBJ /* -save-temps in object directory */
143 } save_temps_flag;
145 /* Output file to use to get the object directory for -save-temps=obj */
146 static char *save_temps_prefix = 0;
147 static size_t save_temps_length = 0;
149 /* The compiler version. */
151 static const char *compiler_version;
153 /* The target version. */
155 static const char *const spec_version = DEFAULT_TARGET_VERSION;
157 /* The target machine. */
159 static const char *spec_machine = DEFAULT_TARGET_MACHINE;
161 /* Nonzero if cross-compiling.
162 When -b is used, the value comes from the `specs' file. */
164 #ifdef CROSS_DIRECTORY_STRUCTURE
165 static const char *cross_compile = "1";
166 #else
167 static const char *cross_compile = "0";
168 #endif
170 /* Greatest exit code of sub-processes that has been encountered up to
171 now. */
172 static int greatest_status = 1;
174 /* This is the obstack which we use to allocate many strings. */
176 static struct obstack obstack;
178 /* This is the obstack to build an environment variable to pass to
179 collect2 that describes all of the relevant switches of what to
180 pass the compiler in building the list of pointers to constructors
181 and destructors. */
183 static struct obstack collect_obstack;
185 /* Forward declaration for prototypes. */
186 struct path_prefix;
187 struct prefix_list;
189 static void init_spec (void);
190 static void store_arg (const char *, int, int);
191 static void insert_wrapper (const char *);
192 static char *load_specs (const char *);
193 static void read_specs (const char *, bool, bool);
194 static void set_spec (const char *, const char *, bool);
195 static struct compiler *lookup_compiler (const char *, size_t, const char *);
196 static char *build_search_list (const struct path_prefix *, const char *,
197 bool, bool);
198 static void xputenv (const char *);
199 static void putenv_from_prefixes (const struct path_prefix *, const char *,
200 bool);
201 static int access_check (const char *, int);
202 static char *find_a_file (const struct path_prefix *, const char *, int, bool);
203 static void add_prefix (struct path_prefix *, const char *, const char *,
204 int, int, int);
205 static void add_sysrooted_prefix (struct path_prefix *, const char *,
206 const char *, int, int, int);
207 static char *skip_whitespace (char *);
208 static void delete_if_ordinary (const char *);
209 static void delete_temp_files (void);
210 static void delete_failure_queue (void);
211 static void clear_failure_queue (void);
212 static int check_live_switch (int, int);
213 static const char *handle_braces (const char *);
214 static inline bool input_suffix_matches (const char *, const char *);
215 static inline bool switch_matches (const char *, const char *, int);
216 static inline void mark_matching_switches (const char *, const char *, int);
217 static inline void process_marked_switches (void);
218 static const char *process_brace_body (const char *, const char *, const char *, int, int);
219 static const struct spec_function *lookup_spec_function (const char *);
220 static const char *eval_spec_function (const char *, const char *);
221 static const char *handle_spec_function (const char *);
222 static char *save_string (const char *, int);
223 static void set_collect_gcc_options (void);
224 static int do_spec_1 (const char *, int, const char *);
225 static int do_spec_2 (const char *);
226 static void do_option_spec (const char *, const char *);
227 static void do_self_spec (const char *);
228 static const char *find_file (const char *);
229 static int is_directory (const char *, bool);
230 static const char *validate_switches (const char *, bool);
231 static void validate_all_switches (void);
232 static inline void validate_switches_from_spec (const char *, bool);
233 static void give_switch (int, int);
234 static int used_arg (const char *, int);
235 static int default_arg (const char *, int);
236 static void set_multilib_dir (void);
237 static void print_multilib_info (void);
238 static void perror_with_name (const char *);
239 static void display_help (void);
240 static void add_preprocessor_option (const char *, int);
241 static void add_assembler_option (const char *, int);
242 static void add_linker_option (const char *, int);
243 static void process_command (unsigned int, struct cl_decoded_option *);
244 static int execute (void);
245 static void alloc_args (void);
246 static void clear_args (void);
247 static void fatal_signal (int);
248 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
249 static void init_gcc_specs (struct obstack *, const char *, const char *,
250 const char *);
251 #endif
252 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
253 static const char *convert_filename (const char *, int, int);
254 #endif
256 static const char *getenv_spec_function (int, const char **);
257 static const char *if_exists_spec_function (int, const char **);
258 static const char *if_exists_else_spec_function (int, const char **);
259 static const char *replace_outfile_spec_function (int, const char **);
260 static const char *remove_outfile_spec_function (int, const char **);
261 static const char *version_compare_spec_function (int, const char **);
262 static const char *include_spec_function (int, const char **);
263 static const char *find_file_spec_function (int, const char **);
264 static const char *find_plugindir_spec_function (int, const char **);
265 static const char *print_asm_header_spec_function (int, const char **);
266 static const char *compare_debug_dump_opt_spec_function (int, const char **);
267 static const char *compare_debug_self_opt_spec_function (int, const char **);
268 static const char *compare_debug_auxbase_opt_spec_function (int, const char **);
269 static const char *pass_through_libs_spec_func (int, const char **);
271 /* The Specs Language
273 Specs are strings containing lines, each of which (if not blank)
274 is made up of a program name, and arguments separated by spaces.
275 The program name must be exact and start from root, since no path
276 is searched and it is unreliable to depend on the current working directory.
277 Redirection of input or output is not supported; the subprograms must
278 accept filenames saying what files to read and write.
280 In addition, the specs can contain %-sequences to substitute variable text
281 or for conditional text. Here is a table of all defined %-sequences.
282 Note that spaces are not generated automatically around the results of
283 expanding these sequences; therefore, you can concatenate them together
284 or with constant text in a single argument.
286 %% substitute one % into the program name or argument.
287 %i substitute the name of the input file being processed.
288 %b substitute the basename of the input file being processed.
289 This is the substring up to (and not including) the last period
290 and not including the directory unless -save-temps was specified
291 to put temporaries in a different location.
292 %B same as %b, but include the file suffix (text after the last period).
293 %gSUFFIX
294 substitute a file name that has suffix SUFFIX and is chosen
295 once per compilation, and mark the argument a la %d. To reduce
296 exposure to denial-of-service attacks, the file name is now
297 chosen in a way that is hard to predict even when previously
298 chosen file names are known. For example, `%g.s ... %g.o ... %g.s'
299 might turn into `ccUVUUAU.s ccXYAXZ12.o ccUVUUAU.s'. SUFFIX matches
300 the regexp "[.0-9A-Za-z]*%O"; "%O" is treated exactly as if it
301 had been pre-processed. Previously, %g was simply substituted
302 with a file name chosen once per compilation, without regard
303 to any appended suffix (which was therefore treated just like
304 ordinary text), making such attacks more likely to succeed.
305 %|SUFFIX
306 like %g, but if -pipe is in effect, expands simply to "-".
307 %mSUFFIX
308 like %g, but if -pipe is in effect, expands to nothing. (We have both
309 %| and %m to accommodate differences between system assemblers; see
310 the AS_NEEDS_DASH_FOR_PIPED_INPUT target macro.)
311 %uSUFFIX
312 like %g, but generates a new temporary file name even if %uSUFFIX
313 was already seen.
314 %USUFFIX
315 substitutes the last file name generated with %uSUFFIX, generating a
316 new one if there is no such last file name. In the absence of any
317 %uSUFFIX, this is just like %gSUFFIX, except they don't share
318 the same suffix "space", so `%g.s ... %U.s ... %g.s ... %U.s'
319 would involve the generation of two distinct file names, one
320 for each `%g.s' and another for each `%U.s'. Previously, %U was
321 simply substituted with a file name chosen for the previous %u,
322 without regard to any appended suffix.
323 %jSUFFIX
324 substitutes the name of the HOST_BIT_BUCKET, if any, and if it is
325 writable, and if save-temps is off; otherwise, substitute the name
326 of a temporary file, just like %u. This temporary file is not
327 meant for communication between processes, but rather as a junk
328 disposal mechanism.
329 %.SUFFIX
330 substitutes .SUFFIX for the suffixes of a matched switch's args when
331 it is subsequently output with %*. SUFFIX is terminated by the next
332 space or %.
333 %d marks the argument containing or following the %d as a
334 temporary file name, so that that file will be deleted if GCC exits
335 successfully. Unlike %g, this contributes no text to the argument.
336 %w marks the argument containing or following the %w as the
337 "output file" of this compilation. This puts the argument
338 into the sequence of arguments that %o will substitute later.
339 %V indicates that this compilation produces no "output file".
340 %W{...}
341 like %{...} but mark last argument supplied within
342 as a file to be deleted on failure.
343 %o substitutes the names of all the output files, with spaces
344 automatically placed around them. You should write spaces
345 around the %o as well or the results are undefined.
346 %o is for use in the specs for running the linker.
347 Input files whose names have no recognized suffix are not compiled
348 at all, but they are included among the output files, so they will
349 be linked.
350 %O substitutes the suffix for object files. Note that this is
351 handled specially when it immediately follows %g, %u, or %U
352 (with or without a suffix argument) because of the need for
353 those to form complete file names. The handling is such that
354 %O is treated exactly as if it had already been substituted,
355 except that %g, %u, and %U do not currently support additional
356 SUFFIX characters following %O as they would following, for
357 example, `.o'.
358 %I Substitute any of -iprefix (made from GCC_EXEC_PREFIX), -isysroot
359 (made from TARGET_SYSTEM_ROOT), -isystem (made from COMPILER_PATH
360 and -B options) and -imultilib as necessary.
361 %s current argument is the name of a library or startup file of some sort.
362 Search for that file in a standard list of directories
363 and substitute the full name found.
364 %eSTR Print STR as an error message. STR is terminated by a newline.
365 Use this when inconsistent options are detected.
366 %nSTR Print STR as a notice. STR is terminated by a newline.
367 %x{OPTION} Accumulate an option for %X.
368 %X Output the accumulated linker options specified by compilations.
369 %Y Output the accumulated assembler options specified by compilations.
370 %Z Output the accumulated preprocessor options specified by compilations.
371 %a process ASM_SPEC as a spec.
372 This allows config.h to specify part of the spec for running as.
373 %A process ASM_FINAL_SPEC as a spec. A capital A is actually
374 used here. This can be used to run a post-processor after the
375 assembler has done its job.
376 %D Dump out a -L option for each directory in startfile_prefixes.
377 If multilib_dir is set, extra entries are generated with it affixed.
378 %l process LINK_SPEC as a spec.
379 %L process LIB_SPEC as a spec.
380 %M Output multilib_os_dir.
381 %G process LIBGCC_SPEC as a spec.
382 %R Output the concatenation of target_system_root and
383 target_sysroot_suffix.
384 %S process STARTFILE_SPEC as a spec. A capital S is actually used here.
385 %E process ENDFILE_SPEC as a spec. A capital E is actually used here.
386 %C process CPP_SPEC as a spec.
387 %1 process CC1_SPEC as a spec.
388 %2 process CC1PLUS_SPEC as a spec.
389 %* substitute the variable part of a matched option. (See below.)
390 Note that each comma in the substituted string is replaced by
391 a single space.
392 %<S remove all occurrences of -S from the command line.
393 Note - this command is position dependent. % commands in the
394 spec string before this one will see -S, % commands in the
395 spec string after this one will not.
396 %>S Similar to "%<S", but keep it in the GCC command line.
397 %<S* remove all occurrences of all switches beginning with -S from the
398 command line.
399 %:function(args)
400 Call the named function FUNCTION, passing it ARGS. ARGS is
401 first processed as a nested spec string, then split into an
402 argument vector in the usual fashion. The function returns
403 a string which is processed as if it had appeared literally
404 as part of the current spec.
405 %{S} substitutes the -S switch, if that switch was given to GCC.
406 If that switch was not specified, this substitutes nothing.
407 Here S is a metasyntactic variable.
408 %{S*} substitutes all the switches specified to GCC whose names start
409 with -S. This is used for -o, -I, etc; switches that take
410 arguments. GCC considers `-o foo' as being one switch whose
411 name starts with `o'. %{o*} would substitute this text,
412 including the space; thus, two arguments would be generated.
413 %{S*&T*} likewise, but preserve order of S and T options (the order
414 of S and T in the spec is not significant). Can be any number
415 of ampersand-separated variables; for each the wild card is
416 optional. Useful for CPP as %{D*&U*&A*}.
418 %{S:X} substitutes X, if the -S switch was given to GCC.
419 %{!S:X} substitutes X, if the -S switch was NOT given to GCC.
420 %{S*:X} substitutes X if one or more switches whose names start
421 with -S was given to GCC. Normally X is substituted only
422 once, no matter how many such switches appeared. However,
423 if %* appears somewhere in X, then X will be substituted
424 once for each matching switch, with the %* replaced by the
425 part of that switch that matched the '*'.
426 %{.S:X} substitutes X, if processing a file with suffix S.
427 %{!.S:X} substitutes X, if NOT processing a file with suffix S.
428 %{,S:X} substitutes X, if processing a file which will use spec S.
429 %{!,S:X} substitutes X, if NOT processing a file which will use spec S.
431 %{S|T:X} substitutes X if either -S or -T was given to GCC. This may be
432 combined with '!', '.', ',', and '*' as above binding stronger
433 than the OR.
434 If %* appears in X, all of the alternatives must be starred, and
435 only the first matching alternative is substituted.
436 %{S:X; if S was given to GCC, substitutes X;
437 T:Y; else if T was given to GCC, substitutes Y;
438 :D} else substitutes D. There can be as many clauses as you need.
439 This may be combined with '.', '!', ',', '|', and '*' as above.
441 %(Spec) processes a specification defined in a specs file as *Spec:
443 The conditional text X in a %{S:X} or similar construct may contain
444 other nested % constructs or spaces, or even newlines. They are
445 processed as usual, as described above. Trailing white space in X is
446 ignored. White space may also appear anywhere on the left side of the
447 colon in these constructs, except between . or * and the corresponding
448 word.
450 The -O, -f, -m, and -W switches are handled specifically in these
451 constructs. If another value of -O or the negated form of a -f, -m, or
452 -W switch is found later in the command line, the earlier switch
453 value is ignored, except with {S*} where S is just one letter; this
454 passes all matching options.
456 The character | at the beginning of the predicate text is used to indicate
457 that a command should be piped to the following command, but only if -pipe
458 is specified.
460 Note that it is built into GCC which switches take arguments and which
461 do not. You might think it would be useful to generalize this to
462 allow each compiler's spec to say which switches take arguments. But
463 this cannot be done in a consistent fashion. GCC cannot even decide
464 which input files have been specified without knowing which switches
465 take arguments, and it must know which input files to compile in order
466 to tell which compilers to run.
468 GCC also knows implicitly that arguments starting in `-l' are to be
469 treated as compiler output files, and passed to the linker in their
470 proper position among the other output files. */
472 /* Define the macros used for specs %a, %l, %L, %S, %C, %1. */
474 /* config.h can define ASM_SPEC to provide extra args to the assembler
475 or extra switch-translations. */
476 #ifndef ASM_SPEC
477 #define ASM_SPEC ""
478 #endif
480 /* config.h can define ASM_FINAL_SPEC to run a post processor after
481 the assembler has run. */
482 #ifndef ASM_FINAL_SPEC
483 #define ASM_FINAL_SPEC ""
484 #endif
486 /* config.h can define CPP_SPEC to provide extra args to the C preprocessor
487 or extra switch-translations. */
488 #ifndef CPP_SPEC
489 #define CPP_SPEC ""
490 #endif
492 /* config.h can define CC1_SPEC to provide extra args to cc1 and cc1plus
493 or extra switch-translations. */
494 #ifndef CC1_SPEC
495 #define CC1_SPEC ""
496 #endif
498 /* config.h can define CC1PLUS_SPEC to provide extra args to cc1plus
499 or extra switch-translations. */
500 #ifndef CC1PLUS_SPEC
501 #define CC1PLUS_SPEC ""
502 #endif
504 /* config.h can define LINK_SPEC to provide extra args to the linker
505 or extra switch-translations. */
506 #ifndef LINK_SPEC
507 #define LINK_SPEC ""
508 #endif
510 /* config.h can define LIB_SPEC to override the default libraries. */
511 #ifndef LIB_SPEC
512 #define LIB_SPEC "%{!shared:%{g*:-lg} %{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}}"
513 #endif
515 /* mudflap specs */
516 #ifndef MFWRAP_SPEC
517 /* XXX: valid only for GNU ld */
518 /* XXX: should exactly match hooks provided by libmudflap.a */
519 #define MFWRAP_SPEC " %{static: %{fmudflap|fmudflapth: \
520 --wrap=malloc --wrap=free --wrap=calloc --wrap=realloc\
521 --wrap=mmap --wrap=mmap64 --wrap=munmap --wrap=alloca\
522 } %{fmudflapth: --wrap=pthread_create\
523 }} %{fmudflap|fmudflapth: --wrap=main}"
524 #endif
525 #ifndef MFLIB_SPEC
526 #define MFLIB_SPEC "%{fmudflap|fmudflapth: -export-dynamic}"
527 #endif
529 /* When using -fsplit-stack we need to wrap pthread_create, in order
530 to initialize the stack guard. We always use wrapping, rather than
531 shared library ordering, and we keep the wrapper function in
532 libgcc. This is not yet a real spec, though it could become one;
533 it is currently just stuffed into LINK_SPEC. FIXME: This wrapping
534 only works with GNU ld and gold. FIXME: This is incompatible with
535 -fmudflap when linking statically, which wants to do its own
536 wrapping. */
537 #define STACK_SPLIT_SPEC " %{fsplit-stack: --wrap=pthread_create}"
539 /* config.h can define LIBGCC_SPEC to override how and when libgcc.a is
540 included. */
541 #ifndef LIBGCC_SPEC
542 #if defined(REAL_LIBGCC_SPEC)
543 #define LIBGCC_SPEC REAL_LIBGCC_SPEC
544 #elif defined(LINK_LIBGCC_SPECIAL_1)
545 /* Have gcc do the search for libgcc.a. */
546 #define LIBGCC_SPEC "libgcc.a%s"
547 #else
548 #define LIBGCC_SPEC "-lgcc"
549 #endif
550 #endif
552 /* config.h can define STARTFILE_SPEC to override the default crt0 files. */
553 #ifndef STARTFILE_SPEC
554 #define STARTFILE_SPEC \
555 "%{!shared:%{pg:gcrt0%O%s}%{!pg:%{p:mcrt0%O%s}%{!p:crt0%O%s}}}"
556 #endif
558 /* config.h can define ENDFILE_SPEC to override the default crtn files. */
559 #ifndef ENDFILE_SPEC
560 #define ENDFILE_SPEC ""
561 #endif
563 #ifndef LINKER_NAME
564 #define LINKER_NAME "collect2"
565 #endif
567 #ifdef HAVE_AS_DEBUG_PREFIX_MAP
568 #define ASM_MAP " %{fdebug-prefix-map=*:--debug-prefix-map %*}"
569 #else
570 #define ASM_MAP ""
571 #endif
573 /* Define ASM_DEBUG_SPEC to be a spec suitable for translating '-g'
574 to the assembler. */
575 #ifndef ASM_DEBUG_SPEC
576 # if defined(DBX_DEBUGGING_INFO) && defined(DWARF2_DEBUGGING_INFO) \
577 && defined(HAVE_AS_GDWARF2_DEBUG_FLAG) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
578 # define ASM_DEBUG_SPEC \
579 (PREFERRED_DEBUGGING_TYPE == DBX_DEBUG \
580 ? "%{!g0:%{gdwarf-2*:--gdwarf2}%{!gdwarf-2*:%{g*:--gstabs}}}" ASM_MAP \
581 : "%{!g0:%{gstabs*:--gstabs}%{!gstabs*:%{g*:--gdwarf2}}}" ASM_MAP)
582 # else
583 # if defined(DBX_DEBUGGING_INFO) && defined(HAVE_AS_GSTABS_DEBUG_FLAG)
584 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gstabs}}" ASM_MAP
585 # endif
586 # if defined(DWARF2_DEBUGGING_INFO) && defined(HAVE_AS_GDWARF2_DEBUG_FLAG)
587 # define ASM_DEBUG_SPEC "%{g*:%{!g0:--gdwarf2}}" ASM_MAP
588 # endif
589 # endif
590 #endif
591 #ifndef ASM_DEBUG_SPEC
592 # define ASM_DEBUG_SPEC ""
593 #endif
595 /* Here is the spec for running the linker, after compiling all files. */
597 /* This is overridable by the target in case they need to specify the
598 -lgcc and -lc order specially, yet not require them to override all
599 of LINK_COMMAND_SPEC. */
600 #ifndef LINK_GCC_C_SEQUENCE_SPEC
601 #define LINK_GCC_C_SEQUENCE_SPEC "%G %L %G"
602 #endif
604 #ifndef LINK_SSP_SPEC
605 #ifdef TARGET_LIBC_PROVIDES_SSP
606 #define LINK_SSP_SPEC "%{fstack-protector:}"
607 #else
608 #define LINK_SSP_SPEC "%{fstack-protector|fstack-protector-all:-lssp_nonshared -lssp}"
609 #endif
610 #endif
612 #ifndef LINK_PIE_SPEC
613 #ifdef HAVE_LD_PIE
614 #define LINK_PIE_SPEC "%{pie:-pie} "
615 #else
616 #define LINK_PIE_SPEC "%{pie:} "
617 #endif
618 #endif
620 #ifndef LINK_BUILDID_SPEC
621 # if defined(HAVE_LD_BUILDID) && defined(ENABLE_LD_BUILDID)
622 # define LINK_BUILDID_SPEC "%{!r:--build-id} "
623 # endif
624 #endif
626 /* Conditional to test whether the LTO plugin is used or not.
627 FIXME: For slim LTO we will need to enable plugin unconditionally. This
628 still cause problems with PLUGIN_LD != LD and when plugin is built but
629 not useable. For GCC 4.6 we don't support slim LTO and thus we can enable
630 plugin only when LTO is enabled. We still honor explicit
631 -fuse-linker-plugin if the linker used understands -plugin. */
633 /* The linker has some plugin support. */
634 #if HAVE_LTO_PLUGIN > 0
635 /* The linker used has full plugin support, use LTO plugin by default. */
636 #if HAVE_LTO_PLUGIN == 2
637 #define PLUGIN_COND "!fno-use-linker-plugin:%{flto|flto=*|fuse-linker-plugin"
638 #define PLUGIN_COND_CLOSE "}"
639 #else
640 /* The linker used has limited plugin support, use LTO plugin with explicit
641 -fuse-linker-plugin. */
642 #define PLUGIN_COND "fuse-linker-plugin"
643 #define PLUGIN_COND_CLOSE ""
644 #endif
645 #define LINK_PLUGIN_SPEC \
646 "%{"PLUGIN_COND": \
647 -plugin %(linker_plugin_file) \
648 -plugin-opt=%(lto_wrapper) \
649 -plugin-opt=-fresolution=%u.res \
650 %{!nostdlib:%{!nodefaultlibs:%:pass-through-libs(%(link_gcc_c_sequence))}} \
651 }"PLUGIN_COND_CLOSE
652 #else
653 /* The linker used doesn't support -plugin, reject -fuse-linker-plugin. */
654 #define LINK_PLUGIN_SPEC "%{fuse-linker-plugin:\
655 %e-fuse-linker-plugin is not supported in this configuration}"
656 #endif
659 /* -u* was put back because both BSD and SysV seem to support it. */
660 /* %{static:} simply prevents an error message if the target machine
661 doesn't handle -static. */
662 /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
663 scripts which exist in user specified directories, or in standard
664 directories. */
665 /* We pass any -flto flags on to the linker, which is expected
666 to understand them. In practice, this means it had better be collect2. */
667 /* %{e*} includes -export-dynamic; see comment in common.opt. */
668 #ifndef LINK_COMMAND_SPEC
669 #define LINK_COMMAND_SPEC "\
670 %{!fsyntax-only:%{!c:%{!M:%{!MM:%{!E:%{!S:\
671 %(linker) " \
672 LINK_PLUGIN_SPEC \
673 "%{flto|flto=*:%<fcompare-debug*} \
674 %{flto} %{flto=*} %l " LINK_PIE_SPEC \
675 "%X %{o*} %{e*} %{N} %{n} %{r}\
676 %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}}\
677 %{static:} %{L*} %(mfwrap) %(link_libgcc) %o\
678 %{fopenmp|ftree-parallelize-loops=*:%:include(libgomp.spec)%(link_gomp)}\
679 %{fgnu-tm:%:include(libitm.spec)%(link_itm)}\
680 %(mflib) " STACK_SPLIT_SPEC "\
681 %{fprofile-arcs|fprofile-generate*|coverage:-lgcov}\
682 %{!nostdlib:%{!nodefaultlibs:%(link_ssp) %(link_gcc_c_sequence)}}\
683 %{!nostdlib:%{!nostartfiles:%E}} %{T*} }}}}}}"
684 #endif
686 #ifndef LINK_LIBGCC_SPEC
687 /* Generate -L options for startfile prefix list. */
688 # define LINK_LIBGCC_SPEC "%D"
689 #endif
691 #ifndef STARTFILE_PREFIX_SPEC
692 # define STARTFILE_PREFIX_SPEC ""
693 #endif
695 #ifndef SYSROOT_SPEC
696 # define SYSROOT_SPEC "--sysroot=%R"
697 #endif
699 #ifndef SYSROOT_SUFFIX_SPEC
700 # define SYSROOT_SUFFIX_SPEC ""
701 #endif
703 #ifndef SYSROOT_HEADERS_SUFFIX_SPEC
704 # define SYSROOT_HEADERS_SUFFIX_SPEC ""
705 #endif
707 static const char *asm_debug = ASM_DEBUG_SPEC;
708 static const char *cpp_spec = CPP_SPEC;
709 static const char *cc1_spec = CC1_SPEC;
710 static const char *cc1plus_spec = CC1PLUS_SPEC;
711 static const char *link_gcc_c_sequence_spec = LINK_GCC_C_SEQUENCE_SPEC;
712 static const char *link_ssp_spec = LINK_SSP_SPEC;
713 static const char *asm_spec = ASM_SPEC;
714 static const char *asm_final_spec = ASM_FINAL_SPEC;
715 static const char *link_spec = LINK_SPEC;
716 static const char *lib_spec = LIB_SPEC;
717 static const char *mfwrap_spec = MFWRAP_SPEC;
718 static const char *mflib_spec = MFLIB_SPEC;
719 static const char *link_gomp_spec = "";
720 static const char *libgcc_spec = LIBGCC_SPEC;
721 static const char *endfile_spec = ENDFILE_SPEC;
722 static const char *startfile_spec = STARTFILE_SPEC;
723 static const char *linker_name_spec = LINKER_NAME;
724 static const char *linker_plugin_file_spec = "";
725 static const char *lto_wrapper_spec = "";
726 static const char *lto_gcc_spec = "";
727 static const char *link_command_spec = LINK_COMMAND_SPEC;
728 static const char *link_libgcc_spec = LINK_LIBGCC_SPEC;
729 static const char *startfile_prefix_spec = STARTFILE_PREFIX_SPEC;
730 static const char *sysroot_spec = SYSROOT_SPEC;
731 static const char *sysroot_suffix_spec = SYSROOT_SUFFIX_SPEC;
732 static const char *sysroot_hdrs_suffix_spec = SYSROOT_HEADERS_SUFFIX_SPEC;
733 static const char *self_spec = "";
735 /* Standard options to cpp, cc1, and as, to reduce duplication in specs.
736 There should be no need to override these in target dependent files,
737 but we need to copy them to the specs file so that newer versions
738 of the GCC driver can correctly drive older tool chains with the
739 appropriate -B options. */
741 /* When cpplib handles traditional preprocessing, get rid of this, and
742 call cc1 (or cc1obj in objc/lang-specs.h) from the main specs so
743 that we default the front end language better. */
744 static const char *trad_capable_cpp =
745 "cc1 -E %{traditional|traditional-cpp:-traditional-cpp}";
747 /* We don't wrap .d files in %W{} since a missing .d file, and
748 therefore no dependency entry, confuses make into thinking a .o
749 file that happens to exist is up-to-date. */
750 static const char *cpp_unique_options =
751 "%{!Q:-quiet} %{nostdinc*} %{C} %{CC} %{v} %{I*&F*} %{P} %I\
752 %{MD:-MD %{!o:%b.d}%{o*:%.d%*}}\
753 %{MMD:-MMD %{!o:%b.d}%{o*:%.d%*}}\
754 %{M} %{MM} %{MF*} %{MG} %{MP} %{MQ*} %{MT*}\
755 %{!E:%{!M:%{!MM:%{!MT:%{!MQ:%{MD|MMD:%{o*:-MQ %*}}}}}}}\
756 %{remap} %{g3|ggdb3|gstabs3|gcoff3|gxcoff3|gvms3:-dD}\
757 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
758 %{H} %C %{D*&U*&A*} %{i*} %Z %i\
759 %{fmudflap:-D_MUDFLAP -include mf-runtime.h}\
760 %{fmudflapth:-D_MUDFLAP -D_MUDFLAPTH -include mf-runtime.h}\
761 %{E|M|MM:%W{o*}}";
763 /* This contains cpp options which are common with cc1_options and are passed
764 only when preprocessing only to avoid duplication. We pass the cc1 spec
765 options to the preprocessor so that it the cc1 spec may manipulate
766 options used to set target flags. Those special target flags settings may
767 in turn cause preprocessor symbols to be defined specially. */
768 static const char *cpp_options =
769 "%(cpp_unique_options) %1 %{m*} %{std*&ansi&trigraphs} %{W*&pedantic*} %{w}\
770 %{f*} %{g*:%{!g0:%{g*} %{!fno-working-directory:-fworking-directory}}} %{O*}\
771 %{undef} %{save-temps*:-fpch-preprocess}";
773 /* This contains cpp options which are not passed when the preprocessor
774 output will be used by another program. */
775 static const char *cpp_debug_options = "%{d*}";
777 /* NB: This is shared amongst all front-ends, except for Ada. */
778 static const char *cc1_options =
779 "%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
780 %{!iplugindir*:%{fplugin*:%:find-plugindir()}}\
781 %1 %{!Q:-quiet} %{!dumpbase:-dumpbase %B} %{d*} %{m*} %{aux-info*}\
782 %{fcompare-debug-second:%:compare-debug-auxbase-opt(%b)} \
783 %{!fcompare-debug-second:%{c|S:%{o*:-auxbase-strip %*}%{!o*:-auxbase %b}}}%{!c:%{!S:-auxbase %b}} \
784 %{g*} %{O*} %{W*&pedantic*} %{w} %{std*&ansi&trigraphs}\
785 %{v:-version} %{pg:-p} %{p} %{f*} %{undef}\
786 %{Qn:-fno-ident} %{Qy:} %{-help:--help}\
787 %{-target-help:--target-help}\
788 %{-version:--version}\
789 %{-help=*:--help=%*}\
790 %{!fsyntax-only:%{S:%W{o*}%{!o*:-o %b.s}}}\
791 %{fsyntax-only:-o %j} %{-param*}\
792 %{fmudflap|fmudflapth:-fno-builtin -fno-merge-constants}\
793 %{coverage:-fprofile-arcs -ftest-coverage}";
795 static const char *asm_options =
796 "%{-target-help:%:print-asm-header()} "
797 #if HAVE_GNU_AS
798 /* If GNU AS is used, then convert -w (no warnings), -I, and -v
799 to the assembler equivalents. */
800 "%{v} %{w:-W} %{I*} "
801 #endif
802 "%a %Y %{c:%W{o*}%{!o*:-o %w%b%O}}%{!c:-o %d%w%u%O}";
804 static const char *invoke_as =
805 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
806 "%{!fwpa:\
807 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
808 %{!S:-o %|.s |\n as %(asm_options) %|.s %A }\
810 #else
811 "%{!fwpa:\
812 %{fcompare-debug=*|fdump-final-insns=*:%:compare-debug-dump-opt()}\
813 %{!S:-o %|.s |\n as %(asm_options) %m.s %A }\
815 #endif
817 /* Some compilers have limits on line lengths, and the multilib_select
818 and/or multilib_matches strings can be very long, so we build them at
819 run time. */
820 static struct obstack multilib_obstack;
821 static const char *multilib_select;
822 static const char *multilib_matches;
823 static const char *multilib_defaults;
824 static const char *multilib_exclusions;
826 /* Check whether a particular argument is a default argument. */
828 #ifndef MULTILIB_DEFAULTS
829 #define MULTILIB_DEFAULTS { "" }
830 #endif
832 static const char *const multilib_defaults_raw[] = MULTILIB_DEFAULTS;
834 #ifndef DRIVER_SELF_SPECS
835 #define DRIVER_SELF_SPECS ""
836 #endif
838 /* Adding -fopenmp should imply pthreads. This is particularly important
839 for targets that use different start files and suchlike. */
840 #ifndef GOMP_SELF_SPECS
841 #define GOMP_SELF_SPECS "%{fopenmp|ftree-parallelize-loops=*: -pthread}"
842 #endif
844 /* Likewise for -fgnu-tm. */
845 #ifndef GTM_SELF_SPECS
846 #define GTM_SELF_SPECS "%{fgnu-tm: -pthread}"
847 #endif
849 static const char *const driver_self_specs[] = {
850 "%{fdump-final-insns:-fdump-final-insns=.} %<fdump-final-insns",
851 DRIVER_SELF_SPECS, CONFIGURE_SPECS, GOMP_SELF_SPECS, GTM_SELF_SPECS
854 #ifndef OPTION_DEFAULT_SPECS
855 #define OPTION_DEFAULT_SPECS { "", "" }
856 #endif
858 struct default_spec
860 const char *name;
861 const char *spec;
864 static const struct default_spec
865 option_default_specs[] = { OPTION_DEFAULT_SPECS };
867 struct user_specs
869 struct user_specs *next;
870 const char *filename;
873 static struct user_specs *user_specs_head, *user_specs_tail;
876 /* Record the mapping from file suffixes for compilation specs. */
878 struct compiler
880 const char *suffix; /* Use this compiler for input files
881 whose names end in this suffix. */
883 const char *spec; /* To use this compiler, run this spec. */
885 const char *cpp_spec; /* If non-NULL, substitute this spec
886 for `%C', rather than the usual
887 cpp_spec. */
888 const int combinable; /* If nonzero, compiler can deal with
889 multiple source files at once (IMA). */
890 const int needs_preprocessing; /* If nonzero, source files need to
891 be run through a preprocessor. */
894 /* Pointer to a vector of `struct compiler' that gives the spec for
895 compiling a file, based on its suffix.
896 A file that does not end in any of these suffixes will be passed
897 unchanged to the loader and nothing else will be done to it.
899 An entry containing two 0s is used to terminate the vector.
901 If multiple entries match a file, the last matching one is used. */
903 static struct compiler *compilers;
905 /* Number of entries in `compilers', not counting the null terminator. */
907 static int n_compilers;
909 /* The default list of file name suffixes and their compilation specs. */
911 static const struct compiler default_compilers[] =
913 /* Add lists of suffixes of known languages here. If those languages
914 were not present when we built the driver, we will hit these copies
915 and be given a more meaningful error than "file not used since
916 linking is not done". */
917 {".m", "#Objective-C", 0, 0, 0}, {".mi", "#Objective-C", 0, 0, 0},
918 {".mm", "#Objective-C++", 0, 0, 0}, {".M", "#Objective-C++", 0, 0, 0},
919 {".mii", "#Objective-C++", 0, 0, 0},
920 {".cc", "#C++", 0, 0, 0}, {".cxx", "#C++", 0, 0, 0},
921 {".cpp", "#C++", 0, 0, 0}, {".cp", "#C++", 0, 0, 0},
922 {".c++", "#C++", 0, 0, 0}, {".C", "#C++", 0, 0, 0},
923 {".CPP", "#C++", 0, 0, 0}, {".ii", "#C++", 0, 0, 0},
924 {".ads", "#Ada", 0, 0, 0}, {".adb", "#Ada", 0, 0, 0},
925 {".f", "#Fortran", 0, 0, 0}, {".F", "#Fortran", 0, 0, 0},
926 {".for", "#Fortran", 0, 0, 0}, {".FOR", "#Fortran", 0, 0, 0},
927 {".ftn", "#Fortran", 0, 0, 0}, {".FTN", "#Fortran", 0, 0, 0},
928 {".fpp", "#Fortran", 0, 0, 0}, {".FPP", "#Fortran", 0, 0, 0},
929 {".f90", "#Fortran", 0, 0, 0}, {".F90", "#Fortran", 0, 0, 0},
930 {".f95", "#Fortran", 0, 0, 0}, {".F95", "#Fortran", 0, 0, 0},
931 {".f03", "#Fortran", 0, 0, 0}, {".F03", "#Fortran", 0, 0, 0},
932 {".f08", "#Fortran", 0, 0, 0}, {".F08", "#Fortran", 0, 0, 0},
933 {".r", "#Ratfor", 0, 0, 0},
934 {".p", "#Pascal", 0, 0, 0}, {".pas", "#Pascal", 0, 0, 0},
935 {".java", "#Java", 0, 0, 0}, {".class", "#Java", 0, 0, 0},
936 {".zip", "#Java", 0, 0, 0}, {".jar", "#Java", 0, 0, 0},
937 {".go", "#Go", 0, 1, 0},
938 /* Next come the entries for C. */
939 {".c", "@c", 0, 0, 1},
940 {"@c",
941 /* cc1 has an integrated ISO C preprocessor. We should invoke the
942 external preprocessor if -save-temps is given. */
943 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
944 %{!E:%{!M:%{!MM:\
945 %{traditional:\
946 %eGNU C no longer supports -traditional without -E}\
947 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
948 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
949 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
950 %(cc1_options)}\
951 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
952 cc1 %(cpp_unique_options) %(cc1_options)}}}\
953 %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 1},
954 {"-",
955 "%{!E:%e-E or -x required when input is from standard input}\
956 %(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)", 0, 0, 0},
957 {".h", "@c-header", 0, 0, 0},
958 {"@c-header",
959 /* cc1 has an integrated ISO C preprocessor. We should invoke the
960 external preprocessor if -save-temps is given. */
961 "%{E|M|MM:%(trad_capable_cpp) %(cpp_options) %(cpp_debug_options)}\
962 %{!E:%{!M:%{!MM:\
963 %{save-temps*|traditional-cpp|no-integrated-cpp:%(trad_capable_cpp) \
964 %(cpp_options) -o %{save-temps*:%b.i} %{!save-temps*:%g.i} \n\
965 cc1 -fpreprocessed %{save-temps*:%b.i} %{!save-temps*:%g.i} \
966 %(cc1_options)\
967 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
968 %W{o*:--output-pch=%*}}%V}\
969 %{!save-temps*:%{!traditional-cpp:%{!no-integrated-cpp:\
970 cc1 %(cpp_unique_options) %(cc1_options)\
971 %{!fdump-ada-spec*:-o %g.s %{!o*:--output-pch=%i.gch}\
972 %W{o*:--output-pch=%*}}%V}}}}}}", 0, 0, 0},
973 {".i", "@cpp-output", 0, 0, 0},
974 {"@cpp-output",
975 "%{!M:%{!MM:%{!E:cc1 -fpreprocessed %i %(cc1_options) %{!fsyntax-only:%(invoke_as)}}}}", 0, 0, 0},
976 {".s", "@assembler", 0, 0, 0},
977 {"@assembler",
978 "%{!M:%{!MM:%{!E:%{!S:as %(asm_debug) %(asm_options) %i %A }}}}", 0, 0, 0},
979 {".sx", "@assembler-with-cpp", 0, 0, 0},
980 {".S", "@assembler-with-cpp", 0, 0, 0},
981 {"@assembler-with-cpp",
982 #ifdef AS_NEEDS_DASH_FOR_PIPED_INPUT
983 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
984 %{E|M|MM:%(cpp_debug_options)}\
985 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
986 as %(asm_debug) %(asm_options) %|.s %A }}}}"
987 #else
988 "%(trad_capable_cpp) -lang-asm %(cpp_options) -fno-directives-only\
989 %{E|M|MM:%(cpp_debug_options)}\
990 %{!M:%{!MM:%{!E:%{!S:-o %|.s |\n\
991 as %(asm_debug) %(asm_options) %m.s %A }}}}"
992 #endif
993 , 0, 0, 0},
995 #include "specs.h"
996 /* Mark end of table. */
997 {0, 0, 0, 0, 0}
1000 /* Number of elements in default_compilers, not counting the terminator. */
1002 static const int n_default_compilers = ARRAY_SIZE (default_compilers) - 1;
1004 typedef char *char_p; /* For DEF_VEC_P. */
1005 DEF_VEC_P(char_p);
1006 DEF_VEC_ALLOC_P(char_p,heap);
1008 /* A vector of options to give to the linker.
1009 These options are accumulated by %x,
1010 and substituted into the linker command with %X. */
1011 static VEC(char_p,heap) *linker_options;
1013 /* A vector of options to give to the assembler.
1014 These options are accumulated by -Wa,
1015 and substituted into the assembler command with %Y. */
1016 static VEC(char_p,heap) *assembler_options;
1018 /* A vector of options to give to the preprocessor.
1019 These options are accumulated by -Wp,
1020 and substituted into the preprocessor command with %Z. */
1021 static VEC(char_p,heap) *preprocessor_options;
1023 static char *
1024 skip_whitespace (char *p)
1026 while (1)
1028 /* A fully-blank line is a delimiter in the SPEC file and shouldn't
1029 be considered whitespace. */
1030 if (p[0] == '\n' && p[1] == '\n' && p[2] == '\n')
1031 return p + 1;
1032 else if (*p == '\n' || *p == ' ' || *p == '\t')
1033 p++;
1034 else if (*p == '#')
1036 while (*p != '\n')
1037 p++;
1038 p++;
1040 else
1041 break;
1044 return p;
1046 /* Structures to keep track of prefixes to try when looking for files. */
1048 struct prefix_list
1050 const char *prefix; /* String to prepend to the path. */
1051 struct prefix_list *next; /* Next in linked list. */
1052 int require_machine_suffix; /* Don't use without machine_suffix. */
1053 /* 2 means try both machine_suffix and just_machine_suffix. */
1054 int priority; /* Sort key - priority within list. */
1055 int os_multilib; /* 1 if OS multilib scheme should be used,
1056 0 for GCC multilib scheme. */
1059 struct path_prefix
1061 struct prefix_list *plist; /* List of prefixes to try */
1062 int max_len; /* Max length of a prefix in PLIST */
1063 const char *name; /* Name of this list (used in config stuff) */
1066 /* List of prefixes to try when looking for executables. */
1068 static struct path_prefix exec_prefixes = { 0, 0, "exec" };
1070 /* List of prefixes to try when looking for startup (crt0) files. */
1072 static struct path_prefix startfile_prefixes = { 0, 0, "startfile" };
1074 /* List of prefixes to try when looking for include files. */
1076 static struct path_prefix include_prefixes = { 0, 0, "include" };
1078 /* Suffix to attach to directories searched for commands.
1079 This looks like `MACHINE/VERSION/'. */
1081 static const char *machine_suffix = 0;
1083 /* Suffix to attach to directories searched for commands.
1084 This is just `MACHINE/'. */
1086 static const char *just_machine_suffix = 0;
1088 /* Adjusted value of GCC_EXEC_PREFIX envvar. */
1090 static const char *gcc_exec_prefix;
1092 /* Adjusted value of standard_libexec_prefix. */
1094 static const char *gcc_libexec_prefix;
1096 /* Default prefixes to attach to command names. */
1098 #ifndef STANDARD_STARTFILE_PREFIX_1
1099 #define STANDARD_STARTFILE_PREFIX_1 "/lib/"
1100 #endif
1101 #ifndef STANDARD_STARTFILE_PREFIX_2
1102 #define STANDARD_STARTFILE_PREFIX_2 "/usr/lib/"
1103 #endif
1105 #ifdef CROSS_DIRECTORY_STRUCTURE /* Don't use these prefixes for a cross compiler. */
1106 #undef MD_EXEC_PREFIX
1107 #undef MD_STARTFILE_PREFIX
1108 #undef MD_STARTFILE_PREFIX_1
1109 #endif
1111 /* If no prefixes defined, use the null string, which will disable them. */
1112 #ifndef MD_EXEC_PREFIX
1113 #define MD_EXEC_PREFIX ""
1114 #endif
1115 #ifndef MD_STARTFILE_PREFIX
1116 #define MD_STARTFILE_PREFIX ""
1117 #endif
1118 #ifndef MD_STARTFILE_PREFIX_1
1119 #define MD_STARTFILE_PREFIX_1 ""
1120 #endif
1122 /* These directories are locations set at configure-time based on the
1123 --prefix option provided to configure. Their initializers are
1124 defined in Makefile.in. These paths are not *directly* used when
1125 gcc_exec_prefix is set because, in that case, we know where the
1126 compiler has been installed, and use paths relative to that
1127 location instead. */
1128 static const char *const standard_exec_prefix = STANDARD_EXEC_PREFIX;
1129 static const char *const standard_libexec_prefix = STANDARD_LIBEXEC_PREFIX;
1130 static const char *const standard_bindir_prefix = STANDARD_BINDIR_PREFIX;
1131 static const char *const standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
1133 /* For native compilers, these are well-known paths containing
1134 components that may be provided by the system. For cross
1135 compilers, these paths are not used. */
1136 static const char *md_exec_prefix = MD_EXEC_PREFIX;
1137 static const char *md_startfile_prefix = MD_STARTFILE_PREFIX;
1138 static const char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
1139 static const char *const standard_startfile_prefix_1
1140 = STANDARD_STARTFILE_PREFIX_1;
1141 static const char *const standard_startfile_prefix_2
1142 = STANDARD_STARTFILE_PREFIX_2;
1144 /* A relative path to be used in finding the location of tools
1145 relative to the driver. */
1146 static const char *const tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
1148 /* Subdirectory to use for locating libraries. Set by
1149 set_multilib_dir based on the compilation options. */
1151 static const char *multilib_dir;
1153 /* Subdirectory to use for locating libraries in OS conventions. Set by
1154 set_multilib_dir based on the compilation options. */
1156 static const char *multilib_os_dir;
1158 /* Structure to keep track of the specs that have been defined so far.
1159 These are accessed using %(specname) in a compiler or link
1160 spec. */
1162 struct spec_list
1164 /* The following 2 fields must be first */
1165 /* to allow EXTRA_SPECS to be initialized */
1166 const char *name; /* name of the spec. */
1167 const char *ptr; /* available ptr if no static pointer */
1169 /* The following fields are not initialized */
1170 /* by EXTRA_SPECS */
1171 const char **ptr_spec; /* pointer to the spec itself. */
1172 struct spec_list *next; /* Next spec in linked list. */
1173 int name_len; /* length of the name */
1174 bool user_p; /* whether string come from file spec. */
1175 bool alloc_p; /* whether string was allocated */
1178 #define INIT_STATIC_SPEC(NAME,PTR) \
1179 { NAME, NULL, PTR, (struct spec_list *) 0, sizeof (NAME) - 1, false, false }
1181 /* List of statically defined specs. */
1182 static struct spec_list static_specs[] =
1184 INIT_STATIC_SPEC ("asm", &asm_spec),
1185 INIT_STATIC_SPEC ("asm_debug", &asm_debug),
1186 INIT_STATIC_SPEC ("asm_final", &asm_final_spec),
1187 INIT_STATIC_SPEC ("asm_options", &asm_options),
1188 INIT_STATIC_SPEC ("invoke_as", &invoke_as),
1189 INIT_STATIC_SPEC ("cpp", &cpp_spec),
1190 INIT_STATIC_SPEC ("cpp_options", &cpp_options),
1191 INIT_STATIC_SPEC ("cpp_debug_options", &cpp_debug_options),
1192 INIT_STATIC_SPEC ("cpp_unique_options", &cpp_unique_options),
1193 INIT_STATIC_SPEC ("trad_capable_cpp", &trad_capable_cpp),
1194 INIT_STATIC_SPEC ("cc1", &cc1_spec),
1195 INIT_STATIC_SPEC ("cc1_options", &cc1_options),
1196 INIT_STATIC_SPEC ("cc1plus", &cc1plus_spec),
1197 INIT_STATIC_SPEC ("link_gcc_c_sequence", &link_gcc_c_sequence_spec),
1198 INIT_STATIC_SPEC ("link_ssp", &link_ssp_spec),
1199 INIT_STATIC_SPEC ("endfile", &endfile_spec),
1200 INIT_STATIC_SPEC ("link", &link_spec),
1201 INIT_STATIC_SPEC ("lib", &lib_spec),
1202 INIT_STATIC_SPEC ("mfwrap", &mfwrap_spec),
1203 INIT_STATIC_SPEC ("mflib", &mflib_spec),
1204 INIT_STATIC_SPEC ("link_gomp", &link_gomp_spec),
1205 INIT_STATIC_SPEC ("libgcc", &libgcc_spec),
1206 INIT_STATIC_SPEC ("startfile", &startfile_spec),
1207 INIT_STATIC_SPEC ("cross_compile", &cross_compile),
1208 INIT_STATIC_SPEC ("version", &compiler_version),
1209 INIT_STATIC_SPEC ("multilib", &multilib_select),
1210 INIT_STATIC_SPEC ("multilib_defaults", &multilib_defaults),
1211 INIT_STATIC_SPEC ("multilib_extra", &multilib_extra),
1212 INIT_STATIC_SPEC ("multilib_matches", &multilib_matches),
1213 INIT_STATIC_SPEC ("multilib_exclusions", &multilib_exclusions),
1214 INIT_STATIC_SPEC ("multilib_options", &multilib_options),
1215 INIT_STATIC_SPEC ("linker", &linker_name_spec),
1216 INIT_STATIC_SPEC ("linker_plugin_file", &linker_plugin_file_spec),
1217 INIT_STATIC_SPEC ("lto_wrapper", &lto_wrapper_spec),
1218 INIT_STATIC_SPEC ("lto_gcc", &lto_gcc_spec),
1219 INIT_STATIC_SPEC ("link_libgcc", &link_libgcc_spec),
1220 INIT_STATIC_SPEC ("md_exec_prefix", &md_exec_prefix),
1221 INIT_STATIC_SPEC ("md_startfile_prefix", &md_startfile_prefix),
1222 INIT_STATIC_SPEC ("md_startfile_prefix_1", &md_startfile_prefix_1),
1223 INIT_STATIC_SPEC ("startfile_prefix_spec", &startfile_prefix_spec),
1224 INIT_STATIC_SPEC ("sysroot_spec", &sysroot_spec),
1225 INIT_STATIC_SPEC ("sysroot_suffix_spec", &sysroot_suffix_spec),
1226 INIT_STATIC_SPEC ("sysroot_hdrs_suffix_spec", &sysroot_hdrs_suffix_spec),
1227 INIT_STATIC_SPEC ("self_spec", &self_spec),
1230 #ifdef EXTRA_SPECS /* additional specs needed */
1231 /* Structure to keep track of just the first two args of a spec_list.
1232 That is all that the EXTRA_SPECS macro gives us. */
1233 struct spec_list_1
1235 const char *const name;
1236 const char *const ptr;
1239 static const struct spec_list_1 extra_specs_1[] = { EXTRA_SPECS };
1240 static struct spec_list *extra_specs = (struct spec_list *) 0;
1241 #endif
1243 /* List of dynamically allocates specs that have been defined so far. */
1245 static struct spec_list *specs = (struct spec_list *) 0;
1247 /* List of static spec functions. */
1249 static const struct spec_function static_spec_functions[] =
1251 { "getenv", getenv_spec_function },
1252 { "if-exists", if_exists_spec_function },
1253 { "if-exists-else", if_exists_else_spec_function },
1254 { "replace-outfile", replace_outfile_spec_function },
1255 { "remove-outfile", remove_outfile_spec_function },
1256 { "version-compare", version_compare_spec_function },
1257 { "include", include_spec_function },
1258 { "find-file", find_file_spec_function },
1259 { "find-plugindir", find_plugindir_spec_function },
1260 { "print-asm-header", print_asm_header_spec_function },
1261 { "compare-debug-dump-opt", compare_debug_dump_opt_spec_function },
1262 { "compare-debug-self-opt", compare_debug_self_opt_spec_function },
1263 { "compare-debug-auxbase-opt", compare_debug_auxbase_opt_spec_function },
1264 { "pass-through-libs", pass_through_libs_spec_func },
1265 #ifdef EXTRA_SPEC_FUNCTIONS
1266 EXTRA_SPEC_FUNCTIONS
1267 #endif
1268 { 0, 0 }
1271 static int processing_spec_function;
1273 /* Add appropriate libgcc specs to OBSTACK, taking into account
1274 various permutations of -shared-libgcc, -shared, and such. */
1276 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1278 #ifndef USE_LD_AS_NEEDED
1279 #define USE_LD_AS_NEEDED 0
1280 #endif
1282 static void
1283 init_gcc_specs (struct obstack *obstack, const char *shared_name,
1284 const char *static_name, const char *eh_name)
1286 char *buf;
1288 buf = concat ("%{static|static-libgcc:", static_name, " ", eh_name, "}"
1289 "%{!static:%{!static-libgcc:"
1290 #if USE_LD_AS_NEEDED
1291 "%{!shared-libgcc:",
1292 static_name, " --as-needed ", shared_name, " --no-as-needed"
1294 "%{shared-libgcc:",
1295 shared_name, "%{!shared: ", static_name, "}"
1297 #else
1298 "%{!shared:"
1299 "%{!shared-libgcc:", static_name, " ", eh_name, "}"
1300 "%{shared-libgcc:", shared_name, " ", static_name, "}"
1302 #ifdef LINK_EH_SPEC
1303 "%{shared:"
1304 "%{shared-libgcc:", shared_name, "}"
1305 "%{!shared-libgcc:", static_name, "}"
1307 #else
1308 "%{shared:", shared_name, "}"
1309 #endif
1310 #endif
1311 "}}", NULL);
1313 obstack_grow (obstack, buf, strlen (buf));
1314 free (buf);
1316 #endif /* ENABLE_SHARED_LIBGCC */
1318 /* Initialize the specs lookup routines. */
1320 static void
1321 init_spec (void)
1323 struct spec_list *next = (struct spec_list *) 0;
1324 struct spec_list *sl = (struct spec_list *) 0;
1325 int i;
1327 if (specs)
1328 return; /* Already initialized. */
1330 if (verbose_flag)
1331 fnotice (stderr, "Using built-in specs.\n");
1333 #ifdef EXTRA_SPECS
1334 extra_specs = XCNEWVEC (struct spec_list, ARRAY_SIZE (extra_specs_1));
1336 for (i = ARRAY_SIZE (extra_specs_1) - 1; i >= 0; i--)
1338 sl = &extra_specs[i];
1339 sl->name = extra_specs_1[i].name;
1340 sl->ptr = extra_specs_1[i].ptr;
1341 sl->next = next;
1342 sl->name_len = strlen (sl->name);
1343 sl->ptr_spec = &sl->ptr;
1344 next = sl;
1346 #endif
1348 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1350 sl = &static_specs[i];
1351 sl->next = next;
1352 next = sl;
1355 #if defined(ENABLE_SHARED_LIBGCC) && !defined(REAL_LIBGCC_SPEC)
1356 /* ??? If neither -shared-libgcc nor --static-libgcc was
1357 seen, then we should be making an educated guess. Some proposed
1358 heuristics for ELF include:
1360 (1) If "-Wl,--export-dynamic", then it's a fair bet that the
1361 program will be doing dynamic loading, which will likely
1362 need the shared libgcc.
1364 (2) If "-ldl", then it's also a fair bet that we're doing
1365 dynamic loading.
1367 (3) For each ET_DYN we're linking against (either through -lfoo
1368 or /some/path/foo.so), check to see whether it or one of
1369 its dependencies depends on a shared libgcc.
1371 (4) If "-shared"
1373 If the runtime is fixed to look for program headers instead
1374 of calling __register_frame_info at all, for each object,
1375 use the shared libgcc if any EH symbol referenced.
1377 If crtstuff is fixed to not invoke __register_frame_info
1378 automatically, for each object, use the shared libgcc if
1379 any non-empty unwind section found.
1381 Doing any of this probably requires invoking an external program to
1382 do the actual object file scanning. */
1384 const char *p = libgcc_spec;
1385 int in_sep = 1;
1387 /* Transform the extant libgcc_spec into one that uses the shared libgcc
1388 when given the proper command line arguments. */
1389 while (*p)
1391 if (in_sep && *p == '-' && strncmp (p, "-lgcc", 5) == 0)
1393 init_gcc_specs (&obstack,
1394 "-lgcc_s"
1395 #ifdef USE_LIBUNWIND_EXCEPTIONS
1396 " -lunwind"
1397 #endif
1399 "-lgcc",
1400 "-lgcc_eh"
1401 #ifdef USE_LIBUNWIND_EXCEPTIONS
1402 # ifdef HAVE_LD_STATIC_DYNAMIC
1403 " %{!static:" LD_STATIC_OPTION "} -lunwind"
1404 " %{!static:" LD_DYNAMIC_OPTION "}"
1405 # else
1406 " -lunwind"
1407 # endif
1408 #endif
1411 p += 5;
1412 in_sep = 0;
1414 else if (in_sep && *p == 'l' && strncmp (p, "libgcc.a%s", 10) == 0)
1416 /* Ug. We don't know shared library extensions. Hope that
1417 systems that use this form don't do shared libraries. */
1418 init_gcc_specs (&obstack,
1419 "-lgcc_s",
1420 "libgcc.a%s",
1421 "libgcc_eh.a%s"
1422 #ifdef USE_LIBUNWIND_EXCEPTIONS
1423 " -lunwind"
1424 #endif
1426 p += 10;
1427 in_sep = 0;
1429 else
1431 obstack_1grow (&obstack, *p);
1432 in_sep = (*p == ' ');
1433 p += 1;
1437 obstack_1grow (&obstack, '\0');
1438 libgcc_spec = XOBFINISH (&obstack, const char *);
1440 #endif
1441 #ifdef USE_AS_TRADITIONAL_FORMAT
1442 /* Prepend "--traditional-format" to whatever asm_spec we had before. */
1444 static const char tf[] = "--traditional-format ";
1445 obstack_grow (&obstack, tf, sizeof(tf) - 1);
1446 obstack_grow0 (&obstack, asm_spec, strlen (asm_spec));
1447 asm_spec = XOBFINISH (&obstack, const char *);
1449 #endif
1451 #if defined LINK_EH_SPEC || defined LINK_BUILDID_SPEC || \
1452 defined LINKER_HASH_STYLE
1453 # ifdef LINK_BUILDID_SPEC
1454 /* Prepend LINK_BUILDID_SPEC to whatever link_spec we had before. */
1455 obstack_grow (&obstack, LINK_BUILDID_SPEC, sizeof(LINK_BUILDID_SPEC) - 1);
1456 # endif
1457 # ifdef LINK_EH_SPEC
1458 /* Prepend LINK_EH_SPEC to whatever link_spec we had before. */
1459 obstack_grow (&obstack, LINK_EH_SPEC, sizeof(LINK_EH_SPEC) - 1);
1460 # endif
1461 # ifdef LINKER_HASH_STYLE
1462 /* Prepend --hash-style=LINKER_HASH_STYLE to whatever link_spec we had
1463 before. */
1465 static const char hash_style[] = "--hash-style=";
1466 obstack_grow (&obstack, hash_style, sizeof(hash_style) - 1);
1467 obstack_grow (&obstack, LINKER_HASH_STYLE, sizeof(LINKER_HASH_STYLE) - 1);
1468 obstack_1grow (&obstack, ' ');
1470 # endif
1471 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
1472 link_spec = XOBFINISH (&obstack, const char *);
1473 #endif
1475 specs = sl;
1478 /* Change the value of spec NAME to SPEC. If SPEC is empty, then the spec is
1479 removed; If the spec starts with a + then SPEC is added to the end of the
1480 current spec. */
1482 static void
1483 set_spec (const char *name, const char *spec, bool user_p)
1485 struct spec_list *sl;
1486 const char *old_spec;
1487 int name_len = strlen (name);
1488 int i;
1490 /* If this is the first call, initialize the statically allocated specs. */
1491 if (!specs)
1493 struct spec_list *next = (struct spec_list *) 0;
1494 for (i = ARRAY_SIZE (static_specs) - 1; i >= 0; i--)
1496 sl = &static_specs[i];
1497 sl->next = next;
1498 next = sl;
1500 specs = sl;
1503 /* See if the spec already exists. */
1504 for (sl = specs; sl; sl = sl->next)
1505 if (name_len == sl->name_len && !strcmp (sl->name, name))
1506 break;
1508 if (!sl)
1510 /* Not found - make it. */
1511 sl = XNEW (struct spec_list);
1512 sl->name = xstrdup (name);
1513 sl->name_len = name_len;
1514 sl->ptr_spec = &sl->ptr;
1515 sl->alloc_p = 0;
1516 *(sl->ptr_spec) = "";
1517 sl->next = specs;
1518 specs = sl;
1521 old_spec = *(sl->ptr_spec);
1522 *(sl->ptr_spec) = ((spec[0] == '+' && ISSPACE ((unsigned char)spec[1]))
1523 ? concat (old_spec, spec + 1, NULL)
1524 : xstrdup (spec));
1526 #ifdef DEBUG_SPECS
1527 if (verbose_flag)
1528 fnotice (stderr, "Setting spec %s to '%s'\n\n", name, *(sl->ptr_spec));
1529 #endif
1531 /* Free the old spec. */
1532 if (old_spec && sl->alloc_p)
1533 free (CONST_CAST(char *, old_spec));
1535 sl->user_p = user_p;
1536 sl->alloc_p = true;
1539 /* Accumulate a command (program name and args), and run it. */
1541 typedef const char *const_char_p; /* For DEF_VEC_P. */
1542 DEF_VEC_P(const_char_p);
1543 DEF_VEC_ALLOC_P(const_char_p,heap);
1545 /* Vector of pointers to arguments in the current line of specifications. */
1547 static VEC(const_char_p,heap) *argbuf;
1549 /* Position in the argbuf vector containing the name of the output file
1550 (the value associated with the "-o" flag). */
1552 static int have_o_argbuf_index = 0;
1554 /* Were the options -c, -S or -E passed. */
1555 static int have_c = 0;
1557 /* Was the option -o passed. */
1558 static int have_o = 0;
1560 /* This is the list of suffixes and codes (%g/%u/%U/%j) and the associated
1561 temp file. If the HOST_BIT_BUCKET is used for %j, no entry is made for
1562 it here. */
1564 static struct temp_name {
1565 const char *suffix; /* suffix associated with the code. */
1566 int length; /* strlen (suffix). */
1567 int unique; /* Indicates whether %g or %u/%U was used. */
1568 const char *filename; /* associated filename. */
1569 int filename_length; /* strlen (filename). */
1570 struct temp_name *next;
1571 } *temp_names;
1573 /* Number of commands executed so far. */
1575 static int execution_count;
1577 /* Number of commands that exited with a signal. */
1579 static int signal_count;
1581 /* Allocate the argument vector. */
1583 static void
1584 alloc_args (void)
1586 argbuf = VEC_alloc (const_char_p, heap, 10);
1589 /* Clear out the vector of arguments (after a command is executed). */
1591 static void
1592 clear_args (void)
1594 VEC_truncate (const_char_p, argbuf, 0);
1597 /* Add one argument to the vector at the end.
1598 This is done when a space is seen or at the end of the line.
1599 If DELETE_ALWAYS is nonzero, the arg is a filename
1600 and the file should be deleted eventually.
1601 If DELETE_FAILURE is nonzero, the arg is a filename
1602 and the file should be deleted if this compilation fails. */
1604 static void
1605 store_arg (const char *arg, int delete_always, int delete_failure)
1607 VEC_safe_push (const_char_p, heap, argbuf, arg);
1609 if (strcmp (arg, "-o") == 0)
1610 have_o_argbuf_index = VEC_length (const_char_p, argbuf);
1611 if (delete_always || delete_failure)
1613 const char *p;
1614 /* If the temporary file we should delete is specified as
1615 part of a joined argument extract the filename. */
1616 if (arg[0] == '-'
1617 && (p = strrchr (arg, '=')))
1618 arg = p + 1;
1619 record_temp_file (arg, delete_always, delete_failure);
1623 /* Load specs from a file name named FILENAME, replacing occurrences of
1624 various different types of line-endings, \r\n, \n\r and just \r, with
1625 a single \n. */
1627 static char *
1628 load_specs (const char *filename)
1630 int desc;
1631 int readlen;
1632 struct stat statbuf;
1633 char *buffer;
1634 char *buffer_p;
1635 char *specs;
1636 char *specs_p;
1638 if (verbose_flag)
1639 fnotice (stderr, "Reading specs from %s\n", filename);
1641 /* Open and stat the file. */
1642 desc = open (filename, O_RDONLY, 0);
1643 if (desc < 0)
1644 pfatal_with_name (filename);
1645 if (stat (filename, &statbuf) < 0)
1646 pfatal_with_name (filename);
1648 /* Read contents of file into BUFFER. */
1649 buffer = XNEWVEC (char, statbuf.st_size + 1);
1650 readlen = read (desc, buffer, (unsigned) statbuf.st_size);
1651 if (readlen < 0)
1652 pfatal_with_name (filename);
1653 buffer[readlen] = 0;
1654 close (desc);
1656 specs = XNEWVEC (char, readlen + 1);
1657 specs_p = specs;
1658 for (buffer_p = buffer; buffer_p && *buffer_p; buffer_p++)
1660 int skip = 0;
1661 char c = *buffer_p;
1662 if (c == '\r')
1664 if (buffer_p > buffer && *(buffer_p - 1) == '\n') /* \n\r */
1665 skip = 1;
1666 else if (*(buffer_p + 1) == '\n') /* \r\n */
1667 skip = 1;
1668 else /* \r */
1669 c = '\n';
1671 if (! skip)
1672 *specs_p++ = c;
1674 *specs_p = '\0';
1676 free (buffer);
1677 return (specs);
1680 /* Read compilation specs from a file named FILENAME,
1681 replacing the default ones.
1683 A suffix which starts with `*' is a definition for
1684 one of the machine-specific sub-specs. The "suffix" should be
1685 *asm, *cc1, *cpp, *link, *startfile, etc.
1686 The corresponding spec is stored in asm_spec, etc.,
1687 rather than in the `compilers' vector.
1689 Anything invalid in the file is a fatal error. */
1691 static void
1692 read_specs (const char *filename, bool main_p, bool user_p)
1694 char *buffer;
1695 char *p;
1697 buffer = load_specs (filename);
1699 /* Scan BUFFER for specs, putting them in the vector. */
1700 p = buffer;
1701 while (1)
1703 char *suffix;
1704 char *spec;
1705 char *in, *out, *p1, *p2, *p3;
1707 /* Advance P in BUFFER to the next nonblank nocomment line. */
1708 p = skip_whitespace (p);
1709 if (*p == 0)
1710 break;
1712 /* Is this a special command that starts with '%'? */
1713 /* Don't allow this for the main specs file, since it would
1714 encourage people to overwrite it. */
1715 if (*p == '%' && !main_p)
1717 p1 = p;
1718 while (*p && *p != '\n')
1719 p++;
1721 /* Skip '\n'. */
1722 p++;
1724 if (!strncmp (p1, "%include", sizeof ("%include") - 1)
1725 && (p1[sizeof "%include" - 1] == ' '
1726 || p1[sizeof "%include" - 1] == '\t'))
1728 char *new_filename;
1730 p1 += sizeof ("%include");
1731 while (*p1 == ' ' || *p1 == '\t')
1732 p1++;
1734 if (*p1++ != '<' || p[-2] != '>')
1735 fatal_error ("specs %%include syntax malformed after "
1736 "%ld characters",
1737 (long) (p1 - buffer + 1));
1739 p[-2] = '\0';
1740 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1741 read_specs (new_filename ? new_filename : p1, false, user_p);
1742 continue;
1744 else if (!strncmp (p1, "%include_noerr", sizeof "%include_noerr" - 1)
1745 && (p1[sizeof "%include_noerr" - 1] == ' '
1746 || p1[sizeof "%include_noerr" - 1] == '\t'))
1748 char *new_filename;
1750 p1 += sizeof "%include_noerr";
1751 while (*p1 == ' ' || *p1 == '\t')
1752 p1++;
1754 if (*p1++ != '<' || p[-2] != '>')
1755 fatal_error ("specs %%include syntax malformed after "
1756 "%ld characters",
1757 (long) (p1 - buffer + 1));
1759 p[-2] = '\0';
1760 new_filename = find_a_file (&startfile_prefixes, p1, R_OK, true);
1761 if (new_filename)
1762 read_specs (new_filename, false, user_p);
1763 else if (verbose_flag)
1764 fnotice (stderr, "could not find specs file %s\n", p1);
1765 continue;
1767 else if (!strncmp (p1, "%rename", sizeof "%rename" - 1)
1768 && (p1[sizeof "%rename" - 1] == ' '
1769 || p1[sizeof "%rename" - 1] == '\t'))
1771 int name_len;
1772 struct spec_list *sl;
1773 struct spec_list *newsl;
1775 /* Get original name. */
1776 p1 += sizeof "%rename";
1777 while (*p1 == ' ' || *p1 == '\t')
1778 p1++;
1780 if (! ISALPHA ((unsigned char) *p1))
1781 fatal_error ("specs %%rename syntax malformed after "
1782 "%ld characters",
1783 (long) (p1 - buffer));
1785 p2 = p1;
1786 while (*p2 && !ISSPACE ((unsigned char) *p2))
1787 p2++;
1789 if (*p2 != ' ' && *p2 != '\t')
1790 fatal_error ("specs %%rename syntax malformed after "
1791 "%ld characters",
1792 (long) (p2 - buffer));
1794 name_len = p2 - p1;
1795 *p2++ = '\0';
1796 while (*p2 == ' ' || *p2 == '\t')
1797 p2++;
1799 if (! ISALPHA ((unsigned char) *p2))
1800 fatal_error ("specs %%rename syntax malformed after "
1801 "%ld characters",
1802 (long) (p2 - buffer));
1804 /* Get new spec name. */
1805 p3 = p2;
1806 while (*p3 && !ISSPACE ((unsigned char) *p3))
1807 p3++;
1809 if (p3 != p - 1)
1810 fatal_error ("specs %%rename syntax malformed after "
1811 "%ld characters",
1812 (long) (p3 - buffer));
1813 *p3 = '\0';
1815 for (sl = specs; sl; sl = sl->next)
1816 if (name_len == sl->name_len && !strcmp (sl->name, p1))
1817 break;
1819 if (!sl)
1820 fatal_error ("specs %s spec was not found to be renamed", p1);
1822 if (strcmp (p1, p2) == 0)
1823 continue;
1825 for (newsl = specs; newsl; newsl = newsl->next)
1826 if (strcmp (newsl->name, p2) == 0)
1827 fatal_error ("%s: attempt to rename spec %qs to "
1828 "already defined spec %qs",
1829 filename, p1, p2);
1831 if (verbose_flag)
1833 fnotice (stderr, "rename spec %s to %s\n", p1, p2);
1834 #ifdef DEBUG_SPECS
1835 fnotice (stderr, "spec is '%s'\n\n", *(sl->ptr_spec));
1836 #endif
1839 set_spec (p2, *(sl->ptr_spec), user_p);
1840 if (sl->alloc_p)
1841 free (CONST_CAST (char *, *(sl->ptr_spec)));
1843 *(sl->ptr_spec) = "";
1844 sl->alloc_p = 0;
1845 continue;
1847 else
1848 fatal_error ("specs unknown %% command after %ld characters",
1849 (long) (p1 - buffer));
1852 /* Find the colon that should end the suffix. */
1853 p1 = p;
1854 while (*p1 && *p1 != ':' && *p1 != '\n')
1855 p1++;
1857 /* The colon shouldn't be missing. */
1858 if (*p1 != ':')
1859 fatal_error ("specs file malformed after %ld characters",
1860 (long) (p1 - buffer));
1862 /* Skip back over trailing whitespace. */
1863 p2 = p1;
1864 while (p2 > buffer && (p2[-1] == ' ' || p2[-1] == '\t'))
1865 p2--;
1867 /* Copy the suffix to a string. */
1868 suffix = save_string (p, p2 - p);
1869 /* Find the next line. */
1870 p = skip_whitespace (p1 + 1);
1871 if (p[1] == 0)
1872 fatal_error ("specs file malformed after %ld characters",
1873 (long) (p - buffer));
1875 p1 = p;
1876 /* Find next blank line or end of string. */
1877 while (*p1 && !(*p1 == '\n' && (p1[1] == '\n' || p1[1] == '\0')))
1878 p1++;
1880 /* Specs end at the blank line and do not include the newline. */
1881 spec = save_string (p, p1 - p);
1882 p = p1;
1884 /* Delete backslash-newline sequences from the spec. */
1885 in = spec;
1886 out = spec;
1887 while (*in != 0)
1889 if (in[0] == '\\' && in[1] == '\n')
1890 in += 2;
1891 else if (in[0] == '#')
1892 while (*in && *in != '\n')
1893 in++;
1895 else
1896 *out++ = *in++;
1898 *out = 0;
1900 if (suffix[0] == '*')
1902 if (! strcmp (suffix, "*link_command"))
1903 link_command_spec = spec;
1904 else
1905 set_spec (suffix + 1, spec, user_p);
1907 else
1909 /* Add this pair to the vector. */
1910 compilers
1911 = XRESIZEVEC (struct compiler, compilers, n_compilers + 2);
1913 compilers[n_compilers].suffix = suffix;
1914 compilers[n_compilers].spec = spec;
1915 n_compilers++;
1916 memset (&compilers[n_compilers], 0, sizeof compilers[n_compilers]);
1919 if (*suffix == 0)
1920 link_command_spec = spec;
1923 if (link_command_spec == 0)
1924 fatal_error ("spec file has no spec for linking");
1927 /* Record the names of temporary files we tell compilers to write,
1928 and delete them at the end of the run. */
1930 /* This is the common prefix we use to make temp file names.
1931 It is chosen once for each run of this program.
1932 It is substituted into a spec by %g or %j.
1933 Thus, all temp file names contain this prefix.
1934 In practice, all temp file names start with this prefix.
1936 This prefix comes from the envvar TMPDIR if it is defined;
1937 otherwise, from the P_tmpdir macro if that is defined;
1938 otherwise, in /usr/tmp or /tmp;
1939 or finally the current directory if all else fails. */
1941 static const char *temp_filename;
1943 /* Length of the prefix. */
1945 static int temp_filename_length;
1947 /* Define the list of temporary files to delete. */
1949 struct temp_file
1951 const char *name;
1952 struct temp_file *next;
1955 /* Queue of files to delete on success or failure of compilation. */
1956 static struct temp_file *always_delete_queue;
1957 /* Queue of files to delete on failure of compilation. */
1958 static struct temp_file *failure_delete_queue;
1960 /* Record FILENAME as a file to be deleted automatically.
1961 ALWAYS_DELETE nonzero means delete it if all compilation succeeds;
1962 otherwise delete it in any case.
1963 FAIL_DELETE nonzero means delete it if a compilation step fails;
1964 otherwise delete it in any case. */
1966 void
1967 record_temp_file (const char *filename, int always_delete, int fail_delete)
1969 char *const name = xstrdup (filename);
1971 if (always_delete)
1973 struct temp_file *temp;
1974 for (temp = always_delete_queue; temp; temp = temp->next)
1975 if (! filename_cmp (name, temp->name))
1976 goto already1;
1978 temp = XNEW (struct temp_file);
1979 temp->next = always_delete_queue;
1980 temp->name = name;
1981 always_delete_queue = temp;
1983 already1:;
1986 if (fail_delete)
1988 struct temp_file *temp;
1989 for (temp = failure_delete_queue; temp; temp = temp->next)
1990 if (! filename_cmp (name, temp->name))
1992 free (name);
1993 goto already2;
1996 temp = XNEW (struct temp_file);
1997 temp->next = failure_delete_queue;
1998 temp->name = name;
1999 failure_delete_queue = temp;
2001 already2:;
2005 /* Delete all the temporary files whose names we previously recorded. */
2007 #ifndef DELETE_IF_ORDINARY
2008 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2009 do \
2011 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2012 if (unlink (NAME) < 0) \
2013 if (VERBOSE_FLAG) \
2014 perror_with_name (NAME); \
2015 } while (0)
2016 #endif
2018 static void
2019 delete_if_ordinary (const char *name)
2021 struct stat st;
2022 #ifdef DEBUG
2023 int i, c;
2025 printf ("Delete %s? (y or n) ", name);
2026 fflush (stdout);
2027 i = getchar ();
2028 if (i != '\n')
2029 while ((c = getchar ()) != '\n' && c != EOF)
2032 if (i == 'y' || i == 'Y')
2033 #endif /* DEBUG */
2034 DELETE_IF_ORDINARY (name, st, verbose_flag);
2037 static void
2038 delete_temp_files (void)
2040 struct temp_file *temp;
2042 for (temp = always_delete_queue; temp; temp = temp->next)
2043 delete_if_ordinary (temp->name);
2044 always_delete_queue = 0;
2047 /* Delete all the files to be deleted on error. */
2049 static void
2050 delete_failure_queue (void)
2052 struct temp_file *temp;
2054 for (temp = failure_delete_queue; temp; temp = temp->next)
2055 delete_if_ordinary (temp->name);
2058 static void
2059 clear_failure_queue (void)
2061 failure_delete_queue = 0;
2064 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2065 returns non-NULL.
2066 If DO_MULTI is true iterate over the paths twice, first with multilib
2067 suffix then without, otherwise iterate over the paths once without
2068 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2069 to avoid visiting the same path twice, but we could do better. For
2070 instance, /usr/lib/../lib is considered different from /usr/lib.
2071 At least EXTRA_SPACE chars past the end of the path passed to
2072 CALLBACK are available for use by the callback.
2073 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2075 Returns the value returned by CALLBACK. */
2077 static void *
2078 for_each_path (const struct path_prefix *paths,
2079 bool do_multi,
2080 size_t extra_space,
2081 void *(*callback) (char *, void *),
2082 void *callback_info)
2084 struct prefix_list *pl;
2085 const char *multi_dir = NULL;
2086 const char *multi_os_dir = NULL;
2087 const char *multi_suffix;
2088 const char *just_multi_suffix;
2089 char *path = NULL;
2090 void *ret = NULL;
2091 bool skip_multi_dir = false;
2092 bool skip_multi_os_dir = false;
2094 multi_suffix = machine_suffix;
2095 just_multi_suffix = just_machine_suffix;
2096 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2098 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2099 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2100 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2102 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2103 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2105 while (1)
2107 size_t multi_dir_len = 0;
2108 size_t multi_os_dir_len = 0;
2109 size_t suffix_len;
2110 size_t just_suffix_len;
2111 size_t len;
2113 if (multi_dir)
2114 multi_dir_len = strlen (multi_dir);
2115 if (multi_os_dir)
2116 multi_os_dir_len = strlen (multi_os_dir);
2117 suffix_len = strlen (multi_suffix);
2118 just_suffix_len = strlen (just_multi_suffix);
2120 if (path == NULL)
2122 len = paths->max_len + extra_space + 1;
2123 if (suffix_len > multi_os_dir_len)
2124 len += suffix_len;
2125 else
2126 len += multi_os_dir_len;
2127 path = XNEWVEC (char, len);
2130 for (pl = paths->plist; pl != 0; pl = pl->next)
2132 len = strlen (pl->prefix);
2133 memcpy (path, pl->prefix, len);
2135 /* Look first in MACHINE/VERSION subdirectory. */
2136 if (!skip_multi_dir)
2138 memcpy (path + len, multi_suffix, suffix_len + 1);
2139 ret = callback (path, callback_info);
2140 if (ret)
2141 break;
2144 /* Some paths are tried with just the machine (ie. target)
2145 subdir. This is used for finding as, ld, etc. */
2146 if (!skip_multi_dir
2147 && pl->require_machine_suffix == 2)
2149 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2150 ret = callback (path, callback_info);
2151 if (ret)
2152 break;
2155 /* Now try the base path. */
2156 if (!pl->require_machine_suffix
2157 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2159 const char *this_multi;
2160 size_t this_multi_len;
2162 if (pl->os_multilib)
2164 this_multi = multi_os_dir;
2165 this_multi_len = multi_os_dir_len;
2167 else
2169 this_multi = multi_dir;
2170 this_multi_len = multi_dir_len;
2173 if (this_multi_len)
2174 memcpy (path + len, this_multi, this_multi_len + 1);
2175 else
2176 path[len] = '\0';
2178 ret = callback (path, callback_info);
2179 if (ret)
2180 break;
2183 if (pl)
2184 break;
2186 if (multi_dir == NULL && multi_os_dir == NULL)
2187 break;
2189 /* Run through the paths again, this time without multilibs.
2190 Don't repeat any we have already seen. */
2191 if (multi_dir)
2193 free (CONST_CAST (char *, multi_dir));
2194 multi_dir = NULL;
2195 free (CONST_CAST (char *, multi_suffix));
2196 multi_suffix = machine_suffix;
2197 free (CONST_CAST (char *, just_multi_suffix));
2198 just_multi_suffix = just_machine_suffix;
2200 else
2201 skip_multi_dir = true;
2202 if (multi_os_dir)
2204 free (CONST_CAST (char *, multi_os_dir));
2205 multi_os_dir = NULL;
2207 else
2208 skip_multi_os_dir = true;
2211 if (multi_dir)
2213 free (CONST_CAST (char *, multi_dir));
2214 free (CONST_CAST (char *, multi_suffix));
2215 free (CONST_CAST (char *, just_multi_suffix));
2217 if (multi_os_dir)
2218 free (CONST_CAST (char *, multi_os_dir));
2219 if (ret != path)
2220 free (path);
2221 return ret;
2224 /* Callback for build_search_list. Adds path to obstack being built. */
2226 struct add_to_obstack_info {
2227 struct obstack *ob;
2228 bool check_dir;
2229 bool first_time;
2232 static void *
2233 add_to_obstack (char *path, void *data)
2235 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2237 if (info->check_dir && !is_directory (path, false))
2238 return NULL;
2240 if (!info->first_time)
2241 obstack_1grow (info->ob, PATH_SEPARATOR);
2243 obstack_grow (info->ob, path, strlen (path));
2245 info->first_time = false;
2246 return NULL;
2249 /* Add or change the value of an environment variable, outputting the
2250 change to standard error if in verbose mode. */
2251 static void
2252 xputenv (const char *string)
2254 if (verbose_flag)
2255 fnotice (stderr, "%s\n", string);
2256 putenv (CONST_CAST (char *, string));
2259 /* Build a list of search directories from PATHS.
2260 PREFIX is a string to prepend to the list.
2261 If CHECK_DIR_P is true we ensure the directory exists.
2262 If DO_MULTI is true, multilib paths are output first, then
2263 non-multilib paths.
2264 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2265 It is also used by the --print-search-dirs flag. */
2267 static char *
2268 build_search_list (const struct path_prefix *paths, const char *prefix,
2269 bool check_dir, bool do_multi)
2271 struct add_to_obstack_info info;
2273 info.ob = &collect_obstack;
2274 info.check_dir = check_dir;
2275 info.first_time = true;
2277 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2278 obstack_1grow (&collect_obstack, '=');
2280 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2282 obstack_1grow (&collect_obstack, '\0');
2283 return XOBFINISH (&collect_obstack, char *);
2286 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2287 for collect. */
2289 static void
2290 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2291 bool do_multi)
2293 xputenv (build_search_list (paths, env_var, true, do_multi));
2296 /* Check whether NAME can be accessed in MODE. This is like access,
2297 except that it never considers directories to be executable. */
2299 static int
2300 access_check (const char *name, int mode)
2302 if (mode == X_OK)
2304 struct stat st;
2306 if (stat (name, &st) < 0
2307 || S_ISDIR (st.st_mode))
2308 return -1;
2311 return access (name, mode);
2314 /* Callback for find_a_file. Appends the file name to the directory
2315 path. If the resulting file exists in the right mode, return the
2316 full pathname to the file. */
2318 struct file_at_path_info {
2319 const char *name;
2320 const char *suffix;
2321 int name_len;
2322 int suffix_len;
2323 int mode;
2326 static void *
2327 file_at_path (char *path, void *data)
2329 struct file_at_path_info *info = (struct file_at_path_info *) data;
2330 size_t len = strlen (path);
2332 memcpy (path + len, info->name, info->name_len);
2333 len += info->name_len;
2335 /* Some systems have a suffix for executable files.
2336 So try appending that first. */
2337 if (info->suffix_len)
2339 memcpy (path + len, info->suffix, info->suffix_len + 1);
2340 if (access_check (path, info->mode) == 0)
2341 return path;
2344 path[len] = '\0';
2345 if (access_check (path, info->mode) == 0)
2346 return path;
2348 return NULL;
2351 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2352 access to check permissions. If DO_MULTI is true, search multilib
2353 paths then non-multilib paths, otherwise do not search multilib paths.
2354 Return 0 if not found, otherwise return its name, allocated with malloc. */
2356 static char *
2357 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2358 bool do_multi)
2360 struct file_at_path_info info;
2362 #ifdef DEFAULT_ASSEMBLER
2363 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2364 return xstrdup (DEFAULT_ASSEMBLER);
2365 #endif
2367 #ifdef DEFAULT_LINKER
2368 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2369 return xstrdup (DEFAULT_LINKER);
2370 #endif
2372 /* Determine the filename to execute (special case for absolute paths). */
2374 if (IS_ABSOLUTE_PATH (name))
2376 if (access (name, mode) == 0)
2377 return xstrdup (name);
2379 return NULL;
2382 info.name = name;
2383 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2384 info.name_len = strlen (info.name);
2385 info.suffix_len = strlen (info.suffix);
2386 info.mode = mode;
2388 return (char*) for_each_path (pprefix, do_multi,
2389 info.name_len + info.suffix_len,
2390 file_at_path, &info);
2393 /* Ranking of prefixes in the sort list. -B prefixes are put before
2394 all others. */
2396 enum path_prefix_priority
2398 PREFIX_PRIORITY_B_OPT,
2399 PREFIX_PRIORITY_LAST
2402 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2403 order according to PRIORITY. Within each PRIORITY, new entries are
2404 appended.
2406 If WARN is nonzero, we will warn if no file is found
2407 through this prefix. WARN should point to an int
2408 which will be set to 1 if this entry is used.
2410 COMPONENT is the value to be passed to update_path.
2412 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2413 the complete value of machine_suffix.
2414 2 means try both machine_suffix and just_machine_suffix. */
2416 static void
2417 add_prefix (struct path_prefix *pprefix, const char *prefix,
2418 const char *component, /* enum prefix_priority */ int priority,
2419 int require_machine_suffix, int os_multilib)
2421 struct prefix_list *pl, **prev;
2422 int len;
2424 for (prev = &pprefix->plist;
2425 (*prev) != NULL && (*prev)->priority <= priority;
2426 prev = &(*prev)->next)
2429 /* Keep track of the longest prefix. */
2431 prefix = update_path (prefix, component);
2432 len = strlen (prefix);
2433 if (len > pprefix->max_len)
2434 pprefix->max_len = len;
2436 pl = XNEW (struct prefix_list);
2437 pl->prefix = prefix;
2438 pl->require_machine_suffix = require_machine_suffix;
2439 pl->priority = priority;
2440 pl->os_multilib = os_multilib;
2442 /* Insert after PREV. */
2443 pl->next = (*prev);
2444 (*prev) = pl;
2447 /* Same as add_prefix, but prepending target_system_root to prefix. */
2448 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2449 static void
2450 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2451 const char *component,
2452 /* enum prefix_priority */ int priority,
2453 int require_machine_suffix, int os_multilib)
2455 if (!IS_ABSOLUTE_PATH (prefix))
2456 fatal_error ("system path %qs is not absolute", prefix);
2458 if (target_system_root)
2460 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2461 size_t sysroot_len = strlen (target_system_root);
2463 if (sysroot_len > 0
2464 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2465 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2467 if (target_sysroot_suffix)
2468 prefix = concat (sysroot_no_trailing_dir_separator,
2469 target_sysroot_suffix, prefix, NULL);
2470 else
2471 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2473 free (sysroot_no_trailing_dir_separator);
2475 /* We have to override this because GCC's notion of sysroot
2476 moves along with GCC. */
2477 component = "GCC";
2480 add_prefix (pprefix, prefix, component, priority,
2481 require_machine_suffix, os_multilib);
2484 /* Execute the command specified by the arguments on the current line of spec.
2485 When using pipes, this includes several piped-together commands
2486 with `|' between them.
2488 Return 0 if successful, -1 if failed. */
2490 static int
2491 execute (void)
2493 int i;
2494 int n_commands; /* # of command. */
2495 char *string;
2496 struct pex_obj *pex;
2497 struct command
2499 const char *prog; /* program name. */
2500 const char **argv; /* vector of args. */
2502 const char *arg;
2504 struct command *commands; /* each command buffer with above info. */
2506 gcc_assert (!processing_spec_function);
2508 if (wrapper_string)
2510 string = find_a_file (&exec_prefixes,
2511 VEC_index (const_char_p, argbuf, 0), X_OK, false);
2512 if (string)
2513 VEC_replace (const_char_p, argbuf, 0, string);
2514 insert_wrapper (wrapper_string);
2517 /* Count # of piped commands. */
2518 for (n_commands = 1, i = 0; VEC_iterate (const_char_p, argbuf, i, arg); i++)
2519 if (strcmp (arg, "|") == 0)
2520 n_commands++;
2522 /* Get storage for each command. */
2523 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2525 /* Split argbuf into its separate piped processes,
2526 and record info about each one.
2527 Also search for the programs that are to be run. */
2529 VEC_safe_push (const_char_p, heap, argbuf, 0);
2531 commands[0].prog = VEC_index (const_char_p, argbuf, 0); /* first command. */
2532 commands[0].argv = VEC_address (const_char_p, argbuf);
2534 if (!wrapper_string)
2536 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2537 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2540 for (n_commands = 1, i = 0; VEC_iterate (const_char_p, argbuf, i, arg); i++)
2541 if (arg && strcmp (arg, "|") == 0)
2542 { /* each command. */
2543 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2544 fatal_error ("-pipe not supported");
2545 #endif
2546 VEC_replace (const_char_p, argbuf, i, 0); /* Termination of
2547 command args. */
2548 commands[n_commands].prog = VEC_index (const_char_p, argbuf, i + 1);
2549 commands[n_commands].argv
2550 = &(VEC_address (const_char_p, argbuf))[i + 1];
2551 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2552 X_OK, false);
2553 if (string)
2554 commands[n_commands].argv[0] = string;
2555 n_commands++;
2558 /* If -v, print what we are about to do, and maybe query. */
2560 if (verbose_flag)
2562 /* For help listings, put a blank line between sub-processes. */
2563 if (print_help_list)
2564 fputc ('\n', stderr);
2566 /* Print each piped command as a separate line. */
2567 for (i = 0; i < n_commands; i++)
2569 const char *const *j;
2571 if (verbose_only_flag)
2573 for (j = commands[i].argv; *j; j++)
2575 const char *p;
2576 for (p = *j; *p; ++p)
2577 if (!ISALNUM ((unsigned char) *p)
2578 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2579 break;
2580 if (*p || !*j)
2582 fprintf (stderr, " \"");
2583 for (p = *j; *p; ++p)
2585 if (*p == '"' || *p == '\\' || *p == '$')
2586 fputc ('\\', stderr);
2587 fputc (*p, stderr);
2589 fputc ('"', stderr);
2591 /* If it's empty, print "". */
2592 else if (!**j)
2593 fprintf (stderr, " \"\"");
2594 else
2595 fprintf (stderr, " %s", *j);
2598 else
2599 for (j = commands[i].argv; *j; j++)
2600 /* If it's empty, print "". */
2601 if (!**j)
2602 fprintf (stderr, " \"\"");
2603 else
2604 fprintf (stderr, " %s", *j);
2606 /* Print a pipe symbol after all but the last command. */
2607 if (i + 1 != n_commands)
2608 fprintf (stderr, " |");
2609 fprintf (stderr, "\n");
2611 fflush (stderr);
2612 if (verbose_only_flag != 0)
2614 /* verbose_only_flag should act as if the spec was
2615 executed, so increment execution_count before
2616 returning. This prevents spurious warnings about
2617 unused linker input files, etc. */
2618 execution_count++;
2619 return 0;
2621 #ifdef DEBUG
2622 fnotice (stderr, "\nGo ahead? (y or n) ");
2623 fflush (stderr);
2624 i = getchar ();
2625 if (i != '\n')
2626 while (getchar () != '\n')
2629 if (i != 'y' && i != 'Y')
2630 return 0;
2631 #endif /* DEBUG */
2634 #ifdef ENABLE_VALGRIND_CHECKING
2635 /* Run the each command through valgrind. To simplify prepending the
2636 path to valgrind and the option "-q" (for quiet operation unless
2637 something triggers), we allocate a separate argv array. */
2639 for (i = 0; i < n_commands; i++)
2641 const char **argv;
2642 int argc;
2643 int j;
2645 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2648 argv = XALLOCAVEC (const char *, argc + 3);
2650 argv[0] = VALGRIND_PATH;
2651 argv[1] = "-q";
2652 for (j = 2; j < argc + 2; j++)
2653 argv[j] = commands[i].argv[j - 2];
2654 argv[j] = NULL;
2656 commands[i].argv = argv;
2657 commands[i].prog = argv[0];
2659 #endif
2661 /* Run each piped subprocess. */
2663 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2664 ? PEX_RECORD_TIMES : 0),
2665 progname, temp_filename);
2666 if (pex == NULL)
2667 fatal_error ("pex_init failed: %m");
2669 for (i = 0; i < n_commands; i++)
2671 const char *errmsg;
2672 int err;
2673 const char *string = commands[i].argv[0];
2675 errmsg = pex_run (pex,
2676 ((i + 1 == n_commands ? PEX_LAST : 0)
2677 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2678 string, CONST_CAST (char **, commands[i].argv),
2679 NULL, NULL, &err);
2680 if (errmsg != NULL)
2682 if (err == 0)
2683 fatal_error (errmsg);
2684 else
2686 errno = err;
2687 pfatal_with_name (errmsg);
2691 if (string != commands[i].prog)
2692 free (CONST_CAST (char *, string));
2695 execution_count++;
2697 /* Wait for all the subprocesses to finish. */
2700 int *statuses;
2701 struct pex_time *times = NULL;
2702 int ret_code = 0;
2704 statuses = (int *) alloca (n_commands * sizeof (int));
2705 if (!pex_get_status (pex, n_commands, statuses))
2706 fatal_error ("failed to get exit status: %m");
2708 if (report_times || report_times_to_file)
2710 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2711 if (!pex_get_times (pex, n_commands, times))
2712 fatal_error ("failed to get process times: %m");
2715 pex_free (pex);
2717 for (i = 0; i < n_commands; ++i)
2719 int status = statuses[i];
2721 if (WIFSIGNALED (status))
2723 #ifdef SIGPIPE
2724 /* SIGPIPE is a special case. It happens in -pipe mode
2725 when the compiler dies before the preprocessor is done,
2726 or the assembler dies before the compiler is done.
2727 There's generally been an error already, and this is
2728 just fallout. So don't generate another error unless
2729 we would otherwise have succeeded. */
2730 if (WTERMSIG (status) == SIGPIPE
2731 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2733 signal_count++;
2734 ret_code = -1;
2736 else
2737 #endif
2738 internal_error ("%s (program %s)",
2739 strsignal (WTERMSIG (status)), commands[i].prog);
2741 else if (WIFEXITED (status)
2742 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2744 if (WEXITSTATUS (status) > greatest_status)
2745 greatest_status = WEXITSTATUS (status);
2746 ret_code = -1;
2749 if (report_times || report_times_to_file)
2751 struct pex_time *pt = &times[i];
2752 double ut, st;
2754 ut = ((double) pt->user_seconds
2755 + (double) pt->user_microseconds / 1.0e6);
2756 st = ((double) pt->system_seconds
2757 + (double) pt->system_microseconds / 1.0e6);
2759 if (ut + st != 0)
2761 if (report_times)
2762 fnotice (stderr, "# %s %.2f %.2f\n",
2763 commands[i].prog, ut, st);
2765 if (report_times_to_file)
2767 int c = 0;
2768 const char *const *j;
2770 fprintf (report_times_to_file, "%g %g", ut, st);
2772 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
2774 const char *p;
2775 for (p = *j; *p; ++p)
2776 if (*p == '"' || *p == '\\' || *p == '$'
2777 || ISSPACE (*p))
2778 break;
2780 if (*p)
2782 fprintf (report_times_to_file, " \"");
2783 for (p = *j; *p; ++p)
2785 if (*p == '"' || *p == '\\' || *p == '$')
2786 fputc ('\\', report_times_to_file);
2787 fputc (*p, report_times_to_file);
2789 fputc ('"', report_times_to_file);
2791 else
2792 fprintf (report_times_to_file, " %s", *j);
2795 fputc ('\n', report_times_to_file);
2801 return ret_code;
2805 /* Find all the switches given to us
2806 and make a vector describing them.
2807 The elements of the vector are strings, one per switch given.
2808 If a switch uses following arguments, then the `part1' field
2809 is the switch itself and the `args' field
2810 is a null-terminated vector containing the following arguments.
2811 Bits in the `live_cond' field are:
2812 SWITCH_LIVE to indicate this switch is true in a conditional spec.
2813 SWITCH_FALSE to indicate this switch is overridden by a later switch.
2814 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
2815 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
2816 in all do_spec calls afterwards. Used for %<S from self specs.
2817 The `validated' field is nonzero if any spec has looked at this switch;
2818 if it remains zero at the end of the run, it must be meaningless. */
2820 #define SWITCH_LIVE (1 << 0)
2821 #define SWITCH_FALSE (1 << 1)
2822 #define SWITCH_IGNORE (1 << 2)
2823 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
2824 #define SWITCH_KEEP_FOR_GCC (1 << 4)
2826 struct switchstr
2828 const char *part1;
2829 const char **args;
2830 unsigned int live_cond;
2831 bool known;
2832 bool validated;
2833 bool ordering;
2836 static struct switchstr *switches;
2838 static int n_switches;
2840 static int n_switches_alloc;
2842 /* Set to zero if -fcompare-debug is disabled, positive if it's
2843 enabled and we're running the first compilation, negative if it's
2844 enabled and we're running the second compilation. For most of the
2845 time, it's in the range -1..1, but it can be temporarily set to 2
2846 or 3 to indicate that the -fcompare-debug flags didn't come from
2847 the command-line, but rather from the GCC_COMPARE_DEBUG environment
2848 variable, until a synthesized -fcompare-debug flag is added to the
2849 command line. */
2850 int compare_debug;
2852 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
2853 int compare_debug_second;
2855 /* Set to the flags that should be passed to the second compilation in
2856 a -fcompare-debug compilation. */
2857 const char *compare_debug_opt;
2859 static struct switchstr *switches_debug_check[2];
2861 static int n_switches_debug_check[2];
2863 static int n_switches_alloc_debug_check[2];
2865 static char *debug_check_temp_file[2];
2867 /* Language is one of three things:
2869 1) The name of a real programming language.
2870 2) NULL, indicating that no one has figured out
2871 what it is yet.
2872 3) '*', indicating that the file should be passed
2873 to the linker. */
2874 struct infile
2876 const char *name;
2877 const char *language;
2878 struct compiler *incompiler;
2879 bool compiled;
2880 bool preprocessed;
2883 /* Also a vector of input files specified. */
2885 static struct infile *infiles;
2887 int n_infiles;
2889 static int n_infiles_alloc;
2891 /* True if multiple input files are being compiled to a single
2892 assembly file. */
2894 static bool combine_inputs;
2896 /* This counts the number of libraries added by lang_specific_driver, so that
2897 we can tell if there were any user supplied any files or libraries. */
2899 static int added_libraries;
2901 /* And a vector of corresponding output files is made up later. */
2903 const char **outfiles;
2905 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2907 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2908 is true if we should look for an executable suffix. DO_OBJ
2909 is true if we should look for an object suffix. */
2911 static const char *
2912 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
2913 int do_obj ATTRIBUTE_UNUSED)
2915 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2916 int i;
2917 #endif
2918 int len;
2920 if (name == NULL)
2921 return NULL;
2923 len = strlen (name);
2925 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2926 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
2927 if (do_obj && len > 2
2928 && name[len - 2] == '.'
2929 && name[len - 1] == 'o')
2931 obstack_grow (&obstack, name, len - 2);
2932 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
2933 name = XOBFINISH (&obstack, const char *);
2935 #endif
2937 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2938 /* If there is no filetype, make it the executable suffix (which includes
2939 the "."). But don't get confused if we have just "-o". */
2940 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
2941 return name;
2943 for (i = len - 1; i >= 0; i--)
2944 if (IS_DIR_SEPARATOR (name[i]))
2945 break;
2947 for (i++; i < len; i++)
2948 if (name[i] == '.')
2949 return name;
2951 obstack_grow (&obstack, name, len);
2952 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
2953 strlen (TARGET_EXECUTABLE_SUFFIX));
2954 name = XOBFINISH (&obstack, const char *);
2955 #endif
2957 return name;
2959 #endif
2961 /* Display the command line switches accepted by gcc. */
2962 static void
2963 display_help (void)
2965 printf (_("Usage: %s [options] file...\n"), progname);
2966 fputs (_("Options:\n"), stdout);
2968 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
2969 fputs (_(" --help Display this information\n"), stdout);
2970 fputs (_(" --target-help Display target specific command line options\n"), stdout);
2971 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
2972 fputs (_(" Display specific types of command line options\n"), stdout);
2973 if (! verbose_flag)
2974 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
2975 fputs (_(" --version Display compiler version information\n"), stdout);
2976 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
2977 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
2978 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
2979 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
2980 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
2981 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
2982 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
2983 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
2984 fputs (_("\
2985 -print-multi-lib Display the mapping between command line options and\n\
2986 multiple library search directories\n"), stdout);
2987 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
2988 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
2989 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
2990 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
2991 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
2992 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
2993 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
2994 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
2995 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
2996 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
2997 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
2998 fputs (_("\
2999 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
3000 prefixes to other gcc components\n"), stdout);
3001 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
3002 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
3003 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
3004 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
3005 fputs (_("\
3006 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3007 and libraries\n"), stdout);
3008 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3009 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3010 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3011 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3012 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3013 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3014 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3015 fputs (_(" -pie Create a position independent executable\n"), stdout);
3016 fputs (_(" -shared Create a shared library\n"), stdout);
3017 fputs (_("\
3018 -x <language> Specify the language of the following input files\n\
3019 Permissible languages include: c c++ assembler none\n\
3020 'none' means revert to the default behavior of\n\
3021 guessing the language based on the file's extension\n\
3022 "), stdout);
3024 printf (_("\
3025 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3026 passed on to the various sub-processes invoked by %s. In order to pass\n\
3027 other options on to these processes the -W<letter> options must be used.\n\
3028 "), progname);
3030 /* The rest of the options are displayed by invocations of the various
3031 sub-processes. */
3034 static void
3035 add_preprocessor_option (const char *option, int len)
3037 VEC_safe_push (char_p, heap, preprocessor_options,
3038 save_string (option, len));
3041 static void
3042 add_assembler_option (const char *option, int len)
3044 VEC_safe_push (char_p, heap, assembler_options, save_string (option, len));
3047 static void
3048 add_linker_option (const char *option, int len)
3050 VEC_safe_push (char_p, heap, linker_options, save_string (option, len));
3053 /* Allocate space for an input file in infiles. */
3055 static void
3056 alloc_infile (void)
3058 if (n_infiles_alloc == 0)
3060 n_infiles_alloc = 16;
3061 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3063 else if (n_infiles_alloc == n_infiles)
3065 n_infiles_alloc *= 2;
3066 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3070 /* Store an input file with the given NAME and LANGUAGE in
3071 infiles. */
3073 static void
3074 add_infile (const char *name, const char *language)
3076 alloc_infile ();
3077 infiles[n_infiles].name = name;
3078 infiles[n_infiles++].language = language;
3081 /* Allocate space for a switch in switches. */
3083 static void
3084 alloc_switch (void)
3086 if (n_switches_alloc == 0)
3088 n_switches_alloc = 16;
3089 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3091 else if (n_switches_alloc == n_switches)
3093 n_switches_alloc *= 2;
3094 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3098 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3099 as validated if VALIDATED and KNOWN if it is an internal switch. */
3101 static void
3102 save_switch (const char *opt, size_t n_args, const char *const *args,
3103 bool validated, bool known)
3105 alloc_switch ();
3106 switches[n_switches].part1 = opt + 1;
3107 if (n_args == 0)
3108 switches[n_switches].args = 0;
3109 else
3111 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3112 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3113 switches[n_switches].args[n_args] = NULL;
3116 switches[n_switches].live_cond = 0;
3117 switches[n_switches].validated = validated;
3118 switches[n_switches].known = known;
3119 switches[n_switches].ordering = 0;
3120 n_switches++;
3123 /* Handle an option DECODED that is unknown to the option-processing
3124 machinery. */
3126 static bool
3127 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3129 const char *opt = decoded->arg;
3130 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3131 && !(decoded->errors & CL_ERR_NEGATIVE))
3133 /* Leave unknown -Wno-* options for the compiler proper, to be
3134 diagnosed only if there are warnings. */
3135 save_switch (decoded->canonical_option[0],
3136 decoded->canonical_option_num_elements - 1,
3137 &decoded->canonical_option[1], false, true);
3138 return false;
3140 if (decoded->opt_index == OPT_SPECIAL_unknown)
3142 /* Give it a chance to define it a a spec file. */
3143 save_switch (decoded->canonical_option[0],
3144 decoded->canonical_option_num_elements - 1,
3145 &decoded->canonical_option[1], false, false);
3146 return false;
3148 else
3149 return true;
3152 /* Handle an option DECODED that is not marked as CL_DRIVER.
3153 LANG_MASK will always be CL_DRIVER. */
3155 static void
3156 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3157 unsigned int lang_mask ATTRIBUTE_UNUSED)
3159 /* At this point, non-driver options are accepted (and expected to
3160 be passed down by specs) unless marked to be rejected by the
3161 driver. Options to be rejected by the driver but accepted by the
3162 compilers proper are treated just like completely unknown
3163 options. */
3164 const struct cl_option *option = &cl_options[decoded->opt_index];
3166 if (option->cl_reject_driver)
3167 error ("unrecognized command line option %qs",
3168 decoded->orig_option_with_args_text);
3169 else
3170 save_switch (decoded->canonical_option[0],
3171 decoded->canonical_option_num_elements - 1,
3172 &decoded->canonical_option[1], false, true);
3175 static const char *spec_lang = 0;
3176 static int last_language_n_infiles;
3178 /* Handle a driver option; arguments and return value as for
3179 handle_option. */
3181 static bool
3182 driver_handle_option (struct gcc_options *opts,
3183 struct gcc_options *opts_set,
3184 const struct cl_decoded_option *decoded,
3185 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3186 location_t loc,
3187 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3188 diagnostic_context *dc)
3190 size_t opt_index = decoded->opt_index;
3191 const char *arg = decoded->arg;
3192 const char *compare_debug_replacement_opt;
3193 int value = decoded->value;
3194 bool validated = false;
3195 bool do_save = true;
3197 gcc_assert (opts == &global_options);
3198 gcc_assert (opts_set == &global_options_set);
3199 gcc_assert (kind == DK_UNSPECIFIED);
3200 gcc_assert (loc == UNKNOWN_LOCATION);
3201 gcc_assert (dc == global_dc);
3203 switch (opt_index)
3205 case OPT_dumpspecs:
3207 struct spec_list *sl;
3208 init_spec ();
3209 for (sl = specs; sl; sl = sl->next)
3210 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3211 if (link_command_spec)
3212 printf ("*link_command:\n%s\n\n", link_command_spec);
3213 exit (0);
3216 case OPT_dumpversion:
3217 printf ("%s\n", spec_version);
3218 exit (0);
3220 case OPT_dumpmachine:
3221 printf ("%s\n", spec_machine);
3222 exit (0);
3224 case OPT__version:
3225 print_version = 1;
3227 /* CPP driver cannot obtain switch from cc1_options. */
3228 if (is_cpp_driver)
3229 add_preprocessor_option ("--version", strlen ("--version"));
3230 add_assembler_option ("--version", strlen ("--version"));
3231 add_linker_option ("--version", strlen ("--version"));
3232 break;
3234 case OPT__help:
3235 print_help_list = 1;
3237 /* CPP driver cannot obtain switch from cc1_options. */
3238 if (is_cpp_driver)
3239 add_preprocessor_option ("--help", 6);
3240 add_assembler_option ("--help", 6);
3241 add_linker_option ("--help", 6);
3242 break;
3244 case OPT__help_:
3245 print_subprocess_help = 2;
3246 break;
3248 case OPT__target_help:
3249 print_subprocess_help = 1;
3251 /* CPP driver cannot obtain switch from cc1_options. */
3252 if (is_cpp_driver)
3253 add_preprocessor_option ("--target-help", 13);
3254 add_assembler_option ("--target-help", 13);
3255 add_linker_option ("--target-help", 13);
3256 break;
3258 case OPT__no_sysroot_suffix:
3259 case OPT_pass_exit_codes:
3260 case OPT_print_search_dirs:
3261 case OPT_print_file_name_:
3262 case OPT_print_prog_name_:
3263 case OPT_print_multi_lib:
3264 case OPT_print_multi_directory:
3265 case OPT_print_sysroot:
3266 case OPT_print_multi_os_directory:
3267 case OPT_print_sysroot_headers_suffix:
3268 case OPT_time:
3269 case OPT_wrapper:
3270 /* These options set the variables specified in common.opt
3271 automatically, and do not need to be saved for spec
3272 processing. */
3273 do_save = false;
3274 break;
3276 case OPT_print_libgcc_file_name:
3277 print_file_name = "libgcc.a";
3278 do_save = false;
3279 break;
3281 case OPT_fcompare_debug_second:
3282 compare_debug_second = 1;
3283 break;
3285 case OPT_fcompare_debug:
3286 switch (value)
3288 case 0:
3289 compare_debug_replacement_opt = "-fcompare-debug=";
3290 arg = "";
3291 goto compare_debug_with_arg;
3293 case 1:
3294 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3295 arg = "-gtoggle";
3296 goto compare_debug_with_arg;
3298 default:
3299 gcc_unreachable ();
3301 break;
3303 case OPT_fcompare_debug_:
3304 compare_debug_replacement_opt = decoded->canonical_option[0];
3305 compare_debug_with_arg:
3306 gcc_assert (decoded->canonical_option_num_elements == 1);
3307 gcc_assert (arg != NULL);
3308 if (*arg)
3309 compare_debug = 1;
3310 else
3311 compare_debug = -1;
3312 if (compare_debug < 0)
3313 compare_debug_opt = NULL;
3314 else
3315 compare_debug_opt = arg;
3316 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3317 return true;
3319 case OPT_Wa_:
3321 int prev, j;
3322 /* Pass the rest of this option to the assembler. */
3324 /* Split the argument at commas. */
3325 prev = 0;
3326 for (j = 0; arg[j]; j++)
3327 if (arg[j] == ',')
3329 add_assembler_option (arg + prev, j - prev);
3330 prev = j + 1;
3333 /* Record the part after the last comma. */
3334 add_assembler_option (arg + prev, j - prev);
3336 do_save = false;
3337 break;
3339 case OPT_Wp_:
3341 int prev, j;
3342 /* Pass the rest of this option to the preprocessor. */
3344 /* Split the argument at commas. */
3345 prev = 0;
3346 for (j = 0; arg[j]; j++)
3347 if (arg[j] == ',')
3349 add_preprocessor_option (arg + prev, j - prev);
3350 prev = j + 1;
3353 /* Record the part after the last comma. */
3354 add_preprocessor_option (arg + prev, j - prev);
3356 do_save = false;
3357 break;
3359 case OPT_Wl_:
3361 int prev, j;
3362 /* Split the argument at commas. */
3363 prev = 0;
3364 for (j = 0; arg[j]; j++)
3365 if (arg[j] == ',')
3367 add_infile (save_string (arg + prev, j - prev), "*");
3368 prev = j + 1;
3370 /* Record the part after the last comma. */
3371 add_infile (arg + prev, "*");
3373 do_save = false;
3374 break;
3376 case OPT_Xlinker:
3377 add_infile (arg, "*");
3378 do_save = false;
3379 break;
3381 case OPT_Xpreprocessor:
3382 add_preprocessor_option (arg, strlen (arg));
3383 do_save = false;
3384 break;
3386 case OPT_Xassembler:
3387 add_assembler_option (arg, strlen (arg));
3388 do_save = false;
3389 break;
3391 case OPT_l:
3392 /* POSIX allows separation of -l and the lib arg; canonicalize
3393 by concatenating -l with its arg */
3394 add_infile (concat ("-l", arg, NULL), "*");
3395 do_save = false;
3396 break;
3398 case OPT_L:
3399 /* Similarly, canonicalize -L for linkers that may not accept
3400 separate arguments. */
3401 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3402 return true;
3404 case OPT_F:
3405 /* Likewise -F. */
3406 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3407 return true;
3409 case OPT_save_temps:
3410 save_temps_flag = SAVE_TEMPS_CWD;
3411 validated = true;
3412 break;
3414 case OPT_save_temps_:
3415 if (strcmp (arg, "cwd") == 0)
3416 save_temps_flag = SAVE_TEMPS_CWD;
3417 else if (strcmp (arg, "obj") == 0
3418 || strcmp (arg, "object") == 0)
3419 save_temps_flag = SAVE_TEMPS_OBJ;
3420 else
3421 fatal_error ("%qs is an unknown -save-temps option",
3422 decoded->orig_option_with_args_text);
3423 break;
3425 case OPT_no_canonical_prefixes:
3426 /* Already handled as a special case, so ignored here. */
3427 do_save = false;
3428 break;
3430 case OPT_pipe:
3431 validated = true;
3432 /* These options set the variables specified in common.opt
3433 automatically, but do need to be saved for spec
3434 processing. */
3435 break;
3437 case OPT_specs_:
3439 struct user_specs *user = XNEW (struct user_specs);
3441 user->next = (struct user_specs *) 0;
3442 user->filename = arg;
3443 if (user_specs_tail)
3444 user_specs_tail->next = user;
3445 else
3446 user_specs_head = user;
3447 user_specs_tail = user;
3449 validated = true;
3450 break;
3452 case OPT__sysroot_:
3453 target_system_root = arg;
3454 target_system_root_changed = 1;
3455 do_save = false;
3456 break;
3458 case OPT_time_:
3459 if (report_times_to_file)
3460 fclose (report_times_to_file);
3461 report_times_to_file = fopen (arg, "a");
3462 do_save = false;
3463 break;
3465 case OPT____:
3466 /* "-###"
3467 This is similar to -v except that there is no execution
3468 of the commands and the echoed arguments are quoted. It
3469 is intended for use in shell scripts to capture the
3470 driver-generated command line. */
3471 verbose_only_flag++;
3472 verbose_flag = 1;
3473 do_save = false;
3474 break;
3476 case OPT_B:
3478 size_t len = strlen (arg);
3480 /* Catch the case where the user has forgotten to append a
3481 directory separator to the path. Note, they may be using
3482 -B to add an executable name prefix, eg "i386-elf-", in
3483 order to distinguish between multiple installations of
3484 GCC in the same directory. Hence we must check to see
3485 if appending a directory separator actually makes a
3486 valid directory name. */
3487 if (!IS_DIR_SEPARATOR (arg[len - 1])
3488 && is_directory (arg, false))
3490 char *tmp = XNEWVEC (char, len + 2);
3491 strcpy (tmp, arg);
3492 tmp[len] = DIR_SEPARATOR;
3493 tmp[++len] = 0;
3494 arg = tmp;
3497 add_prefix (&exec_prefixes, arg, NULL,
3498 PREFIX_PRIORITY_B_OPT, 0, 0);
3499 add_prefix (&startfile_prefixes, arg, NULL,
3500 PREFIX_PRIORITY_B_OPT, 0, 0);
3501 add_prefix (&include_prefixes, arg, NULL,
3502 PREFIX_PRIORITY_B_OPT, 0, 0);
3504 validated = true;
3505 break;
3507 case OPT_x:
3508 spec_lang = arg;
3509 if (!strcmp (spec_lang, "none"))
3510 /* Suppress the warning if -xnone comes after the last input
3511 file, because alternate command interfaces like g++ might
3512 find it useful to place -xnone after each input file. */
3513 spec_lang = 0;
3514 else
3515 last_language_n_infiles = n_infiles;
3516 do_save = false;
3517 break;
3519 case OPT_o:
3520 have_o = 1;
3521 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3522 arg = convert_filename (arg, ! have_c, 0);
3523 #endif
3524 /* Save the output name in case -save-temps=obj was used. */
3525 save_temps_prefix = xstrdup (arg);
3526 /* On some systems, ld cannot handle "-o" without a space. So
3527 split the option from its argument. */
3528 save_switch ("-o", 1, &arg, validated, true);
3529 return true;
3531 case OPT_static_libgcc:
3532 case OPT_shared_libgcc:
3533 case OPT_static_libgfortran:
3534 case OPT_static_libstdc__:
3535 /* These are always valid, since gcc.c itself understands the
3536 first two, gfortranspec.c understands -static-libgfortran and
3537 g++spec.c understands -static-libstdc++ */
3538 validated = true;
3539 break;
3541 default:
3542 /* Various driver options need no special processing at this
3543 point, having been handled in a prescan above or being
3544 handled by specs. */
3545 break;
3548 if (do_save)
3549 save_switch (decoded->canonical_option[0],
3550 decoded->canonical_option_num_elements - 1,
3551 &decoded->canonical_option[1], validated, true);
3552 return true;
3555 /* Put the driver's standard set of option handlers in *HANDLERS. */
3557 static void
3558 set_option_handlers (struct cl_option_handlers *handlers)
3560 handlers->unknown_option_callback = driver_unknown_option_callback;
3561 handlers->wrong_lang_callback = driver_wrong_lang_callback;
3562 handlers->num_handlers = 3;
3563 handlers->handlers[0].handler = driver_handle_option;
3564 handlers->handlers[0].mask = CL_DRIVER;
3565 handlers->handlers[1].handler = common_handle_option;
3566 handlers->handlers[1].mask = CL_COMMON;
3567 handlers->handlers[2].handler = target_handle_option;
3568 handlers->handlers[2].mask = CL_TARGET;
3571 /* Create the vector `switches' and its contents.
3572 Store its length in `n_switches'. */
3574 static void
3575 process_command (unsigned int decoded_options_count,
3576 struct cl_decoded_option *decoded_options)
3578 const char *temp;
3579 char *temp1;
3580 char *tooldir_prefix, *tooldir_prefix2;
3581 char *(*get_relative_prefix) (const char *, const char *,
3582 const char *) = NULL;
3583 struct cl_option_handlers handlers;
3584 unsigned int j;
3586 gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
3588 n_switches = 0;
3589 n_infiles = 0;
3590 added_libraries = 0;
3592 /* Figure compiler version from version string. */
3594 compiler_version = temp1 = xstrdup (version_string);
3596 for (; *temp1; ++temp1)
3598 if (*temp1 == ' ')
3600 *temp1 = '\0';
3601 break;
3605 /* Handle any -no-canonical-prefixes flag early, to assign the function
3606 that builds relative prefixes. This function creates default search
3607 paths that are needed later in normal option handling. */
3609 for (j = 1; j < decoded_options_count; j++)
3611 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3613 get_relative_prefix = make_relative_prefix_ignore_links;
3614 break;
3617 if (! get_relative_prefix)
3618 get_relative_prefix = make_relative_prefix;
3620 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3621 see if we can create it from the pathname specified in
3622 decoded_options[0].arg. */
3624 gcc_libexec_prefix = standard_libexec_prefix;
3625 #ifndef VMS
3626 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3627 if (!gcc_exec_prefix)
3629 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
3630 standard_bindir_prefix,
3631 standard_exec_prefix);
3632 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
3633 standard_bindir_prefix,
3634 standard_libexec_prefix);
3635 if (gcc_exec_prefix)
3636 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3638 else
3640 /* make_relative_prefix requires a program name, but
3641 GCC_EXEC_PREFIX is typically a directory name with a trailing
3642 / (which is ignored by make_relative_prefix), so append a
3643 program name. */
3644 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3645 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
3646 standard_exec_prefix,
3647 standard_libexec_prefix);
3649 /* The path is unrelocated, so fallback to the original setting. */
3650 if (!gcc_libexec_prefix)
3651 gcc_libexec_prefix = standard_libexec_prefix;
3653 free (tmp_prefix);
3655 #else
3656 #endif
3657 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3658 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3659 or an automatically created GCC_EXEC_PREFIX from
3660 decoded_options[0].arg. */
3662 /* Do language-specific adjustment/addition of flags. */
3663 lang_specific_driver (&decoded_options, &decoded_options_count,
3664 &added_libraries);
3666 if (gcc_exec_prefix)
3668 int len = strlen (gcc_exec_prefix);
3670 if (len > (int) sizeof ("/lib/gcc/") - 1
3671 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3673 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3674 if (IS_DIR_SEPARATOR (*temp)
3675 && filename_ncmp (temp + 1, "lib", 3) == 0
3676 && IS_DIR_SEPARATOR (temp[4])
3677 && filename_ncmp (temp + 5, "gcc", 3) == 0)
3678 len -= sizeof ("/lib/gcc/") - 1;
3681 set_std_prefix (gcc_exec_prefix, len);
3682 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3683 PREFIX_PRIORITY_LAST, 0, 0);
3684 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3685 PREFIX_PRIORITY_LAST, 0, 0);
3688 /* COMPILER_PATH and LIBRARY_PATH have values
3689 that are lists of directory names with colons. */
3691 temp = getenv ("COMPILER_PATH");
3692 if (temp)
3694 const char *startp, *endp;
3695 char *nstore = (char *) alloca (strlen (temp) + 3);
3697 startp = endp = temp;
3698 while (1)
3700 if (*endp == PATH_SEPARATOR || *endp == 0)
3702 strncpy (nstore, startp, endp - startp);
3703 if (endp == startp)
3704 strcpy (nstore, concat (".", dir_separator_str, NULL));
3705 else if (!IS_DIR_SEPARATOR (endp[-1]))
3707 nstore[endp - startp] = DIR_SEPARATOR;
3708 nstore[endp - startp + 1] = 0;
3710 else
3711 nstore[endp - startp] = 0;
3712 add_prefix (&exec_prefixes, nstore, 0,
3713 PREFIX_PRIORITY_LAST, 0, 0);
3714 add_prefix (&include_prefixes, nstore, 0,
3715 PREFIX_PRIORITY_LAST, 0, 0);
3716 if (*endp == 0)
3717 break;
3718 endp = startp = endp + 1;
3720 else
3721 endp++;
3725 temp = getenv (LIBRARY_PATH_ENV);
3726 if (temp && *cross_compile == '0')
3728 const char *startp, *endp;
3729 char *nstore = (char *) alloca (strlen (temp) + 3);
3731 startp = endp = temp;
3732 while (1)
3734 if (*endp == PATH_SEPARATOR || *endp == 0)
3736 strncpy (nstore, startp, endp - startp);
3737 if (endp == startp)
3738 strcpy (nstore, concat (".", dir_separator_str, NULL));
3739 else if (!IS_DIR_SEPARATOR (endp[-1]))
3741 nstore[endp - startp] = DIR_SEPARATOR;
3742 nstore[endp - startp + 1] = 0;
3744 else
3745 nstore[endp - startp] = 0;
3746 add_prefix (&startfile_prefixes, nstore, NULL,
3747 PREFIX_PRIORITY_LAST, 0, 1);
3748 if (*endp == 0)
3749 break;
3750 endp = startp = endp + 1;
3752 else
3753 endp++;
3757 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3758 temp = getenv ("LPATH");
3759 if (temp && *cross_compile == '0')
3761 const char *startp, *endp;
3762 char *nstore = (char *) alloca (strlen (temp) + 3);
3764 startp = endp = temp;
3765 while (1)
3767 if (*endp == PATH_SEPARATOR || *endp == 0)
3769 strncpy (nstore, startp, endp - startp);
3770 if (endp == startp)
3771 strcpy (nstore, concat (".", dir_separator_str, NULL));
3772 else if (!IS_DIR_SEPARATOR (endp[-1]))
3774 nstore[endp - startp] = DIR_SEPARATOR;
3775 nstore[endp - startp + 1] = 0;
3777 else
3778 nstore[endp - startp] = 0;
3779 add_prefix (&startfile_prefixes, nstore, NULL,
3780 PREFIX_PRIORITY_LAST, 0, 1);
3781 if (*endp == 0)
3782 break;
3783 endp = startp = endp + 1;
3785 else
3786 endp++;
3790 /* Process the options and store input files and switches in their
3791 vectors. */
3793 last_language_n_infiles = -1;
3795 set_option_handlers (&handlers);
3797 for (j = 1; j < decoded_options_count; j++)
3799 switch (decoded_options[j].opt_index)
3801 case OPT_S:
3802 case OPT_c:
3803 case OPT_E:
3804 have_c = 1;
3805 break;
3807 if (have_c)
3808 break;
3811 for (j = 1; j < decoded_options_count; j++)
3813 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
3815 const char *arg = decoded_options[j].arg;
3816 const char *p = strrchr (arg, '@');
3817 char *fname;
3818 long offset;
3819 int consumed;
3820 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3821 arg = convert_filename (arg, 0, access (arg, F_OK));
3822 #endif
3823 /* For LTO static archive support we handle input file
3824 specifications that are composed of a filename and
3825 an offset like FNAME@OFFSET. */
3826 if (p
3827 && p != arg
3828 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
3829 && strlen (p) == (unsigned int)consumed)
3831 fname = (char *)xmalloc (p - arg + 1);
3832 memcpy (fname, arg, p - arg);
3833 fname[p - arg] = '\0';
3834 /* Only accept non-stdin and existing FNAME parts, otherwise
3835 try with the full name. */
3836 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
3838 free (fname);
3839 fname = xstrdup (arg);
3842 else
3843 fname = xstrdup (arg);
3845 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
3846 perror_with_name (fname);
3847 else
3848 add_infile (arg, spec_lang);
3850 free (fname);
3851 continue;
3854 read_cmdline_option (&global_options, &global_options_set,
3855 decoded_options + j, UNKNOWN_LOCATION,
3856 CL_DRIVER, &handlers, global_dc);
3859 /* If -save-temps=obj and -o name, create the prefix to use for %b.
3860 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
3861 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
3863 save_temps_length = strlen (save_temps_prefix);
3864 temp = strrchr (lbasename (save_temps_prefix), '.');
3865 if (temp)
3867 save_temps_length -= strlen (temp);
3868 save_temps_prefix[save_temps_length] = '\0';
3872 else if (save_temps_prefix != NULL)
3874 free (save_temps_prefix);
3875 save_temps_prefix = NULL;
3878 if (save_temps_flag && use_pipes)
3880 /* -save-temps overrides -pipe, so that temp files are produced */
3881 if (save_temps_flag)
3882 warning (0, "-pipe ignored because -save-temps specified");
3883 use_pipes = 0;
3886 if (!compare_debug)
3888 const char *gcd = getenv ("GCC_COMPARE_DEBUG");
3890 if (gcd && gcd[0] == '-')
3892 compare_debug = 2;
3893 compare_debug_opt = gcd;
3895 else if (gcd && *gcd && strcmp (gcd, "0"))
3897 compare_debug = 3;
3898 compare_debug_opt = "-gtoggle";
3901 else if (compare_debug < 0)
3903 compare_debug = 0;
3904 gcc_assert (!compare_debug_opt);
3907 /* Set up the search paths. We add directories that we expect to
3908 contain GNU Toolchain components before directories specified by
3909 the machine description so that we will find GNU components (like
3910 the GNU assembler) before those of the host system. */
3912 /* If we don't know where the toolchain has been installed, use the
3913 configured-in locations. */
3914 if (!gcc_exec_prefix)
3916 #ifndef OS2
3917 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
3918 PREFIX_PRIORITY_LAST, 1, 0);
3919 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
3920 PREFIX_PRIORITY_LAST, 2, 0);
3921 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3922 PREFIX_PRIORITY_LAST, 2, 0);
3923 #endif
3924 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3925 PREFIX_PRIORITY_LAST, 1, 0);
3928 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
3929 tooldir_prefix2 = concat (tooldir_base_prefix, spec_machine,
3930 dir_separator_str, NULL);
3932 /* Look for tools relative to the location from which the driver is
3933 running, or, if that is not available, the configured prefix. */
3934 tooldir_prefix
3935 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
3936 spec_machine, dir_separator_str,
3937 spec_version, dir_separator_str, tooldir_prefix2, NULL);
3938 free (tooldir_prefix2);
3940 add_prefix (&exec_prefixes,
3941 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3942 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
3943 add_prefix (&startfile_prefixes,
3944 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3945 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
3946 free (tooldir_prefix);
3948 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
3949 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
3950 then consider it to relocate with the rest of the GCC installation
3951 if GCC_EXEC_PREFIX is set.
3952 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
3953 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
3955 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
3956 standard_bindir_prefix,
3957 target_system_root);
3958 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
3960 target_system_root = tmp_prefix;
3961 target_system_root_changed = 1;
3964 #endif
3966 /* More prefixes are enabled in main, after we read the specs file
3967 and determine whether this is cross-compilation or not. */
3969 if (n_infiles == last_language_n_infiles && spec_lang != 0)
3970 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
3972 if (compare_debug == 2 || compare_debug == 3)
3974 alloc_switch ();
3975 switches[n_switches].part1 = concat ("fcompare-debug=",
3976 compare_debug_opt,
3977 NULL);
3978 switches[n_switches].args = 0;
3979 switches[n_switches].live_cond = 0;
3980 switches[n_switches].validated = false;
3981 switches[n_switches].known = false;
3982 switches[n_switches].ordering = 0;
3983 n_switches++;
3984 compare_debug = 1;
3987 /* Ensure we only invoke each subprocess once. */
3988 if (print_subprocess_help || print_help_list || print_version)
3990 n_infiles = 0;
3992 /* Create a dummy input file, so that we can pass
3993 the help option on to the various sub-processes. */
3994 add_infile ("help-dummy", "c");
3997 alloc_switch ();
3998 switches[n_switches].part1 = 0;
3999 alloc_infile ();
4000 infiles[n_infiles].name = 0;
4003 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
4004 and place that in the environment. */
4006 static void
4007 set_collect_gcc_options (void)
4009 int i;
4010 int first_time;
4012 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4013 the compiler. */
4014 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4015 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4017 first_time = TRUE;
4018 for (i = 0; (int) i < n_switches; i++)
4020 const char *const *args;
4021 const char *p, *q;
4022 if (!first_time)
4023 obstack_grow (&collect_obstack, " ", 1);
4025 first_time = FALSE;
4027 /* Ignore elided switches. */
4028 if ((switches[i].live_cond
4029 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4030 == SWITCH_IGNORE)
4031 continue;
4033 obstack_grow (&collect_obstack, "'-", 2);
4034 q = switches[i].part1;
4035 while ((p = strchr (q, '\'')))
4037 obstack_grow (&collect_obstack, q, p - q);
4038 obstack_grow (&collect_obstack, "'\\''", 4);
4039 q = ++p;
4041 obstack_grow (&collect_obstack, q, strlen (q));
4042 obstack_grow (&collect_obstack, "'", 1);
4044 for (args = switches[i].args; args && *args; args++)
4046 obstack_grow (&collect_obstack, " '", 2);
4047 q = *args;
4048 while ((p = strchr (q, '\'')))
4050 obstack_grow (&collect_obstack, q, p - q);
4051 obstack_grow (&collect_obstack, "'\\''", 4);
4052 q = ++p;
4054 obstack_grow (&collect_obstack, q, strlen (q));
4055 obstack_grow (&collect_obstack, "'", 1);
4058 obstack_grow (&collect_obstack, "\0", 1);
4059 xputenv (XOBFINISH (&collect_obstack, char *));
4062 /* Process a spec string, accumulating and running commands. */
4064 /* These variables describe the input file name.
4065 input_file_number is the index on outfiles of this file,
4066 so that the output file name can be stored for later use by %o.
4067 input_basename is the start of the part of the input file
4068 sans all directory names, and basename_length is the number
4069 of characters starting there excluding the suffix .c or whatever. */
4071 static const char *gcc_input_filename;
4072 static int input_file_number;
4073 size_t input_filename_length;
4074 static int basename_length;
4075 static int suffixed_basename_length;
4076 static const char *input_basename;
4077 static const char *input_suffix;
4078 #ifndef HOST_LACKS_INODE_NUMBERS
4079 static struct stat input_stat;
4080 #endif
4081 static int input_stat_set;
4083 /* The compiler used to process the current input file. */
4084 static struct compiler *input_file_compiler;
4086 /* These are variables used within do_spec and do_spec_1. */
4088 /* Nonzero if an arg has been started and not yet terminated
4089 (with space, tab or newline). */
4090 static int arg_going;
4092 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4093 is a temporary file name. */
4094 static int delete_this_arg;
4096 /* Nonzero means %w has been seen; the next arg to be terminated
4097 is the output file name of this compilation. */
4098 static int this_is_output_file;
4100 /* Nonzero means %s has been seen; the next arg to be terminated
4101 is the name of a library file and we should try the standard
4102 search dirs for it. */
4103 static int this_is_library_file;
4105 /* Nonzero means %T has been seen; the next arg to be terminated
4106 is the name of a linker script and we should try all of the
4107 standard search dirs for it. If it is found insert a --script
4108 command line switch and then substitute the full path in place,
4109 otherwise generate an error message. */
4110 static int this_is_linker_script;
4112 /* Nonzero means that the input of this command is coming from a pipe. */
4113 static int input_from_pipe;
4115 /* Nonnull means substitute this for any suffix when outputting a switches
4116 arguments. */
4117 static const char *suffix_subst;
4119 /* If there is an argument being accumulated, terminate it and store it. */
4121 static void
4122 end_going_arg (void)
4124 if (arg_going)
4126 const char *string;
4128 obstack_1grow (&obstack, 0);
4129 string = XOBFINISH (&obstack, const char *);
4130 if (this_is_library_file)
4131 string = find_file (string);
4132 if (this_is_linker_script)
4134 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4136 if (full_script_path == NULL)
4138 error ("unable to locate default linker script %qs in the library search paths", string);
4139 /* Script was not found on search path. */
4140 return;
4142 store_arg ("--script", false, false);
4143 string = full_script_path;
4145 store_arg (string, delete_this_arg, this_is_output_file);
4146 if (this_is_output_file)
4147 outfiles[input_file_number] = string;
4148 arg_going = 0;
4153 /* Parse the WRAPPER string which is a comma separated list of the command line
4154 and insert them into the beginning of argbuf. */
4156 static void
4157 insert_wrapper (const char *wrapper)
4159 int n = 0;
4160 int i;
4161 char *buf = xstrdup (wrapper);
4162 char *p = buf;
4163 unsigned int old_length = VEC_length (const_char_p, argbuf);
4167 n++;
4168 while (*p == ',')
4169 p++;
4171 while ((p = strchr (p, ',')) != NULL);
4173 VEC_safe_grow (const_char_p, heap, argbuf, old_length + n);
4174 memmove (VEC_address (const_char_p, argbuf) + n,
4175 VEC_address (const_char_p, argbuf),
4176 old_length * sizeof (const_char_p));
4178 i = 0;
4179 p = buf;
4182 while (*p == ',')
4184 *p = 0;
4185 p++;
4187 VEC_replace (const_char_p, argbuf, i, p);
4188 i++;
4190 while ((p = strchr (p, ',')) != NULL);
4191 gcc_assert (i == n);
4194 /* Process the spec SPEC and run the commands specified therein.
4195 Returns 0 if the spec is successfully processed; -1 if failed. */
4198 do_spec (const char *spec)
4200 int value;
4202 value = do_spec_2 (spec);
4204 /* Force out any unfinished command.
4205 If -pipe, this forces out the last command if it ended in `|'. */
4206 if (value == 0)
4208 if (VEC_length (const_char_p, argbuf) > 0
4209 && !strcmp (VEC_last (const_char_p, argbuf), "|"))
4210 VEC_pop (const_char_p, argbuf);
4212 set_collect_gcc_options ();
4214 if (VEC_length (const_char_p, argbuf) > 0)
4215 value = execute ();
4218 return value;
4221 static int
4222 do_spec_2 (const char *spec)
4224 int result;
4226 clear_args ();
4227 arg_going = 0;
4228 delete_this_arg = 0;
4229 this_is_output_file = 0;
4230 this_is_library_file = 0;
4231 this_is_linker_script = 0;
4232 input_from_pipe = 0;
4233 suffix_subst = NULL;
4235 result = do_spec_1 (spec, 0, NULL);
4237 end_going_arg ();
4239 return result;
4243 /* Process the given spec string and add any new options to the end
4244 of the switches/n_switches array. */
4246 static void
4247 do_option_spec (const char *name, const char *spec)
4249 unsigned int i, value_count, value_len;
4250 const char *p, *q, *value;
4251 char *tmp_spec, *tmp_spec_p;
4253 if (configure_default_options[0].name == NULL)
4254 return;
4256 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4257 if (strcmp (configure_default_options[i].name, name) == 0)
4258 break;
4259 if (i == ARRAY_SIZE (configure_default_options))
4260 return;
4262 value = configure_default_options[i].value;
4263 value_len = strlen (value);
4265 /* Compute the size of the final spec. */
4266 value_count = 0;
4267 p = spec;
4268 while ((p = strstr (p, "%(VALUE)")) != NULL)
4270 p ++;
4271 value_count ++;
4274 /* Replace each %(VALUE) by the specified value. */
4275 tmp_spec = (char *) alloca (strlen (spec) + 1
4276 + value_count * (value_len - strlen ("%(VALUE)")));
4277 tmp_spec_p = tmp_spec;
4278 q = spec;
4279 while ((p = strstr (q, "%(VALUE)")) != NULL)
4281 memcpy (tmp_spec_p, q, p - q);
4282 tmp_spec_p = tmp_spec_p + (p - q);
4283 memcpy (tmp_spec_p, value, value_len);
4284 tmp_spec_p += value_len;
4285 q = p + strlen ("%(VALUE)");
4287 strcpy (tmp_spec_p, q);
4289 do_self_spec (tmp_spec);
4292 /* Process the given spec string and add any new options to the end
4293 of the switches/n_switches array. */
4295 static void
4296 do_self_spec (const char *spec)
4298 int i;
4300 do_spec_2 (spec);
4301 do_spec_1 (" ", 0, NULL);
4303 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4304 do_self_specs adds the replacements to switches array, so it shouldn't
4305 be processed afterwards. */
4306 for (i = 0; i < n_switches; i++)
4307 if ((switches[i].live_cond & SWITCH_IGNORE))
4308 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4310 if (VEC_length (const_char_p, argbuf) > 0)
4312 const char **argbuf_copy;
4313 struct cl_decoded_option *decoded_options;
4314 struct cl_option_handlers handlers;
4315 unsigned int decoded_options_count;
4316 unsigned int j;
4318 /* Create a copy of argbuf with a dummy argv[0] entry for
4319 decode_cmdline_options_to_array. */
4320 argbuf_copy = XNEWVEC (const char *,
4321 VEC_length (const_char_p, argbuf) + 1);
4322 argbuf_copy[0] = "";
4323 memcpy (argbuf_copy + 1, VEC_address (const_char_p, argbuf),
4324 VEC_length (const_char_p, argbuf) * sizeof (const char *));
4326 decode_cmdline_options_to_array (VEC_length (const_char_p, argbuf) + 1,
4327 argbuf_copy,
4328 CL_DRIVER, &decoded_options,
4329 &decoded_options_count);
4330 free (argbuf_copy);
4332 set_option_handlers (&handlers);
4334 for (j = 1; j < decoded_options_count; j++)
4336 switch (decoded_options[j].opt_index)
4338 case OPT_SPECIAL_input_file:
4339 /* Specs should only generate options, not input
4340 files. */
4341 if (strcmp (decoded_options[j].arg, "-") != 0)
4342 fatal_error ("switch %qs does not start with %<-%>",
4343 decoded_options[j].arg);
4344 else
4345 fatal_error ("spec-generated switch is just %<-%>");
4346 break;
4348 case OPT_fcompare_debug_second:
4349 case OPT_fcompare_debug:
4350 case OPT_fcompare_debug_:
4351 case OPT_o:
4352 /* Avoid duplicate processing of some options from
4353 compare-debug specs; just save them here. */
4354 save_switch (decoded_options[j].canonical_option[0],
4355 (decoded_options[j].canonical_option_num_elements
4356 - 1),
4357 &decoded_options[j].canonical_option[1], false, true);
4358 break;
4360 default:
4361 read_cmdline_option (&global_options, &global_options_set,
4362 decoded_options + j, UNKNOWN_LOCATION,
4363 CL_DRIVER, &handlers, global_dc);
4364 break;
4368 alloc_switch ();
4369 switches[n_switches].part1 = 0;
4373 /* Callback for processing %D and %I specs. */
4375 struct spec_path_info {
4376 const char *option;
4377 const char *append;
4378 size_t append_len;
4379 bool omit_relative;
4380 bool separate_options;
4383 static void *
4384 spec_path (char *path, void *data)
4386 struct spec_path_info *info = (struct spec_path_info *) data;
4387 size_t len = 0;
4388 char save = 0;
4390 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4391 return NULL;
4393 if (info->append_len != 0)
4395 len = strlen (path);
4396 memcpy (path + len, info->append, info->append_len + 1);
4399 if (!is_directory (path, true))
4400 return NULL;
4402 do_spec_1 (info->option, 1, NULL);
4403 if (info->separate_options)
4404 do_spec_1 (" ", 0, NULL);
4406 if (info->append_len == 0)
4408 len = strlen (path);
4409 save = path[len - 1];
4410 if (IS_DIR_SEPARATOR (path[len - 1]))
4411 path[len - 1] = '\0';
4414 do_spec_1 (path, 1, NULL);
4415 do_spec_1 (" ", 0, NULL);
4417 /* Must not damage the original path. */
4418 if (info->append_len == 0)
4419 path[len - 1] = save;
4421 return NULL;
4424 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4425 argument list. */
4427 static void
4428 create_at_file (char **argv)
4430 char *temp_file = make_temp_file ("");
4431 char *at_argument = concat ("@", temp_file, NULL);
4432 FILE *f = fopen (temp_file, "w");
4433 int status;
4435 if (f == NULL)
4436 fatal_error ("could not open temporary response file %s",
4437 temp_file);
4439 status = writeargv (argv, f);
4441 if (status)
4442 fatal_error ("could not write to temporary response file %s",
4443 temp_file);
4445 status = fclose (f);
4447 if (EOF == status)
4448 fatal_error ("could not close temporary response file %s",
4449 temp_file);
4451 store_arg (at_argument, 0, 0);
4453 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4456 /* True if we should compile INFILE. */
4458 static bool
4459 compile_input_file_p (struct infile *infile)
4461 if ((!infile->language) || (infile->language[0] != '*'))
4462 if (infile->incompiler == input_file_compiler)
4463 return true;
4464 return false;
4467 /* Process each member of VEC as a spec. */
4469 static void
4470 do_specs_vec (VEC(char_p,heap) *vec)
4472 unsigned ix;
4473 char *opt;
4475 FOR_EACH_VEC_ELT (char_p, vec, ix, opt)
4477 do_spec_1 (opt, 1, NULL);
4478 /* Make each accumulated option a separate argument. */
4479 do_spec_1 (" ", 0, NULL);
4483 /* Process the sub-spec SPEC as a portion of a larger spec.
4484 This is like processing a whole spec except that we do
4485 not initialize at the beginning and we do not supply a
4486 newline by default at the end.
4487 INSWITCH nonzero means don't process %-sequences in SPEC;
4488 in this case, % is treated as an ordinary character.
4489 This is used while substituting switches.
4490 INSWITCH nonzero also causes SPC not to terminate an argument.
4492 Value is zero unless a line was finished
4493 and the command on that line reported an error. */
4495 static int
4496 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4498 const char *p = spec;
4499 int c;
4500 int i;
4501 int value;
4503 /* If it's an empty string argument to a switch, keep it as is. */
4504 if (inswitch && !*p)
4505 arg_going = 1;
4507 while ((c = *p++))
4508 /* If substituting a switch, treat all chars like letters.
4509 Otherwise, NL, SPC, TAB and % are special. */
4510 switch (inswitch ? 'a' : c)
4512 case '\n':
4513 end_going_arg ();
4515 if (VEC_length (const_char_p, argbuf) > 0
4516 && !strcmp (VEC_last (const_char_p, argbuf), "|"))
4518 /* A `|' before the newline means use a pipe here,
4519 but only if -pipe was specified.
4520 Otherwise, execute now and don't pass the `|' as an arg. */
4521 if (use_pipes)
4523 input_from_pipe = 1;
4524 break;
4526 else
4527 VEC_pop (const_char_p, argbuf);
4530 set_collect_gcc_options ();
4532 if (VEC_length (const_char_p, argbuf) > 0)
4534 value = execute ();
4535 if (value)
4536 return value;
4538 /* Reinitialize for a new command, and for a new argument. */
4539 clear_args ();
4540 arg_going = 0;
4541 delete_this_arg = 0;
4542 this_is_output_file = 0;
4543 this_is_library_file = 0;
4544 this_is_linker_script = 0;
4545 input_from_pipe = 0;
4546 break;
4548 case '|':
4549 end_going_arg ();
4551 /* Use pipe */
4552 obstack_1grow (&obstack, c);
4553 arg_going = 1;
4554 break;
4556 case '\t':
4557 case ' ':
4558 end_going_arg ();
4560 /* Reinitialize for a new argument. */
4561 delete_this_arg = 0;
4562 this_is_output_file = 0;
4563 this_is_library_file = 0;
4564 this_is_linker_script = 0;
4565 break;
4567 case '%':
4568 switch (c = *p++)
4570 case 0:
4571 fatal_error ("spec %qs invalid", spec);
4573 case 'b':
4574 if (save_temps_length)
4575 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4576 else
4577 obstack_grow (&obstack, input_basename, basename_length);
4578 if (compare_debug < 0)
4579 obstack_grow (&obstack, ".gk", 3);
4580 arg_going = 1;
4581 break;
4583 case 'B':
4584 if (save_temps_length)
4585 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4586 else
4587 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4588 if (compare_debug < 0)
4589 obstack_grow (&obstack, ".gk", 3);
4590 arg_going = 1;
4591 break;
4593 case 'd':
4594 delete_this_arg = 2;
4595 break;
4597 /* Dump out the directories specified with LIBRARY_PATH,
4598 followed by the absolute directories
4599 that we search for startfiles. */
4600 case 'D':
4602 struct spec_path_info info;
4604 info.option = "-L";
4605 info.append_len = 0;
4606 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4607 /* Used on systems which record the specified -L dirs
4608 and use them to search for dynamic linking.
4609 Relative directories always come from -B,
4610 and it is better not to use them for searching
4611 at run time. In particular, stage1 loses. */
4612 info.omit_relative = true;
4613 #else
4614 info.omit_relative = false;
4615 #endif
4616 info.separate_options = false;
4618 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4620 break;
4622 case 'e':
4623 /* %efoo means report an error with `foo' as error message
4624 and don't execute any more commands for this file. */
4626 const char *q = p;
4627 char *buf;
4628 while (*p != 0 && *p != '\n')
4629 p++;
4630 buf = (char *) alloca (p - q + 1);
4631 strncpy (buf, q, p - q);
4632 buf[p - q] = 0;
4633 error ("%s", _(buf));
4634 return -1;
4636 break;
4637 case 'n':
4638 /* %nfoo means report a notice with `foo' on stderr. */
4640 const char *q = p;
4641 char *buf;
4642 while (*p != 0 && *p != '\n')
4643 p++;
4644 buf = (char *) alloca (p - q + 1);
4645 strncpy (buf, q, p - q);
4646 buf[p - q] = 0;
4647 inform (0, "%s", _(buf));
4648 if (*p)
4649 p++;
4651 break;
4653 case 'j':
4655 struct stat st;
4657 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4658 defined, and it is not a directory, and it is
4659 writable, use it. Otherwise, treat this like any
4660 other temporary file. */
4662 if ((!save_temps_flag)
4663 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4664 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4666 obstack_grow (&obstack, HOST_BIT_BUCKET,
4667 strlen (HOST_BIT_BUCKET));
4668 delete_this_arg = 0;
4669 arg_going = 1;
4670 break;
4673 goto create_temp_file;
4674 case '|':
4675 if (use_pipes)
4677 obstack_1grow (&obstack, '-');
4678 delete_this_arg = 0;
4679 arg_going = 1;
4681 /* consume suffix */
4682 while (*p == '.' || ISALNUM ((unsigned char) *p))
4683 p++;
4684 if (p[0] == '%' && p[1] == 'O')
4685 p += 2;
4687 break;
4689 goto create_temp_file;
4690 case 'm':
4691 if (use_pipes)
4693 /* consume suffix */
4694 while (*p == '.' || ISALNUM ((unsigned char) *p))
4695 p++;
4696 if (p[0] == '%' && p[1] == 'O')
4697 p += 2;
4699 break;
4701 goto create_temp_file;
4702 case 'g':
4703 case 'u':
4704 case 'U':
4705 create_temp_file:
4707 struct temp_name *t;
4708 int suffix_length;
4709 const char *suffix = p;
4710 char *saved_suffix = NULL;
4712 while (*p == '.' || ISALNUM ((unsigned char) *p))
4713 p++;
4714 suffix_length = p - suffix;
4715 if (p[0] == '%' && p[1] == 'O')
4717 p += 2;
4718 /* We don't support extra suffix characters after %O. */
4719 if (*p == '.' || ISALNUM ((unsigned char) *p))
4720 fatal_error ("spec %qs has invalid %<%%0%c%>", spec, *p);
4721 if (suffix_length == 0)
4722 suffix = TARGET_OBJECT_SUFFIX;
4723 else
4725 saved_suffix
4726 = XNEWVEC (char, suffix_length
4727 + strlen (TARGET_OBJECT_SUFFIX));
4728 strncpy (saved_suffix, suffix, suffix_length);
4729 strcpy (saved_suffix + suffix_length,
4730 TARGET_OBJECT_SUFFIX);
4732 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4735 if (compare_debug < 0)
4737 suffix = concat (".gk", suffix, NULL);
4738 suffix_length += 3;
4741 /* If -save-temps=obj and -o were specified, use that for the
4742 temp file. */
4743 if (save_temps_length)
4745 char *tmp;
4746 temp_filename_length
4747 = save_temps_length + suffix_length + 1;
4748 tmp = (char *) alloca (temp_filename_length);
4749 memcpy (tmp, save_temps_prefix, save_temps_length);
4750 memcpy (tmp + save_temps_length, suffix, suffix_length);
4751 tmp[save_temps_length + suffix_length] = '\0';
4752 temp_filename = save_string (tmp, save_temps_length
4753 + suffix_length);
4754 obstack_grow (&obstack, temp_filename,
4755 temp_filename_length);
4756 arg_going = 1;
4757 delete_this_arg = 0;
4758 break;
4761 /* If the gcc_input_filename has the same suffix specified
4762 for the %g, %u, or %U, and -save-temps is specified,
4763 we could end up using that file as an intermediate
4764 thus clobbering the user's source file (.e.g.,
4765 gcc -save-temps foo.s would clobber foo.s with the
4766 output of cpp0). So check for this condition and
4767 generate a temp file as the intermediate. */
4769 if (save_temps_flag)
4771 char *tmp;
4772 temp_filename_length = basename_length + suffix_length + 1;
4773 tmp = (char *) alloca (temp_filename_length);
4774 memcpy (tmp, input_basename, basename_length);
4775 memcpy (tmp + basename_length, suffix, suffix_length);
4776 tmp[basename_length + suffix_length] = '\0';
4777 temp_filename = tmp;
4779 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
4781 #ifndef HOST_LACKS_INODE_NUMBERS
4782 struct stat st_temp;
4784 /* Note, set_input() resets input_stat_set to 0. */
4785 if (input_stat_set == 0)
4787 input_stat_set = stat (gcc_input_filename,
4788 &input_stat);
4789 if (input_stat_set >= 0)
4790 input_stat_set = 1;
4793 /* If we have the stat for the gcc_input_filename
4794 and we can do the stat for the temp_filename
4795 then the they could still refer to the same
4796 file if st_dev/st_ino's are the same. */
4797 if (input_stat_set != 1
4798 || stat (temp_filename, &st_temp) < 0
4799 || input_stat.st_dev != st_temp.st_dev
4800 || input_stat.st_ino != st_temp.st_ino)
4801 #else
4802 /* Just compare canonical pathnames. */
4803 char* input_realname = lrealpath (gcc_input_filename);
4804 char* temp_realname = lrealpath (temp_filename);
4805 bool files_differ = filename_cmp (input_realname, temp_realname);
4806 free (input_realname);
4807 free (temp_realname);
4808 if (files_differ)
4809 #endif
4811 temp_filename = save_string (temp_filename,
4812 temp_filename_length + 1);
4813 obstack_grow (&obstack, temp_filename,
4814 temp_filename_length);
4815 arg_going = 1;
4816 delete_this_arg = 0;
4817 break;
4822 /* See if we already have an association of %g/%u/%U and
4823 suffix. */
4824 for (t = temp_names; t; t = t->next)
4825 if (t->length == suffix_length
4826 && strncmp (t->suffix, suffix, suffix_length) == 0
4827 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4828 break;
4830 /* Make a new association if needed. %u and %j
4831 require one. */
4832 if (t == 0 || c == 'u' || c == 'j')
4834 if (t == 0)
4836 t = XNEW (struct temp_name);
4837 t->next = temp_names;
4838 temp_names = t;
4840 t->length = suffix_length;
4841 if (saved_suffix)
4843 t->suffix = saved_suffix;
4844 saved_suffix = NULL;
4846 else
4847 t->suffix = save_string (suffix, suffix_length);
4848 t->unique = (c == 'u' || c == 'U' || c == 'j');
4849 temp_filename = make_temp_file (t->suffix);
4850 temp_filename_length = strlen (temp_filename);
4851 t->filename = temp_filename;
4852 t->filename_length = temp_filename_length;
4855 free (saved_suffix);
4857 obstack_grow (&obstack, t->filename, t->filename_length);
4858 delete_this_arg = 1;
4860 arg_going = 1;
4861 break;
4863 case 'i':
4864 if (combine_inputs)
4866 if (at_file_supplied)
4868 /* We are going to expand `%i' to `@FILE', where FILE
4869 is a newly-created temporary filename. The filenames
4870 that would usually be expanded in place of %o will be
4871 written to the temporary file. */
4872 char **argv;
4873 int n_files = 0;
4874 int j;
4876 for (i = 0; i < n_infiles; i++)
4877 if (compile_input_file_p (&infiles[i]))
4878 n_files++;
4880 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
4882 /* Copy the strings over. */
4883 for (i = 0, j = 0; i < n_infiles; i++)
4884 if (compile_input_file_p (&infiles[i]))
4886 argv[j] = CONST_CAST (char *, infiles[i].name);
4887 infiles[i].compiled = true;
4888 j++;
4890 argv[j] = NULL;
4892 create_at_file (argv);
4894 else
4895 for (i = 0; (int) i < n_infiles; i++)
4896 if (compile_input_file_p (&infiles[i]))
4898 store_arg (infiles[i].name, 0, 0);
4899 infiles[i].compiled = true;
4902 else
4904 obstack_grow (&obstack, gcc_input_filename,
4905 input_filename_length);
4906 arg_going = 1;
4908 break;
4910 case 'I':
4912 struct spec_path_info info;
4914 if (multilib_dir)
4916 do_spec_1 ("-imultilib", 1, NULL);
4917 /* Make this a separate argument. */
4918 do_spec_1 (" ", 0, NULL);
4919 do_spec_1 (multilib_dir, 1, NULL);
4920 do_spec_1 (" ", 0, NULL);
4923 if (gcc_exec_prefix)
4925 do_spec_1 ("-iprefix", 1, NULL);
4926 /* Make this a separate argument. */
4927 do_spec_1 (" ", 0, NULL);
4928 do_spec_1 (gcc_exec_prefix, 1, NULL);
4929 do_spec_1 (" ", 0, NULL);
4932 if (target_system_root_changed ||
4933 (target_system_root && target_sysroot_hdrs_suffix))
4935 do_spec_1 ("-isysroot", 1, NULL);
4936 /* Make this a separate argument. */
4937 do_spec_1 (" ", 0, NULL);
4938 do_spec_1 (target_system_root, 1, NULL);
4939 if (target_sysroot_hdrs_suffix)
4940 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
4941 do_spec_1 (" ", 0, NULL);
4944 info.option = "-isystem";
4945 info.append = "include";
4946 info.append_len = strlen (info.append);
4947 info.omit_relative = false;
4948 info.separate_options = true;
4950 for_each_path (&include_prefixes, false, info.append_len,
4951 spec_path, &info);
4953 info.append = "include-fixed";
4954 if (*sysroot_hdrs_suffix_spec)
4955 info.append = concat (info.append, dir_separator_str,
4956 multilib_dir, NULL);
4957 info.append_len = strlen (info.append);
4958 for_each_path (&include_prefixes, false, info.append_len,
4959 spec_path, &info);
4961 break;
4963 case 'o':
4965 int max = n_infiles;
4966 max += lang_specific_extra_outfiles;
4968 if (HAVE_GNU_LD && at_file_supplied)
4970 /* We are going to expand `%o' to `@FILE', where FILE
4971 is a newly-created temporary filename. The filenames
4972 that would usually be expanded in place of %o will be
4973 written to the temporary file. */
4975 char **argv;
4976 int n_files, j;
4978 /* Convert OUTFILES into a form suitable for writeargv. */
4980 /* Determine how many are non-NULL. */
4981 for (n_files = 0, i = 0; i < max; i++)
4982 n_files += outfiles[i] != NULL;
4984 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
4986 /* Copy the strings over. */
4987 for (i = 0, j = 0; i < max; i++)
4988 if (outfiles[i])
4990 argv[j] = CONST_CAST (char *, outfiles[i]);
4991 j++;
4993 argv[j] = NULL;
4995 create_at_file (argv);
4997 else
4998 for (i = 0; i < max; i++)
4999 if (outfiles[i])
5000 store_arg (outfiles[i], 0, 0);
5001 break;
5004 case 'O':
5005 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
5006 arg_going = 1;
5007 break;
5009 case 's':
5010 this_is_library_file = 1;
5011 break;
5013 case 'T':
5014 this_is_linker_script = 1;
5015 break;
5017 case 'V':
5018 outfiles[input_file_number] = NULL;
5019 break;
5021 case 'w':
5022 this_is_output_file = 1;
5023 break;
5025 case 'W':
5027 unsigned int cur_index = VEC_length (const_char_p, argbuf);
5028 /* Handle the {...} following the %W. */
5029 if (*p != '{')
5030 fatal_error ("spec %qs has invalid %<%%W%c%>", spec, *p);
5031 p = handle_braces (p + 1);
5032 if (p == 0)
5033 return -1;
5034 end_going_arg ();
5035 /* If any args were output, mark the last one for deletion
5036 on failure. */
5037 if (VEC_length (const_char_p, argbuf) != cur_index)
5038 record_temp_file (VEC_last (const_char_p, argbuf), 0, 1);
5039 break;
5042 /* %x{OPTION} records OPTION for %X to output. */
5043 case 'x':
5045 const char *p1 = p;
5046 char *string;
5047 char *opt;
5048 unsigned ix;
5050 /* Skip past the option value and make a copy. */
5051 if (*p != '{')
5052 fatal_error ("spec %qs has invalid %<%%x%c%>", spec, *p);
5053 while (*p++ != '}')
5055 string = save_string (p1 + 1, p - p1 - 2);
5057 /* See if we already recorded this option. */
5058 FOR_EACH_VEC_ELT (char_p, linker_options, ix, opt)
5059 if (! strcmp (string, opt))
5061 free (string);
5062 return 0;
5065 /* This option is new; add it. */
5066 add_linker_option (string, strlen (string));
5067 free (string);
5069 break;
5071 /* Dump out the options accumulated previously using %x. */
5072 case 'X':
5073 do_specs_vec (linker_options);
5074 break;
5076 /* Dump out the options accumulated previously using -Wa,. */
5077 case 'Y':
5078 do_specs_vec (assembler_options);
5079 break;
5081 /* Dump out the options accumulated previously using -Wp,. */
5082 case 'Z':
5083 do_specs_vec (preprocessor_options);
5084 break;
5086 /* Here are digits and numbers that just process
5087 a certain constant string as a spec. */
5089 case '1':
5090 value = do_spec_1 (cc1_spec, 0, NULL);
5091 if (value != 0)
5092 return value;
5093 break;
5095 case '2':
5096 value = do_spec_1 (cc1plus_spec, 0, NULL);
5097 if (value != 0)
5098 return value;
5099 break;
5101 case 'a':
5102 value = do_spec_1 (asm_spec, 0, NULL);
5103 if (value != 0)
5104 return value;
5105 break;
5107 case 'A':
5108 value = do_spec_1 (asm_final_spec, 0, NULL);
5109 if (value != 0)
5110 return value;
5111 break;
5113 case 'C':
5115 const char *const spec
5116 = (input_file_compiler->cpp_spec
5117 ? input_file_compiler->cpp_spec
5118 : cpp_spec);
5119 value = do_spec_1 (spec, 0, NULL);
5120 if (value != 0)
5121 return value;
5123 break;
5125 case 'E':
5126 value = do_spec_1 (endfile_spec, 0, NULL);
5127 if (value != 0)
5128 return value;
5129 break;
5131 case 'l':
5132 value = do_spec_1 (link_spec, 0, NULL);
5133 if (value != 0)
5134 return value;
5135 break;
5137 case 'L':
5138 value = do_spec_1 (lib_spec, 0, NULL);
5139 if (value != 0)
5140 return value;
5141 break;
5143 case 'M':
5144 if (multilib_os_dir == NULL)
5145 obstack_1grow (&obstack, '.');
5146 else
5147 obstack_grow (&obstack, multilib_os_dir,
5148 strlen (multilib_os_dir));
5149 break;
5151 case 'G':
5152 value = do_spec_1 (libgcc_spec, 0, NULL);
5153 if (value != 0)
5154 return value;
5155 break;
5157 case 'R':
5158 /* We assume there is a directory
5159 separator at the end of this string. */
5160 if (target_system_root)
5162 obstack_grow (&obstack, target_system_root,
5163 strlen (target_system_root));
5164 if (target_sysroot_suffix)
5165 obstack_grow (&obstack, target_sysroot_suffix,
5166 strlen (target_sysroot_suffix));
5168 break;
5170 case 'S':
5171 value = do_spec_1 (startfile_spec, 0, NULL);
5172 if (value != 0)
5173 return value;
5174 break;
5176 /* Here we define characters other than letters and digits. */
5178 case '{':
5179 p = handle_braces (p);
5180 if (p == 0)
5181 return -1;
5182 break;
5184 case ':':
5185 p = handle_spec_function (p);
5186 if (p == 0)
5187 return -1;
5188 break;
5190 case '%':
5191 obstack_1grow (&obstack, '%');
5192 break;
5194 case '.':
5196 unsigned len = 0;
5198 while (p[len] && p[len] != ' ' && p[len] != '%')
5199 len++;
5200 suffix_subst = save_string (p - 1, len + 1);
5201 p += len;
5203 break;
5205 /* Henceforth ignore the option(s) matching the pattern
5206 after the %<. */
5207 case '<':
5208 case '>':
5210 unsigned len = 0;
5211 int have_wildcard = 0;
5212 int i;
5213 int switch_option;
5215 if (c == '>')
5216 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5217 else
5218 switch_option = SWITCH_IGNORE;
5220 while (p[len] && p[len] != ' ' && p[len] != '\t')
5221 len++;
5223 if (p[len-1] == '*')
5224 have_wildcard = 1;
5226 for (i = 0; i < n_switches; i++)
5227 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5228 && (have_wildcard || switches[i].part1[len] == '\0'))
5230 switches[i].live_cond |= switch_option;
5231 /* User switch be validated from validate_all_switches.
5232 when the definition is seen from the spec file.
5233 If not defined anywhere, will be rejected. */
5234 if (switches[i].known)
5235 switches[i].validated = true;
5238 p += len;
5240 break;
5242 case '*':
5243 if (soft_matched_part)
5245 if (soft_matched_part[0])
5246 do_spec_1 (soft_matched_part, 1, NULL);
5247 do_spec_1 (" ", 0, NULL);
5249 else
5250 /* Catch the case where a spec string contains something like
5251 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5252 hand side of the :. */
5253 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5254 break;
5256 /* Process a string found as the value of a spec given by name.
5257 This feature allows individual machine descriptions
5258 to add and use their own specs. */
5259 case '(':
5261 const char *name = p;
5262 struct spec_list *sl;
5263 int len;
5265 /* The string after the S/P is the name of a spec that is to be
5266 processed. */
5267 while (*p && *p != ')')
5268 p++;
5270 /* See if it's in the list. */
5271 for (len = p - name, sl = specs; sl; sl = sl->next)
5272 if (sl->name_len == len && !strncmp (sl->name, name, len))
5274 name = *(sl->ptr_spec);
5275 #ifdef DEBUG_SPECS
5276 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5277 sl->name, name);
5278 #endif
5279 break;
5282 if (sl)
5284 value = do_spec_1 (name, 0, NULL);
5285 if (value != 0)
5286 return value;
5289 /* Discard the closing paren. */
5290 if (*p)
5291 p++;
5293 break;
5295 default:
5296 error ("spec failure: unrecognized spec option %qc", c);
5297 break;
5299 break;
5301 case '\\':
5302 /* Backslash: treat next character as ordinary. */
5303 c = *p++;
5305 /* Fall through. */
5306 default:
5307 /* Ordinary character: put it into the current argument. */
5308 obstack_1grow (&obstack, c);
5309 arg_going = 1;
5312 /* End of string. If we are processing a spec function, we need to
5313 end any pending argument. */
5314 if (processing_spec_function)
5315 end_going_arg ();
5317 return 0;
5320 /* Look up a spec function. */
5322 static const struct spec_function *
5323 lookup_spec_function (const char *name)
5325 const struct spec_function *sf;
5327 for (sf = static_spec_functions; sf->name != NULL; sf++)
5328 if (strcmp (sf->name, name) == 0)
5329 return sf;
5331 return NULL;
5334 /* Evaluate a spec function. */
5336 static const char *
5337 eval_spec_function (const char *func, const char *args)
5339 const struct spec_function *sf;
5340 const char *funcval;
5342 /* Saved spec processing context. */
5343 VEC(const_char_p,heap) *save_argbuf;
5345 int save_arg_going;
5346 int save_delete_this_arg;
5347 int save_this_is_output_file;
5348 int save_this_is_library_file;
5349 int save_input_from_pipe;
5350 int save_this_is_linker_script;
5351 const char *save_suffix_subst;
5353 int save_growing_size;
5354 void *save_growing_value;
5356 sf = lookup_spec_function (func);
5357 if (sf == NULL)
5358 fatal_error ("unknown spec function %qs", func);
5360 /* Push the spec processing context. */
5361 save_argbuf = argbuf;
5363 save_arg_going = arg_going;
5364 save_delete_this_arg = delete_this_arg;
5365 save_this_is_output_file = this_is_output_file;
5366 save_this_is_library_file = this_is_library_file;
5367 save_this_is_linker_script = this_is_linker_script;
5368 save_input_from_pipe = input_from_pipe;
5369 save_suffix_subst = suffix_subst;
5371 /* If we have some object growing now, finalize it so the args and function
5372 eval proceed from a cleared context. This is needed to prevent the first
5373 constructed arg from mistakenly including the growing value. We'll push
5374 this value back on the obstack once the function evaluation is done, to
5375 restore a consistent processing context for our caller. This is fine as
5376 the address of growing objects isn't guaranteed to remain stable until
5377 they are finalized, and we expect this situation to be rare enough for
5378 the extra copy not to be an issue. */
5379 save_growing_size = obstack_object_size (&obstack);
5380 if (save_growing_size > 0)
5381 save_growing_value = obstack_finish (&obstack);
5383 /* Create a new spec processing context, and build the function
5384 arguments. */
5386 alloc_args ();
5387 if (do_spec_2 (args) < 0)
5388 fatal_error ("error in args to spec function %qs", func);
5390 /* argbuf_index is an index for the next argument to be inserted, and
5391 so contains the count of the args already inserted. */
5393 funcval = (*sf->func) (VEC_length (const_char_p, argbuf),
5394 VEC_address (const_char_p, argbuf));
5396 /* Pop the spec processing context. */
5397 VEC_free (const_char_p, heap, argbuf);
5398 argbuf = save_argbuf;
5400 arg_going = save_arg_going;
5401 delete_this_arg = save_delete_this_arg;
5402 this_is_output_file = save_this_is_output_file;
5403 this_is_library_file = save_this_is_library_file;
5404 this_is_linker_script = save_this_is_linker_script;
5405 input_from_pipe = save_input_from_pipe;
5406 suffix_subst = save_suffix_subst;
5408 if (save_growing_size > 0)
5409 obstack_grow (&obstack, save_growing_value, save_growing_size);
5411 return funcval;
5414 /* Handle a spec function call of the form:
5416 %:function(args)
5418 ARGS is processed as a spec in a separate context and split into an
5419 argument vector in the normal fashion. The function returns a string
5420 containing a spec which we then process in the caller's context, or
5421 NULL if no processing is required. */
5423 static const char *
5424 handle_spec_function (const char *p)
5426 char *func, *args;
5427 const char *endp, *funcval;
5428 int count;
5430 processing_spec_function++;
5432 /* Get the function name. */
5433 for (endp = p; *endp != '\0'; endp++)
5435 if (*endp == '(') /* ) */
5436 break;
5437 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5438 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5439 fatal_error ("malformed spec function name");
5441 if (*endp != '(') /* ) */
5442 fatal_error ("no arguments for spec function");
5443 func = save_string (p, endp - p);
5444 p = ++endp;
5446 /* Get the arguments. */
5447 for (count = 0; *endp != '\0'; endp++)
5449 /* ( */
5450 if (*endp == ')')
5452 if (count == 0)
5453 break;
5454 count--;
5456 else if (*endp == '(') /* ) */
5457 count++;
5459 /* ( */
5460 if (*endp != ')')
5461 fatal_error ("malformed spec function arguments");
5462 args = save_string (p, endp - p);
5463 p = ++endp;
5465 /* p now points to just past the end of the spec function expression. */
5467 funcval = eval_spec_function (func, args);
5468 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5469 p = NULL;
5471 free (func);
5472 free (args);
5474 processing_spec_function--;
5476 return p;
5479 /* Inline subroutine of handle_braces. Returns true if the current
5480 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5481 static inline bool
5482 input_suffix_matches (const char *atom, const char *end_atom)
5484 return (input_suffix
5485 && !strncmp (input_suffix, atom, end_atom - atom)
5486 && input_suffix[end_atom - atom] == '\0');
5489 /* Subroutine of handle_braces. Returns true if the current
5490 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
5491 static bool
5492 input_spec_matches (const char *atom, const char *end_atom)
5494 return (input_file_compiler
5495 && input_file_compiler->suffix
5496 && input_file_compiler->suffix[0] != '\0'
5497 && !strncmp (input_file_compiler->suffix + 1, atom,
5498 end_atom - atom)
5499 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5502 /* Subroutine of handle_braces. Returns true if a switch
5503 matching the atom bracketed by ATOM and END_ATOM appeared on the
5504 command line. */
5505 static bool
5506 switch_matches (const char *atom, const char *end_atom, int starred)
5508 int i;
5509 int len = end_atom - atom;
5510 int plen = starred ? len : -1;
5512 for (i = 0; i < n_switches; i++)
5513 if (!strncmp (switches[i].part1, atom, len)
5514 && (starred || switches[i].part1[len] == '\0')
5515 && check_live_switch (i, plen))
5516 return true;
5518 /* Check if a switch with separated form matching the atom.
5519 We check -D and -U switches. */
5520 else if (switches[i].args != 0)
5522 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
5523 && *switches[i].part1 == atom[0])
5525 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
5526 && (starred || (switches[i].part1[1] == '\0'
5527 && switches[i].args[0][len - 1] == '\0'))
5528 && check_live_switch (i, (starred ? 1 : -1)))
5529 return true;
5533 return false;
5536 /* Inline subroutine of handle_braces. Mark all of the switches which
5537 match ATOM (extends to END_ATOM; STARRED indicates whether there
5538 was a star after the atom) for later processing. */
5539 static inline void
5540 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5542 int i;
5543 int len = end_atom - atom;
5544 int plen = starred ? len : -1;
5546 for (i = 0; i < n_switches; i++)
5547 if (!strncmp (switches[i].part1, atom, len)
5548 && (starred || switches[i].part1[len] == '\0')
5549 && check_live_switch (i, plen))
5550 switches[i].ordering = 1;
5553 /* Inline subroutine of handle_braces. Process all the currently
5554 marked switches through give_switch, and clear the marks. */
5555 static inline void
5556 process_marked_switches (void)
5558 int i;
5560 for (i = 0; i < n_switches; i++)
5561 if (switches[i].ordering == 1)
5563 switches[i].ordering = 0;
5564 give_switch (i, 0);
5568 /* Handle a %{ ... } construct. P points just inside the leading {.
5569 Returns a pointer one past the end of the brace block, or 0
5570 if we call do_spec_1 and that returns -1. */
5572 static const char *
5573 handle_braces (const char *p)
5575 const char *atom, *end_atom;
5576 const char *d_atom = NULL, *d_end_atom = NULL;
5577 const char *orig = p;
5579 bool a_is_suffix;
5580 bool a_is_spectype;
5581 bool a_is_starred;
5582 bool a_is_negated;
5583 bool a_matched;
5585 bool a_must_be_last = false;
5586 bool ordered_set = false;
5587 bool disjunct_set = false;
5588 bool disj_matched = false;
5589 bool disj_starred = true;
5590 bool n_way_choice = false;
5591 bool n_way_matched = false;
5593 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5597 if (a_must_be_last)
5598 goto invalid;
5600 /* Scan one "atom" (S in the description above of %{}, possibly
5601 with '!', '.', '@', ',', or '*' modifiers). */
5602 a_matched = false;
5603 a_is_suffix = false;
5604 a_is_starred = false;
5605 a_is_negated = false;
5606 a_is_spectype = false;
5608 SKIP_WHITE();
5609 if (*p == '!')
5610 p++, a_is_negated = true;
5612 SKIP_WHITE();
5613 if (*p == '.')
5614 p++, a_is_suffix = true;
5615 else if (*p == ',')
5616 p++, a_is_spectype = true;
5618 atom = p;
5619 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5620 || *p == ',' || *p == '.' || *p == '@')
5621 p++;
5622 end_atom = p;
5624 if (*p == '*')
5625 p++, a_is_starred = 1;
5627 SKIP_WHITE();
5628 switch (*p)
5630 case '&': case '}':
5631 /* Substitute the switch(es) indicated by the current atom. */
5632 ordered_set = true;
5633 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5634 || a_is_spectype || atom == end_atom)
5635 goto invalid;
5637 mark_matching_switches (atom, end_atom, a_is_starred);
5639 if (*p == '}')
5640 process_marked_switches ();
5641 break;
5643 case '|': case ':':
5644 /* Substitute some text if the current atom appears as a switch
5645 or suffix. */
5646 disjunct_set = true;
5647 if (ordered_set)
5648 goto invalid;
5650 if (atom == end_atom)
5652 if (!n_way_choice || disj_matched || *p == '|'
5653 || a_is_negated || a_is_suffix || a_is_spectype
5654 || a_is_starred)
5655 goto invalid;
5657 /* An empty term may appear as the last choice of an
5658 N-way choice set; it means "otherwise". */
5659 a_must_be_last = true;
5660 disj_matched = !n_way_matched;
5661 disj_starred = false;
5663 else
5665 if ((a_is_suffix || a_is_spectype) && a_is_starred)
5666 goto invalid;
5668 if (!a_is_starred)
5669 disj_starred = false;
5671 /* Don't bother testing this atom if we already have a
5672 match. */
5673 if (!disj_matched && !n_way_matched)
5675 if (a_is_suffix)
5676 a_matched = input_suffix_matches (atom, end_atom);
5677 else if (a_is_spectype)
5678 a_matched = input_spec_matches (atom, end_atom);
5679 else
5680 a_matched = switch_matches (atom, end_atom, a_is_starred);
5682 if (a_matched != a_is_negated)
5684 disj_matched = true;
5685 d_atom = atom;
5686 d_end_atom = end_atom;
5691 if (*p == ':')
5693 /* Found the body, that is, the text to substitute if the
5694 current disjunction matches. */
5695 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5696 disj_matched && !n_way_matched);
5697 if (p == 0)
5698 return 0;
5700 /* If we have an N-way choice, reset state for the next
5701 disjunction. */
5702 if (*p == ';')
5704 n_way_choice = true;
5705 n_way_matched |= disj_matched;
5706 disj_matched = false;
5707 disj_starred = true;
5708 d_atom = d_end_atom = NULL;
5711 break;
5713 default:
5714 goto invalid;
5717 while (*p++ != '}');
5719 return p;
5721 invalid:
5722 fatal_error ("braced spec %qs is invalid at %qc", orig, *p);
5724 #undef SKIP_WHITE
5727 /* Subroutine of handle_braces. Scan and process a brace substitution body
5728 (X in the description of %{} syntax). P points one past the colon;
5729 ATOM and END_ATOM bracket the first atom which was found to be true
5730 (present) in the current disjunction; STARRED indicates whether all
5731 the atoms in the current disjunction were starred (for syntax validation);
5732 MATCHED indicates whether the disjunction matched or not, and therefore
5733 whether or not the body is to be processed through do_spec_1 or just
5734 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5735 returns -1. */
5737 static const char *
5738 process_brace_body (const char *p, const char *atom, const char *end_atom,
5739 int starred, int matched)
5741 const char *body, *end_body;
5742 unsigned int nesting_level;
5743 bool have_subst = false;
5745 /* Locate the closing } or ;, honoring nested braces.
5746 Trim trailing whitespace. */
5747 body = p;
5748 nesting_level = 1;
5749 for (;;)
5751 if (*p == '{')
5752 nesting_level++;
5753 else if (*p == '}')
5755 if (!--nesting_level)
5756 break;
5758 else if (*p == ';' && nesting_level == 1)
5759 break;
5760 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5761 have_subst = true;
5762 else if (*p == '\0')
5763 goto invalid;
5764 p++;
5767 end_body = p;
5768 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5769 end_body--;
5771 if (have_subst && !starred)
5772 goto invalid;
5774 if (matched)
5776 /* Copy the substitution body to permanent storage and execute it.
5777 If have_subst is false, this is a simple matter of running the
5778 body through do_spec_1... */
5779 char *string = save_string (body, end_body - body);
5780 if (!have_subst)
5782 if (do_spec_1 (string, 0, NULL) < 0)
5783 return 0;
5785 else
5787 /* ... but if have_subst is true, we have to process the
5788 body once for each matching switch, with %* set to the
5789 variant part of the switch. */
5790 unsigned int hard_match_len = end_atom - atom;
5791 int i;
5793 for (i = 0; i < n_switches; i++)
5794 if (!strncmp (switches[i].part1, atom, hard_match_len)
5795 && check_live_switch (i, hard_match_len))
5797 if (do_spec_1 (string, 0,
5798 &switches[i].part1[hard_match_len]) < 0)
5799 return 0;
5800 /* Pass any arguments this switch has. */
5801 give_switch (i, 1);
5802 suffix_subst = NULL;
5807 return p;
5809 invalid:
5810 fatal_error ("braced spec body %qs is invalid", body);
5813 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5814 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5815 spec, or -1 if either exact match or %* is used.
5817 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5818 whose value does not begin with "no-" is obsoleted by the same value
5819 with the "no-", similarly for a switch with the "no-" prefix. */
5821 static int
5822 check_live_switch (int switchnum, int prefix_length)
5824 const char *name = switches[switchnum].part1;
5825 int i;
5827 /* If we already processed this switch and determined if it was
5828 live or not, return our past determination. */
5829 if (switches[switchnum].live_cond != 0)
5830 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
5831 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
5832 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
5833 == 0);
5835 /* In the common case of {<at-most-one-letter>*}, a negating
5836 switch would always match, so ignore that case. We will just
5837 send the conflicting switches to the compiler phase. */
5838 if (prefix_length >= 0 && prefix_length <= 1)
5839 return 1;
5841 /* Now search for duplicate in a manner that depends on the name. */
5842 switch (*name)
5844 case 'O':
5845 for (i = switchnum + 1; i < n_switches; i++)
5846 if (switches[i].part1[0] == 'O')
5848 switches[switchnum].validated = true;
5849 switches[switchnum].live_cond = SWITCH_FALSE;
5850 return 0;
5852 break;
5854 case 'W': case 'f': case 'm':
5855 if (! strncmp (name + 1, "no-", 3))
5857 /* We have Xno-YYY, search for XYYY. */
5858 for (i = switchnum + 1; i < n_switches; i++)
5859 if (switches[i].part1[0] == name[0]
5860 && ! strcmp (&switches[i].part1[1], &name[4]))
5862 /* --specs are validated with the validate_switches mechanism. */
5863 if (switches[switchnum].known)
5864 switches[switchnum].validated = true;
5865 switches[switchnum].live_cond = SWITCH_FALSE;
5866 return 0;
5869 else
5871 /* We have XYYY, search for Xno-YYY. */
5872 for (i = switchnum + 1; i < n_switches; i++)
5873 if (switches[i].part1[0] == name[0]
5874 && switches[i].part1[1] == 'n'
5875 && switches[i].part1[2] == 'o'
5876 && switches[i].part1[3] == '-'
5877 && !strcmp (&switches[i].part1[4], &name[1]))
5879 /* --specs are validated with the validate_switches mechanism. */
5880 if (switches[switchnum].known)
5881 switches[switchnum].validated = true;
5882 switches[switchnum].live_cond = SWITCH_FALSE;
5883 return 0;
5886 break;
5889 /* Otherwise the switch is live. */
5890 switches[switchnum].live_cond |= SWITCH_LIVE;
5891 return 1;
5894 /* Pass a switch to the current accumulating command
5895 in the same form that we received it.
5896 SWITCHNUM identifies the switch; it is an index into
5897 the vector of switches gcc received, which is `switches'.
5898 This cannot fail since it never finishes a command line.
5900 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5902 static void
5903 give_switch (int switchnum, int omit_first_word)
5905 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
5906 return;
5908 if (!omit_first_word)
5910 do_spec_1 ("-", 0, NULL);
5911 do_spec_1 (switches[switchnum].part1, 1, NULL);
5914 if (switches[switchnum].args != 0)
5916 const char **p;
5917 for (p = switches[switchnum].args; *p; p++)
5919 const char *arg = *p;
5921 do_spec_1 (" ", 0, NULL);
5922 if (suffix_subst)
5924 unsigned length = strlen (arg);
5925 int dot = 0;
5927 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5928 if (arg[length] == '.')
5930 (CONST_CAST(char *, arg))[length] = 0;
5931 dot = 1;
5932 break;
5934 do_spec_1 (arg, 1, NULL);
5935 if (dot)
5936 (CONST_CAST(char *, arg))[length] = '.';
5937 do_spec_1 (suffix_subst, 1, NULL);
5939 else
5940 do_spec_1 (arg, 1, NULL);
5944 do_spec_1 (" ", 0, NULL);
5945 switches[switchnum].validated = true;
5948 /* Search for a file named NAME trying various prefixes including the
5949 user's -B prefix and some standard ones.
5950 Return the absolute file name found. If nothing is found, return NAME. */
5952 static const char *
5953 find_file (const char *name)
5955 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
5956 return newname ? newname : name;
5959 /* Determine whether a directory exists. If LINKER, return 0 for
5960 certain fixed names not needed by the linker. */
5962 static int
5963 is_directory (const char *path1, bool linker)
5965 int len1;
5966 char *path;
5967 char *cp;
5968 struct stat st;
5970 /* Ensure the string ends with "/.". The resulting path will be a
5971 directory even if the given path is a symbolic link. */
5972 len1 = strlen (path1);
5973 path = (char *) alloca (3 + len1);
5974 memcpy (path, path1, len1);
5975 cp = path + len1;
5976 if (!IS_DIR_SEPARATOR (cp[-1]))
5977 *cp++ = DIR_SEPARATOR;
5978 *cp++ = '.';
5979 *cp = '\0';
5981 /* Exclude directories that the linker is known to search. */
5982 if (linker
5983 && IS_DIR_SEPARATOR (path[0])
5984 && ((cp - path == 6
5985 && filename_ncmp (path + 1, "lib", 3) == 0)
5986 || (cp - path == 10
5987 && filename_ncmp (path + 1, "usr", 3) == 0
5988 && IS_DIR_SEPARATOR (path[4])
5989 && filename_ncmp (path + 5, "lib", 3) == 0)))
5990 return 0;
5992 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
5995 /* Set up the various global variables to indicate that we're processing
5996 the input file named FILENAME. */
5998 void
5999 set_input (const char *filename)
6001 const char *p;
6003 gcc_input_filename = filename;
6004 input_filename_length = strlen (gcc_input_filename);
6005 input_basename = lbasename (gcc_input_filename);
6007 /* Find a suffix starting with the last period,
6008 and set basename_length to exclude that suffix. */
6009 basename_length = strlen (input_basename);
6010 suffixed_basename_length = basename_length;
6011 p = input_basename + basename_length;
6012 while (p != input_basename && *p != '.')
6013 --p;
6014 if (*p == '.' && p != input_basename)
6016 basename_length = p - input_basename;
6017 input_suffix = p + 1;
6019 else
6020 input_suffix = "";
6022 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6023 we will need to do a stat on the gcc_input_filename. The
6024 INPUT_STAT_SET signals that the stat is needed. */
6025 input_stat_set = 0;
6028 /* On fatal signals, delete all the temporary files. */
6030 static void
6031 fatal_signal (int signum)
6033 signal (signum, SIG_DFL);
6034 delete_failure_queue ();
6035 delete_temp_files ();
6036 /* Get the same signal again, this time not handled,
6037 so its normal effect occurs. */
6038 kill (getpid (), signum);
6041 /* Compare the contents of the two files named CMPFILE[0] and
6042 CMPFILE[1]. Return zero if they're identical, nonzero
6043 otherwise. */
6045 static int
6046 compare_files (char *cmpfile[])
6048 int ret = 0;
6049 FILE *temp[2] = { NULL, NULL };
6050 int i;
6052 #if HAVE_MMAP_FILE
6054 size_t length[2];
6055 void *map[2] = { NULL, NULL };
6057 for (i = 0; i < 2; i++)
6059 struct stat st;
6061 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6063 error ("%s: could not determine length of compare-debug file %s",
6064 gcc_input_filename, cmpfile[i]);
6065 ret = 1;
6066 break;
6069 length[i] = st.st_size;
6072 if (!ret && length[0] != length[1])
6074 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
6075 ret = 1;
6078 if (!ret)
6079 for (i = 0; i < 2; i++)
6081 int fd = open (cmpfile[i], O_RDONLY);
6082 if (fd < 0)
6084 error ("%s: could not open compare-debug file %s",
6085 gcc_input_filename, cmpfile[i]);
6086 ret = 1;
6087 break;
6090 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
6091 close (fd);
6093 if (map[i] == (void *) MAP_FAILED)
6095 ret = -1;
6096 break;
6100 if (!ret)
6102 if (memcmp (map[0], map[1], length[0]) != 0)
6104 error ("%s: -fcompare-debug failure", gcc_input_filename);
6105 ret = 1;
6109 for (i = 0; i < 2; i++)
6110 if (map[i])
6111 munmap ((caddr_t) map[i], length[i]);
6113 if (ret >= 0)
6114 return ret;
6116 ret = 0;
6118 #endif
6120 for (i = 0; i < 2; i++)
6122 temp[i] = fopen (cmpfile[i], "r");
6123 if (!temp[i])
6125 error ("%s: could not open compare-debug file %s",
6126 gcc_input_filename, cmpfile[i]);
6127 ret = 1;
6128 break;
6132 if (!ret && temp[0] && temp[1])
6133 for (;;)
6135 int c0, c1;
6136 c0 = fgetc (temp[0]);
6137 c1 = fgetc (temp[1]);
6139 if (c0 != c1)
6141 error ("%s: -fcompare-debug failure",
6142 gcc_input_filename);
6143 ret = 1;
6144 break;
6147 if (c0 == EOF)
6148 break;
6151 for (i = 1; i >= 0; i--)
6153 if (temp[i])
6154 fclose (temp[i]);
6157 return ret;
6160 extern int main (int, char **);
6163 main (int argc, char **argv)
6165 size_t i;
6166 int value;
6167 int linker_was_run = 0;
6168 int lang_n_infiles = 0;
6169 int num_linker_inputs = 0;
6170 char *explicit_link_files;
6171 char *specs_file;
6172 char *lto_wrapper_file;
6173 const char *p;
6174 struct user_specs *uptr;
6175 char **old_argv = argv;
6176 struct cl_decoded_option *decoded_options;
6177 unsigned int decoded_options_count;
6179 p = argv[0] + strlen (argv[0]);
6180 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6181 --p;
6182 progname = p;
6184 xmalloc_set_program_name (progname);
6186 expandargv (&argc, &argv);
6188 /* Determine if any expansions were made. */
6189 if (argv != old_argv)
6190 at_file_supplied = true;
6192 /* Register the language-independent parameters. */
6193 global_init_params ();
6194 finish_params ();
6196 init_options_struct (&global_options, &global_options_set);
6198 decode_cmdline_options_to_array (argc, CONST_CAST2 (const char **, char **,
6199 argv),
6200 CL_DRIVER,
6201 &decoded_options, &decoded_options_count);
6203 /* Unlock the stdio streams. */
6204 unlock_std_streams ();
6206 gcc_init_libintl ();
6208 diagnostic_initialize (global_dc, 0);
6210 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6211 /* Perform host dependent initialization when needed. */
6212 GCC_DRIVER_HOST_INITIALIZATION;
6213 #endif
6215 if (atexit (delete_temp_files) != 0)
6216 fatal_error ("atexit failed");
6218 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6219 signal (SIGINT, fatal_signal);
6220 #ifdef SIGHUP
6221 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6222 signal (SIGHUP, fatal_signal);
6223 #endif
6224 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6225 signal (SIGTERM, fatal_signal);
6226 #ifdef SIGPIPE
6227 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6228 signal (SIGPIPE, fatal_signal);
6229 #endif
6230 #ifdef SIGCHLD
6231 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6232 receive the signal. A different setting is inheritable */
6233 signal (SIGCHLD, SIG_DFL);
6234 #endif
6236 /* Parsing and gimplification sometimes need quite large stack.
6237 Increase stack size limits if possible. */
6238 stack_limit_increase (64 * 1024 * 1024);
6240 /* Allocate the argument vector. */
6241 alloc_args ();
6243 obstack_init (&obstack);
6245 /* Build multilib_select, et. al from the separate lines that make up each
6246 multilib selection. */
6248 const char *const *q = multilib_raw;
6249 int need_space;
6251 obstack_init (&multilib_obstack);
6252 while ((p = *q++) != (char *) 0)
6253 obstack_grow (&multilib_obstack, p, strlen (p));
6255 obstack_1grow (&multilib_obstack, 0);
6256 multilib_select = XOBFINISH (&multilib_obstack, const char *);
6258 q = multilib_matches_raw;
6259 while ((p = *q++) != (char *) 0)
6260 obstack_grow (&multilib_obstack, p, strlen (p));
6262 obstack_1grow (&multilib_obstack, 0);
6263 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6265 q = multilib_exclusions_raw;
6266 while ((p = *q++) != (char *) 0)
6267 obstack_grow (&multilib_obstack, p, strlen (p));
6269 obstack_1grow (&multilib_obstack, 0);
6270 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6272 need_space = FALSE;
6273 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6275 if (need_space)
6276 obstack_1grow (&multilib_obstack, ' ');
6277 obstack_grow (&multilib_obstack,
6278 multilib_defaults_raw[i],
6279 strlen (multilib_defaults_raw[i]));
6280 need_space = TRUE;
6283 obstack_1grow (&multilib_obstack, 0);
6284 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6287 #ifdef INIT_ENVIRONMENT
6288 /* Set up any other necessary machine specific environment variables. */
6289 xputenv (INIT_ENVIRONMENT);
6290 #endif
6292 /* Make a table of what switches there are (switches, n_switches).
6293 Make a table of specified input files (infiles, n_infiles).
6294 Decode switches that are handled locally. */
6296 process_command (decoded_options_count, decoded_options);
6298 /* Initialize the vector of specs to just the default.
6299 This means one element containing 0s, as a terminator. */
6301 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
6302 memcpy (compilers, default_compilers, sizeof default_compilers);
6303 n_compilers = n_default_compilers;
6305 /* Read specs from a file if there is one. */
6307 machine_suffix = concat (spec_machine, dir_separator_str,
6308 spec_version, dir_separator_str, NULL);
6309 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6311 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
6312 /* Read the specs file unless it is a default one. */
6313 if (specs_file != 0 && strcmp (specs_file, "specs"))
6314 read_specs (specs_file, true, false);
6315 else
6316 init_spec ();
6318 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6319 for any override of as, ld and libraries. */
6320 specs_file = (char *) alloca (strlen (standard_exec_prefix)
6321 + strlen (just_machine_suffix) + sizeof ("specs"));
6323 strcpy (specs_file, standard_exec_prefix);
6324 strcat (specs_file, just_machine_suffix);
6325 strcat (specs_file, "specs");
6326 if (access (specs_file, R_OK) == 0)
6327 read_specs (specs_file, true, false);
6329 /* Process any configure-time defaults specified for the command line
6330 options, via OPTION_DEFAULT_SPECS. */
6331 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6332 do_option_spec (option_default_specs[i].name,
6333 option_default_specs[i].spec);
6335 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6336 of the command line. */
6338 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6339 do_self_spec (driver_self_specs[i]);
6341 /* If not cross-compiling, look for executables in the standard
6342 places. */
6343 if (*cross_compile == '0')
6345 if (*md_exec_prefix)
6347 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6348 PREFIX_PRIORITY_LAST, 0, 0);
6352 /* Process sysroot_suffix_spec. */
6353 if (*sysroot_suffix_spec != 0
6354 && !no_sysroot_suffix
6355 && do_spec_2 (sysroot_suffix_spec) == 0)
6357 if (VEC_length (const_char_p, argbuf) > 1)
6358 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
6359 else if (VEC_length (const_char_p, argbuf) == 1)
6360 target_sysroot_suffix = xstrdup (VEC_last (const_char_p, argbuf));
6363 #ifdef HAVE_LD_SYSROOT
6364 /* Pass the --sysroot option to the linker, if it supports that. If
6365 there is a sysroot_suffix_spec, it has already been processed by
6366 this point, so target_system_root really is the system root we
6367 should be using. */
6368 if (target_system_root)
6370 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6371 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6372 set_spec ("link", XOBFINISH (&obstack, const char *), false);
6374 #endif
6376 /* Process sysroot_hdrs_suffix_spec. */
6377 if (*sysroot_hdrs_suffix_spec != 0
6378 && !no_sysroot_suffix
6379 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6381 if (VEC_length (const_char_p, argbuf) > 1)
6382 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
6383 else if (VEC_length (const_char_p, argbuf) == 1)
6384 target_sysroot_hdrs_suffix = xstrdup (VEC_last (const_char_p, argbuf));
6387 /* Look for startfiles in the standard places. */
6388 if (*startfile_prefix_spec != 0
6389 && do_spec_2 (startfile_prefix_spec) == 0
6390 && do_spec_1 (" ", 0, NULL) == 0)
6392 const char *arg;
6393 int ndx;
6394 FOR_EACH_VEC_ELT (const_char_p, argbuf, ndx, arg)
6395 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
6396 PREFIX_PRIORITY_LAST, 0, 1);
6398 /* We should eventually get rid of all these and stick to
6399 startfile_prefix_spec exclusively. */
6400 else if (*cross_compile == '0' || target_system_root)
6402 if (*md_startfile_prefix)
6403 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6404 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6406 if (*md_startfile_prefix_1)
6407 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6408 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6410 /* If standard_startfile_prefix is relative, base it on
6411 standard_exec_prefix. This lets us move the installed tree
6412 as a unit. If GCC_EXEC_PREFIX is defined, base
6413 standard_startfile_prefix on that as well.
6415 If the prefix is relative, only search it for native compilers;
6416 otherwise we will search a directory containing host libraries. */
6417 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6418 add_sysrooted_prefix (&startfile_prefixes,
6419 standard_startfile_prefix, "BINUTILS",
6420 PREFIX_PRIORITY_LAST, 0, 1);
6421 else if (*cross_compile == '0')
6423 add_prefix (&startfile_prefixes,
6424 concat (gcc_exec_prefix
6425 ? gcc_exec_prefix : standard_exec_prefix,
6426 machine_suffix,
6427 standard_startfile_prefix, NULL),
6428 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6431 /* Sysrooted prefixes are relocated because target_system_root is
6432 also relocated by gcc_exec_prefix. */
6433 if (*standard_startfile_prefix_1)
6434 add_sysrooted_prefix (&startfile_prefixes,
6435 standard_startfile_prefix_1, "BINUTILS",
6436 PREFIX_PRIORITY_LAST, 0, 1);
6437 if (*standard_startfile_prefix_2)
6438 add_sysrooted_prefix (&startfile_prefixes,
6439 standard_startfile_prefix_2, "BINUTILS",
6440 PREFIX_PRIORITY_LAST, 0, 1);
6443 /* Process any user specified specs in the order given on the command
6444 line. */
6445 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6447 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6448 R_OK, true);
6449 read_specs (filename ? filename : uptr->filename, false, true);
6452 /* Process any user self specs. */
6454 struct spec_list *sl;
6455 for (sl = specs; sl; sl = sl->next)
6456 if (sl->name_len == sizeof "self_spec" - 1
6457 && !strcmp (sl->name, "self_spec"))
6458 do_self_spec (*sl->ptr_spec);
6461 if (compare_debug)
6463 enum save_temps save;
6465 if (!compare_debug_second)
6467 n_switches_debug_check[1] = n_switches;
6468 n_switches_alloc_debug_check[1] = n_switches_alloc;
6469 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
6470 n_switches_alloc);
6472 do_self_spec ("%:compare-debug-self-opt()");
6473 n_switches_debug_check[0] = n_switches;
6474 n_switches_alloc_debug_check[0] = n_switches_alloc;
6475 switches_debug_check[0] = switches;
6477 n_switches = n_switches_debug_check[1];
6478 n_switches_alloc = n_switches_alloc_debug_check[1];
6479 switches = switches_debug_check[1];
6482 /* Avoid crash when computing %j in this early. */
6483 save = save_temps_flag;
6484 save_temps_flag = SAVE_TEMPS_NONE;
6486 compare_debug = -compare_debug;
6487 do_self_spec ("%:compare-debug-self-opt()");
6489 save_temps_flag = save;
6491 if (!compare_debug_second)
6493 n_switches_debug_check[1] = n_switches;
6494 n_switches_alloc_debug_check[1] = n_switches_alloc;
6495 switches_debug_check[1] = switches;
6496 compare_debug = -compare_debug;
6497 n_switches = n_switches_debug_check[0];
6498 n_switches_alloc = n_switches_debug_check[0];
6499 switches = switches_debug_check[0];
6504 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6505 if (gcc_exec_prefix)
6506 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6507 spec_version, dir_separator_str, NULL);
6509 /* Now we have the specs.
6510 Set the `valid' bits for switches that match anything in any spec. */
6512 validate_all_switches ();
6514 /* Now that we have the switches and the specs, set
6515 the subdirectory based on the options. */
6516 set_multilib_dir ();
6518 /* Set up to remember the pathname of gcc and any options
6519 needed for collect. We use argv[0] instead of progname because
6520 we need the complete pathname. */
6521 obstack_init (&collect_obstack);
6522 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6523 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6524 xputenv (XOBFINISH (&collect_obstack, char *));
6526 /* Set up to remember the pathname of the lto wrapper. */
6528 if (have_c)
6529 lto_wrapper_file = NULL;
6530 else
6531 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
6532 X_OK, false);
6533 if (lto_wrapper_file)
6535 lto_wrapper_spec = lto_wrapper_file;
6536 obstack_init (&collect_obstack);
6537 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
6538 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
6539 obstack_grow (&collect_obstack, lto_wrapper_spec,
6540 strlen (lto_wrapper_spec) + 1);
6541 xputenv (XOBFINISH (&collect_obstack, char *));
6544 /* Reject switches that no pass was interested in. */
6546 for (i = 0; (int) i < n_switches; i++)
6547 if (! switches[i].validated)
6548 error ("unrecognized command line option %<-%s%>", switches[i].part1);
6550 /* Obey some of the options. */
6552 if (print_search_dirs)
6554 printf (_("install: %s%s\n"),
6555 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
6556 gcc_exec_prefix ? "" : machine_suffix);
6557 printf (_("programs: %s\n"),
6558 build_search_list (&exec_prefixes, "", false, false));
6559 printf (_("libraries: %s\n"),
6560 build_search_list (&startfile_prefixes, "", false, true));
6561 return (0);
6564 if (print_file_name)
6566 printf ("%s\n", find_file (print_file_name));
6567 return (0);
6570 if (print_prog_name)
6572 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6573 printf ("%s\n", (newname ? newname : print_prog_name));
6574 return (0);
6577 if (print_multi_lib)
6579 print_multilib_info ();
6580 return (0);
6583 if (print_multi_directory)
6585 if (multilib_dir == NULL)
6586 printf (".\n");
6587 else
6588 printf ("%s\n", multilib_dir);
6589 return (0);
6592 if (print_sysroot)
6594 if (target_system_root)
6596 if (target_sysroot_suffix)
6597 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
6598 else
6599 printf ("%s\n", target_system_root);
6601 return (0);
6604 if (print_multi_os_directory)
6606 if (multilib_os_dir == NULL)
6607 printf (".\n");
6608 else
6609 printf ("%s\n", multilib_os_dir);
6610 return (0);
6613 if (print_sysroot_headers_suffix)
6615 if (*sysroot_hdrs_suffix_spec)
6617 printf("%s\n", (target_sysroot_hdrs_suffix
6618 ? target_sysroot_hdrs_suffix
6619 : ""));
6620 return (0);
6622 else
6623 /* The error status indicates that only one set of fixed
6624 headers should be built. */
6625 fatal_error ("not configured with sysroot headers suffix");
6628 if (print_help_list)
6630 display_help ();
6632 if (! verbose_flag)
6634 printf (_("\nFor bug reporting instructions, please see:\n"));
6635 printf ("%s.\n", bug_report_url);
6637 return (0);
6640 /* We do not exit here. Instead we have created a fake input file
6641 called 'help-dummy' which needs to be compiled, and we pass this
6642 on the various sub-processes, along with the --help switch.
6643 Ensure their output appears after ours. */
6644 fputc ('\n', stdout);
6645 fflush (stdout);
6648 if (print_version)
6650 printf (_("%s %s%s\n"), progname, pkgversion_string,
6651 version_string);
6652 printf ("Copyright %s 2012 Free Software Foundation, Inc.\n",
6653 _("(C)"));
6654 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
6655 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
6656 stdout);
6657 if (! verbose_flag)
6658 return 0;
6660 /* We do not exit here. We use the same mechanism of --help to print
6661 the version of the sub-processes. */
6662 fputc ('\n', stdout);
6663 fflush (stdout);
6666 if (verbose_flag)
6668 int n;
6669 const char *thrmod;
6671 fnotice (stderr, "Target: %s\n", spec_machine);
6672 fnotice (stderr, "Configured with: %s\n", configuration_arguments);
6674 #ifdef THREAD_MODEL_SPEC
6675 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6676 but there's no point in doing all this processing just to get
6677 thread_model back. */
6678 obstack_init (&obstack);
6679 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6680 obstack_1grow (&obstack, '\0');
6681 thrmod = XOBFINISH (&obstack, const char *);
6682 #else
6683 thrmod = thread_model;
6684 #endif
6686 fnotice (stderr, "Thread model: %s\n", thrmod);
6688 /* compiler_version is truncated at the first space when initialized
6689 from version string, so truncate version_string at the first space
6690 before comparing. */
6691 for (n = 0; version_string[n]; n++)
6692 if (version_string[n] == ' ')
6693 break;
6695 if (! strncmp (version_string, compiler_version, n)
6696 && compiler_version[n] == 0)
6697 fnotice (stderr, "gcc version %s %s\n", version_string,
6698 pkgversion_string);
6699 else
6700 fnotice (stderr, "gcc driver version %s %sexecuting gcc version %s\n",
6701 version_string, pkgversion_string, compiler_version);
6703 if (n_infiles == 0)
6704 return (0);
6707 if (n_infiles == added_libraries)
6708 fatal_error ("no input files");
6710 if (seen_error ())
6711 goto out;
6713 /* Make a place to record the compiler output file names
6714 that correspond to the input files. */
6716 i = n_infiles;
6717 i += lang_specific_extra_outfiles;
6718 outfiles = XCNEWVEC (const char *, i);
6720 /* Record which files were specified explicitly as link input. */
6722 explicit_link_files = XCNEWVEC (char, n_infiles);
6724 combine_inputs = have_o || flag_wpa;
6726 for (i = 0; (int) i < n_infiles; i++)
6728 const char *name = infiles[i].name;
6729 struct compiler *compiler = lookup_compiler (name,
6730 strlen (name),
6731 infiles[i].language);
6733 if (compiler && !(compiler->combinable))
6734 combine_inputs = false;
6736 if (lang_n_infiles > 0 && compiler != input_file_compiler
6737 && infiles[i].language && infiles[i].language[0] != '*')
6738 infiles[i].incompiler = compiler;
6739 else if (compiler)
6741 lang_n_infiles++;
6742 input_file_compiler = compiler;
6743 infiles[i].incompiler = compiler;
6745 else
6747 /* Since there is no compiler for this input file, assume it is a
6748 linker file. */
6749 explicit_link_files[i] = 1;
6750 infiles[i].incompiler = NULL;
6752 infiles[i].compiled = false;
6753 infiles[i].preprocessed = false;
6756 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
6757 fatal_error ("cannot specify -o with -c, -S or -E with multiple files");
6759 for (i = 0; (int) i < n_infiles; i++)
6761 int this_file_error = 0;
6763 /* Tell do_spec what to substitute for %i. */
6765 input_file_number = i;
6766 set_input (infiles[i].name);
6768 if (infiles[i].compiled)
6769 continue;
6771 /* Use the same thing in %o, unless cp->spec says otherwise. */
6773 outfiles[i] = gcc_input_filename;
6775 /* Figure out which compiler from the file's suffix. */
6777 input_file_compiler
6778 = lookup_compiler (infiles[i].name, input_filename_length,
6779 infiles[i].language);
6781 if (input_file_compiler)
6783 /* Ok, we found an applicable compiler. Run its spec. */
6785 if (input_file_compiler->spec[0] == '#')
6787 error ("%s: %s compiler not installed on this system",
6788 gcc_input_filename, &input_file_compiler->spec[1]);
6789 this_file_error = 1;
6791 else
6793 if (compare_debug)
6795 free (debug_check_temp_file[0]);
6796 debug_check_temp_file[0] = NULL;
6798 free (debug_check_temp_file[1]);
6799 debug_check_temp_file[1] = NULL;
6802 value = do_spec (input_file_compiler->spec);
6803 infiles[i].compiled = true;
6804 if (value < 0)
6805 this_file_error = 1;
6806 else if (compare_debug && debug_check_temp_file[0])
6808 if (verbose_flag)
6809 inform (0, "recompiling with -fcompare-debug");
6811 compare_debug = -compare_debug;
6812 n_switches = n_switches_debug_check[1];
6813 n_switches_alloc = n_switches_alloc_debug_check[1];
6814 switches = switches_debug_check[1];
6816 value = do_spec (input_file_compiler->spec);
6818 compare_debug = -compare_debug;
6819 n_switches = n_switches_debug_check[0];
6820 n_switches_alloc = n_switches_alloc_debug_check[0];
6821 switches = switches_debug_check[0];
6823 if (value < 0)
6825 error ("during -fcompare-debug recompilation");
6826 this_file_error = 1;
6829 gcc_assert (debug_check_temp_file[1]
6830 && filename_cmp (debug_check_temp_file[0],
6831 debug_check_temp_file[1]));
6833 if (verbose_flag)
6834 inform (0, "comparing final insns dumps");
6836 if (compare_files (debug_check_temp_file))
6837 this_file_error = 1;
6840 if (compare_debug)
6842 free (debug_check_temp_file[0]);
6843 debug_check_temp_file[0] = NULL;
6845 free (debug_check_temp_file[1]);
6846 debug_check_temp_file[1] = NULL;
6851 /* If this file's name does not contain a recognized suffix,
6852 record it as explicit linker input. */
6854 else
6855 explicit_link_files[i] = 1;
6857 /* Clear the delete-on-failure queue, deleting the files in it
6858 if this compilation failed. */
6860 if (this_file_error)
6862 delete_failure_queue ();
6863 errorcount++;
6865 /* If this compilation succeeded, don't delete those files later. */
6866 clear_failure_queue ();
6869 /* Reset the input file name to the first compile/object file name, for use
6870 with %b in LINK_SPEC. We use the first input file that we can find
6871 a compiler to compile it instead of using infiles.language since for
6872 languages other than C we use aliases that we then lookup later. */
6873 if (n_infiles > 0)
6875 int i;
6877 for (i = 0; i < n_infiles ; i++)
6878 if (infiles[i].incompiler
6879 || (infiles[i].language && infiles[i].language[0] != '*'))
6881 set_input (infiles[i].name);
6882 break;
6886 if (!seen_error ())
6888 /* Make sure INPUT_FILE_NUMBER points to first available open
6889 slot. */
6890 input_file_number = n_infiles;
6891 if (lang_specific_pre_link ())
6892 errorcount++;
6895 /* Determine if there are any linker input files. */
6896 num_linker_inputs = 0;
6897 for (i = 0; (int) i < n_infiles; i++)
6898 if (explicit_link_files[i] || outfiles[i] != NULL)
6899 num_linker_inputs++;
6901 /* Run ld to link all the compiler output files. */
6903 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
6905 int tmp = execution_count;
6907 if (! have_c)
6909 #if HAVE_LTO_PLUGIN > 0
6910 #if HAVE_LTO_PLUGIN == 2
6911 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
6912 #else
6913 const char *fuse_linker_plugin = "fuse-linker-plugin";
6914 #endif
6915 #endif
6917 /* We'll use ld if we can't find collect2. */
6918 if (! strcmp (linker_name_spec, "collect2"))
6920 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
6921 if (s == NULL)
6922 linker_name_spec = "ld";
6925 #if HAVE_LTO_PLUGIN > 0
6926 #if HAVE_LTO_PLUGIN == 2
6927 if (!switch_matches (fno_use_linker_plugin,
6928 fno_use_linker_plugin
6929 + strlen (fno_use_linker_plugin), 0))
6930 #else
6931 if (switch_matches (fuse_linker_plugin,
6932 fuse_linker_plugin
6933 + strlen (fuse_linker_plugin), 0))
6934 #endif
6936 linker_plugin_file_spec = find_a_file (&exec_prefixes,
6937 LTOPLUGINSONAME, R_OK,
6938 false);
6939 if (!linker_plugin_file_spec)
6940 fatal_error ("-fuse-linker-plugin, but %s not found",
6941 LTOPLUGINSONAME);
6943 #endif
6944 lto_gcc_spec = argv[0];
6947 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6948 for collect. */
6949 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
6950 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
6952 if (print_subprocess_help == 1)
6954 printf (_("\nLinker options\n==============\n\n"));
6955 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
6956 " to the linker.\n\n"));
6957 fflush (stdout);
6959 value = do_spec (link_command_spec);
6960 if (value < 0)
6961 errorcount = 1;
6962 linker_was_run = (tmp != execution_count);
6965 /* If options said don't run linker,
6966 complain about input files to be given to the linker. */
6968 if (! linker_was_run && !seen_error ())
6969 for (i = 0; (int) i < n_infiles; i++)
6970 if (explicit_link_files[i]
6971 && !(infiles[i].language && infiles[i].language[0] == '*'))
6972 warning (0, "%s: linker input file unused because linking not done",
6973 outfiles[i]);
6975 /* Delete some or all of the temporary files we made. */
6977 if (seen_error ())
6978 delete_failure_queue ();
6979 delete_temp_files ();
6981 if (print_help_list)
6983 printf (("\nFor bug reporting instructions, please see:\n"));
6984 printf ("%s\n", bug_report_url);
6987 out:
6988 return (signal_count != 0 ? 2
6989 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
6990 : 0);
6993 /* Find the proper compilation spec for the file name NAME,
6994 whose length is LENGTH. LANGUAGE is the specified language,
6995 or 0 if this file is to be passed to the linker. */
6997 static struct compiler *
6998 lookup_compiler (const char *name, size_t length, const char *language)
7000 struct compiler *cp;
7002 /* If this was specified by the user to be a linker input, indicate that. */
7003 if (language != 0 && language[0] == '*')
7004 return 0;
7006 /* Otherwise, look for the language, if one is spec'd. */
7007 if (language != 0)
7009 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7010 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
7011 return cp;
7013 error ("language %s not recognized", language);
7014 return 0;
7017 /* Look for a suffix. */
7018 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7020 if (/* The suffix `-' matches only the file name `-'. */
7021 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7022 || (strlen (cp->suffix) < length
7023 /* See if the suffix matches the end of NAME. */
7024 && !strcmp (cp->suffix,
7025 name + length - strlen (cp->suffix))
7027 break;
7030 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
7031 /* Look again, but case-insensitively this time. */
7032 if (cp < compilers)
7033 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7035 if (/* The suffix `-' matches only the file name `-'. */
7036 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7037 || (strlen (cp->suffix) < length
7038 /* See if the suffix matches the end of NAME. */
7039 && ((!strcmp (cp->suffix,
7040 name + length - strlen (cp->suffix))
7041 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
7042 && !strcasecmp (cp->suffix,
7043 name + length - strlen (cp->suffix)))
7045 break;
7047 #endif
7049 if (cp >= compilers)
7051 if (cp->spec[0] != '@')
7052 /* A non-alias entry: return it. */
7053 return cp;
7055 /* An alias entry maps a suffix to a language.
7056 Search for the language; pass 0 for NAME and LENGTH
7057 to avoid infinite recursion if language not found. */
7058 return lookup_compiler (NULL, 0, cp->spec + 1);
7060 return 0;
7063 static char *
7064 save_string (const char *s, int len)
7066 char *result = XNEWVEC (char, len + 1);
7068 memcpy (result, s, len);
7069 result[len] = 0;
7070 return result;
7073 void
7074 pfatal_with_name (const char *name)
7076 perror_with_name (name);
7077 delete_temp_files ();
7078 exit (1);
7081 static void
7082 perror_with_name (const char *name)
7084 error ("%s: %m", name);
7087 static inline void
7088 validate_switches_from_spec (const char *spec, bool user)
7090 const char *p = spec;
7091 char c;
7092 while ((c = *p++))
7093 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
7094 /* We have a switch spec. */
7095 p = validate_switches (p + 1, user);
7098 static void
7099 validate_all_switches (void)
7101 struct compiler *comp;
7102 struct spec_list *spec;
7104 for (comp = compilers; comp->spec; comp++)
7105 validate_switches_from_spec (comp->spec, false);
7107 /* Look through the linked list of specs read from the specs file. */
7108 for (spec = specs; spec; spec = spec->next)
7109 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
7111 validate_switches_from_spec (link_command_spec, false);
7114 /* Look at the switch-name that comes after START
7115 and mark as valid all supplied switches that match it. */
7117 static const char *
7118 validate_switches (const char *start, bool user_spec)
7120 const char *p = start;
7121 const char *atom;
7122 size_t len;
7123 int i;
7124 bool suffix = false;
7125 bool starred = false;
7127 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7129 next_member:
7130 SKIP_WHITE ();
7132 if (*p == '!')
7133 p++;
7135 SKIP_WHITE ();
7136 if (*p == '.' || *p == ',')
7137 suffix = true, p++;
7139 atom = p;
7140 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7141 || *p == ',' || *p == '.' || *p == '@')
7142 p++;
7143 len = p - atom;
7145 if (*p == '*')
7146 starred = true, p++;
7148 SKIP_WHITE ();
7150 if (!suffix)
7152 /* Mark all matching switches as valid. */
7153 for (i = 0; i < n_switches; i++)
7154 if (!strncmp (switches[i].part1, atom, len)
7155 && (starred || switches[i].part1[len] == '\0')
7156 && (switches[i].known || user_spec))
7157 switches[i].validated = true;
7160 if (*p) p++;
7161 if (*p && (p[-1] == '|' || p[-1] == '&'))
7162 goto next_member;
7164 if (*p && p[-1] == ':')
7166 while (*p && *p != ';' && *p != '}')
7168 if (*p == '%')
7170 p++;
7171 if (*p == '{' || *p == '<')
7172 p = validate_switches (p+1, user_spec);
7173 else if (p[0] == 'W' && p[1] == '{')
7174 p = validate_switches (p+2, user_spec);
7176 else
7177 p++;
7180 if (*p) p++;
7181 if (*p && p[-1] == ';')
7182 goto next_member;
7185 return p;
7186 #undef SKIP_WHITE
7189 struct mdswitchstr
7191 const char *str;
7192 int len;
7195 static struct mdswitchstr *mdswitches;
7196 static int n_mdswitches;
7198 /* Check whether a particular argument was used. The first time we
7199 canonicalize the switches to keep only the ones we care about. */
7201 static int
7202 used_arg (const char *p, int len)
7204 struct mswitchstr
7206 const char *str;
7207 const char *replace;
7208 int len;
7209 int rep_len;
7212 static struct mswitchstr *mswitches;
7213 static int n_mswitches;
7214 int i, j;
7216 if (!mswitches)
7218 struct mswitchstr *matches;
7219 const char *q;
7220 int cnt = 0;
7222 /* Break multilib_matches into the component strings of string
7223 and replacement string. */
7224 for (q = multilib_matches; *q != '\0'; q++)
7225 if (*q == ';')
7226 cnt++;
7228 matches
7229 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
7230 i = 0;
7231 q = multilib_matches;
7232 while (*q != '\0')
7234 matches[i].str = q;
7235 while (*q != ' ')
7237 if (*q == '\0')
7239 invalid_matches:
7240 fatal_error ("multilib spec %qs is invalid",
7241 multilib_matches);
7243 q++;
7245 matches[i].len = q - matches[i].str;
7247 matches[i].replace = ++q;
7248 while (*q != ';' && *q != '\0')
7250 if (*q == ' ')
7251 goto invalid_matches;
7252 q++;
7254 matches[i].rep_len = q - matches[i].replace;
7255 i++;
7256 if (*q == ';')
7257 q++;
7260 /* Now build a list of the replacement string for switches that we care
7261 about. Make sure we allocate at least one entry. This prevents
7262 xmalloc from calling fatal, and prevents us from re-executing this
7263 block of code. */
7264 mswitches
7265 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
7266 for (i = 0; i < n_switches; i++)
7267 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
7269 int xlen = strlen (switches[i].part1);
7270 for (j = 0; j < cnt; j++)
7271 if (xlen == matches[j].len
7272 && ! strncmp (switches[i].part1, matches[j].str, xlen))
7274 mswitches[n_mswitches].str = matches[j].replace;
7275 mswitches[n_mswitches].len = matches[j].rep_len;
7276 mswitches[n_mswitches].replace = (char *) 0;
7277 mswitches[n_mswitches].rep_len = 0;
7278 n_mswitches++;
7279 break;
7283 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7284 on the command line nor any options mutually incompatible with
7285 them. */
7286 for (i = 0; i < n_mdswitches; i++)
7288 const char *r;
7290 for (q = multilib_options; *q != '\0'; q++)
7292 while (*q == ' ')
7293 q++;
7295 r = q;
7296 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7297 || strchr (" /", q[mdswitches[i].len]) == NULL)
7299 while (*q != ' ' && *q != '/' && *q != '\0')
7300 q++;
7301 if (*q != '/')
7302 break;
7303 q++;
7306 if (*q != ' ' && *q != '\0')
7308 while (*r != ' ' && *r != '\0')
7310 q = r;
7311 while (*q != ' ' && *q != '/' && *q != '\0')
7312 q++;
7314 if (used_arg (r, q - r))
7315 break;
7317 if (*q != '/')
7319 mswitches[n_mswitches].str = mdswitches[i].str;
7320 mswitches[n_mswitches].len = mdswitches[i].len;
7321 mswitches[n_mswitches].replace = (char *) 0;
7322 mswitches[n_mswitches].rep_len = 0;
7323 n_mswitches++;
7324 break;
7327 r = q + 1;
7329 break;
7335 for (i = 0; i < n_mswitches; i++)
7336 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7337 return 1;
7339 return 0;
7342 static int
7343 default_arg (const char *p, int len)
7345 int i;
7347 for (i = 0; i < n_mdswitches; i++)
7348 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7349 return 1;
7351 return 0;
7354 /* Work out the subdirectory to use based on the options. The format of
7355 multilib_select is a list of elements. Each element is a subdirectory
7356 name followed by a list of options followed by a semicolon. The format
7357 of multilib_exclusions is the same, but without the preceding
7358 directory. First gcc will check the exclusions, if none of the options
7359 beginning with an exclamation point are present, and all of the other
7360 options are present, then we will ignore this completely. Passing
7361 that, gcc will consider each multilib_select in turn using the same
7362 rules for matching the options. If a match is found, that subdirectory
7363 will be used. */
7365 static void
7366 set_multilib_dir (void)
7368 const char *p;
7369 unsigned int this_path_len;
7370 const char *this_path, *this_arg;
7371 const char *start, *end;
7372 int not_arg;
7373 int ok, ndfltok, first;
7375 n_mdswitches = 0;
7376 start = multilib_defaults;
7377 while (*start == ' ' || *start == '\t')
7378 start++;
7379 while (*start != '\0')
7381 n_mdswitches++;
7382 while (*start != ' ' && *start != '\t' && *start != '\0')
7383 start++;
7384 while (*start == ' ' || *start == '\t')
7385 start++;
7388 if (n_mdswitches)
7390 int i = 0;
7392 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
7393 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7395 while (*start == ' ' || *start == '\t')
7396 start++;
7398 if (*start == '\0')
7399 break;
7401 for (end = start + 1;
7402 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7405 obstack_grow (&multilib_obstack, start, end - start);
7406 obstack_1grow (&multilib_obstack, 0);
7407 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7408 mdswitches[i++].len = end - start;
7410 if (*end == '\0')
7411 break;
7415 p = multilib_exclusions;
7416 while (*p != '\0')
7418 /* Ignore newlines. */
7419 if (*p == '\n')
7421 ++p;
7422 continue;
7425 /* Check the arguments. */
7426 ok = 1;
7427 while (*p != ';')
7429 if (*p == '\0')
7431 invalid_exclusions:
7432 fatal_error ("multilib exclusions %qs is invalid",
7433 multilib_exclusions);
7436 if (! ok)
7438 ++p;
7439 continue;
7442 this_arg = p;
7443 while (*p != ' ' && *p != ';')
7445 if (*p == '\0')
7446 goto invalid_exclusions;
7447 ++p;
7450 if (*this_arg != '!')
7451 not_arg = 0;
7452 else
7454 not_arg = 1;
7455 ++this_arg;
7458 ok = used_arg (this_arg, p - this_arg);
7459 if (not_arg)
7460 ok = ! ok;
7462 if (*p == ' ')
7463 ++p;
7466 if (ok)
7467 return;
7469 ++p;
7472 first = 1;
7473 p = multilib_select;
7474 while (*p != '\0')
7476 /* Ignore newlines. */
7477 if (*p == '\n')
7479 ++p;
7480 continue;
7483 /* Get the initial path. */
7484 this_path = p;
7485 while (*p != ' ')
7487 if (*p == '\0')
7489 invalid_select:
7490 fatal_error ("multilib select %qs is invalid",
7491 multilib_select);
7493 ++p;
7495 this_path_len = p - this_path;
7497 /* Check the arguments. */
7498 ok = 1;
7499 ndfltok = 1;
7500 ++p;
7501 while (*p != ';')
7503 if (*p == '\0')
7504 goto invalid_select;
7506 if (! ok)
7508 ++p;
7509 continue;
7512 this_arg = p;
7513 while (*p != ' ' && *p != ';')
7515 if (*p == '\0')
7516 goto invalid_select;
7517 ++p;
7520 if (*this_arg != '!')
7521 not_arg = 0;
7522 else
7524 not_arg = 1;
7525 ++this_arg;
7528 /* If this is a default argument, we can just ignore it.
7529 This is true even if this_arg begins with '!'. Beginning
7530 with '!' does not mean that this argument is necessarily
7531 inappropriate for this library: it merely means that
7532 there is a more specific library which uses this
7533 argument. If this argument is a default, we need not
7534 consider that more specific library. */
7535 ok = used_arg (this_arg, p - this_arg);
7536 if (not_arg)
7537 ok = ! ok;
7539 if (! ok)
7540 ndfltok = 0;
7542 if (default_arg (this_arg, p - this_arg))
7543 ok = 1;
7545 if (*p == ' ')
7546 ++p;
7549 if (ok && first)
7551 if (this_path_len != 1
7552 || this_path[0] != '.')
7554 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
7555 char *q;
7557 strncpy (new_multilib_dir, this_path, this_path_len);
7558 new_multilib_dir[this_path_len] = '\0';
7559 q = strchr (new_multilib_dir, ':');
7560 if (q != NULL)
7561 *q = '\0';
7562 multilib_dir = new_multilib_dir;
7564 first = 0;
7567 if (ndfltok)
7569 const char *q = this_path, *end = this_path + this_path_len;
7571 while (q < end && *q != ':')
7572 q++;
7573 if (q < end)
7575 char *new_multilib_os_dir = XNEWVEC (char, end - q);
7576 memcpy (new_multilib_os_dir, q + 1, end - q - 1);
7577 new_multilib_os_dir[end - q - 1] = '\0';
7578 multilib_os_dir = new_multilib_os_dir;
7579 break;
7583 ++p;
7586 if (multilib_dir == NULL && multilib_os_dir != NULL
7587 && strcmp (multilib_os_dir, ".") == 0)
7589 free (CONST_CAST (char *, multilib_os_dir));
7590 multilib_os_dir = NULL;
7592 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7593 multilib_os_dir = multilib_dir;
7596 /* Print out the multiple library subdirectory selection
7597 information. This prints out a series of lines. Each line looks
7598 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7599 required. Only the desired options are printed out, the negative
7600 matches. The options are print without a leading dash. There are
7601 no spaces to make it easy to use the information in the shell.
7602 Each subdirectory is printed only once. This assumes the ordering
7603 generated by the genmultilib script. Also, we leave out ones that match
7604 the exclusions. */
7606 static void
7607 print_multilib_info (void)
7609 const char *p = multilib_select;
7610 const char *last_path = 0, *this_path;
7611 int skip;
7612 unsigned int last_path_len = 0;
7614 while (*p != '\0')
7616 skip = 0;
7617 /* Ignore newlines. */
7618 if (*p == '\n')
7620 ++p;
7621 continue;
7624 /* Get the initial path. */
7625 this_path = p;
7626 while (*p != ' ')
7628 if (*p == '\0')
7630 invalid_select:
7631 fatal_error ("multilib select %qs is invalid", multilib_select);
7634 ++p;
7637 /* When --disable-multilib was used but target defines
7638 MULTILIB_OSDIRNAMES, entries starting with .: are there just
7639 to find multilib_os_dir, so skip them from output. */
7640 if (this_path[0] == '.' && this_path[1] == ':')
7641 skip = 1;
7643 /* Check for matches with the multilib_exclusions. We don't bother
7644 with the '!' in either list. If any of the exclusion rules match
7645 all of its options with the select rule, we skip it. */
7647 const char *e = multilib_exclusions;
7648 const char *this_arg;
7650 while (*e != '\0')
7652 int m = 1;
7653 /* Ignore newlines. */
7654 if (*e == '\n')
7656 ++e;
7657 continue;
7660 /* Check the arguments. */
7661 while (*e != ';')
7663 const char *q;
7664 int mp = 0;
7666 if (*e == '\0')
7668 invalid_exclusion:
7669 fatal_error ("multilib exclusion %qs is invalid",
7670 multilib_exclusions);
7673 if (! m)
7675 ++e;
7676 continue;
7679 this_arg = e;
7681 while (*e != ' ' && *e != ';')
7683 if (*e == '\0')
7684 goto invalid_exclusion;
7685 ++e;
7688 q = p + 1;
7689 while (*q != ';')
7691 const char *arg;
7692 int len = e - this_arg;
7694 if (*q == '\0')
7695 goto invalid_select;
7697 arg = q;
7699 while (*q != ' ' && *q != ';')
7701 if (*q == '\0')
7702 goto invalid_select;
7703 ++q;
7706 if (! strncmp (arg, this_arg,
7707 (len < q - arg) ? q - arg : len)
7708 || default_arg (this_arg, e - this_arg))
7710 mp = 1;
7711 break;
7714 if (*q == ' ')
7715 ++q;
7718 if (! mp)
7719 m = 0;
7721 if (*e == ' ')
7722 ++e;
7725 if (m)
7727 skip = 1;
7728 break;
7731 if (*e != '\0')
7732 ++e;
7736 if (! skip)
7738 /* If this is a duplicate, skip it. */
7739 skip = (last_path != 0
7740 && (unsigned int) (p - this_path) == last_path_len
7741 && ! filename_ncmp (last_path, this_path, last_path_len));
7743 last_path = this_path;
7744 last_path_len = p - this_path;
7747 /* If this directory requires any default arguments, we can skip
7748 it. We will already have printed a directory identical to
7749 this one which does not require that default argument. */
7750 if (! skip)
7752 const char *q;
7754 q = p + 1;
7755 while (*q != ';')
7757 const char *arg;
7759 if (*q == '\0')
7760 goto invalid_select;
7762 if (*q == '!')
7763 arg = NULL;
7764 else
7765 arg = q;
7767 while (*q != ' ' && *q != ';')
7769 if (*q == '\0')
7770 goto invalid_select;
7771 ++q;
7774 if (arg != NULL
7775 && default_arg (arg, q - arg))
7777 skip = 1;
7778 break;
7781 if (*q == ' ')
7782 ++q;
7786 if (! skip)
7788 const char *p1;
7790 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7791 putchar (*p1);
7792 putchar (';');
7795 ++p;
7796 while (*p != ';')
7798 int use_arg;
7800 if (*p == '\0')
7801 goto invalid_select;
7803 if (skip)
7805 ++p;
7806 continue;
7809 use_arg = *p != '!';
7811 if (use_arg)
7812 putchar ('@');
7814 while (*p != ' ' && *p != ';')
7816 if (*p == '\0')
7817 goto invalid_select;
7818 if (use_arg)
7819 putchar (*p);
7820 ++p;
7823 if (*p == ' ')
7824 ++p;
7827 if (! skip)
7829 /* If there are extra options, print them now. */
7830 if (multilib_extra && *multilib_extra)
7832 int print_at = TRUE;
7833 const char *q;
7835 for (q = multilib_extra; *q != '\0'; q++)
7837 if (*q == ' ')
7838 print_at = TRUE;
7839 else
7841 if (print_at)
7842 putchar ('@');
7843 putchar (*q);
7844 print_at = FALSE;
7849 putchar ('\n');
7852 ++p;
7856 /* getenv built-in spec function.
7858 Returns the value of the environment variable given by its first
7859 argument, concatenated with the second argument. If the
7860 environment variable is not defined, a fatal error is issued. */
7862 static const char *
7863 getenv_spec_function (int argc, const char **argv)
7865 char *value;
7866 char *result;
7867 char *ptr;
7868 size_t len;
7870 if (argc != 2)
7871 return NULL;
7873 value = getenv (argv[0]);
7874 if (!value)
7875 fatal_error ("environment variable %qs not defined", argv[0]);
7877 /* We have to escape every character of the environment variable so
7878 they are not interpreted as active spec characters. A
7879 particularly painful case is when we are reading a variable
7880 holding a windows path complete with \ separators. */
7881 len = strlen (value) * 2 + strlen (argv[1]) + 1;
7882 result = XNEWVAR (char, len);
7883 for (ptr = result; *value; ptr += 2)
7885 ptr[0] = '\\';
7886 ptr[1] = *value++;
7889 strcpy (ptr, argv[1]);
7891 return result;
7894 /* if-exists built-in spec function.
7896 Checks to see if the file specified by the absolute pathname in
7897 ARGS exists. Returns that pathname if found.
7899 The usual use for this function is to check for a library file
7900 (whose name has been expanded with %s). */
7902 static const char *
7903 if_exists_spec_function (int argc, const char **argv)
7905 /* Must have only one argument. */
7906 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7907 return argv[0];
7909 return NULL;
7912 /* if-exists-else built-in spec function.
7914 This is like if-exists, but takes an additional argument which
7915 is returned if the first argument does not exist. */
7917 static const char *
7918 if_exists_else_spec_function (int argc, const char **argv)
7920 /* Must have exactly two arguments. */
7921 if (argc != 2)
7922 return NULL;
7924 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7925 return argv[0];
7927 return argv[1];
7930 /* replace-outfile built-in spec function.
7932 This looks for the first argument in the outfiles array's name and
7933 replaces it with the second argument. */
7935 static const char *
7936 replace_outfile_spec_function (int argc, const char **argv)
7938 int i;
7939 /* Must have exactly two arguments. */
7940 if (argc != 2)
7941 abort ();
7943 for (i = 0; i < n_infiles; i++)
7945 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
7946 outfiles[i] = xstrdup (argv[1]);
7948 return NULL;
7951 /* remove-outfile built-in spec function.
7953 * This looks for the first argument in the outfiles array's name and
7954 * removes it. */
7956 static const char *
7957 remove_outfile_spec_function (int argc, const char **argv)
7959 int i;
7960 /* Must have exactly one argument. */
7961 if (argc != 1)
7962 abort ();
7964 for (i = 0; i < n_infiles; i++)
7966 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
7967 outfiles[i] = NULL;
7969 return NULL;
7972 /* Given two version numbers, compares the two numbers.
7973 A version number must match the regular expression
7974 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
7976 static int
7977 compare_version_strings (const char *v1, const char *v2)
7979 int rresult;
7980 regex_t r;
7982 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
7983 REG_EXTENDED | REG_NOSUB) != 0)
7984 abort ();
7985 rresult = regexec (&r, v1, 0, NULL, 0);
7986 if (rresult == REG_NOMATCH)
7987 fatal_error ("invalid version number %qs", v1);
7988 else if (rresult != 0)
7989 abort ();
7990 rresult = regexec (&r, v2, 0, NULL, 0);
7991 if (rresult == REG_NOMATCH)
7992 fatal_error ("invalid version number %qs", v2);
7993 else if (rresult != 0)
7994 abort ();
7996 return strverscmp (v1, v2);
8000 /* version_compare built-in spec function.
8002 This takes an argument of the following form:
8004 <comparison-op> <arg1> [<arg2>] <switch> <result>
8006 and produces "result" if the comparison evaluates to true,
8007 and nothing if it doesn't.
8009 The supported <comparison-op> values are:
8011 >= true if switch is a later (or same) version than arg1
8012 !> opposite of >=
8013 < true if switch is an earlier version than arg1
8014 !< opposite of <
8015 >< true if switch is arg1 or later, and earlier than arg2
8016 <> true if switch is earlier than arg1 or is arg2 or later
8018 If the switch is not present, the condition is false unless
8019 the first character of the <comparison-op> is '!'.
8021 For example,
8022 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
8023 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
8025 static const char *
8026 version_compare_spec_function (int argc, const char **argv)
8028 int comp1, comp2;
8029 size_t switch_len;
8030 const char *switch_value = NULL;
8031 int nargs = 1, i;
8032 bool result;
8034 if (argc < 3)
8035 fatal_error ("too few arguments to %%:version-compare");
8036 if (argv[0][0] == '\0')
8037 abort ();
8038 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
8039 nargs = 2;
8040 if (argc != nargs + 3)
8041 fatal_error ("too many arguments to %%:version-compare");
8043 switch_len = strlen (argv[nargs + 1]);
8044 for (i = 0; i < n_switches; i++)
8045 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
8046 && check_live_switch (i, switch_len))
8047 switch_value = switches[i].part1 + switch_len;
8049 if (switch_value == NULL)
8050 comp1 = comp2 = -1;
8051 else
8053 comp1 = compare_version_strings (switch_value, argv[1]);
8054 if (nargs == 2)
8055 comp2 = compare_version_strings (switch_value, argv[2]);
8056 else
8057 comp2 = -1; /* This value unused. */
8060 switch (argv[0][0] << 8 | argv[0][1])
8062 case '>' << 8 | '=':
8063 result = comp1 >= 0;
8064 break;
8065 case '!' << 8 | '<':
8066 result = comp1 >= 0 || switch_value == NULL;
8067 break;
8068 case '<' << 8:
8069 result = comp1 < 0;
8070 break;
8071 case '!' << 8 | '>':
8072 result = comp1 < 0 || switch_value == NULL;
8073 break;
8074 case '>' << 8 | '<':
8075 result = comp1 >= 0 && comp2 < 0;
8076 break;
8077 case '<' << 8 | '>':
8078 result = comp1 < 0 || comp2 >= 0;
8079 break;
8081 default:
8082 fatal_error ("unknown operator %qs in %%:version-compare", argv[0]);
8084 if (! result)
8085 return NULL;
8087 return argv[nargs + 2];
8090 /* %:include builtin spec function. This differs from %include in that it
8091 can be nested inside a spec, and thus be conditionalized. It takes
8092 one argument, the filename, and looks for it in the startfile path.
8093 The result is always NULL, i.e. an empty expansion. */
8095 static const char *
8096 include_spec_function (int argc, const char **argv)
8098 char *file;
8100 if (argc != 1)
8101 abort ();
8103 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
8104 read_specs (file ? file : argv[0], false, false);
8106 return NULL;
8109 /* %:find-file spec function. This function replaces its argument by
8110 the file found through find_file, that is the -print-file-name gcc
8111 program option. */
8112 static const char *
8113 find_file_spec_function (int argc, const char **argv)
8115 const char *file;
8117 if (argc != 1)
8118 abort ();
8120 file = find_file (argv[0]);
8121 return file;
8125 /* %:find-plugindir spec function. This function replaces its argument
8126 by the -iplugindir=<dir> option. `dir' is found through find_file, that
8127 is the -print-file-name gcc program option. */
8128 static const char *
8129 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
8131 const char *option;
8133 if (argc != 0)
8134 abort ();
8136 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
8137 return option;
8141 /* %:print-asm-header spec function. Print a banner to say that the
8142 following output is from the assembler. */
8144 static const char *
8145 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
8146 const char **argv ATTRIBUTE_UNUSED)
8148 printf (_("Assembler options\n=================\n\n"));
8149 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
8150 fflush (stdout);
8151 return NULL;
8154 /* Get a random number for -frandom-seed */
8156 static unsigned HOST_WIDE_INT
8157 get_random_number (void)
8159 unsigned HOST_WIDE_INT ret = 0;
8160 int fd;
8162 fd = open ("/dev/urandom", O_RDONLY);
8163 if (fd >= 0)
8165 read (fd, &ret, sizeof (HOST_WIDE_INT));
8166 close (fd);
8167 if (ret)
8168 return ret;
8171 /* Get some more or less random data. */
8172 #ifdef HAVE_GETTIMEOFDAY
8174 struct timeval tv;
8176 gettimeofday (&tv, NULL);
8177 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
8179 #else
8181 time_t now = time (NULL);
8183 if (now != (time_t)-1)
8184 ret = (unsigned) now;
8186 #endif
8188 return ret ^ getpid();
8191 /* %:compare-debug-dump-opt spec function. Save the last argument,
8192 expected to be the last -fdump-final-insns option, or generate a
8193 temporary. */
8195 static const char *
8196 compare_debug_dump_opt_spec_function (int arg,
8197 const char **argv ATTRIBUTE_UNUSED)
8199 char *ret;
8200 char *name;
8201 int which;
8202 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
8204 if (arg != 0)
8205 fatal_error ("too many arguments to %%:compare-debug-dump-opt");
8207 do_spec_2 ("%{fdump-final-insns=*:%*}");
8208 do_spec_1 (" ", 0, NULL);
8210 if (VEC_length (const_char_p, argbuf) > 0
8211 && strcmp (argv[VEC_length (const_char_p, argbuf) - 1], "."))
8213 if (!compare_debug)
8214 return NULL;
8216 name = xstrdup (argv[VEC_length (const_char_p, argbuf) - 1]);
8217 ret = NULL;
8219 else
8221 const char *ext = NULL;
8223 if (VEC_length (const_char_p, argbuf) > 0)
8225 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
8226 ext = ".gkd";
8228 else if (!compare_debug)
8229 return NULL;
8230 else
8231 do_spec_2 ("%g.gkd");
8233 do_spec_1 (" ", 0, NULL);
8235 gcc_assert (VEC_length (const_char_p, argbuf) > 0);
8237 name = concat (VEC_last (const_char_p, argbuf), ext, NULL);
8239 ret = concat ("-fdump-final-insns=", name, NULL);
8242 which = compare_debug < 0;
8243 debug_check_temp_file[which] = name;
8245 if (!which)
8247 unsigned HOST_WIDE_INT value = get_random_number ();
8249 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
8252 if (*random_seed)
8254 char *tmp = ret;
8255 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
8256 ret, NULL);
8257 free (tmp);
8260 if (which)
8261 *random_seed = 0;
8263 return ret;
8266 static const char *debug_auxbase_opt;
8268 /* %:compare-debug-self-opt spec function. Expands to the options
8269 that are to be passed in the second compilation of
8270 compare-debug. */
8272 static const char *
8273 compare_debug_self_opt_spec_function (int arg,
8274 const char **argv ATTRIBUTE_UNUSED)
8276 if (arg != 0)
8277 fatal_error ("too many arguments to %%:compare-debug-self-opt");
8279 if (compare_debug >= 0)
8280 return NULL;
8282 do_spec_2 ("%{c|S:%{o*:%*}}");
8283 do_spec_1 (" ", 0, NULL);
8285 if (VEC_length (const_char_p, argbuf) > 0)
8286 debug_auxbase_opt = concat ("-auxbase-strip ",
8287 VEC_last (const_char_p, argbuf),
8288 NULL);
8289 else
8290 debug_auxbase_opt = NULL;
8292 return concat ("\
8293 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
8294 %<fdump-final-insns=* -w -S -o %j \
8295 %{!fcompare-debug-second:-fcompare-debug-second} \
8296 ", compare_debug_opt, NULL);
8299 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
8300 options that are to be passed in the second compilation of
8301 compare-debug. It expects, as an argument, the basename of the
8302 current input file name, with the .gk suffix appended to it. */
8304 static const char *
8305 compare_debug_auxbase_opt_spec_function (int arg,
8306 const char **argv)
8308 char *name;
8309 int len;
8311 if (arg == 0)
8312 fatal_error ("too few arguments to %%:compare-debug-auxbase-opt");
8314 if (arg != 1)
8315 fatal_error ("too many arguments to %%:compare-debug-auxbase-opt");
8317 if (compare_debug >= 0)
8318 return NULL;
8320 len = strlen (argv[0]);
8321 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
8322 fatal_error ("argument to %%:compare-debug-auxbase-opt "
8323 "does not end in .gk");
8325 if (debug_auxbase_opt)
8326 return debug_auxbase_opt;
8328 #define OPT "-auxbase "
8330 len -= 3;
8331 name = (char*) xmalloc (sizeof (OPT) + len);
8332 memcpy (name, OPT, sizeof (OPT) - 1);
8333 memcpy (name + sizeof (OPT) - 1, argv[0], len);
8334 name[sizeof (OPT) - 1 + len] = '\0';
8336 #undef OPT
8338 return name;
8341 /* %:pass-through-libs spec function. Finds all -l options and input
8342 file names in the lib spec passed to it, and makes a list of them
8343 prepended with the plugin option to cause them to be passed through
8344 to the final link after all the new object files have been added. */
8346 const char *
8347 pass_through_libs_spec_func (int argc, const char **argv)
8349 char *prepended = xstrdup (" ");
8350 int n;
8351 /* Shlemiel the painter's algorithm. Innately horrible, but at least
8352 we know that there will never be more than a handful of strings to
8353 concat, and it's only once per run, so it's not worth optimising. */
8354 for (n = 0; n < argc; n++)
8356 char *old = prepended;
8357 /* Anything that isn't an option is a full path to an output
8358 file; pass it through if it ends in '.a'. Among options,
8359 pass only -l. */
8360 if (argv[n][0] == '-' && argv[n][1] == 'l')
8362 const char *lopt = argv[n] + 2;
8363 /* Handle both joined and non-joined -l options. If for any
8364 reason there's a trailing -l with no joined or following
8365 arg just discard it. */
8366 if (!*lopt && ++n >= argc)
8367 break;
8368 else if (!*lopt)
8369 lopt = argv[n];
8370 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
8371 lopt, " ", NULL);
8373 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
8375 prepended = concat (prepended, "-plugin-opt=-pass-through=",
8376 argv[n], " ", NULL);
8378 if (prepended != old)
8379 free (old);
8381 return prepended;