PR c++/54198
[official-gcc.git] / gcc / gcc.c
blob5f68d5978e3b7c7ff5efa62887f3eaae25c6f9f0
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))
1991 goto already2;
1993 temp = XNEW (struct temp_file);
1994 temp->next = failure_delete_queue;
1995 temp->name = name;
1996 failure_delete_queue = temp;
1998 already2:;
2002 /* Delete all the temporary files whose names we previously recorded. */
2004 #ifndef DELETE_IF_ORDINARY
2005 #define DELETE_IF_ORDINARY(NAME,ST,VERBOSE_FLAG) \
2006 do \
2008 if (stat (NAME, &ST) >= 0 && S_ISREG (ST.st_mode)) \
2009 if (unlink (NAME) < 0) \
2010 if (VERBOSE_FLAG) \
2011 perror_with_name (NAME); \
2012 } while (0)
2013 #endif
2015 static void
2016 delete_if_ordinary (const char *name)
2018 struct stat st;
2019 #ifdef DEBUG
2020 int i, c;
2022 printf ("Delete %s? (y or n) ", name);
2023 fflush (stdout);
2024 i = getchar ();
2025 if (i != '\n')
2026 while ((c = getchar ()) != '\n' && c != EOF)
2029 if (i == 'y' || i == 'Y')
2030 #endif /* DEBUG */
2031 DELETE_IF_ORDINARY (name, st, verbose_flag);
2034 static void
2035 delete_temp_files (void)
2037 struct temp_file *temp;
2039 for (temp = always_delete_queue; temp; temp = temp->next)
2040 delete_if_ordinary (temp->name);
2041 always_delete_queue = 0;
2044 /* Delete all the files to be deleted on error. */
2046 static void
2047 delete_failure_queue (void)
2049 struct temp_file *temp;
2051 for (temp = failure_delete_queue; temp; temp = temp->next)
2052 delete_if_ordinary (temp->name);
2055 static void
2056 clear_failure_queue (void)
2058 failure_delete_queue = 0;
2061 /* Call CALLBACK for each path in PATHS, breaking out early if CALLBACK
2062 returns non-NULL.
2063 If DO_MULTI is true iterate over the paths twice, first with multilib
2064 suffix then without, otherwise iterate over the paths once without
2065 adding a multilib suffix. When DO_MULTI is true, some attempt is made
2066 to avoid visiting the same path twice, but we could do better. For
2067 instance, /usr/lib/../lib is considered different from /usr/lib.
2068 At least EXTRA_SPACE chars past the end of the path passed to
2069 CALLBACK are available for use by the callback.
2070 CALLBACK_INFO allows extra parameters to be passed to CALLBACK.
2072 Returns the value returned by CALLBACK. */
2074 static void *
2075 for_each_path (const struct path_prefix *paths,
2076 bool do_multi,
2077 size_t extra_space,
2078 void *(*callback) (char *, void *),
2079 void *callback_info)
2081 struct prefix_list *pl;
2082 const char *multi_dir = NULL;
2083 const char *multi_os_dir = NULL;
2084 const char *multi_suffix;
2085 const char *just_multi_suffix;
2086 char *path = NULL;
2087 void *ret = NULL;
2088 bool skip_multi_dir = false;
2089 bool skip_multi_os_dir = false;
2091 multi_suffix = machine_suffix;
2092 just_multi_suffix = just_machine_suffix;
2093 if (do_multi && multilib_dir && strcmp (multilib_dir, ".") != 0)
2095 multi_dir = concat (multilib_dir, dir_separator_str, NULL);
2096 multi_suffix = concat (multi_suffix, multi_dir, NULL);
2097 just_multi_suffix = concat (just_multi_suffix, multi_dir, NULL);
2099 if (do_multi && multilib_os_dir && strcmp (multilib_os_dir, ".") != 0)
2100 multi_os_dir = concat (multilib_os_dir, dir_separator_str, NULL);
2102 while (1)
2104 size_t multi_dir_len = 0;
2105 size_t multi_os_dir_len = 0;
2106 size_t suffix_len;
2107 size_t just_suffix_len;
2108 size_t len;
2110 if (multi_dir)
2111 multi_dir_len = strlen (multi_dir);
2112 if (multi_os_dir)
2113 multi_os_dir_len = strlen (multi_os_dir);
2114 suffix_len = strlen (multi_suffix);
2115 just_suffix_len = strlen (just_multi_suffix);
2117 if (path == NULL)
2119 len = paths->max_len + extra_space + 1;
2120 if (suffix_len > multi_os_dir_len)
2121 len += suffix_len;
2122 else
2123 len += multi_os_dir_len;
2124 path = XNEWVEC (char, len);
2127 for (pl = paths->plist; pl != 0; pl = pl->next)
2129 len = strlen (pl->prefix);
2130 memcpy (path, pl->prefix, len);
2132 /* Look first in MACHINE/VERSION subdirectory. */
2133 if (!skip_multi_dir)
2135 memcpy (path + len, multi_suffix, suffix_len + 1);
2136 ret = callback (path, callback_info);
2137 if (ret)
2138 break;
2141 /* Some paths are tried with just the machine (ie. target)
2142 subdir. This is used for finding as, ld, etc. */
2143 if (!skip_multi_dir
2144 && pl->require_machine_suffix == 2)
2146 memcpy (path + len, just_multi_suffix, just_suffix_len + 1);
2147 ret = callback (path, callback_info);
2148 if (ret)
2149 break;
2152 /* Now try the base path. */
2153 if (!pl->require_machine_suffix
2154 && !(pl->os_multilib ? skip_multi_os_dir : skip_multi_dir))
2156 const char *this_multi;
2157 size_t this_multi_len;
2159 if (pl->os_multilib)
2161 this_multi = multi_os_dir;
2162 this_multi_len = multi_os_dir_len;
2164 else
2166 this_multi = multi_dir;
2167 this_multi_len = multi_dir_len;
2170 if (this_multi_len)
2171 memcpy (path + len, this_multi, this_multi_len + 1);
2172 else
2173 path[len] = '\0';
2175 ret = callback (path, callback_info);
2176 if (ret)
2177 break;
2180 if (pl)
2181 break;
2183 if (multi_dir == NULL && multi_os_dir == NULL)
2184 break;
2186 /* Run through the paths again, this time without multilibs.
2187 Don't repeat any we have already seen. */
2188 if (multi_dir)
2190 free (CONST_CAST (char *, multi_dir));
2191 multi_dir = NULL;
2192 free (CONST_CAST (char *, multi_suffix));
2193 multi_suffix = machine_suffix;
2194 free (CONST_CAST (char *, just_multi_suffix));
2195 just_multi_suffix = just_machine_suffix;
2197 else
2198 skip_multi_dir = true;
2199 if (multi_os_dir)
2201 free (CONST_CAST (char *, multi_os_dir));
2202 multi_os_dir = NULL;
2204 else
2205 skip_multi_os_dir = true;
2208 if (multi_dir)
2210 free (CONST_CAST (char *, multi_dir));
2211 free (CONST_CAST (char *, multi_suffix));
2212 free (CONST_CAST (char *, just_multi_suffix));
2214 if (multi_os_dir)
2215 free (CONST_CAST (char *, multi_os_dir));
2216 if (ret != path)
2217 free (path);
2218 return ret;
2221 /* Callback for build_search_list. Adds path to obstack being built. */
2223 struct add_to_obstack_info {
2224 struct obstack *ob;
2225 bool check_dir;
2226 bool first_time;
2229 static void *
2230 add_to_obstack (char *path, void *data)
2232 struct add_to_obstack_info *info = (struct add_to_obstack_info *) data;
2234 if (info->check_dir && !is_directory (path, false))
2235 return NULL;
2237 if (!info->first_time)
2238 obstack_1grow (info->ob, PATH_SEPARATOR);
2240 obstack_grow (info->ob, path, strlen (path));
2242 info->first_time = false;
2243 return NULL;
2246 /* Add or change the value of an environment variable, outputting the
2247 change to standard error if in verbose mode. */
2248 static void
2249 xputenv (const char *string)
2251 if (verbose_flag)
2252 fnotice (stderr, "%s\n", string);
2253 putenv (CONST_CAST (char *, string));
2256 /* Build a list of search directories from PATHS.
2257 PREFIX is a string to prepend to the list.
2258 If CHECK_DIR_P is true we ensure the directory exists.
2259 If DO_MULTI is true, multilib paths are output first, then
2260 non-multilib paths.
2261 This is used mostly by putenv_from_prefixes so we use `collect_obstack'.
2262 It is also used by the --print-search-dirs flag. */
2264 static char *
2265 build_search_list (const struct path_prefix *paths, const char *prefix,
2266 bool check_dir, bool do_multi)
2268 struct add_to_obstack_info info;
2270 info.ob = &collect_obstack;
2271 info.check_dir = check_dir;
2272 info.first_time = true;
2274 obstack_grow (&collect_obstack, prefix, strlen (prefix));
2275 obstack_1grow (&collect_obstack, '=');
2277 for_each_path (paths, do_multi, 0, add_to_obstack, &info);
2279 obstack_1grow (&collect_obstack, '\0');
2280 return XOBFINISH (&collect_obstack, char *);
2283 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
2284 for collect. */
2286 static void
2287 putenv_from_prefixes (const struct path_prefix *paths, const char *env_var,
2288 bool do_multi)
2290 xputenv (build_search_list (paths, env_var, true, do_multi));
2293 /* Check whether NAME can be accessed in MODE. This is like access,
2294 except that it never considers directories to be executable. */
2296 static int
2297 access_check (const char *name, int mode)
2299 if (mode == X_OK)
2301 struct stat st;
2303 if (stat (name, &st) < 0
2304 || S_ISDIR (st.st_mode))
2305 return -1;
2308 return access (name, mode);
2311 /* Callback for find_a_file. Appends the file name to the directory
2312 path. If the resulting file exists in the right mode, return the
2313 full pathname to the file. */
2315 struct file_at_path_info {
2316 const char *name;
2317 const char *suffix;
2318 int name_len;
2319 int suffix_len;
2320 int mode;
2323 static void *
2324 file_at_path (char *path, void *data)
2326 struct file_at_path_info *info = (struct file_at_path_info *) data;
2327 size_t len = strlen (path);
2329 memcpy (path + len, info->name, info->name_len);
2330 len += info->name_len;
2332 /* Some systems have a suffix for executable files.
2333 So try appending that first. */
2334 if (info->suffix_len)
2336 memcpy (path + len, info->suffix, info->suffix_len + 1);
2337 if (access_check (path, info->mode) == 0)
2338 return path;
2341 path[len] = '\0';
2342 if (access_check (path, info->mode) == 0)
2343 return path;
2345 return NULL;
2348 /* Search for NAME using the prefix list PREFIXES. MODE is passed to
2349 access to check permissions. If DO_MULTI is true, search multilib
2350 paths then non-multilib paths, otherwise do not search multilib paths.
2351 Return 0 if not found, otherwise return its name, allocated with malloc. */
2353 static char *
2354 find_a_file (const struct path_prefix *pprefix, const char *name, int mode,
2355 bool do_multi)
2357 struct file_at_path_info info;
2359 #ifdef DEFAULT_ASSEMBLER
2360 if (! strcmp (name, "as") && access (DEFAULT_ASSEMBLER, mode) == 0)
2361 return xstrdup (DEFAULT_ASSEMBLER);
2362 #endif
2364 #ifdef DEFAULT_LINKER
2365 if (! strcmp(name, "ld") && access (DEFAULT_LINKER, mode) == 0)
2366 return xstrdup (DEFAULT_LINKER);
2367 #endif
2369 /* Determine the filename to execute (special case for absolute paths). */
2371 if (IS_ABSOLUTE_PATH (name))
2373 if (access (name, mode) == 0)
2374 return xstrdup (name);
2376 return NULL;
2379 info.name = name;
2380 info.suffix = (mode & X_OK) != 0 ? HOST_EXECUTABLE_SUFFIX : "";
2381 info.name_len = strlen (info.name);
2382 info.suffix_len = strlen (info.suffix);
2383 info.mode = mode;
2385 return (char*) for_each_path (pprefix, do_multi,
2386 info.name_len + info.suffix_len,
2387 file_at_path, &info);
2390 /* Ranking of prefixes in the sort list. -B prefixes are put before
2391 all others. */
2393 enum path_prefix_priority
2395 PREFIX_PRIORITY_B_OPT,
2396 PREFIX_PRIORITY_LAST
2399 /* Add an entry for PREFIX in PLIST. The PLIST is kept in ascending
2400 order according to PRIORITY. Within each PRIORITY, new entries are
2401 appended.
2403 If WARN is nonzero, we will warn if no file is found
2404 through this prefix. WARN should point to an int
2405 which will be set to 1 if this entry is used.
2407 COMPONENT is the value to be passed to update_path.
2409 REQUIRE_MACHINE_SUFFIX is 1 if this prefix can't be used without
2410 the complete value of machine_suffix.
2411 2 means try both machine_suffix and just_machine_suffix. */
2413 static void
2414 add_prefix (struct path_prefix *pprefix, const char *prefix,
2415 const char *component, /* enum prefix_priority */ int priority,
2416 int require_machine_suffix, int os_multilib)
2418 struct prefix_list *pl, **prev;
2419 int len;
2421 for (prev = &pprefix->plist;
2422 (*prev) != NULL && (*prev)->priority <= priority;
2423 prev = &(*prev)->next)
2426 /* Keep track of the longest prefix. */
2428 prefix = update_path (prefix, component);
2429 len = strlen (prefix);
2430 if (len > pprefix->max_len)
2431 pprefix->max_len = len;
2433 pl = XNEW (struct prefix_list);
2434 pl->prefix = prefix;
2435 pl->require_machine_suffix = require_machine_suffix;
2436 pl->priority = priority;
2437 pl->os_multilib = os_multilib;
2439 /* Insert after PREV. */
2440 pl->next = (*prev);
2441 (*prev) = pl;
2444 /* Same as add_prefix, but prepending target_system_root to prefix. */
2445 /* The target_system_root prefix has been relocated by gcc_exec_prefix. */
2446 static void
2447 add_sysrooted_prefix (struct path_prefix *pprefix, const char *prefix,
2448 const char *component,
2449 /* enum prefix_priority */ int priority,
2450 int require_machine_suffix, int os_multilib)
2452 if (!IS_ABSOLUTE_PATH (prefix))
2453 fatal_error ("system path %qs is not absolute", prefix);
2455 if (target_system_root)
2457 char *sysroot_no_trailing_dir_separator = xstrdup (target_system_root);
2458 size_t sysroot_len = strlen (target_system_root);
2460 if (sysroot_len > 0
2461 && target_system_root[sysroot_len - 1] == DIR_SEPARATOR)
2462 sysroot_no_trailing_dir_separator[sysroot_len - 1] = '\0';
2464 if (target_sysroot_suffix)
2465 prefix = concat (target_sysroot_suffix, prefix, NULL);
2466 prefix = concat (sysroot_no_trailing_dir_separator, prefix, NULL);
2467 free (sysroot_no_trailing_dir_separator);
2469 /* We have to override this because GCC's notion of sysroot
2470 moves along with GCC. */
2471 component = "GCC";
2474 add_prefix (pprefix, prefix, component, priority,
2475 require_machine_suffix, os_multilib);
2478 /* Execute the command specified by the arguments on the current line of spec.
2479 When using pipes, this includes several piped-together commands
2480 with `|' between them.
2482 Return 0 if successful, -1 if failed. */
2484 static int
2485 execute (void)
2487 int i;
2488 int n_commands; /* # of command. */
2489 char *string;
2490 struct pex_obj *pex;
2491 struct command
2493 const char *prog; /* program name. */
2494 const char **argv; /* vector of args. */
2496 const char *arg;
2498 struct command *commands; /* each command buffer with above info. */
2500 gcc_assert (!processing_spec_function);
2502 if (wrapper_string)
2504 string = find_a_file (&exec_prefixes,
2505 VEC_index (const_char_p, argbuf, 0), X_OK, false);
2506 if (string)
2507 VEC_replace (const_char_p, argbuf, 0, string);
2508 insert_wrapper (wrapper_string);
2511 /* Count # of piped commands. */
2512 for (n_commands = 1, i = 0; VEC_iterate (const_char_p, argbuf, i, arg); i++)
2513 if (strcmp (arg, "|") == 0)
2514 n_commands++;
2516 /* Get storage for each command. */
2517 commands = (struct command *) alloca (n_commands * sizeof (struct command));
2519 /* Split argbuf into its separate piped processes,
2520 and record info about each one.
2521 Also search for the programs that are to be run. */
2523 VEC_safe_push (const_char_p, heap, argbuf, (const_char_p)0);
2525 commands[0].prog = VEC_index (const_char_p, argbuf, 0); /* first command. */
2526 commands[0].argv = VEC_address (const_char_p, argbuf);
2528 if (!wrapper_string)
2530 string = find_a_file (&exec_prefixes, commands[0].prog, X_OK, false);
2531 commands[0].argv[0] = (string) ? string : commands[0].argv[0];
2534 for (n_commands = 1, i = 0; VEC_iterate (const_char_p, argbuf, i, arg); i++)
2535 if (arg && strcmp (arg, "|") == 0)
2536 { /* each command. */
2537 #if defined (__MSDOS__) || defined (OS2) || defined (VMS)
2538 fatal_error ("-pipe not supported");
2539 #endif
2540 VEC_replace (const_char_p, argbuf, i, 0); /* Termination of
2541 command args. */
2542 commands[n_commands].prog = VEC_index (const_char_p, argbuf, i + 1);
2543 commands[n_commands].argv
2544 = &(VEC_address (const_char_p, argbuf))[i + 1];
2545 string = find_a_file (&exec_prefixes, commands[n_commands].prog,
2546 X_OK, false);
2547 if (string)
2548 commands[n_commands].argv[0] = string;
2549 n_commands++;
2552 /* If -v, print what we are about to do, and maybe query. */
2554 if (verbose_flag)
2556 /* For help listings, put a blank line between sub-processes. */
2557 if (print_help_list)
2558 fputc ('\n', stderr);
2560 /* Print each piped command as a separate line. */
2561 for (i = 0; i < n_commands; i++)
2563 const char *const *j;
2565 if (verbose_only_flag)
2567 for (j = commands[i].argv; *j; j++)
2569 const char *p;
2570 for (p = *j; *p; ++p)
2571 if (!ISALNUM ((unsigned char) *p)
2572 && *p != '_' && *p != '/' && *p != '-' && *p != '.')
2573 break;
2574 if (*p || !*j)
2576 fprintf (stderr, " \"");
2577 for (p = *j; *p; ++p)
2579 if (*p == '"' || *p == '\\' || *p == '$')
2580 fputc ('\\', stderr);
2581 fputc (*p, stderr);
2583 fputc ('"', stderr);
2585 /* If it's empty, print "". */
2586 else if (!**j)
2587 fprintf (stderr, " \"\"");
2588 else
2589 fprintf (stderr, " %s", *j);
2592 else
2593 for (j = commands[i].argv; *j; j++)
2594 /* If it's empty, print "". */
2595 if (!**j)
2596 fprintf (stderr, " \"\"");
2597 else
2598 fprintf (stderr, " %s", *j);
2600 /* Print a pipe symbol after all but the last command. */
2601 if (i + 1 != n_commands)
2602 fprintf (stderr, " |");
2603 fprintf (stderr, "\n");
2605 fflush (stderr);
2606 if (verbose_only_flag != 0)
2608 /* verbose_only_flag should act as if the spec was
2609 executed, so increment execution_count before
2610 returning. This prevents spurious warnings about
2611 unused linker input files, etc. */
2612 execution_count++;
2613 return 0;
2615 #ifdef DEBUG
2616 fnotice (stderr, "\nGo ahead? (y or n) ");
2617 fflush (stderr);
2618 i = getchar ();
2619 if (i != '\n')
2620 while (getchar () != '\n')
2623 if (i != 'y' && i != 'Y')
2624 return 0;
2625 #endif /* DEBUG */
2628 #ifdef ENABLE_VALGRIND_CHECKING
2629 /* Run the each command through valgrind. To simplify prepending the
2630 path to valgrind and the option "-q" (for quiet operation unless
2631 something triggers), we allocate a separate argv array. */
2633 for (i = 0; i < n_commands; i++)
2635 const char **argv;
2636 int argc;
2637 int j;
2639 for (argc = 0; commands[i].argv[argc] != NULL; argc++)
2642 argv = XALLOCAVEC (const char *, argc + 3);
2644 argv[0] = VALGRIND_PATH;
2645 argv[1] = "-q";
2646 for (j = 2; j < argc + 2; j++)
2647 argv[j] = commands[i].argv[j - 2];
2648 argv[j] = NULL;
2650 commands[i].argv = argv;
2651 commands[i].prog = argv[0];
2653 #endif
2655 /* Run each piped subprocess. */
2657 pex = pex_init (PEX_USE_PIPES | ((report_times || report_times_to_file)
2658 ? PEX_RECORD_TIMES : 0),
2659 progname, temp_filename);
2660 if (pex == NULL)
2661 fatal_error ("pex_init failed: %m");
2663 for (i = 0; i < n_commands; i++)
2665 const char *errmsg;
2666 int err;
2667 const char *string = commands[i].argv[0];
2669 errmsg = pex_run (pex,
2670 ((i + 1 == n_commands ? PEX_LAST : 0)
2671 | (string == commands[i].prog ? PEX_SEARCH : 0)),
2672 string, CONST_CAST (char **, commands[i].argv),
2673 NULL, NULL, &err);
2674 if (errmsg != NULL)
2676 if (err == 0)
2677 fatal_error (errmsg);
2678 else
2680 errno = err;
2681 pfatal_with_name (errmsg);
2685 if (string != commands[i].prog)
2686 free (CONST_CAST (char *, string));
2689 execution_count++;
2691 /* Wait for all the subprocesses to finish. */
2694 int *statuses;
2695 struct pex_time *times = NULL;
2696 int ret_code = 0;
2698 statuses = (int *) alloca (n_commands * sizeof (int));
2699 if (!pex_get_status (pex, n_commands, statuses))
2700 fatal_error ("failed to get exit status: %m");
2702 if (report_times || report_times_to_file)
2704 times = (struct pex_time *) alloca (n_commands * sizeof (struct pex_time));
2705 if (!pex_get_times (pex, n_commands, times))
2706 fatal_error ("failed to get process times: %m");
2709 pex_free (pex);
2711 for (i = 0; i < n_commands; ++i)
2713 int status = statuses[i];
2715 if (WIFSIGNALED (status))
2717 #ifdef SIGPIPE
2718 /* SIGPIPE is a special case. It happens in -pipe mode
2719 when the compiler dies before the preprocessor is done,
2720 or the assembler dies before the compiler is done.
2721 There's generally been an error already, and this is
2722 just fallout. So don't generate another error unless
2723 we would otherwise have succeeded. */
2724 if (WTERMSIG (status) == SIGPIPE
2725 && (signal_count || greatest_status >= MIN_FATAL_STATUS))
2727 signal_count++;
2728 ret_code = -1;
2730 else
2731 #endif
2732 internal_error ("%s (program %s)",
2733 strsignal (WTERMSIG (status)), commands[i].prog);
2735 else if (WIFEXITED (status)
2736 && WEXITSTATUS (status) >= MIN_FATAL_STATUS)
2738 if (WEXITSTATUS (status) > greatest_status)
2739 greatest_status = WEXITSTATUS (status);
2740 ret_code = -1;
2743 if (report_times || report_times_to_file)
2745 struct pex_time *pt = &times[i];
2746 double ut, st;
2748 ut = ((double) pt->user_seconds
2749 + (double) pt->user_microseconds / 1.0e6);
2750 st = ((double) pt->system_seconds
2751 + (double) pt->system_microseconds / 1.0e6);
2753 if (ut + st != 0)
2755 if (report_times)
2756 fnotice (stderr, "# %s %.2f %.2f\n",
2757 commands[i].prog, ut, st);
2759 if (report_times_to_file)
2761 int c = 0;
2762 const char *const *j;
2764 fprintf (report_times_to_file, "%g %g", ut, st);
2766 for (j = &commands[i].prog; *j; j = &commands[i].argv[++c])
2768 const char *p;
2769 for (p = *j; *p; ++p)
2770 if (*p == '"' || *p == '\\' || *p == '$'
2771 || ISSPACE (*p))
2772 break;
2774 if (*p)
2776 fprintf (report_times_to_file, " \"");
2777 for (p = *j; *p; ++p)
2779 if (*p == '"' || *p == '\\' || *p == '$')
2780 fputc ('\\', report_times_to_file);
2781 fputc (*p, report_times_to_file);
2783 fputc ('"', report_times_to_file);
2785 else
2786 fprintf (report_times_to_file, " %s", *j);
2789 fputc ('\n', report_times_to_file);
2795 return ret_code;
2799 /* Find all the switches given to us
2800 and make a vector describing them.
2801 The elements of the vector are strings, one per switch given.
2802 If a switch uses following arguments, then the `part1' field
2803 is the switch itself and the `args' field
2804 is a null-terminated vector containing the following arguments.
2805 Bits in the `live_cond' field are:
2806 SWITCH_LIVE to indicate this switch is true in a conditional spec.
2807 SWITCH_FALSE to indicate this switch is overridden by a later switch.
2808 SWITCH_IGNORE to indicate this switch should be ignored (used in %<S).
2809 SWITCH_IGNORE_PERMANENTLY to indicate this switch should be ignored
2810 in all do_spec calls afterwards. Used for %<S from self specs.
2811 The `validated' field is nonzero if any spec has looked at this switch;
2812 if it remains zero at the end of the run, it must be meaningless. */
2814 #define SWITCH_LIVE (1 << 0)
2815 #define SWITCH_FALSE (1 << 1)
2816 #define SWITCH_IGNORE (1 << 2)
2817 #define SWITCH_IGNORE_PERMANENTLY (1 << 3)
2818 #define SWITCH_KEEP_FOR_GCC (1 << 4)
2820 struct switchstr
2822 const char *part1;
2823 const char **args;
2824 unsigned int live_cond;
2825 bool known;
2826 bool validated;
2827 bool ordering;
2830 static struct switchstr *switches;
2832 static int n_switches;
2834 static int n_switches_alloc;
2836 /* Set to zero if -fcompare-debug is disabled, positive if it's
2837 enabled and we're running the first compilation, negative if it's
2838 enabled and we're running the second compilation. For most of the
2839 time, it's in the range -1..1, but it can be temporarily set to 2
2840 or 3 to indicate that the -fcompare-debug flags didn't come from
2841 the command-line, but rather from the GCC_COMPARE_DEBUG environment
2842 variable, until a synthesized -fcompare-debug flag is added to the
2843 command line. */
2844 int compare_debug;
2846 /* Set to nonzero if we've seen the -fcompare-debug-second flag. */
2847 int compare_debug_second;
2849 /* Set to the flags that should be passed to the second compilation in
2850 a -fcompare-debug compilation. */
2851 const char *compare_debug_opt;
2853 static struct switchstr *switches_debug_check[2];
2855 static int n_switches_debug_check[2];
2857 static int n_switches_alloc_debug_check[2];
2859 static char *debug_check_temp_file[2];
2861 /* Language is one of three things:
2863 1) The name of a real programming language.
2864 2) NULL, indicating that no one has figured out
2865 what it is yet.
2866 3) '*', indicating that the file should be passed
2867 to the linker. */
2868 struct infile
2870 const char *name;
2871 const char *language;
2872 struct compiler *incompiler;
2873 bool compiled;
2874 bool preprocessed;
2877 /* Also a vector of input files specified. */
2879 static struct infile *infiles;
2881 int n_infiles;
2883 static int n_infiles_alloc;
2885 /* True if multiple input files are being compiled to a single
2886 assembly file. */
2888 static bool combine_inputs;
2890 /* This counts the number of libraries added by lang_specific_driver, so that
2891 we can tell if there were any user supplied any files or libraries. */
2893 static int added_libraries;
2895 /* And a vector of corresponding output files is made up later. */
2897 const char **outfiles;
2899 #if defined(HAVE_TARGET_OBJECT_SUFFIX) || defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2901 /* Convert NAME to a new name if it is the standard suffix. DO_EXE
2902 is true if we should look for an executable suffix. DO_OBJ
2903 is true if we should look for an object suffix. */
2905 static const char *
2906 convert_filename (const char *name, int do_exe ATTRIBUTE_UNUSED,
2907 int do_obj ATTRIBUTE_UNUSED)
2909 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2910 int i;
2911 #endif
2912 int len;
2914 if (name == NULL)
2915 return NULL;
2917 len = strlen (name);
2919 #ifdef HAVE_TARGET_OBJECT_SUFFIX
2920 /* Convert x.o to x.obj if TARGET_OBJECT_SUFFIX is ".obj". */
2921 if (do_obj && len > 2
2922 && name[len - 2] == '.'
2923 && name[len - 1] == 'o')
2925 obstack_grow (&obstack, name, len - 2);
2926 obstack_grow0 (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
2927 name = XOBFINISH (&obstack, const char *);
2929 #endif
2931 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX)
2932 /* If there is no filetype, make it the executable suffix (which includes
2933 the "."). But don't get confused if we have just "-o". */
2934 if (! do_exe || TARGET_EXECUTABLE_SUFFIX[0] == 0 || (len == 2 && name[0] == '-'))
2935 return name;
2937 for (i = len - 1; i >= 0; i--)
2938 if (IS_DIR_SEPARATOR (name[i]))
2939 break;
2941 for (i++; i < len; i++)
2942 if (name[i] == '.')
2943 return name;
2945 obstack_grow (&obstack, name, len);
2946 obstack_grow0 (&obstack, TARGET_EXECUTABLE_SUFFIX,
2947 strlen (TARGET_EXECUTABLE_SUFFIX));
2948 name = XOBFINISH (&obstack, const char *);
2949 #endif
2951 return name;
2953 #endif
2955 /* Display the command line switches accepted by gcc. */
2956 static void
2957 display_help (void)
2959 printf (_("Usage: %s [options] file...\n"), progname);
2960 fputs (_("Options:\n"), stdout);
2962 fputs (_(" -pass-exit-codes Exit with highest error code from a phase\n"), stdout);
2963 fputs (_(" --help Display this information\n"), stdout);
2964 fputs (_(" --target-help Display target specific command line options\n"), stdout);
2965 fputs (_(" --help={common|optimizers|params|target|warnings|[^]{joined|separate|undocumented}}[,...]\n"), stdout);
2966 fputs (_(" Display specific types of command line options\n"), stdout);
2967 if (! verbose_flag)
2968 fputs (_(" (Use '-v --help' to display command line options of sub-processes)\n"), stdout);
2969 fputs (_(" --version Display compiler version information\n"), stdout);
2970 fputs (_(" -dumpspecs Display all of the built in spec strings\n"), stdout);
2971 fputs (_(" -dumpversion Display the version of the compiler\n"), stdout);
2972 fputs (_(" -dumpmachine Display the compiler's target processor\n"), stdout);
2973 fputs (_(" -print-search-dirs Display the directories in the compiler's search path\n"), stdout);
2974 fputs (_(" -print-libgcc-file-name Display the name of the compiler's companion library\n"), stdout);
2975 fputs (_(" -print-file-name=<lib> Display the full path to library <lib>\n"), stdout);
2976 fputs (_(" -print-prog-name=<prog> Display the full path to compiler component <prog>\n"), stdout);
2977 fputs (_(" -print-multi-directory Display the root directory for versions of libgcc\n"), stdout);
2978 fputs (_("\
2979 -print-multi-lib Display the mapping between command line options and\n\
2980 multiple library search directories\n"), stdout);
2981 fputs (_(" -print-multi-os-directory Display the relative path to OS libraries\n"), stdout);
2982 fputs (_(" -print-sysroot Display the target libraries directory\n"), stdout);
2983 fputs (_(" -print-sysroot-headers-suffix Display the sysroot suffix used to find headers\n"), stdout);
2984 fputs (_(" -Wa,<options> Pass comma-separated <options> on to the assembler\n"), stdout);
2985 fputs (_(" -Wp,<options> Pass comma-separated <options> on to the preprocessor\n"), stdout);
2986 fputs (_(" -Wl,<options> Pass comma-separated <options> on to the linker\n"), stdout);
2987 fputs (_(" -Xassembler <arg> Pass <arg> on to the assembler\n"), stdout);
2988 fputs (_(" -Xpreprocessor <arg> Pass <arg> on to the preprocessor\n"), stdout);
2989 fputs (_(" -Xlinker <arg> Pass <arg> on to the linker\n"), stdout);
2990 fputs (_(" -save-temps Do not delete intermediate files\n"), stdout);
2991 fputs (_(" -save-temps=<arg> Do not delete intermediate files\n"), stdout);
2992 fputs (_("\
2993 -no-canonical-prefixes Do not canonicalize paths when building relative\n\
2994 prefixes to other gcc components\n"), stdout);
2995 fputs (_(" -pipe Use pipes rather than intermediate files\n"), stdout);
2996 fputs (_(" -time Time the execution of each subprocess\n"), stdout);
2997 fputs (_(" -specs=<file> Override built-in specs with the contents of <file>\n"), stdout);
2998 fputs (_(" -std=<standard> Assume that the input sources are for <standard>\n"), stdout);
2999 fputs (_("\
3000 --sysroot=<directory> Use <directory> as the root directory for headers\n\
3001 and libraries\n"), stdout);
3002 fputs (_(" -B <directory> Add <directory> to the compiler's search paths\n"), stdout);
3003 fputs (_(" -v Display the programs invoked by the compiler\n"), stdout);
3004 fputs (_(" -### Like -v but options quoted and commands not executed\n"), stdout);
3005 fputs (_(" -E Preprocess only; do not compile, assemble or link\n"), stdout);
3006 fputs (_(" -S Compile only; do not assemble or link\n"), stdout);
3007 fputs (_(" -c Compile and assemble, but do not link\n"), stdout);
3008 fputs (_(" -o <file> Place the output into <file>\n"), stdout);
3009 fputs (_(" -pie Create a position independent executable\n"), stdout);
3010 fputs (_(" -shared Create a shared library\n"), stdout);
3011 fputs (_("\
3012 -x <language> Specify the language of the following input files\n\
3013 Permissible languages include: c c++ assembler none\n\
3014 'none' means revert to the default behavior of\n\
3015 guessing the language based on the file's extension\n\
3016 "), stdout);
3018 printf (_("\
3019 \nOptions starting with -g, -f, -m, -O, -W, or --param are automatically\n\
3020 passed on to the various sub-processes invoked by %s. In order to pass\n\
3021 other options on to these processes the -W<letter> options must be used.\n\
3022 "), progname);
3024 /* The rest of the options are displayed by invocations of the various
3025 sub-processes. */
3028 static void
3029 add_preprocessor_option (const char *option, int len)
3031 VEC_safe_push (char_p, heap, preprocessor_options,
3032 save_string (option, len));
3035 static void
3036 add_assembler_option (const char *option, int len)
3038 VEC_safe_push (char_p, heap, assembler_options, save_string (option, len));
3041 static void
3042 add_linker_option (const char *option, int len)
3044 VEC_safe_push (char_p, heap, linker_options, save_string (option, len));
3047 /* Allocate space for an input file in infiles. */
3049 static void
3050 alloc_infile (void)
3052 if (n_infiles_alloc == 0)
3054 n_infiles_alloc = 16;
3055 infiles = XNEWVEC (struct infile, n_infiles_alloc);
3057 else if (n_infiles_alloc == n_infiles)
3059 n_infiles_alloc *= 2;
3060 infiles = XRESIZEVEC (struct infile, infiles, n_infiles_alloc);
3064 /* Store an input file with the given NAME and LANGUAGE in
3065 infiles. */
3067 static void
3068 add_infile (const char *name, const char *language)
3070 alloc_infile ();
3071 infiles[n_infiles].name = name;
3072 infiles[n_infiles++].language = language;
3075 /* Allocate space for a switch in switches. */
3077 static void
3078 alloc_switch (void)
3080 if (n_switches_alloc == 0)
3082 n_switches_alloc = 16;
3083 switches = XNEWVEC (struct switchstr, n_switches_alloc);
3085 else if (n_switches_alloc == n_switches)
3087 n_switches_alloc *= 2;
3088 switches = XRESIZEVEC (struct switchstr, switches, n_switches_alloc);
3092 /* Save an option OPT with N_ARGS arguments in array ARGS, marking it
3093 as validated if VALIDATED and KNOWN if it is an internal switch. */
3095 static void
3096 save_switch (const char *opt, size_t n_args, const char *const *args,
3097 bool validated, bool known)
3099 alloc_switch ();
3100 switches[n_switches].part1 = opt + 1;
3101 if (n_args == 0)
3102 switches[n_switches].args = 0;
3103 else
3105 switches[n_switches].args = XNEWVEC (const char *, n_args + 1);
3106 memcpy (switches[n_switches].args, args, n_args * sizeof (const char *));
3107 switches[n_switches].args[n_args] = NULL;
3110 switches[n_switches].live_cond = 0;
3111 switches[n_switches].validated = validated;
3112 switches[n_switches].known = known;
3113 switches[n_switches].ordering = 0;
3114 n_switches++;
3117 /* Handle an option DECODED that is unknown to the option-processing
3118 machinery. */
3120 static bool
3121 driver_unknown_option_callback (const struct cl_decoded_option *decoded)
3123 const char *opt = decoded->arg;
3124 if (opt[1] == 'W' && opt[2] == 'n' && opt[3] == 'o' && opt[4] == '-'
3125 && !(decoded->errors & CL_ERR_NEGATIVE))
3127 /* Leave unknown -Wno-* options for the compiler proper, to be
3128 diagnosed only if there are warnings. */
3129 save_switch (decoded->canonical_option[0],
3130 decoded->canonical_option_num_elements - 1,
3131 &decoded->canonical_option[1], false, true);
3132 return false;
3134 if (decoded->opt_index == OPT_SPECIAL_unknown)
3136 /* Give it a chance to define it a a spec file. */
3137 save_switch (decoded->canonical_option[0],
3138 decoded->canonical_option_num_elements - 1,
3139 &decoded->canonical_option[1], false, false);
3140 return false;
3142 else
3143 return true;
3146 /* Handle an option DECODED that is not marked as CL_DRIVER.
3147 LANG_MASK will always be CL_DRIVER. */
3149 static void
3150 driver_wrong_lang_callback (const struct cl_decoded_option *decoded,
3151 unsigned int lang_mask ATTRIBUTE_UNUSED)
3153 /* At this point, non-driver options are accepted (and expected to
3154 be passed down by specs) unless marked to be rejected by the
3155 driver. Options to be rejected by the driver but accepted by the
3156 compilers proper are treated just like completely unknown
3157 options. */
3158 const struct cl_option *option = &cl_options[decoded->opt_index];
3160 if (option->cl_reject_driver)
3161 error ("unrecognized command line option %qs",
3162 decoded->orig_option_with_args_text);
3163 else
3164 save_switch (decoded->canonical_option[0],
3165 decoded->canonical_option_num_elements - 1,
3166 &decoded->canonical_option[1], false, true);
3169 static const char *spec_lang = 0;
3170 static int last_language_n_infiles;
3172 /* Handle a driver option; arguments and return value as for
3173 handle_option. */
3175 static bool
3176 driver_handle_option (struct gcc_options *opts,
3177 struct gcc_options *opts_set,
3178 const struct cl_decoded_option *decoded,
3179 unsigned int lang_mask ATTRIBUTE_UNUSED, int kind,
3180 location_t loc,
3181 const struct cl_option_handlers *handlers ATTRIBUTE_UNUSED,
3182 diagnostic_context *dc)
3184 size_t opt_index = decoded->opt_index;
3185 const char *arg = decoded->arg;
3186 const char *compare_debug_replacement_opt;
3187 int value = decoded->value;
3188 bool validated = false;
3189 bool do_save = true;
3191 gcc_assert (opts == &global_options);
3192 gcc_assert (opts_set == &global_options_set);
3193 gcc_assert (kind == DK_UNSPECIFIED);
3194 gcc_assert (loc == UNKNOWN_LOCATION);
3195 gcc_assert (dc == global_dc);
3197 switch (opt_index)
3199 case OPT_dumpspecs:
3201 struct spec_list *sl;
3202 init_spec ();
3203 for (sl = specs; sl; sl = sl->next)
3204 printf ("*%s:\n%s\n\n", sl->name, *(sl->ptr_spec));
3205 if (link_command_spec)
3206 printf ("*link_command:\n%s\n\n", link_command_spec);
3207 exit (0);
3210 case OPT_dumpversion:
3211 printf ("%s\n", spec_version);
3212 exit (0);
3214 case OPT_dumpmachine:
3215 printf ("%s\n", spec_machine);
3216 exit (0);
3218 case OPT__version:
3219 print_version = 1;
3221 /* CPP driver cannot obtain switch from cc1_options. */
3222 if (is_cpp_driver)
3223 add_preprocessor_option ("--version", strlen ("--version"));
3224 add_assembler_option ("--version", strlen ("--version"));
3225 add_linker_option ("--version", strlen ("--version"));
3226 break;
3228 case OPT__help:
3229 print_help_list = 1;
3231 /* CPP driver cannot obtain switch from cc1_options. */
3232 if (is_cpp_driver)
3233 add_preprocessor_option ("--help", 6);
3234 add_assembler_option ("--help", 6);
3235 add_linker_option ("--help", 6);
3236 break;
3238 case OPT__help_:
3239 print_subprocess_help = 2;
3240 break;
3242 case OPT__target_help:
3243 print_subprocess_help = 1;
3245 /* CPP driver cannot obtain switch from cc1_options. */
3246 if (is_cpp_driver)
3247 add_preprocessor_option ("--target-help", 13);
3248 add_assembler_option ("--target-help", 13);
3249 add_linker_option ("--target-help", 13);
3250 break;
3252 case OPT__no_sysroot_suffix:
3253 case OPT_pass_exit_codes:
3254 case OPT_print_search_dirs:
3255 case OPT_print_file_name_:
3256 case OPT_print_prog_name_:
3257 case OPT_print_multi_lib:
3258 case OPT_print_multi_directory:
3259 case OPT_print_sysroot:
3260 case OPT_print_multi_os_directory:
3261 case OPT_print_sysroot_headers_suffix:
3262 case OPT_time:
3263 case OPT_wrapper:
3264 /* These options set the variables specified in common.opt
3265 automatically, and do not need to be saved for spec
3266 processing. */
3267 do_save = false;
3268 break;
3270 case OPT_print_libgcc_file_name:
3271 print_file_name = "libgcc.a";
3272 do_save = false;
3273 break;
3275 case OPT_fcompare_debug_second:
3276 compare_debug_second = 1;
3277 break;
3279 case OPT_fcompare_debug:
3280 switch (value)
3282 case 0:
3283 compare_debug_replacement_opt = "-fcompare-debug=";
3284 arg = "";
3285 goto compare_debug_with_arg;
3287 case 1:
3288 compare_debug_replacement_opt = "-fcompare-debug=-gtoggle";
3289 arg = "-gtoggle";
3290 goto compare_debug_with_arg;
3292 default:
3293 gcc_unreachable ();
3295 break;
3297 case OPT_fcompare_debug_:
3298 compare_debug_replacement_opt = decoded->canonical_option[0];
3299 compare_debug_with_arg:
3300 gcc_assert (decoded->canonical_option_num_elements == 1);
3301 gcc_assert (arg != NULL);
3302 if (*arg)
3303 compare_debug = 1;
3304 else
3305 compare_debug = -1;
3306 if (compare_debug < 0)
3307 compare_debug_opt = NULL;
3308 else
3309 compare_debug_opt = arg;
3310 save_switch (compare_debug_replacement_opt, 0, NULL, validated, true);
3311 return true;
3313 case OPT_Wa_:
3315 int prev, j;
3316 /* Pass the rest of this option to the assembler. */
3318 /* Split the argument at commas. */
3319 prev = 0;
3320 for (j = 0; arg[j]; j++)
3321 if (arg[j] == ',')
3323 add_assembler_option (arg + prev, j - prev);
3324 prev = j + 1;
3327 /* Record the part after the last comma. */
3328 add_assembler_option (arg + prev, j - prev);
3330 do_save = false;
3331 break;
3333 case OPT_Wp_:
3335 int prev, j;
3336 /* Pass the rest of this option to the preprocessor. */
3338 /* Split the argument at commas. */
3339 prev = 0;
3340 for (j = 0; arg[j]; j++)
3341 if (arg[j] == ',')
3343 add_preprocessor_option (arg + prev, j - prev);
3344 prev = j + 1;
3347 /* Record the part after the last comma. */
3348 add_preprocessor_option (arg + prev, j - prev);
3350 do_save = false;
3351 break;
3353 case OPT_Wl_:
3355 int prev, j;
3356 /* Split the argument at commas. */
3357 prev = 0;
3358 for (j = 0; arg[j]; j++)
3359 if (arg[j] == ',')
3361 add_infile (save_string (arg + prev, j - prev), "*");
3362 prev = j + 1;
3364 /* Record the part after the last comma. */
3365 add_infile (arg + prev, "*");
3367 do_save = false;
3368 break;
3370 case OPT_Xlinker:
3371 add_infile (arg, "*");
3372 do_save = false;
3373 break;
3375 case OPT_Xpreprocessor:
3376 add_preprocessor_option (arg, strlen (arg));
3377 do_save = false;
3378 break;
3380 case OPT_Xassembler:
3381 add_assembler_option (arg, strlen (arg));
3382 do_save = false;
3383 break;
3385 case OPT_l:
3386 /* POSIX allows separation of -l and the lib arg; canonicalize
3387 by concatenating -l with its arg */
3388 add_infile (concat ("-l", arg, NULL), "*");
3389 do_save = false;
3390 break;
3392 case OPT_L:
3393 /* Similarly, canonicalize -L for linkers that may not accept
3394 separate arguments. */
3395 save_switch (concat ("-L", arg, NULL), 0, NULL, validated, true);
3396 return true;
3398 case OPT_F:
3399 /* Likewise -F. */
3400 save_switch (concat ("-F", arg, NULL), 0, NULL, validated, true);
3401 return true;
3403 case OPT_save_temps:
3404 save_temps_flag = SAVE_TEMPS_CWD;
3405 validated = true;
3406 break;
3408 case OPT_save_temps_:
3409 if (strcmp (arg, "cwd") == 0)
3410 save_temps_flag = SAVE_TEMPS_CWD;
3411 else if (strcmp (arg, "obj") == 0
3412 || strcmp (arg, "object") == 0)
3413 save_temps_flag = SAVE_TEMPS_OBJ;
3414 else
3415 fatal_error ("%qs is an unknown -save-temps option",
3416 decoded->orig_option_with_args_text);
3417 break;
3419 case OPT_no_canonical_prefixes:
3420 /* Already handled as a special case, so ignored here. */
3421 do_save = false;
3422 break;
3424 case OPT_pipe:
3425 validated = true;
3426 /* These options set the variables specified in common.opt
3427 automatically, but do need to be saved for spec
3428 processing. */
3429 break;
3431 case OPT_specs_:
3433 struct user_specs *user = XNEW (struct user_specs);
3435 user->next = (struct user_specs *) 0;
3436 user->filename = arg;
3437 if (user_specs_tail)
3438 user_specs_tail->next = user;
3439 else
3440 user_specs_head = user;
3441 user_specs_tail = user;
3443 validated = true;
3444 break;
3446 case OPT__sysroot_:
3447 target_system_root = arg;
3448 target_system_root_changed = 1;
3449 do_save = false;
3450 break;
3452 case OPT_time_:
3453 if (report_times_to_file)
3454 fclose (report_times_to_file);
3455 report_times_to_file = fopen (arg, "a");
3456 do_save = false;
3457 break;
3459 case OPT____:
3460 /* "-###"
3461 This is similar to -v except that there is no execution
3462 of the commands and the echoed arguments are quoted. It
3463 is intended for use in shell scripts to capture the
3464 driver-generated command line. */
3465 verbose_only_flag++;
3466 verbose_flag = 1;
3467 do_save = false;
3468 break;
3470 case OPT_B:
3472 size_t len = strlen (arg);
3474 /* Catch the case where the user has forgotten to append a
3475 directory separator to the path. Note, they may be using
3476 -B to add an executable name prefix, eg "i386-elf-", in
3477 order to distinguish between multiple installations of
3478 GCC in the same directory. Hence we must check to see
3479 if appending a directory separator actually makes a
3480 valid directory name. */
3481 if (!IS_DIR_SEPARATOR (arg[len - 1])
3482 && is_directory (arg, false))
3484 char *tmp = XNEWVEC (char, len + 2);
3485 strcpy (tmp, arg);
3486 tmp[len] = DIR_SEPARATOR;
3487 tmp[++len] = 0;
3488 arg = tmp;
3491 add_prefix (&exec_prefixes, arg, NULL,
3492 PREFIX_PRIORITY_B_OPT, 0, 0);
3493 add_prefix (&startfile_prefixes, arg, NULL,
3494 PREFIX_PRIORITY_B_OPT, 0, 0);
3495 add_prefix (&include_prefixes, arg, NULL,
3496 PREFIX_PRIORITY_B_OPT, 0, 0);
3498 validated = true;
3499 break;
3501 case OPT_x:
3502 spec_lang = arg;
3503 if (!strcmp (spec_lang, "none"))
3504 /* Suppress the warning if -xnone comes after the last input
3505 file, because alternate command interfaces like g++ might
3506 find it useful to place -xnone after each input file. */
3507 spec_lang = 0;
3508 else
3509 last_language_n_infiles = n_infiles;
3510 do_save = false;
3511 break;
3513 case OPT_o:
3514 have_o = 1;
3515 #if defined(HAVE_TARGET_EXECUTABLE_SUFFIX) || defined(HAVE_TARGET_OBJECT_SUFFIX)
3516 arg = convert_filename (arg, ! have_c, 0);
3517 #endif
3518 /* Save the output name in case -save-temps=obj was used. */
3519 save_temps_prefix = xstrdup (arg);
3520 /* On some systems, ld cannot handle "-o" without a space. So
3521 split the option from its argument. */
3522 save_switch ("-o", 1, &arg, validated, true);
3523 return true;
3525 case OPT_static_libgcc:
3526 case OPT_shared_libgcc:
3527 case OPT_static_libgfortran:
3528 case OPT_static_libstdc__:
3529 /* These are always valid, since gcc.c itself understands the
3530 first two, gfortranspec.c understands -static-libgfortran and
3531 g++spec.c understands -static-libstdc++ */
3532 validated = true;
3533 break;
3535 default:
3536 /* Various driver options need no special processing at this
3537 point, having been handled in a prescan above or being
3538 handled by specs. */
3539 break;
3542 if (do_save)
3543 save_switch (decoded->canonical_option[0],
3544 decoded->canonical_option_num_elements - 1,
3545 &decoded->canonical_option[1], validated, true);
3546 return true;
3549 /* Put the driver's standard set of option handlers in *HANDLERS. */
3551 static void
3552 set_option_handlers (struct cl_option_handlers *handlers)
3554 handlers->unknown_option_callback = driver_unknown_option_callback;
3555 handlers->wrong_lang_callback = driver_wrong_lang_callback;
3556 handlers->num_handlers = 3;
3557 handlers->handlers[0].handler = driver_handle_option;
3558 handlers->handlers[0].mask = CL_DRIVER;
3559 handlers->handlers[1].handler = common_handle_option;
3560 handlers->handlers[1].mask = CL_COMMON;
3561 handlers->handlers[2].handler = target_handle_option;
3562 handlers->handlers[2].mask = CL_TARGET;
3565 /* Create the vector `switches' and its contents.
3566 Store its length in `n_switches'. */
3568 static void
3569 process_command (unsigned int decoded_options_count,
3570 struct cl_decoded_option *decoded_options)
3572 const char *temp;
3573 char *temp1;
3574 const char *tooldir_prefix;
3575 char *(*get_relative_prefix) (const char *, const char *,
3576 const char *) = NULL;
3577 struct cl_option_handlers handlers;
3578 unsigned int j;
3580 gcc_exec_prefix = getenv ("GCC_EXEC_PREFIX");
3582 n_switches = 0;
3583 n_infiles = 0;
3584 added_libraries = 0;
3586 /* Figure compiler version from version string. */
3588 compiler_version = temp1 = xstrdup (version_string);
3590 for (; *temp1; ++temp1)
3592 if (*temp1 == ' ')
3594 *temp1 = '\0';
3595 break;
3599 /* Handle any -no-canonical-prefixes flag early, to assign the function
3600 that builds relative prefixes. This function creates default search
3601 paths that are needed later in normal option handling. */
3603 for (j = 1; j < decoded_options_count; j++)
3605 if (decoded_options[j].opt_index == OPT_no_canonical_prefixes)
3607 get_relative_prefix = make_relative_prefix_ignore_links;
3608 break;
3611 if (! get_relative_prefix)
3612 get_relative_prefix = make_relative_prefix;
3614 /* Set up the default search paths. If there is no GCC_EXEC_PREFIX,
3615 see if we can create it from the pathname specified in
3616 decoded_options[0].arg. */
3618 gcc_libexec_prefix = standard_libexec_prefix;
3619 #ifndef VMS
3620 /* FIXME: make_relative_prefix doesn't yet work for VMS. */
3621 if (!gcc_exec_prefix)
3623 gcc_exec_prefix = get_relative_prefix (decoded_options[0].arg,
3624 standard_bindir_prefix,
3625 standard_exec_prefix);
3626 gcc_libexec_prefix = get_relative_prefix (decoded_options[0].arg,
3627 standard_bindir_prefix,
3628 standard_libexec_prefix);
3629 if (gcc_exec_prefix)
3630 xputenv (concat ("GCC_EXEC_PREFIX=", gcc_exec_prefix, NULL));
3632 else
3634 /* make_relative_prefix requires a program name, but
3635 GCC_EXEC_PREFIX is typically a directory name with a trailing
3636 / (which is ignored by make_relative_prefix), so append a
3637 program name. */
3638 char *tmp_prefix = concat (gcc_exec_prefix, "gcc", NULL);
3639 gcc_libexec_prefix = get_relative_prefix (tmp_prefix,
3640 standard_exec_prefix,
3641 standard_libexec_prefix);
3643 /* The path is unrelocated, so fallback to the original setting. */
3644 if (!gcc_libexec_prefix)
3645 gcc_libexec_prefix = standard_libexec_prefix;
3647 free (tmp_prefix);
3649 #else
3650 #endif
3651 /* From this point onward, gcc_exec_prefix is non-null if the toolchain
3652 is relocated. The toolchain was either relocated using GCC_EXEC_PREFIX
3653 or an automatically created GCC_EXEC_PREFIX from
3654 decoded_options[0].arg. */
3656 /* Do language-specific adjustment/addition of flags. */
3657 lang_specific_driver (&decoded_options, &decoded_options_count,
3658 &added_libraries);
3660 if (gcc_exec_prefix)
3662 int len = strlen (gcc_exec_prefix);
3664 if (len > (int) sizeof ("/lib/gcc/") - 1
3665 && (IS_DIR_SEPARATOR (gcc_exec_prefix[len-1])))
3667 temp = gcc_exec_prefix + len - sizeof ("/lib/gcc/") + 1;
3668 if (IS_DIR_SEPARATOR (*temp)
3669 && filename_ncmp (temp + 1, "lib", 3) == 0
3670 && IS_DIR_SEPARATOR (temp[4])
3671 && filename_ncmp (temp + 5, "gcc", 3) == 0)
3672 len -= sizeof ("/lib/gcc/") - 1;
3675 set_std_prefix (gcc_exec_prefix, len);
3676 add_prefix (&exec_prefixes, gcc_libexec_prefix, "GCC",
3677 PREFIX_PRIORITY_LAST, 0, 0);
3678 add_prefix (&startfile_prefixes, gcc_exec_prefix, "GCC",
3679 PREFIX_PRIORITY_LAST, 0, 0);
3682 /* COMPILER_PATH and LIBRARY_PATH have values
3683 that are lists of directory names with colons. */
3685 temp = getenv ("COMPILER_PATH");
3686 if (temp)
3688 const char *startp, *endp;
3689 char *nstore = (char *) alloca (strlen (temp) + 3);
3691 startp = endp = temp;
3692 while (1)
3694 if (*endp == PATH_SEPARATOR || *endp == 0)
3696 strncpy (nstore, startp, endp - startp);
3697 if (endp == startp)
3698 strcpy (nstore, concat (".", dir_separator_str, NULL));
3699 else if (!IS_DIR_SEPARATOR (endp[-1]))
3701 nstore[endp - startp] = DIR_SEPARATOR;
3702 nstore[endp - startp + 1] = 0;
3704 else
3705 nstore[endp - startp] = 0;
3706 add_prefix (&exec_prefixes, nstore, 0,
3707 PREFIX_PRIORITY_LAST, 0, 0);
3708 add_prefix (&include_prefixes, nstore, 0,
3709 PREFIX_PRIORITY_LAST, 0, 0);
3710 if (*endp == 0)
3711 break;
3712 endp = startp = endp + 1;
3714 else
3715 endp++;
3719 temp = getenv (LIBRARY_PATH_ENV);
3720 if (temp && *cross_compile == '0')
3722 const char *startp, *endp;
3723 char *nstore = (char *) alloca (strlen (temp) + 3);
3725 startp = endp = temp;
3726 while (1)
3728 if (*endp == PATH_SEPARATOR || *endp == 0)
3730 strncpy (nstore, startp, endp - startp);
3731 if (endp == startp)
3732 strcpy (nstore, concat (".", dir_separator_str, NULL));
3733 else if (!IS_DIR_SEPARATOR (endp[-1]))
3735 nstore[endp - startp] = DIR_SEPARATOR;
3736 nstore[endp - startp + 1] = 0;
3738 else
3739 nstore[endp - startp] = 0;
3740 add_prefix (&startfile_prefixes, nstore, NULL,
3741 PREFIX_PRIORITY_LAST, 0, 1);
3742 if (*endp == 0)
3743 break;
3744 endp = startp = endp + 1;
3746 else
3747 endp++;
3751 /* Use LPATH like LIBRARY_PATH (for the CMU build program). */
3752 temp = getenv ("LPATH");
3753 if (temp && *cross_compile == '0')
3755 const char *startp, *endp;
3756 char *nstore = (char *) alloca (strlen (temp) + 3);
3758 startp = endp = temp;
3759 while (1)
3761 if (*endp == PATH_SEPARATOR || *endp == 0)
3763 strncpy (nstore, startp, endp - startp);
3764 if (endp == startp)
3765 strcpy (nstore, concat (".", dir_separator_str, NULL));
3766 else if (!IS_DIR_SEPARATOR (endp[-1]))
3768 nstore[endp - startp] = DIR_SEPARATOR;
3769 nstore[endp - startp + 1] = 0;
3771 else
3772 nstore[endp - startp] = 0;
3773 add_prefix (&startfile_prefixes, nstore, NULL,
3774 PREFIX_PRIORITY_LAST, 0, 1);
3775 if (*endp == 0)
3776 break;
3777 endp = startp = endp + 1;
3779 else
3780 endp++;
3784 /* Process the options and store input files and switches in their
3785 vectors. */
3787 last_language_n_infiles = -1;
3789 set_option_handlers (&handlers);
3791 for (j = 1; j < decoded_options_count; j++)
3793 switch (decoded_options[j].opt_index)
3795 case OPT_S:
3796 case OPT_c:
3797 case OPT_E:
3798 have_c = 1;
3799 break;
3801 if (have_c)
3802 break;
3805 for (j = 1; j < decoded_options_count; j++)
3807 if (decoded_options[j].opt_index == OPT_SPECIAL_input_file)
3809 const char *arg = decoded_options[j].arg;
3810 const char *p = strrchr (arg, '@');
3811 char *fname;
3812 long offset;
3813 int consumed;
3814 #ifdef HAVE_TARGET_OBJECT_SUFFIX
3815 arg = convert_filename (arg, 0, access (arg, F_OK));
3816 #endif
3817 /* For LTO static archive support we handle input file
3818 specifications that are composed of a filename and
3819 an offset like FNAME@OFFSET. */
3820 if (p
3821 && p != arg
3822 && sscanf (p, "@%li%n", &offset, &consumed) >= 1
3823 && strlen (p) == (unsigned int)consumed)
3825 fname = (char *)xmalloc (p - arg + 1);
3826 memcpy (fname, arg, p - arg);
3827 fname[p - arg] = '\0';
3828 /* Only accept non-stdin and existing FNAME parts, otherwise
3829 try with the full name. */
3830 if (strcmp (fname, "-") == 0 || access (fname, F_OK) < 0)
3832 free (fname);
3833 fname = xstrdup (arg);
3836 else
3837 fname = xstrdup (arg);
3839 if (strcmp (fname, "-") != 0 && access (fname, F_OK) < 0)
3840 perror_with_name (fname);
3841 else
3842 add_infile (arg, spec_lang);
3844 free (fname);
3845 continue;
3848 read_cmdline_option (&global_options, &global_options_set,
3849 decoded_options + j, UNKNOWN_LOCATION,
3850 CL_DRIVER, &handlers, global_dc);
3853 /* If -save-temps=obj and -o name, create the prefix to use for %b.
3854 Otherwise just make -save-temps=obj the same as -save-temps=cwd. */
3855 if (save_temps_flag == SAVE_TEMPS_OBJ && save_temps_prefix != NULL)
3857 save_temps_length = strlen (save_temps_prefix);
3858 temp = strrchr (lbasename (save_temps_prefix), '.');
3859 if (temp)
3861 save_temps_length -= strlen (temp);
3862 save_temps_prefix[save_temps_length] = '\0';
3866 else if (save_temps_prefix != NULL)
3868 free (save_temps_prefix);
3869 save_temps_prefix = NULL;
3872 if (save_temps_flag && use_pipes)
3874 /* -save-temps overrides -pipe, so that temp files are produced */
3875 if (save_temps_flag)
3876 warning (0, "-pipe ignored because -save-temps specified");
3877 use_pipes = 0;
3880 if (!compare_debug)
3882 const char *gcd = getenv ("GCC_COMPARE_DEBUG");
3884 if (gcd && gcd[0] == '-')
3886 compare_debug = 2;
3887 compare_debug_opt = gcd;
3889 else if (gcd && *gcd && strcmp (gcd, "0"))
3891 compare_debug = 3;
3892 compare_debug_opt = "-gtoggle";
3895 else if (compare_debug < 0)
3897 compare_debug = 0;
3898 gcc_assert (!compare_debug_opt);
3901 /* Set up the search paths. We add directories that we expect to
3902 contain GNU Toolchain components before directories specified by
3903 the machine description so that we will find GNU components (like
3904 the GNU assembler) before those of the host system. */
3906 /* If we don't know where the toolchain has been installed, use the
3907 configured-in locations. */
3908 if (!gcc_exec_prefix)
3910 #ifndef OS2
3911 add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
3912 PREFIX_PRIORITY_LAST, 1, 0);
3913 add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
3914 PREFIX_PRIORITY_LAST, 2, 0);
3915 add_prefix (&exec_prefixes, standard_exec_prefix, "BINUTILS",
3916 PREFIX_PRIORITY_LAST, 2, 0);
3917 #endif
3918 add_prefix (&startfile_prefixes, standard_exec_prefix, "BINUTILS",
3919 PREFIX_PRIORITY_LAST, 1, 0);
3922 gcc_assert (!IS_ABSOLUTE_PATH (tooldir_base_prefix));
3923 tooldir_prefix = concat (tooldir_base_prefix, spec_machine,
3924 dir_separator_str, NULL);
3926 /* Look for tools relative to the location from which the driver is
3927 running, or, if that is not available, the configured prefix. */
3928 tooldir_prefix
3929 = concat (gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
3930 spec_machine, dir_separator_str,
3931 spec_version, dir_separator_str, tooldir_prefix, NULL);
3933 add_prefix (&exec_prefixes,
3934 concat (tooldir_prefix, "bin", dir_separator_str, NULL),
3935 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 0);
3936 add_prefix (&startfile_prefixes,
3937 concat (tooldir_prefix, "lib", dir_separator_str, NULL),
3938 "BINUTILS", PREFIX_PRIORITY_LAST, 0, 1);
3940 #if defined(TARGET_SYSTEM_ROOT_RELOCATABLE) && !defined(VMS)
3941 /* If the normal TARGET_SYSTEM_ROOT is inside of $exec_prefix,
3942 then consider it to relocate with the rest of the GCC installation
3943 if GCC_EXEC_PREFIX is set.
3944 ``make_relative_prefix'' is not compiled for VMS, so don't call it. */
3945 if (target_system_root && !target_system_root_changed && gcc_exec_prefix)
3947 char *tmp_prefix = get_relative_prefix (decoded_options[0].arg,
3948 standard_bindir_prefix,
3949 target_system_root);
3950 if (tmp_prefix && access_check (tmp_prefix, F_OK) == 0)
3952 target_system_root = tmp_prefix;
3953 target_system_root_changed = 1;
3956 #endif
3958 /* More prefixes are enabled in main, after we read the specs file
3959 and determine whether this is cross-compilation or not. */
3961 if (n_infiles == last_language_n_infiles && spec_lang != 0)
3962 warning (0, "%<-x %s%> after last input file has no effect", spec_lang);
3964 if (compare_debug == 2 || compare_debug == 3)
3966 alloc_switch ();
3967 switches[n_switches].part1 = concat ("fcompare-debug=",
3968 compare_debug_opt,
3969 NULL);
3970 switches[n_switches].args = 0;
3971 switches[n_switches].live_cond = 0;
3972 switches[n_switches].validated = false;
3973 switches[n_switches].known = false;
3974 switches[n_switches].ordering = 0;
3975 n_switches++;
3976 compare_debug = 1;
3979 /* Ensure we only invoke each subprocess once. */
3980 if (print_subprocess_help || print_help_list || print_version)
3982 n_infiles = 0;
3984 /* Create a dummy input file, so that we can pass
3985 the help option on to the various sub-processes. */
3986 add_infile ("help-dummy", "c");
3989 alloc_switch ();
3990 switches[n_switches].part1 = 0;
3991 alloc_infile ();
3992 infiles[n_infiles].name = 0;
3995 /* Store switches not filtered out by %<S in spec in COLLECT_GCC_OPTIONS
3996 and place that in the environment. */
3998 static void
3999 set_collect_gcc_options (void)
4001 int i;
4002 int first_time;
4004 /* Build COLLECT_GCC_OPTIONS to have all of the options specified to
4005 the compiler. */
4006 obstack_grow (&collect_obstack, "COLLECT_GCC_OPTIONS=",
4007 sizeof ("COLLECT_GCC_OPTIONS=") - 1);
4009 first_time = TRUE;
4010 for (i = 0; (int) i < n_switches; i++)
4012 const char *const *args;
4013 const char *p, *q;
4014 if (!first_time)
4015 obstack_grow (&collect_obstack, " ", 1);
4017 first_time = FALSE;
4019 /* Ignore elided switches. */
4020 if ((switches[i].live_cond
4021 & (SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC))
4022 == SWITCH_IGNORE)
4023 continue;
4025 obstack_grow (&collect_obstack, "'-", 2);
4026 q = switches[i].part1;
4027 while ((p = strchr (q, '\'')))
4029 obstack_grow (&collect_obstack, q, p - q);
4030 obstack_grow (&collect_obstack, "'\\''", 4);
4031 q = ++p;
4033 obstack_grow (&collect_obstack, q, strlen (q));
4034 obstack_grow (&collect_obstack, "'", 1);
4036 for (args = switches[i].args; args && *args; args++)
4038 obstack_grow (&collect_obstack, " '", 2);
4039 q = *args;
4040 while ((p = strchr (q, '\'')))
4042 obstack_grow (&collect_obstack, q, p - q);
4043 obstack_grow (&collect_obstack, "'\\''", 4);
4044 q = ++p;
4046 obstack_grow (&collect_obstack, q, strlen (q));
4047 obstack_grow (&collect_obstack, "'", 1);
4050 obstack_grow (&collect_obstack, "\0", 1);
4051 xputenv (XOBFINISH (&collect_obstack, char *));
4054 /* Process a spec string, accumulating and running commands. */
4056 /* These variables describe the input file name.
4057 input_file_number is the index on outfiles of this file,
4058 so that the output file name can be stored for later use by %o.
4059 input_basename is the start of the part of the input file
4060 sans all directory names, and basename_length is the number
4061 of characters starting there excluding the suffix .c or whatever. */
4063 static const char *gcc_input_filename;
4064 static int input_file_number;
4065 size_t input_filename_length;
4066 static int basename_length;
4067 static int suffixed_basename_length;
4068 static const char *input_basename;
4069 static const char *input_suffix;
4070 #ifndef HOST_LACKS_INODE_NUMBERS
4071 static struct stat input_stat;
4072 #endif
4073 static int input_stat_set;
4075 /* The compiler used to process the current input file. */
4076 static struct compiler *input_file_compiler;
4078 /* These are variables used within do_spec and do_spec_1. */
4080 /* Nonzero if an arg has been started and not yet terminated
4081 (with space, tab or newline). */
4082 static int arg_going;
4084 /* Nonzero means %d or %g has been seen; the next arg to be terminated
4085 is a temporary file name. */
4086 static int delete_this_arg;
4088 /* Nonzero means %w has been seen; the next arg to be terminated
4089 is the output file name of this compilation. */
4090 static int this_is_output_file;
4092 /* Nonzero means %s has been seen; the next arg to be terminated
4093 is the name of a library file and we should try the standard
4094 search dirs for it. */
4095 static int this_is_library_file;
4097 /* Nonzero means %T has been seen; the next arg to be terminated
4098 is the name of a linker script and we should try all of the
4099 standard search dirs for it. If it is found insert a --script
4100 command line switch and then substitute the full path in place,
4101 otherwise generate an error message. */
4102 static int this_is_linker_script;
4104 /* Nonzero means that the input of this command is coming from a pipe. */
4105 static int input_from_pipe;
4107 /* Nonnull means substitute this for any suffix when outputting a switches
4108 arguments. */
4109 static const char *suffix_subst;
4111 /* If there is an argument being accumulated, terminate it and store it. */
4113 static void
4114 end_going_arg (void)
4116 if (arg_going)
4118 const char *string;
4120 obstack_1grow (&obstack, 0);
4121 string = XOBFINISH (&obstack, const char *);
4122 if (this_is_library_file)
4123 string = find_file (string);
4124 if (this_is_linker_script)
4126 char * full_script_path = find_a_file (&startfile_prefixes, string, R_OK, true);
4128 if (full_script_path == NULL)
4130 error ("unable to locate default linker script %qs in the library search paths", string);
4131 /* Script was not found on search path. */
4132 return;
4134 store_arg ("--script", false, false);
4135 string = full_script_path;
4137 store_arg (string, delete_this_arg, this_is_output_file);
4138 if (this_is_output_file)
4139 outfiles[input_file_number] = string;
4140 arg_going = 0;
4145 /* Parse the WRAPPER string which is a comma separated list of the command line
4146 and insert them into the beginning of argbuf. */
4148 static void
4149 insert_wrapper (const char *wrapper)
4151 int n = 0;
4152 int i;
4153 char *buf = xstrdup (wrapper);
4154 char *p = buf;
4155 unsigned int old_length = VEC_length (const_char_p, argbuf);
4159 n++;
4160 while (*p == ',')
4161 p++;
4163 while ((p = strchr (p, ',')) != NULL);
4165 VEC_safe_grow (const_char_p, heap, argbuf, old_length + n);
4166 memmove (VEC_address (const_char_p, argbuf) + n,
4167 VEC_address (const_char_p, argbuf),
4168 old_length * sizeof (const_char_p));
4170 i = 0;
4171 p = buf;
4174 while (*p == ',')
4176 *p = 0;
4177 p++;
4179 VEC_replace (const_char_p, argbuf, i, p);
4180 i++;
4182 while ((p = strchr (p, ',')) != NULL);
4183 gcc_assert (i == n);
4186 /* Process the spec SPEC and run the commands specified therein.
4187 Returns 0 if the spec is successfully processed; -1 if failed. */
4190 do_spec (const char *spec)
4192 int value;
4194 value = do_spec_2 (spec);
4196 /* Force out any unfinished command.
4197 If -pipe, this forces out the last command if it ended in `|'. */
4198 if (value == 0)
4200 if (VEC_length (const_char_p, argbuf) > 0
4201 && !strcmp (VEC_last (const_char_p, argbuf), "|"))
4202 VEC_pop (const_char_p, argbuf);
4204 set_collect_gcc_options ();
4206 if (VEC_length (const_char_p, argbuf) > 0)
4207 value = execute ();
4210 return value;
4213 static int
4214 do_spec_2 (const char *spec)
4216 int result;
4218 clear_args ();
4219 arg_going = 0;
4220 delete_this_arg = 0;
4221 this_is_output_file = 0;
4222 this_is_library_file = 0;
4223 this_is_linker_script = 0;
4224 input_from_pipe = 0;
4225 suffix_subst = NULL;
4227 result = do_spec_1 (spec, 0, NULL);
4229 end_going_arg ();
4231 return result;
4235 /* Process the given spec string and add any new options to the end
4236 of the switches/n_switches array. */
4238 static void
4239 do_option_spec (const char *name, const char *spec)
4241 unsigned int i, value_count, value_len;
4242 const char *p, *q, *value;
4243 char *tmp_spec, *tmp_spec_p;
4245 if (configure_default_options[0].name == NULL)
4246 return;
4248 for (i = 0; i < ARRAY_SIZE (configure_default_options); i++)
4249 if (strcmp (configure_default_options[i].name, name) == 0)
4250 break;
4251 if (i == ARRAY_SIZE (configure_default_options))
4252 return;
4254 value = configure_default_options[i].value;
4255 value_len = strlen (value);
4257 /* Compute the size of the final spec. */
4258 value_count = 0;
4259 p = spec;
4260 while ((p = strstr (p, "%(VALUE)")) != NULL)
4262 p ++;
4263 value_count ++;
4266 /* Replace each %(VALUE) by the specified value. */
4267 tmp_spec = (char *) alloca (strlen (spec) + 1
4268 + value_count * (value_len - strlen ("%(VALUE)")));
4269 tmp_spec_p = tmp_spec;
4270 q = spec;
4271 while ((p = strstr (q, "%(VALUE)")) != NULL)
4273 memcpy (tmp_spec_p, q, p - q);
4274 tmp_spec_p = tmp_spec_p + (p - q);
4275 memcpy (tmp_spec_p, value, value_len);
4276 tmp_spec_p += value_len;
4277 q = p + strlen ("%(VALUE)");
4279 strcpy (tmp_spec_p, q);
4281 do_self_spec (tmp_spec);
4284 /* Process the given spec string and add any new options to the end
4285 of the switches/n_switches array. */
4287 static void
4288 do_self_spec (const char *spec)
4290 int i;
4292 do_spec_2 (spec);
4293 do_spec_1 (" ", 0, NULL);
4295 /* Mark %<S switches processed by do_self_spec to be ignored permanently.
4296 do_self_specs adds the replacements to switches array, so it shouldn't
4297 be processed afterwards. */
4298 for (i = 0; i < n_switches; i++)
4299 if ((switches[i].live_cond & SWITCH_IGNORE))
4300 switches[i].live_cond |= SWITCH_IGNORE_PERMANENTLY;
4302 if (VEC_length (const_char_p, argbuf) > 0)
4304 const char **argbuf_copy;
4305 struct cl_decoded_option *decoded_options;
4306 struct cl_option_handlers handlers;
4307 unsigned int decoded_options_count;
4308 unsigned int j;
4310 /* Create a copy of argbuf with a dummy argv[0] entry for
4311 decode_cmdline_options_to_array. */
4312 argbuf_copy = XNEWVEC (const char *,
4313 VEC_length (const_char_p, argbuf) + 1);
4314 argbuf_copy[0] = "";
4315 memcpy (argbuf_copy + 1, VEC_address (const_char_p, argbuf),
4316 VEC_length (const_char_p, argbuf) * sizeof (const char *));
4318 decode_cmdline_options_to_array (VEC_length (const_char_p, argbuf) + 1,
4319 argbuf_copy,
4320 CL_DRIVER, &decoded_options,
4321 &decoded_options_count);
4323 set_option_handlers (&handlers);
4325 for (j = 1; j < decoded_options_count; j++)
4327 switch (decoded_options[j].opt_index)
4329 case OPT_SPECIAL_input_file:
4330 /* Specs should only generate options, not input
4331 files. */
4332 if (strcmp (decoded_options[j].arg, "-") != 0)
4333 fatal_error ("switch %qs does not start with %<-%>",
4334 decoded_options[j].arg);
4335 else
4336 fatal_error ("spec-generated switch is just %<-%>");
4337 break;
4339 case OPT_fcompare_debug_second:
4340 case OPT_fcompare_debug:
4341 case OPT_fcompare_debug_:
4342 case OPT_o:
4343 /* Avoid duplicate processing of some options from
4344 compare-debug specs; just save them here. */
4345 save_switch (decoded_options[j].canonical_option[0],
4346 (decoded_options[j].canonical_option_num_elements
4347 - 1),
4348 &decoded_options[j].canonical_option[1], false, true);
4349 break;
4351 default:
4352 read_cmdline_option (&global_options, &global_options_set,
4353 decoded_options + j, UNKNOWN_LOCATION,
4354 CL_DRIVER, &handlers, global_dc);
4355 break;
4359 alloc_switch ();
4360 switches[n_switches].part1 = 0;
4364 /* Callback for processing %D and %I specs. */
4366 struct spec_path_info {
4367 const char *option;
4368 const char *append;
4369 size_t append_len;
4370 bool omit_relative;
4371 bool separate_options;
4374 static void *
4375 spec_path (char *path, void *data)
4377 struct spec_path_info *info = (struct spec_path_info *) data;
4378 size_t len = 0;
4379 char save = 0;
4381 if (info->omit_relative && !IS_ABSOLUTE_PATH (path))
4382 return NULL;
4384 if (info->append_len != 0)
4386 len = strlen (path);
4387 memcpy (path + len, info->append, info->append_len + 1);
4390 if (!is_directory (path, true))
4391 return NULL;
4393 do_spec_1 (info->option, 1, NULL);
4394 if (info->separate_options)
4395 do_spec_1 (" ", 0, NULL);
4397 if (info->append_len == 0)
4399 len = strlen (path);
4400 save = path[len - 1];
4401 if (IS_DIR_SEPARATOR (path[len - 1]))
4402 path[len - 1] = '\0';
4405 do_spec_1 (path, 1, NULL);
4406 do_spec_1 (" ", 0, NULL);
4408 /* Must not damage the original path. */
4409 if (info->append_len == 0)
4410 path[len - 1] = save;
4412 return NULL;
4415 /* Create a temporary FILE with the contents of ARGV. Add @FILE to the
4416 argument list. */
4418 static void
4419 create_at_file (char **argv)
4421 char *temp_file = make_temp_file ("");
4422 char *at_argument = concat ("@", temp_file, NULL);
4423 FILE *f = fopen (temp_file, "w");
4424 int status;
4426 if (f == NULL)
4427 fatal_error ("could not open temporary response file %s",
4428 temp_file);
4430 status = writeargv (argv, f);
4432 if (status)
4433 fatal_error ("could not write to temporary response file %s",
4434 temp_file);
4436 status = fclose (f);
4438 if (EOF == status)
4439 fatal_error ("could not close temporary response file %s",
4440 temp_file);
4442 store_arg (at_argument, 0, 0);
4444 record_temp_file (temp_file, !save_temps_flag, !save_temps_flag);
4447 /* True if we should compile INFILE. */
4449 static bool
4450 compile_input_file_p (struct infile *infile)
4452 if ((!infile->language) || (infile->language[0] != '*'))
4453 if (infile->incompiler == input_file_compiler)
4454 return true;
4455 return false;
4458 /* Process each member of VEC as a spec. */
4460 static void
4461 do_specs_vec (VEC(char_p,heap) *vec)
4463 unsigned ix;
4464 char *opt;
4466 FOR_EACH_VEC_ELT (char_p, vec, ix, opt)
4468 do_spec_1 (opt, 1, NULL);
4469 /* Make each accumulated option a separate argument. */
4470 do_spec_1 (" ", 0, NULL);
4474 /* Process the sub-spec SPEC as a portion of a larger spec.
4475 This is like processing a whole spec except that we do
4476 not initialize at the beginning and we do not supply a
4477 newline by default at the end.
4478 INSWITCH nonzero means don't process %-sequences in SPEC;
4479 in this case, % is treated as an ordinary character.
4480 This is used while substituting switches.
4481 INSWITCH nonzero also causes SPC not to terminate an argument.
4483 Value is zero unless a line was finished
4484 and the command on that line reported an error. */
4486 static int
4487 do_spec_1 (const char *spec, int inswitch, const char *soft_matched_part)
4489 const char *p = spec;
4490 int c;
4491 int i;
4492 int value;
4494 /* If it's an empty string argument to a switch, keep it as is. */
4495 if (inswitch && !*p)
4496 arg_going = 1;
4498 while ((c = *p++))
4499 /* If substituting a switch, treat all chars like letters.
4500 Otherwise, NL, SPC, TAB and % are special. */
4501 switch (inswitch ? 'a' : c)
4503 case '\n':
4504 end_going_arg ();
4506 if (VEC_length (const_char_p, argbuf) > 0
4507 && !strcmp (VEC_last (const_char_p, argbuf), "|"))
4509 /* A `|' before the newline means use a pipe here,
4510 but only if -pipe was specified.
4511 Otherwise, execute now and don't pass the `|' as an arg. */
4512 if (use_pipes)
4514 input_from_pipe = 1;
4515 break;
4517 else
4518 VEC_pop (const_char_p, argbuf);
4521 set_collect_gcc_options ();
4523 if (VEC_length (const_char_p, argbuf) > 0)
4525 value = execute ();
4526 if (value)
4527 return value;
4529 /* Reinitialize for a new command, and for a new argument. */
4530 clear_args ();
4531 arg_going = 0;
4532 delete_this_arg = 0;
4533 this_is_output_file = 0;
4534 this_is_library_file = 0;
4535 this_is_linker_script = 0;
4536 input_from_pipe = 0;
4537 break;
4539 case '|':
4540 end_going_arg ();
4542 /* Use pipe */
4543 obstack_1grow (&obstack, c);
4544 arg_going = 1;
4545 break;
4547 case '\t':
4548 case ' ':
4549 end_going_arg ();
4551 /* Reinitialize for a new argument. */
4552 delete_this_arg = 0;
4553 this_is_output_file = 0;
4554 this_is_library_file = 0;
4555 this_is_linker_script = 0;
4556 break;
4558 case '%':
4559 switch (c = *p++)
4561 case 0:
4562 fatal_error ("spec %qs invalid", spec);
4564 case 'b':
4565 if (save_temps_length)
4566 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4567 else
4568 obstack_grow (&obstack, input_basename, basename_length);
4569 if (compare_debug < 0)
4570 obstack_grow (&obstack, ".gk", 3);
4571 arg_going = 1;
4572 break;
4574 case 'B':
4575 if (save_temps_length)
4576 obstack_grow (&obstack, save_temps_prefix, save_temps_length);
4577 else
4578 obstack_grow (&obstack, input_basename, suffixed_basename_length);
4579 if (compare_debug < 0)
4580 obstack_grow (&obstack, ".gk", 3);
4581 arg_going = 1;
4582 break;
4584 case 'd':
4585 delete_this_arg = 2;
4586 break;
4588 /* Dump out the directories specified with LIBRARY_PATH,
4589 followed by the absolute directories
4590 that we search for startfiles. */
4591 case 'D':
4593 struct spec_path_info info;
4595 info.option = "-L";
4596 info.append_len = 0;
4597 #ifdef RELATIVE_PREFIX_NOT_LINKDIR
4598 /* Used on systems which record the specified -L dirs
4599 and use them to search for dynamic linking.
4600 Relative directories always come from -B,
4601 and it is better not to use them for searching
4602 at run time. In particular, stage1 loses. */
4603 info.omit_relative = true;
4604 #else
4605 info.omit_relative = false;
4606 #endif
4607 info.separate_options = false;
4609 for_each_path (&startfile_prefixes, true, 0, spec_path, &info);
4611 break;
4613 case 'e':
4614 /* %efoo means report an error with `foo' as error message
4615 and don't execute any more commands for this file. */
4617 const char *q = p;
4618 char *buf;
4619 while (*p != 0 && *p != '\n')
4620 p++;
4621 buf = (char *) alloca (p - q + 1);
4622 strncpy (buf, q, p - q);
4623 buf[p - q] = 0;
4624 error ("%s", _(buf));
4625 return -1;
4627 break;
4628 case 'n':
4629 /* %nfoo means report a notice with `foo' on stderr. */
4631 const char *q = p;
4632 char *buf;
4633 while (*p != 0 && *p != '\n')
4634 p++;
4635 buf = (char *) alloca (p - q + 1);
4636 strncpy (buf, q, p - q);
4637 buf[p - q] = 0;
4638 inform (0, "%s", _(buf));
4639 if (*p)
4640 p++;
4642 break;
4644 case 'j':
4646 struct stat st;
4648 /* If save_temps_flag is off, and the HOST_BIT_BUCKET is
4649 defined, and it is not a directory, and it is
4650 writable, use it. Otherwise, treat this like any
4651 other temporary file. */
4653 if ((!save_temps_flag)
4654 && (stat (HOST_BIT_BUCKET, &st) == 0) && (!S_ISDIR (st.st_mode))
4655 && (access (HOST_BIT_BUCKET, W_OK) == 0))
4657 obstack_grow (&obstack, HOST_BIT_BUCKET,
4658 strlen (HOST_BIT_BUCKET));
4659 delete_this_arg = 0;
4660 arg_going = 1;
4661 break;
4664 goto create_temp_file;
4665 case '|':
4666 if (use_pipes)
4668 obstack_1grow (&obstack, '-');
4669 delete_this_arg = 0;
4670 arg_going = 1;
4672 /* consume suffix */
4673 while (*p == '.' || ISALNUM ((unsigned char) *p))
4674 p++;
4675 if (p[0] == '%' && p[1] == 'O')
4676 p += 2;
4678 break;
4680 goto create_temp_file;
4681 case 'm':
4682 if (use_pipes)
4684 /* consume suffix */
4685 while (*p == '.' || ISALNUM ((unsigned char) *p))
4686 p++;
4687 if (p[0] == '%' && p[1] == 'O')
4688 p += 2;
4690 break;
4692 goto create_temp_file;
4693 case 'g':
4694 case 'u':
4695 case 'U':
4696 create_temp_file:
4698 struct temp_name *t;
4699 int suffix_length;
4700 const char *suffix = p;
4701 char *saved_suffix = NULL;
4703 while (*p == '.' || ISALNUM ((unsigned char) *p))
4704 p++;
4705 suffix_length = p - suffix;
4706 if (p[0] == '%' && p[1] == 'O')
4708 p += 2;
4709 /* We don't support extra suffix characters after %O. */
4710 if (*p == '.' || ISALNUM ((unsigned char) *p))
4711 fatal_error ("spec %qs has invalid %<%%0%c%>", spec, *p);
4712 if (suffix_length == 0)
4713 suffix = TARGET_OBJECT_SUFFIX;
4714 else
4716 saved_suffix
4717 = XNEWVEC (char, suffix_length
4718 + strlen (TARGET_OBJECT_SUFFIX));
4719 strncpy (saved_suffix, suffix, suffix_length);
4720 strcpy (saved_suffix + suffix_length,
4721 TARGET_OBJECT_SUFFIX);
4723 suffix_length += strlen (TARGET_OBJECT_SUFFIX);
4726 if (compare_debug < 0)
4728 suffix = concat (".gk", suffix, NULL);
4729 suffix_length += 3;
4732 /* If -save-temps=obj and -o were specified, use that for the
4733 temp file. */
4734 if (save_temps_length)
4736 char *tmp;
4737 temp_filename_length
4738 = save_temps_length + suffix_length + 1;
4739 tmp = (char *) alloca (temp_filename_length);
4740 memcpy (tmp, save_temps_prefix, save_temps_length);
4741 memcpy (tmp + save_temps_length, suffix, suffix_length);
4742 tmp[save_temps_length + suffix_length] = '\0';
4743 temp_filename = save_string (tmp,
4744 temp_filename_length + 1);
4745 obstack_grow (&obstack, temp_filename,
4746 temp_filename_length);
4747 arg_going = 1;
4748 delete_this_arg = 0;
4749 break;
4752 /* If the gcc_input_filename has the same suffix specified
4753 for the %g, %u, or %U, and -save-temps is specified,
4754 we could end up using that file as an intermediate
4755 thus clobbering the user's source file (.e.g.,
4756 gcc -save-temps foo.s would clobber foo.s with the
4757 output of cpp0). So check for this condition and
4758 generate a temp file as the intermediate. */
4760 if (save_temps_flag)
4762 char *tmp;
4763 temp_filename_length = basename_length + suffix_length + 1;
4764 tmp = (char *) alloca (temp_filename_length);
4765 memcpy (tmp, input_basename, basename_length);
4766 memcpy (tmp + basename_length, suffix, suffix_length);
4767 tmp[basename_length + suffix_length] = '\0';
4768 temp_filename = tmp;
4770 if (filename_cmp (temp_filename, gcc_input_filename) != 0)
4772 #ifndef HOST_LACKS_INODE_NUMBERS
4773 struct stat st_temp;
4775 /* Note, set_input() resets input_stat_set to 0. */
4776 if (input_stat_set == 0)
4778 input_stat_set = stat (gcc_input_filename,
4779 &input_stat);
4780 if (input_stat_set >= 0)
4781 input_stat_set = 1;
4784 /* If we have the stat for the gcc_input_filename
4785 and we can do the stat for the temp_filename
4786 then the they could still refer to the same
4787 file if st_dev/st_ino's are the same. */
4788 if (input_stat_set != 1
4789 || stat (temp_filename, &st_temp) < 0
4790 || input_stat.st_dev != st_temp.st_dev
4791 || input_stat.st_ino != st_temp.st_ino)
4792 #else
4793 /* Just compare canonical pathnames. */
4794 char* input_realname = lrealpath (gcc_input_filename);
4795 char* temp_realname = lrealpath (temp_filename);
4796 bool files_differ = filename_cmp (input_realname, temp_realname);
4797 free (input_realname);
4798 free (temp_realname);
4799 if (files_differ)
4800 #endif
4802 temp_filename = save_string (temp_filename,
4803 temp_filename_length + 1);
4804 obstack_grow (&obstack, temp_filename,
4805 temp_filename_length);
4806 arg_going = 1;
4807 delete_this_arg = 0;
4808 break;
4813 /* See if we already have an association of %g/%u/%U and
4814 suffix. */
4815 for (t = temp_names; t; t = t->next)
4816 if (t->length == suffix_length
4817 && strncmp (t->suffix, suffix, suffix_length) == 0
4818 && t->unique == (c == 'u' || c == 'U' || c == 'j'))
4819 break;
4821 /* Make a new association if needed. %u and %j
4822 require one. */
4823 if (t == 0 || c == 'u' || c == 'j')
4825 if (t == 0)
4827 t = XNEW (struct temp_name);
4828 t->next = temp_names;
4829 temp_names = t;
4831 t->length = suffix_length;
4832 if (saved_suffix)
4834 t->suffix = saved_suffix;
4835 saved_suffix = NULL;
4837 else
4838 t->suffix = save_string (suffix, suffix_length);
4839 t->unique = (c == 'u' || c == 'U' || c == 'j');
4840 temp_filename = make_temp_file (t->suffix);
4841 temp_filename_length = strlen (temp_filename);
4842 t->filename = temp_filename;
4843 t->filename_length = temp_filename_length;
4846 free (saved_suffix);
4848 obstack_grow (&obstack, t->filename, t->filename_length);
4849 delete_this_arg = 1;
4851 arg_going = 1;
4852 break;
4854 case 'i':
4855 if (combine_inputs)
4857 if (at_file_supplied)
4859 /* We are going to expand `%i' to `@FILE', where FILE
4860 is a newly-created temporary filename. The filenames
4861 that would usually be expanded in place of %o will be
4862 written to the temporary file. */
4863 char **argv;
4864 int n_files = 0;
4865 int j;
4867 for (i = 0; i < n_infiles; i++)
4868 if (compile_input_file_p (&infiles[i]))
4869 n_files++;
4871 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
4873 /* Copy the strings over. */
4874 for (i = 0, j = 0; i < n_infiles; i++)
4875 if (compile_input_file_p (&infiles[i]))
4877 argv[j] = CONST_CAST (char *, infiles[i].name);
4878 infiles[i].compiled = true;
4879 j++;
4881 argv[j] = NULL;
4883 create_at_file (argv);
4885 else
4886 for (i = 0; (int) i < n_infiles; i++)
4887 if (compile_input_file_p (&infiles[i]))
4889 store_arg (infiles[i].name, 0, 0);
4890 infiles[i].compiled = true;
4893 else
4895 obstack_grow (&obstack, gcc_input_filename,
4896 input_filename_length);
4897 arg_going = 1;
4899 break;
4901 case 'I':
4903 struct spec_path_info info;
4905 if (multilib_dir)
4907 do_spec_1 ("-imultilib", 1, NULL);
4908 /* Make this a separate argument. */
4909 do_spec_1 (" ", 0, NULL);
4910 do_spec_1 (multilib_dir, 1, NULL);
4911 do_spec_1 (" ", 0, NULL);
4914 if (gcc_exec_prefix)
4916 do_spec_1 ("-iprefix", 1, NULL);
4917 /* Make this a separate argument. */
4918 do_spec_1 (" ", 0, NULL);
4919 do_spec_1 (gcc_exec_prefix, 1, NULL);
4920 do_spec_1 (" ", 0, NULL);
4923 if (target_system_root_changed ||
4924 (target_system_root && target_sysroot_hdrs_suffix))
4926 do_spec_1 ("-isysroot", 1, NULL);
4927 /* Make this a separate argument. */
4928 do_spec_1 (" ", 0, NULL);
4929 do_spec_1 (target_system_root, 1, NULL);
4930 if (target_sysroot_hdrs_suffix)
4931 do_spec_1 (target_sysroot_hdrs_suffix, 1, NULL);
4932 do_spec_1 (" ", 0, NULL);
4935 info.option = "-isystem";
4936 info.append = "include";
4937 info.append_len = strlen (info.append);
4938 info.omit_relative = false;
4939 info.separate_options = true;
4941 for_each_path (&include_prefixes, false, info.append_len,
4942 spec_path, &info);
4944 info.append = "include-fixed";
4945 if (*sysroot_hdrs_suffix_spec)
4946 info.append = concat (info.append, dir_separator_str,
4947 multilib_dir, NULL);
4948 info.append_len = strlen (info.append);
4949 for_each_path (&include_prefixes, false, info.append_len,
4950 spec_path, &info);
4952 break;
4954 case 'o':
4956 int max = n_infiles;
4957 max += lang_specific_extra_outfiles;
4959 if (HAVE_GNU_LD && at_file_supplied)
4961 /* We are going to expand `%o' to `@FILE', where FILE
4962 is a newly-created temporary filename. The filenames
4963 that would usually be expanded in place of %o will be
4964 written to the temporary file. */
4966 char **argv;
4967 int n_files, j;
4969 /* Convert OUTFILES into a form suitable for writeargv. */
4971 /* Determine how many are non-NULL. */
4972 for (n_files = 0, i = 0; i < max; i++)
4973 n_files += outfiles[i] != NULL;
4975 argv = (char **) alloca (sizeof (char *) * (n_files + 1));
4977 /* Copy the strings over. */
4978 for (i = 0, j = 0; i < max; i++)
4979 if (outfiles[i])
4981 argv[j] = CONST_CAST (char *, outfiles[i]);
4982 j++;
4984 argv[j] = NULL;
4986 create_at_file (argv);
4988 else
4989 for (i = 0; i < max; i++)
4990 if (outfiles[i])
4991 store_arg (outfiles[i], 0, 0);
4992 break;
4995 case 'O':
4996 obstack_grow (&obstack, TARGET_OBJECT_SUFFIX, strlen (TARGET_OBJECT_SUFFIX));
4997 arg_going = 1;
4998 break;
5000 case 's':
5001 this_is_library_file = 1;
5002 break;
5004 case 'T':
5005 this_is_linker_script = 1;
5006 break;
5008 case 'V':
5009 outfiles[input_file_number] = NULL;
5010 break;
5012 case 'w':
5013 this_is_output_file = 1;
5014 break;
5016 case 'W':
5018 unsigned int cur_index = VEC_length (const_char_p, argbuf);
5019 /* Handle the {...} following the %W. */
5020 if (*p != '{')
5021 fatal_error ("spec %qs has invalid %<%%W%c%>", spec, *p);
5022 p = handle_braces (p + 1);
5023 if (p == 0)
5024 return -1;
5025 end_going_arg ();
5026 /* If any args were output, mark the last one for deletion
5027 on failure. */
5028 if (VEC_length (const_char_p, argbuf) != cur_index)
5029 record_temp_file (VEC_last (const_char_p, argbuf), 0, 1);
5030 break;
5033 /* %x{OPTION} records OPTION for %X to output. */
5034 case 'x':
5036 const char *p1 = p;
5037 char *string;
5038 char *opt;
5039 unsigned ix;
5041 /* Skip past the option value and make a copy. */
5042 if (*p != '{')
5043 fatal_error ("spec %qs has invalid %<%%x%c%>", spec, *p);
5044 while (*p++ != '}')
5046 string = save_string (p1 + 1, p - p1 - 2);
5048 /* See if we already recorded this option. */
5049 FOR_EACH_VEC_ELT (char_p, linker_options, ix, opt)
5050 if (! strcmp (string, opt))
5052 free (string);
5053 return 0;
5056 /* This option is new; add it. */
5057 add_linker_option (string, strlen (string));
5059 break;
5061 /* Dump out the options accumulated previously using %x. */
5062 case 'X':
5063 do_specs_vec (linker_options);
5064 break;
5066 /* Dump out the options accumulated previously using -Wa,. */
5067 case 'Y':
5068 do_specs_vec (assembler_options);
5069 break;
5071 /* Dump out the options accumulated previously using -Wp,. */
5072 case 'Z':
5073 do_specs_vec (preprocessor_options);
5074 break;
5076 /* Here are digits and numbers that just process
5077 a certain constant string as a spec. */
5079 case '1':
5080 value = do_spec_1 (cc1_spec, 0, NULL);
5081 if (value != 0)
5082 return value;
5083 break;
5085 case '2':
5086 value = do_spec_1 (cc1plus_spec, 0, NULL);
5087 if (value != 0)
5088 return value;
5089 break;
5091 case 'a':
5092 value = do_spec_1 (asm_spec, 0, NULL);
5093 if (value != 0)
5094 return value;
5095 break;
5097 case 'A':
5098 value = do_spec_1 (asm_final_spec, 0, NULL);
5099 if (value != 0)
5100 return value;
5101 break;
5103 case 'C':
5105 const char *const spec
5106 = (input_file_compiler->cpp_spec
5107 ? input_file_compiler->cpp_spec
5108 : cpp_spec);
5109 value = do_spec_1 (spec, 0, NULL);
5110 if (value != 0)
5111 return value;
5113 break;
5115 case 'E':
5116 value = do_spec_1 (endfile_spec, 0, NULL);
5117 if (value != 0)
5118 return value;
5119 break;
5121 case 'l':
5122 value = do_spec_1 (link_spec, 0, NULL);
5123 if (value != 0)
5124 return value;
5125 break;
5127 case 'L':
5128 value = do_spec_1 (lib_spec, 0, NULL);
5129 if (value != 0)
5130 return value;
5131 break;
5133 case 'M':
5134 if (multilib_os_dir == NULL)
5135 obstack_1grow (&obstack, '.');
5136 else
5137 obstack_grow (&obstack, multilib_os_dir,
5138 strlen (multilib_os_dir));
5139 break;
5141 case 'G':
5142 value = do_spec_1 (libgcc_spec, 0, NULL);
5143 if (value != 0)
5144 return value;
5145 break;
5147 case 'R':
5148 /* We assume there is a directory
5149 separator at the end of this string. */
5150 if (target_system_root)
5152 obstack_grow (&obstack, target_system_root,
5153 strlen (target_system_root));
5154 if (target_sysroot_suffix)
5155 obstack_grow (&obstack, target_sysroot_suffix,
5156 strlen (target_sysroot_suffix));
5158 break;
5160 case 'S':
5161 value = do_spec_1 (startfile_spec, 0, NULL);
5162 if (value != 0)
5163 return value;
5164 break;
5166 /* Here we define characters other than letters and digits. */
5168 case '{':
5169 p = handle_braces (p);
5170 if (p == 0)
5171 return -1;
5172 break;
5174 case ':':
5175 p = handle_spec_function (p);
5176 if (p == 0)
5177 return -1;
5178 break;
5180 case '%':
5181 obstack_1grow (&obstack, '%');
5182 break;
5184 case '.':
5186 unsigned len = 0;
5188 while (p[len] && p[len] != ' ' && p[len] != '%')
5189 len++;
5190 suffix_subst = save_string (p - 1, len + 1);
5191 p += len;
5193 break;
5195 /* Henceforth ignore the option(s) matching the pattern
5196 after the %<. */
5197 case '<':
5198 case '>':
5200 unsigned len = 0;
5201 int have_wildcard = 0;
5202 int i;
5203 int switch_option;
5205 if (c == '>')
5206 switch_option = SWITCH_IGNORE | SWITCH_KEEP_FOR_GCC;
5207 else
5208 switch_option = SWITCH_IGNORE;
5210 while (p[len] && p[len] != ' ' && p[len] != '\t')
5211 len++;
5213 if (p[len-1] == '*')
5214 have_wildcard = 1;
5216 for (i = 0; i < n_switches; i++)
5217 if (!strncmp (switches[i].part1, p, len - have_wildcard)
5218 && (have_wildcard || switches[i].part1[len] == '\0'))
5220 switches[i].live_cond |= switch_option;
5221 /* User switch be validated from validate_all_switches.
5222 when the definition is seen from the spec file.
5223 If not defined anywhere, will be rejected. */
5224 if (switches[i].known)
5225 switches[i].validated = true;
5228 p += len;
5230 break;
5232 case '*':
5233 if (soft_matched_part)
5235 if (soft_matched_part[0])
5236 do_spec_1 (soft_matched_part, 1, NULL);
5237 do_spec_1 (" ", 0, NULL);
5239 else
5240 /* Catch the case where a spec string contains something like
5241 '%{foo:%*}'. i.e. there is no * in the pattern on the left
5242 hand side of the :. */
5243 error ("spec failure: %<%%*%> has not been initialized by pattern match");
5244 break;
5246 /* Process a string found as the value of a spec given by name.
5247 This feature allows individual machine descriptions
5248 to add and use their own specs. */
5249 case '(':
5251 const char *name = p;
5252 struct spec_list *sl;
5253 int len;
5255 /* The string after the S/P is the name of a spec that is to be
5256 processed. */
5257 while (*p && *p != ')')
5258 p++;
5260 /* See if it's in the list. */
5261 for (len = p - name, sl = specs; sl; sl = sl->next)
5262 if (sl->name_len == len && !strncmp (sl->name, name, len))
5264 name = *(sl->ptr_spec);
5265 #ifdef DEBUG_SPECS
5266 fnotice (stderr, "Processing spec (%s), which is '%s'\n",
5267 sl->name, name);
5268 #endif
5269 break;
5272 if (sl)
5274 value = do_spec_1 (name, 0, NULL);
5275 if (value != 0)
5276 return value;
5279 /* Discard the closing paren. */
5280 if (*p)
5281 p++;
5283 break;
5285 default:
5286 error ("spec failure: unrecognized spec option %qc", c);
5287 break;
5289 break;
5291 case '\\':
5292 /* Backslash: treat next character as ordinary. */
5293 c = *p++;
5295 /* Fall through. */
5296 default:
5297 /* Ordinary character: put it into the current argument. */
5298 obstack_1grow (&obstack, c);
5299 arg_going = 1;
5302 /* End of string. If we are processing a spec function, we need to
5303 end any pending argument. */
5304 if (processing_spec_function)
5305 end_going_arg ();
5307 return 0;
5310 /* Look up a spec function. */
5312 static const struct spec_function *
5313 lookup_spec_function (const char *name)
5315 const struct spec_function *sf;
5317 for (sf = static_spec_functions; sf->name != NULL; sf++)
5318 if (strcmp (sf->name, name) == 0)
5319 return sf;
5321 return NULL;
5324 /* Evaluate a spec function. */
5326 static const char *
5327 eval_spec_function (const char *func, const char *args)
5329 const struct spec_function *sf;
5330 const char *funcval;
5332 /* Saved spec processing context. */
5333 VEC(const_char_p,heap) *save_argbuf;
5335 int save_arg_going;
5336 int save_delete_this_arg;
5337 int save_this_is_output_file;
5338 int save_this_is_library_file;
5339 int save_input_from_pipe;
5340 int save_this_is_linker_script;
5341 const char *save_suffix_subst;
5343 int save_growing_size;
5344 void *save_growing_value;
5346 sf = lookup_spec_function (func);
5347 if (sf == NULL)
5348 fatal_error ("unknown spec function %qs", func);
5350 /* Push the spec processing context. */
5351 save_argbuf = argbuf;
5353 save_arg_going = arg_going;
5354 save_delete_this_arg = delete_this_arg;
5355 save_this_is_output_file = this_is_output_file;
5356 save_this_is_library_file = this_is_library_file;
5357 save_this_is_linker_script = this_is_linker_script;
5358 save_input_from_pipe = input_from_pipe;
5359 save_suffix_subst = suffix_subst;
5361 /* If we have some object growing now, finalize it so the args and function
5362 eval proceed from a cleared context. This is needed to prevent the first
5363 constructed arg from mistakenly including the growing value. We'll push
5364 this value back on the obstack once the function evaluation is done, to
5365 restore a consistent processing context for our caller. This is fine as
5366 the address of growing objects isn't guaranteed to remain stable until
5367 they are finalized, and we expect this situation to be rare enough for
5368 the extra copy not to be an issue. */
5369 save_growing_size = obstack_object_size (&obstack);
5370 if (save_growing_size > 0)
5371 save_growing_value = obstack_finish (&obstack);
5373 /* Create a new spec processing context, and build the function
5374 arguments. */
5376 alloc_args ();
5377 if (do_spec_2 (args) < 0)
5378 fatal_error ("error in args to spec function %qs", func);
5380 /* argbuf_index is an index for the next argument to be inserted, and
5381 so contains the count of the args already inserted. */
5383 funcval = (*sf->func) (VEC_length (const_char_p, argbuf),
5384 VEC_address (const_char_p, argbuf));
5386 /* Pop the spec processing context. */
5387 VEC_free (const_char_p, heap, argbuf);
5388 argbuf = save_argbuf;
5390 arg_going = save_arg_going;
5391 delete_this_arg = save_delete_this_arg;
5392 this_is_output_file = save_this_is_output_file;
5393 this_is_library_file = save_this_is_library_file;
5394 this_is_linker_script = save_this_is_linker_script;
5395 input_from_pipe = save_input_from_pipe;
5396 suffix_subst = save_suffix_subst;
5398 if (save_growing_size > 0)
5399 obstack_grow (&obstack, save_growing_value, save_growing_size);
5401 return funcval;
5404 /* Handle a spec function call of the form:
5406 %:function(args)
5408 ARGS is processed as a spec in a separate context and split into an
5409 argument vector in the normal fashion. The function returns a string
5410 containing a spec which we then process in the caller's context, or
5411 NULL if no processing is required. */
5413 static const char *
5414 handle_spec_function (const char *p)
5416 char *func, *args;
5417 const char *endp, *funcval;
5418 int count;
5420 processing_spec_function++;
5422 /* Get the function name. */
5423 for (endp = p; *endp != '\0'; endp++)
5425 if (*endp == '(') /* ) */
5426 break;
5427 /* Only allow [A-Za-z0-9], -, and _ in function names. */
5428 if (!ISALNUM (*endp) && !(*endp == '-' || *endp == '_'))
5429 fatal_error ("malformed spec function name");
5431 if (*endp != '(') /* ) */
5432 fatal_error ("no arguments for spec function");
5433 func = save_string (p, endp - p);
5434 p = ++endp;
5436 /* Get the arguments. */
5437 for (count = 0; *endp != '\0'; endp++)
5439 /* ( */
5440 if (*endp == ')')
5442 if (count == 0)
5443 break;
5444 count--;
5446 else if (*endp == '(') /* ) */
5447 count++;
5449 /* ( */
5450 if (*endp != ')')
5451 fatal_error ("malformed spec function arguments");
5452 args = save_string (p, endp - p);
5453 p = ++endp;
5455 /* p now points to just past the end of the spec function expression. */
5457 funcval = eval_spec_function (func, args);
5458 if (funcval != NULL && do_spec_1 (funcval, 0, NULL) < 0)
5459 p = NULL;
5461 free (func);
5462 free (args);
5464 processing_spec_function--;
5466 return p;
5469 /* Inline subroutine of handle_braces. Returns true if the current
5470 input suffix matches the atom bracketed by ATOM and END_ATOM. */
5471 static inline bool
5472 input_suffix_matches (const char *atom, const char *end_atom)
5474 return (input_suffix
5475 && !strncmp (input_suffix, atom, end_atom - atom)
5476 && input_suffix[end_atom - atom] == '\0');
5479 /* Subroutine of handle_braces. Returns true if the current
5480 input file's spec name matches the atom bracketed by ATOM and END_ATOM. */
5481 static bool
5482 input_spec_matches (const char *atom, const char *end_atom)
5484 return (input_file_compiler
5485 && input_file_compiler->suffix
5486 && input_file_compiler->suffix[0] != '\0'
5487 && !strncmp (input_file_compiler->suffix + 1, atom,
5488 end_atom - atom)
5489 && input_file_compiler->suffix[end_atom - atom + 1] == '\0');
5492 /* Subroutine of handle_braces. Returns true if a switch
5493 matching the atom bracketed by ATOM and END_ATOM appeared on the
5494 command line. */
5495 static bool
5496 switch_matches (const char *atom, const char *end_atom, int starred)
5498 int i;
5499 int len = end_atom - atom;
5500 int plen = starred ? len : -1;
5502 for (i = 0; i < n_switches; i++)
5503 if (!strncmp (switches[i].part1, atom, len)
5504 && (starred || switches[i].part1[len] == '\0')
5505 && check_live_switch (i, plen))
5506 return true;
5508 /* Check if a switch with separated form matching the atom.
5509 We check -D and -U switches. */
5510 else if (switches[i].args != 0)
5512 if ((*switches[i].part1 == 'D' || *switches[i].part1 == 'U')
5513 && *switches[i].part1 == atom[0])
5515 if (!strncmp (switches[i].args[0], &atom[1], len - 1)
5516 && (starred || (switches[i].part1[1] == '\0'
5517 && switches[i].args[0][len - 1] == '\0'))
5518 && check_live_switch (i, (starred ? 1 : -1)))
5519 return true;
5523 return false;
5526 /* Inline subroutine of handle_braces. Mark all of the switches which
5527 match ATOM (extends to END_ATOM; STARRED indicates whether there
5528 was a star after the atom) for later processing. */
5529 static inline void
5530 mark_matching_switches (const char *atom, const char *end_atom, int starred)
5532 int i;
5533 int len = end_atom - atom;
5534 int plen = starred ? len : -1;
5536 for (i = 0; i < n_switches; i++)
5537 if (!strncmp (switches[i].part1, atom, len)
5538 && (starred || switches[i].part1[len] == '\0')
5539 && check_live_switch (i, plen))
5540 switches[i].ordering = 1;
5543 /* Inline subroutine of handle_braces. Process all the currently
5544 marked switches through give_switch, and clear the marks. */
5545 static inline void
5546 process_marked_switches (void)
5548 int i;
5550 for (i = 0; i < n_switches; i++)
5551 if (switches[i].ordering == 1)
5553 switches[i].ordering = 0;
5554 give_switch (i, 0);
5558 /* Handle a %{ ... } construct. P points just inside the leading {.
5559 Returns a pointer one past the end of the brace block, or 0
5560 if we call do_spec_1 and that returns -1. */
5562 static const char *
5563 handle_braces (const char *p)
5565 const char *atom, *end_atom;
5566 const char *d_atom = NULL, *d_end_atom = NULL;
5567 const char *orig = p;
5569 bool a_is_suffix;
5570 bool a_is_spectype;
5571 bool a_is_starred;
5572 bool a_is_negated;
5573 bool a_matched;
5575 bool a_must_be_last = false;
5576 bool ordered_set = false;
5577 bool disjunct_set = false;
5578 bool disj_matched = false;
5579 bool disj_starred = true;
5580 bool n_way_choice = false;
5581 bool n_way_matched = false;
5583 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
5587 if (a_must_be_last)
5588 goto invalid;
5590 /* Scan one "atom" (S in the description above of %{}, possibly
5591 with '!', '.', '@', ',', or '*' modifiers). */
5592 a_matched = false;
5593 a_is_suffix = false;
5594 a_is_starred = false;
5595 a_is_negated = false;
5596 a_is_spectype = false;
5598 SKIP_WHITE();
5599 if (*p == '!')
5600 p++, a_is_negated = true;
5602 SKIP_WHITE();
5603 if (*p == '.')
5604 p++, a_is_suffix = true;
5605 else if (*p == ',')
5606 p++, a_is_spectype = true;
5608 atom = p;
5609 while (ISIDNUM(*p) || *p == '-' || *p == '+' || *p == '='
5610 || *p == ',' || *p == '.' || *p == '@')
5611 p++;
5612 end_atom = p;
5614 if (*p == '*')
5615 p++, a_is_starred = 1;
5617 SKIP_WHITE();
5618 switch (*p)
5620 case '&': case '}':
5621 /* Substitute the switch(es) indicated by the current atom. */
5622 ordered_set = true;
5623 if (disjunct_set || n_way_choice || a_is_negated || a_is_suffix
5624 || a_is_spectype || atom == end_atom)
5625 goto invalid;
5627 mark_matching_switches (atom, end_atom, a_is_starred);
5629 if (*p == '}')
5630 process_marked_switches ();
5631 break;
5633 case '|': case ':':
5634 /* Substitute some text if the current atom appears as a switch
5635 or suffix. */
5636 disjunct_set = true;
5637 if (ordered_set)
5638 goto invalid;
5640 if (atom == end_atom)
5642 if (!n_way_choice || disj_matched || *p == '|'
5643 || a_is_negated || a_is_suffix || a_is_spectype
5644 || a_is_starred)
5645 goto invalid;
5647 /* An empty term may appear as the last choice of an
5648 N-way choice set; it means "otherwise". */
5649 a_must_be_last = true;
5650 disj_matched = !n_way_matched;
5651 disj_starred = false;
5653 else
5655 if ((a_is_suffix || a_is_spectype) && a_is_starred)
5656 goto invalid;
5658 if (!a_is_starred)
5659 disj_starred = false;
5661 /* Don't bother testing this atom if we already have a
5662 match. */
5663 if (!disj_matched && !n_way_matched)
5665 if (a_is_suffix)
5666 a_matched = input_suffix_matches (atom, end_atom);
5667 else if (a_is_spectype)
5668 a_matched = input_spec_matches (atom, end_atom);
5669 else
5670 a_matched = switch_matches (atom, end_atom, a_is_starred);
5672 if (a_matched != a_is_negated)
5674 disj_matched = true;
5675 d_atom = atom;
5676 d_end_atom = end_atom;
5681 if (*p == ':')
5683 /* Found the body, that is, the text to substitute if the
5684 current disjunction matches. */
5685 p = process_brace_body (p + 1, d_atom, d_end_atom, disj_starred,
5686 disj_matched && !n_way_matched);
5687 if (p == 0)
5688 return 0;
5690 /* If we have an N-way choice, reset state for the next
5691 disjunction. */
5692 if (*p == ';')
5694 n_way_choice = true;
5695 n_way_matched |= disj_matched;
5696 disj_matched = false;
5697 disj_starred = true;
5698 d_atom = d_end_atom = NULL;
5701 break;
5703 default:
5704 goto invalid;
5707 while (*p++ != '}');
5709 return p;
5711 invalid:
5712 fatal_error ("braced spec %qs is invalid at %qc", orig, *p);
5714 #undef SKIP_WHITE
5717 /* Subroutine of handle_braces. Scan and process a brace substitution body
5718 (X in the description of %{} syntax). P points one past the colon;
5719 ATOM and END_ATOM bracket the first atom which was found to be true
5720 (present) in the current disjunction; STARRED indicates whether all
5721 the atoms in the current disjunction were starred (for syntax validation);
5722 MATCHED indicates whether the disjunction matched or not, and therefore
5723 whether or not the body is to be processed through do_spec_1 or just
5724 skipped. Returns a pointer to the closing } or ;, or 0 if do_spec_1
5725 returns -1. */
5727 static const char *
5728 process_brace_body (const char *p, const char *atom, const char *end_atom,
5729 int starred, int matched)
5731 const char *body, *end_body;
5732 unsigned int nesting_level;
5733 bool have_subst = false;
5735 /* Locate the closing } or ;, honoring nested braces.
5736 Trim trailing whitespace. */
5737 body = p;
5738 nesting_level = 1;
5739 for (;;)
5741 if (*p == '{')
5742 nesting_level++;
5743 else if (*p == '}')
5745 if (!--nesting_level)
5746 break;
5748 else if (*p == ';' && nesting_level == 1)
5749 break;
5750 else if (*p == '%' && p[1] == '*' && nesting_level == 1)
5751 have_subst = true;
5752 else if (*p == '\0')
5753 goto invalid;
5754 p++;
5757 end_body = p;
5758 while (end_body[-1] == ' ' || end_body[-1] == '\t')
5759 end_body--;
5761 if (have_subst && !starred)
5762 goto invalid;
5764 if (matched)
5766 /* Copy the substitution body to permanent storage and execute it.
5767 If have_subst is false, this is a simple matter of running the
5768 body through do_spec_1... */
5769 char *string = save_string (body, end_body - body);
5770 if (!have_subst)
5772 if (do_spec_1 (string, 0, NULL) < 0)
5773 return 0;
5775 else
5777 /* ... but if have_subst is true, we have to process the
5778 body once for each matching switch, with %* set to the
5779 variant part of the switch. */
5780 unsigned int hard_match_len = end_atom - atom;
5781 int i;
5783 for (i = 0; i < n_switches; i++)
5784 if (!strncmp (switches[i].part1, atom, hard_match_len)
5785 && check_live_switch (i, hard_match_len))
5787 if (do_spec_1 (string, 0,
5788 &switches[i].part1[hard_match_len]) < 0)
5789 return 0;
5790 /* Pass any arguments this switch has. */
5791 give_switch (i, 1);
5792 suffix_subst = NULL;
5797 return p;
5799 invalid:
5800 fatal_error ("braced spec body %qs is invalid", body);
5803 /* Return 0 iff switch number SWITCHNUM is obsoleted by a later switch
5804 on the command line. PREFIX_LENGTH is the length of XXX in an {XXX*}
5805 spec, or -1 if either exact match or %* is used.
5807 A -O switch is obsoleted by a later -O switch. A -f, -m, or -W switch
5808 whose value does not begin with "no-" is obsoleted by the same value
5809 with the "no-", similarly for a switch with the "no-" prefix. */
5811 static int
5812 check_live_switch (int switchnum, int prefix_length)
5814 const char *name = switches[switchnum].part1;
5815 int i;
5817 /* If we already processed this switch and determined if it was
5818 live or not, return our past determination. */
5819 if (switches[switchnum].live_cond != 0)
5820 return ((switches[switchnum].live_cond & SWITCH_LIVE) != 0
5821 && (switches[switchnum].live_cond & SWITCH_FALSE) == 0
5822 && (switches[switchnum].live_cond & SWITCH_IGNORE_PERMANENTLY)
5823 == 0);
5825 /* In the common case of {<at-most-one-letter>*}, a negating
5826 switch would always match, so ignore that case. We will just
5827 send the conflicting switches to the compiler phase. */
5828 if (prefix_length >= 0 && prefix_length <= 1)
5829 return 1;
5831 /* Now search for duplicate in a manner that depends on the name. */
5832 switch (*name)
5834 case 'O':
5835 for (i = switchnum + 1; i < n_switches; i++)
5836 if (switches[i].part1[0] == 'O')
5838 switches[switchnum].validated = true;
5839 switches[switchnum].live_cond = SWITCH_FALSE;
5840 return 0;
5842 break;
5844 case 'W': case 'f': case 'm':
5845 if (! strncmp (name + 1, "no-", 3))
5847 /* We have Xno-YYY, search for XYYY. */
5848 for (i = switchnum + 1; i < n_switches; i++)
5849 if (switches[i].part1[0] == name[0]
5850 && ! strcmp (&switches[i].part1[1], &name[4]))
5852 /* --specs are validated with the validate_switches mechanism. */
5853 if (switches[switchnum].known)
5854 switches[switchnum].validated = true;
5855 switches[switchnum].live_cond = SWITCH_FALSE;
5856 return 0;
5859 else
5861 /* We have XYYY, search for Xno-YYY. */
5862 for (i = switchnum + 1; i < n_switches; i++)
5863 if (switches[i].part1[0] == name[0]
5864 && switches[i].part1[1] == 'n'
5865 && switches[i].part1[2] == 'o'
5866 && switches[i].part1[3] == '-'
5867 && !strcmp (&switches[i].part1[4], &name[1]))
5869 /* --specs are validated with the validate_switches mechanism. */
5870 if (switches[switchnum].known)
5871 switches[switchnum].validated = true;
5872 switches[switchnum].live_cond = SWITCH_FALSE;
5873 return 0;
5876 break;
5879 /* Otherwise the switch is live. */
5880 switches[switchnum].live_cond |= SWITCH_LIVE;
5881 return 1;
5884 /* Pass a switch to the current accumulating command
5885 in the same form that we received it.
5886 SWITCHNUM identifies the switch; it is an index into
5887 the vector of switches gcc received, which is `switches'.
5888 This cannot fail since it never finishes a command line.
5890 If OMIT_FIRST_WORD is nonzero, then we omit .part1 of the argument. */
5892 static void
5893 give_switch (int switchnum, int omit_first_word)
5895 if ((switches[switchnum].live_cond & SWITCH_IGNORE) != 0)
5896 return;
5898 if (!omit_first_word)
5900 do_spec_1 ("-", 0, NULL);
5901 do_spec_1 (switches[switchnum].part1, 1, NULL);
5904 if (switches[switchnum].args != 0)
5906 const char **p;
5907 for (p = switches[switchnum].args; *p; p++)
5909 const char *arg = *p;
5911 do_spec_1 (" ", 0, NULL);
5912 if (suffix_subst)
5914 unsigned length = strlen (arg);
5915 int dot = 0;
5917 while (length-- && !IS_DIR_SEPARATOR (arg[length]))
5918 if (arg[length] == '.')
5920 (CONST_CAST(char *, arg))[length] = 0;
5921 dot = 1;
5922 break;
5924 do_spec_1 (arg, 1, NULL);
5925 if (dot)
5926 (CONST_CAST(char *, arg))[length] = '.';
5927 do_spec_1 (suffix_subst, 1, NULL);
5929 else
5930 do_spec_1 (arg, 1, NULL);
5934 do_spec_1 (" ", 0, NULL);
5935 switches[switchnum].validated = true;
5938 /* Search for a file named NAME trying various prefixes including the
5939 user's -B prefix and some standard ones.
5940 Return the absolute file name found. If nothing is found, return NAME. */
5942 static const char *
5943 find_file (const char *name)
5945 char *newname = find_a_file (&startfile_prefixes, name, R_OK, true);
5946 return newname ? newname : name;
5949 /* Determine whether a directory exists. If LINKER, return 0 for
5950 certain fixed names not needed by the linker. */
5952 static int
5953 is_directory (const char *path1, bool linker)
5955 int len1;
5956 char *path;
5957 char *cp;
5958 struct stat st;
5960 /* Ensure the string ends with "/.". The resulting path will be a
5961 directory even if the given path is a symbolic link. */
5962 len1 = strlen (path1);
5963 path = (char *) alloca (3 + len1);
5964 memcpy (path, path1, len1);
5965 cp = path + len1;
5966 if (!IS_DIR_SEPARATOR (cp[-1]))
5967 *cp++ = DIR_SEPARATOR;
5968 *cp++ = '.';
5969 *cp = '\0';
5971 /* Exclude directories that the linker is known to search. */
5972 if (linker
5973 && IS_DIR_SEPARATOR (path[0])
5974 && ((cp - path == 6
5975 && filename_ncmp (path + 1, "lib", 3) == 0)
5976 || (cp - path == 10
5977 && filename_ncmp (path + 1, "usr", 3) == 0
5978 && IS_DIR_SEPARATOR (path[4])
5979 && filename_ncmp (path + 5, "lib", 3) == 0)))
5980 return 0;
5982 return (stat (path, &st) >= 0 && S_ISDIR (st.st_mode));
5985 /* Set up the various global variables to indicate that we're processing
5986 the input file named FILENAME. */
5988 void
5989 set_input (const char *filename)
5991 const char *p;
5993 gcc_input_filename = filename;
5994 input_filename_length = strlen (gcc_input_filename);
5995 input_basename = lbasename (gcc_input_filename);
5997 /* Find a suffix starting with the last period,
5998 and set basename_length to exclude that suffix. */
5999 basename_length = strlen (input_basename);
6000 suffixed_basename_length = basename_length;
6001 p = input_basename + basename_length;
6002 while (p != input_basename && *p != '.')
6003 --p;
6004 if (*p == '.' && p != input_basename)
6006 basename_length = p - input_basename;
6007 input_suffix = p + 1;
6009 else
6010 input_suffix = "";
6012 /* If a spec for 'g', 'u', or 'U' is seen with -save-temps then
6013 we will need to do a stat on the gcc_input_filename. The
6014 INPUT_STAT_SET signals that the stat is needed. */
6015 input_stat_set = 0;
6018 /* On fatal signals, delete all the temporary files. */
6020 static void
6021 fatal_signal (int signum)
6023 signal (signum, SIG_DFL);
6024 delete_failure_queue ();
6025 delete_temp_files ();
6026 /* Get the same signal again, this time not handled,
6027 so its normal effect occurs. */
6028 kill (getpid (), signum);
6031 /* Compare the contents of the two files named CMPFILE[0] and
6032 CMPFILE[1]. Return zero if they're identical, nonzero
6033 otherwise. */
6035 static int
6036 compare_files (char *cmpfile[])
6038 int ret = 0;
6039 FILE *temp[2] = { NULL, NULL };
6040 int i;
6042 #if HAVE_MMAP_FILE
6044 size_t length[2];
6045 void *map[2] = { NULL, NULL };
6047 for (i = 0; i < 2; i++)
6049 struct stat st;
6051 if (stat (cmpfile[i], &st) < 0 || !S_ISREG (st.st_mode))
6053 error ("%s: could not determine length of compare-debug file %s",
6054 gcc_input_filename, cmpfile[i]);
6055 ret = 1;
6056 break;
6059 length[i] = st.st_size;
6062 if (!ret && length[0] != length[1])
6064 error ("%s: -fcompare-debug failure (length)", gcc_input_filename);
6065 ret = 1;
6068 if (!ret)
6069 for (i = 0; i < 2; i++)
6071 int fd = open (cmpfile[i], O_RDONLY);
6072 if (fd < 0)
6074 error ("%s: could not open compare-debug file %s",
6075 gcc_input_filename, cmpfile[i]);
6076 ret = 1;
6077 break;
6080 map[i] = mmap (NULL, length[i], PROT_READ, MAP_PRIVATE, fd, 0);
6081 close (fd);
6083 if (map[i] == (void *) MAP_FAILED)
6085 ret = -1;
6086 break;
6090 if (!ret)
6092 if (memcmp (map[0], map[1], length[0]) != 0)
6094 error ("%s: -fcompare-debug failure", gcc_input_filename);
6095 ret = 1;
6099 for (i = 0; i < 2; i++)
6100 if (map[i])
6101 munmap ((caddr_t) map[i], length[i]);
6103 if (ret >= 0)
6104 return ret;
6106 ret = 0;
6108 #endif
6110 for (i = 0; i < 2; i++)
6112 temp[i] = fopen (cmpfile[i], "r");
6113 if (!temp[i])
6115 error ("%s: could not open compare-debug file %s",
6116 gcc_input_filename, cmpfile[i]);
6117 ret = 1;
6118 break;
6122 if (!ret && temp[0] && temp[1])
6123 for (;;)
6125 int c0, c1;
6126 c0 = fgetc (temp[0]);
6127 c1 = fgetc (temp[1]);
6129 if (c0 != c1)
6131 error ("%s: -fcompare-debug failure",
6132 gcc_input_filename);
6133 ret = 1;
6134 break;
6137 if (c0 == EOF)
6138 break;
6141 for (i = 1; i >= 0; i--)
6143 if (temp[i])
6144 fclose (temp[i]);
6147 return ret;
6150 extern int main (int, char **);
6153 main (int argc, char **argv)
6155 size_t i;
6156 int value;
6157 int linker_was_run = 0;
6158 int lang_n_infiles = 0;
6159 int num_linker_inputs = 0;
6160 char *explicit_link_files;
6161 char *specs_file;
6162 char *lto_wrapper_file;
6163 const char *p;
6164 struct user_specs *uptr;
6165 char **old_argv = argv;
6166 struct cl_decoded_option *decoded_options;
6167 unsigned int decoded_options_count;
6169 p = argv[0] + strlen (argv[0]);
6170 while (p != argv[0] && !IS_DIR_SEPARATOR (p[-1]))
6171 --p;
6172 progname = p;
6174 xmalloc_set_program_name (progname);
6176 expandargv (&argc, &argv);
6178 /* Determine if any expansions were made. */
6179 if (argv != old_argv)
6180 at_file_supplied = true;
6182 /* Register the language-independent parameters. */
6183 global_init_params ();
6184 finish_params ();
6186 init_options_struct (&global_options, &global_options_set);
6188 decode_cmdline_options_to_array (argc, CONST_CAST2 (const char **, char **,
6189 argv),
6190 CL_DRIVER,
6191 &decoded_options, &decoded_options_count);
6193 /* Unlock the stdio streams. */
6194 unlock_std_streams ();
6196 gcc_init_libintl ();
6198 diagnostic_initialize (global_dc, 0);
6200 #ifdef GCC_DRIVER_HOST_INITIALIZATION
6201 /* Perform host dependent initialization when needed. */
6202 GCC_DRIVER_HOST_INITIALIZATION;
6203 #endif
6205 if (atexit (delete_temp_files) != 0)
6206 fatal_error ("atexit failed");
6208 if (signal (SIGINT, SIG_IGN) != SIG_IGN)
6209 signal (SIGINT, fatal_signal);
6210 #ifdef SIGHUP
6211 if (signal (SIGHUP, SIG_IGN) != SIG_IGN)
6212 signal (SIGHUP, fatal_signal);
6213 #endif
6214 if (signal (SIGTERM, SIG_IGN) != SIG_IGN)
6215 signal (SIGTERM, fatal_signal);
6216 #ifdef SIGPIPE
6217 if (signal (SIGPIPE, SIG_IGN) != SIG_IGN)
6218 signal (SIGPIPE, fatal_signal);
6219 #endif
6220 #ifdef SIGCHLD
6221 /* We *MUST* set SIGCHLD to SIG_DFL so that the wait4() call will
6222 receive the signal. A different setting is inheritable */
6223 signal (SIGCHLD, SIG_DFL);
6224 #endif
6226 /* Parsing and gimplification sometimes need quite large stack.
6227 Increase stack size limits if possible. */
6228 stack_limit_increase (64 * 1024 * 1024);
6230 /* Allocate the argument vector. */
6231 alloc_args ();
6233 obstack_init (&obstack);
6235 /* Build multilib_select, et. al from the separate lines that make up each
6236 multilib selection. */
6238 const char *const *q = multilib_raw;
6239 int need_space;
6241 obstack_init (&multilib_obstack);
6242 while ((p = *q++) != (char *) 0)
6243 obstack_grow (&multilib_obstack, p, strlen (p));
6245 obstack_1grow (&multilib_obstack, 0);
6246 multilib_select = XOBFINISH (&multilib_obstack, const char *);
6248 q = multilib_matches_raw;
6249 while ((p = *q++) != (char *) 0)
6250 obstack_grow (&multilib_obstack, p, strlen (p));
6252 obstack_1grow (&multilib_obstack, 0);
6253 multilib_matches = XOBFINISH (&multilib_obstack, const char *);
6255 q = multilib_exclusions_raw;
6256 while ((p = *q++) != (char *) 0)
6257 obstack_grow (&multilib_obstack, p, strlen (p));
6259 obstack_1grow (&multilib_obstack, 0);
6260 multilib_exclusions = XOBFINISH (&multilib_obstack, const char *);
6262 need_space = FALSE;
6263 for (i = 0; i < ARRAY_SIZE (multilib_defaults_raw); i++)
6265 if (need_space)
6266 obstack_1grow (&multilib_obstack, ' ');
6267 obstack_grow (&multilib_obstack,
6268 multilib_defaults_raw[i],
6269 strlen (multilib_defaults_raw[i]));
6270 need_space = TRUE;
6273 obstack_1grow (&multilib_obstack, 0);
6274 multilib_defaults = XOBFINISH (&multilib_obstack, const char *);
6277 #ifdef INIT_ENVIRONMENT
6278 /* Set up any other necessary machine specific environment variables. */
6279 xputenv (INIT_ENVIRONMENT);
6280 #endif
6282 /* Make a table of what switches there are (switches, n_switches).
6283 Make a table of specified input files (infiles, n_infiles).
6284 Decode switches that are handled locally. */
6286 process_command (decoded_options_count, decoded_options);
6288 /* Initialize the vector of specs to just the default.
6289 This means one element containing 0s, as a terminator. */
6291 compilers = XNEWVAR (struct compiler, sizeof default_compilers);
6292 memcpy (compilers, default_compilers, sizeof default_compilers);
6293 n_compilers = n_default_compilers;
6295 /* Read specs from a file if there is one. */
6297 machine_suffix = concat (spec_machine, dir_separator_str,
6298 spec_version, dir_separator_str, NULL);
6299 just_machine_suffix = concat (spec_machine, dir_separator_str, NULL);
6301 specs_file = find_a_file (&startfile_prefixes, "specs", R_OK, true);
6302 /* Read the specs file unless it is a default one. */
6303 if (specs_file != 0 && strcmp (specs_file, "specs"))
6304 read_specs (specs_file, true, false);
6305 else
6306 init_spec ();
6308 /* We need to check standard_exec_prefix/just_machine_suffix/specs
6309 for any override of as, ld and libraries. */
6310 specs_file = (char *) alloca (strlen (standard_exec_prefix)
6311 + strlen (just_machine_suffix) + sizeof ("specs"));
6313 strcpy (specs_file, standard_exec_prefix);
6314 strcat (specs_file, just_machine_suffix);
6315 strcat (specs_file, "specs");
6316 if (access (specs_file, R_OK) == 0)
6317 read_specs (specs_file, true, false);
6319 /* Process any configure-time defaults specified for the command line
6320 options, via OPTION_DEFAULT_SPECS. */
6321 for (i = 0; i < ARRAY_SIZE (option_default_specs); i++)
6322 do_option_spec (option_default_specs[i].name,
6323 option_default_specs[i].spec);
6325 /* Process DRIVER_SELF_SPECS, adding any new options to the end
6326 of the command line. */
6328 for (i = 0; i < ARRAY_SIZE (driver_self_specs); i++)
6329 do_self_spec (driver_self_specs[i]);
6331 /* If not cross-compiling, look for executables in the standard
6332 places. */
6333 if (*cross_compile == '0')
6335 if (*md_exec_prefix)
6337 add_prefix (&exec_prefixes, md_exec_prefix, "GCC",
6338 PREFIX_PRIORITY_LAST, 0, 0);
6342 /* Process sysroot_suffix_spec. */
6343 if (*sysroot_suffix_spec != 0
6344 && !no_sysroot_suffix
6345 && do_spec_2 (sysroot_suffix_spec) == 0)
6347 if (VEC_length (const_char_p, argbuf) > 1)
6348 error ("spec failure: more than one arg to SYSROOT_SUFFIX_SPEC");
6349 else if (VEC_length (const_char_p, argbuf) == 1)
6350 target_sysroot_suffix = xstrdup (VEC_last (const_char_p, argbuf));
6353 #ifdef HAVE_LD_SYSROOT
6354 /* Pass the --sysroot option to the linker, if it supports that. If
6355 there is a sysroot_suffix_spec, it has already been processed by
6356 this point, so target_system_root really is the system root we
6357 should be using. */
6358 if (target_system_root)
6360 obstack_grow (&obstack, "%(sysroot_spec) ", strlen ("%(sysroot_spec) "));
6361 obstack_grow0 (&obstack, link_spec, strlen (link_spec));
6362 set_spec ("link", XOBFINISH (&obstack, const char *), false);
6364 #endif
6366 /* Process sysroot_hdrs_suffix_spec. */
6367 if (*sysroot_hdrs_suffix_spec != 0
6368 && !no_sysroot_suffix
6369 && do_spec_2 (sysroot_hdrs_suffix_spec) == 0)
6371 if (VEC_length (const_char_p, argbuf) > 1)
6372 error ("spec failure: more than one arg to SYSROOT_HEADERS_SUFFIX_SPEC");
6373 else if (VEC_length (const_char_p, argbuf) == 1)
6374 target_sysroot_hdrs_suffix = xstrdup (VEC_last (const_char_p, argbuf));
6377 /* Look for startfiles in the standard places. */
6378 if (*startfile_prefix_spec != 0
6379 && do_spec_2 (startfile_prefix_spec) == 0
6380 && do_spec_1 (" ", 0, NULL) == 0)
6382 const char *arg;
6383 int ndx;
6384 FOR_EACH_VEC_ELT (const_char_p, argbuf, ndx, arg)
6385 add_sysrooted_prefix (&startfile_prefixes, arg, "BINUTILS",
6386 PREFIX_PRIORITY_LAST, 0, 1);
6388 /* We should eventually get rid of all these and stick to
6389 startfile_prefix_spec exclusively. */
6390 else if (*cross_compile == '0' || target_system_root)
6392 if (*md_startfile_prefix)
6393 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix,
6394 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6396 if (*md_startfile_prefix_1)
6397 add_sysrooted_prefix (&startfile_prefixes, md_startfile_prefix_1,
6398 "GCC", PREFIX_PRIORITY_LAST, 0, 1);
6400 /* If standard_startfile_prefix is relative, base it on
6401 standard_exec_prefix. This lets us move the installed tree
6402 as a unit. If GCC_EXEC_PREFIX is defined, base
6403 standard_startfile_prefix on that as well.
6405 If the prefix is relative, only search it for native compilers;
6406 otherwise we will search a directory containing host libraries. */
6407 if (IS_ABSOLUTE_PATH (standard_startfile_prefix))
6408 add_sysrooted_prefix (&startfile_prefixes,
6409 standard_startfile_prefix, "BINUTILS",
6410 PREFIX_PRIORITY_LAST, 0, 1);
6411 else if (*cross_compile == '0')
6413 add_prefix (&startfile_prefixes,
6414 concat (gcc_exec_prefix
6415 ? gcc_exec_prefix : standard_exec_prefix,
6416 machine_suffix,
6417 standard_startfile_prefix, NULL),
6418 NULL, PREFIX_PRIORITY_LAST, 0, 1);
6421 /* Sysrooted prefixes are relocated because target_system_root is
6422 also relocated by gcc_exec_prefix. */
6423 if (*standard_startfile_prefix_1)
6424 add_sysrooted_prefix (&startfile_prefixes,
6425 standard_startfile_prefix_1, "BINUTILS",
6426 PREFIX_PRIORITY_LAST, 0, 1);
6427 if (*standard_startfile_prefix_2)
6428 add_sysrooted_prefix (&startfile_prefixes,
6429 standard_startfile_prefix_2, "BINUTILS",
6430 PREFIX_PRIORITY_LAST, 0, 1);
6433 /* Process any user specified specs in the order given on the command
6434 line. */
6435 for (uptr = user_specs_head; uptr; uptr = uptr->next)
6437 char *filename = find_a_file (&startfile_prefixes, uptr->filename,
6438 R_OK, true);
6439 read_specs (filename ? filename : uptr->filename, false, true);
6442 /* Process any user self specs. */
6444 struct spec_list *sl;
6445 for (sl = specs; sl; sl = sl->next)
6446 if (sl->name_len == sizeof "self_spec" - 1
6447 && !strcmp (sl->name, "self_spec"))
6448 do_self_spec (*sl->ptr_spec);
6451 if (compare_debug)
6453 enum save_temps save;
6455 if (!compare_debug_second)
6457 n_switches_debug_check[1] = n_switches;
6458 n_switches_alloc_debug_check[1] = n_switches_alloc;
6459 switches_debug_check[1] = XDUPVEC (struct switchstr, switches,
6460 n_switches_alloc);
6462 do_self_spec ("%:compare-debug-self-opt()");
6463 n_switches_debug_check[0] = n_switches;
6464 n_switches_alloc_debug_check[0] = n_switches_alloc;
6465 switches_debug_check[0] = switches;
6467 n_switches = n_switches_debug_check[1];
6468 n_switches_alloc = n_switches_alloc_debug_check[1];
6469 switches = switches_debug_check[1];
6472 /* Avoid crash when computing %j in this early. */
6473 save = save_temps_flag;
6474 save_temps_flag = SAVE_TEMPS_NONE;
6476 compare_debug = -compare_debug;
6477 do_self_spec ("%:compare-debug-self-opt()");
6479 save_temps_flag = save;
6481 if (!compare_debug_second)
6483 n_switches_debug_check[1] = n_switches;
6484 n_switches_alloc_debug_check[1] = n_switches_alloc;
6485 switches_debug_check[1] = switches;
6486 compare_debug = -compare_debug;
6487 n_switches = n_switches_debug_check[0];
6488 n_switches_alloc = n_switches_debug_check[0];
6489 switches = switches_debug_check[0];
6494 /* If we have a GCC_EXEC_PREFIX envvar, modify it for cpp's sake. */
6495 if (gcc_exec_prefix)
6496 gcc_exec_prefix = concat (gcc_exec_prefix, spec_machine, dir_separator_str,
6497 spec_version, dir_separator_str, NULL);
6499 /* Now we have the specs.
6500 Set the `valid' bits for switches that match anything in any spec. */
6502 validate_all_switches ();
6504 /* Now that we have the switches and the specs, set
6505 the subdirectory based on the options. */
6506 set_multilib_dir ();
6508 /* Set up to remember the pathname of gcc and any options
6509 needed for collect. We use argv[0] instead of progname because
6510 we need the complete pathname. */
6511 obstack_init (&collect_obstack);
6512 obstack_grow (&collect_obstack, "COLLECT_GCC=", sizeof ("COLLECT_GCC=") - 1);
6513 obstack_grow (&collect_obstack, argv[0], strlen (argv[0]) + 1);
6514 xputenv (XOBFINISH (&collect_obstack, char *));
6516 /* Set up to remember the pathname of the lto wrapper. */
6518 if (have_c)
6519 lto_wrapper_file = NULL;
6520 else
6521 lto_wrapper_file = find_a_file (&exec_prefixes, "lto-wrapper",
6522 X_OK, false);
6523 if (lto_wrapper_file)
6525 lto_wrapper_spec = lto_wrapper_file;
6526 obstack_init (&collect_obstack);
6527 obstack_grow (&collect_obstack, "COLLECT_LTO_WRAPPER=",
6528 sizeof ("COLLECT_LTO_WRAPPER=") - 1);
6529 obstack_grow (&collect_obstack, lto_wrapper_spec,
6530 strlen (lto_wrapper_spec) + 1);
6531 xputenv (XOBFINISH (&collect_obstack, char *));
6534 /* Reject switches that no pass was interested in. */
6536 for (i = 0; (int) i < n_switches; i++)
6537 if (! switches[i].validated)
6538 error ("unrecognized command line option %<-%s%>", switches[i].part1);
6540 /* Obey some of the options. */
6542 if (print_search_dirs)
6544 printf (_("install: %s%s\n"),
6545 gcc_exec_prefix ? gcc_exec_prefix : standard_exec_prefix,
6546 gcc_exec_prefix ? "" : machine_suffix);
6547 printf (_("programs: %s\n"),
6548 build_search_list (&exec_prefixes, "", false, false));
6549 printf (_("libraries: %s\n"),
6550 build_search_list (&startfile_prefixes, "", false, true));
6551 return (0);
6554 if (print_file_name)
6556 printf ("%s\n", find_file (print_file_name));
6557 return (0);
6560 if (print_prog_name)
6562 char *newname = find_a_file (&exec_prefixes, print_prog_name, X_OK, 0);
6563 printf ("%s\n", (newname ? newname : print_prog_name));
6564 return (0);
6567 if (print_multi_lib)
6569 print_multilib_info ();
6570 return (0);
6573 if (print_multi_directory)
6575 if (multilib_dir == NULL)
6576 printf (".\n");
6577 else
6578 printf ("%s\n", multilib_dir);
6579 return (0);
6582 if (print_sysroot)
6584 if (target_system_root)
6586 if (target_sysroot_suffix)
6587 printf ("%s%s\n", target_system_root, target_sysroot_suffix);
6588 else
6589 printf ("%s\n", target_system_root);
6591 return (0);
6594 if (print_multi_os_directory)
6596 if (multilib_os_dir == NULL)
6597 printf (".\n");
6598 else
6599 printf ("%s\n", multilib_os_dir);
6600 return (0);
6603 if (print_sysroot_headers_suffix)
6605 if (*sysroot_hdrs_suffix_spec)
6607 printf("%s\n", (target_sysroot_hdrs_suffix
6608 ? target_sysroot_hdrs_suffix
6609 : ""));
6610 return (0);
6612 else
6613 /* The error status indicates that only one set of fixed
6614 headers should be built. */
6615 fatal_error ("not configured with sysroot headers suffix");
6618 if (print_help_list)
6620 display_help ();
6622 if (! verbose_flag)
6624 printf (_("\nFor bug reporting instructions, please see:\n"));
6625 printf ("%s.\n", bug_report_url);
6627 return (0);
6630 /* We do not exit here. Instead we have created a fake input file
6631 called 'help-dummy' which needs to be compiled, and we pass this
6632 on the various sub-processes, along with the --help switch.
6633 Ensure their output appears after ours. */
6634 fputc ('\n', stdout);
6635 fflush (stdout);
6638 if (print_version)
6640 printf (_("%s %s%s\n"), progname, pkgversion_string,
6641 version_string);
6642 printf ("Copyright %s 2012 Free Software Foundation, Inc.\n",
6643 _("(C)"));
6644 fputs (_("This is free software; see the source for copying conditions. There is NO\n\
6645 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\n"),
6646 stdout);
6647 if (! verbose_flag)
6648 return 0;
6650 /* We do not exit here. We use the same mechanism of --help to print
6651 the version of the sub-processes. */
6652 fputc ('\n', stdout);
6653 fflush (stdout);
6656 if (verbose_flag)
6658 int n;
6659 const char *thrmod;
6661 fnotice (stderr, "Target: %s\n", spec_machine);
6662 fnotice (stderr, "Configured with: %s\n", configuration_arguments);
6664 #ifdef THREAD_MODEL_SPEC
6665 /* We could have defined THREAD_MODEL_SPEC to "%*" by default,
6666 but there's no point in doing all this processing just to get
6667 thread_model back. */
6668 obstack_init (&obstack);
6669 do_spec_1 (THREAD_MODEL_SPEC, 0, thread_model);
6670 obstack_1grow (&obstack, '\0');
6671 thrmod = XOBFINISH (&obstack, const char *);
6672 #else
6673 thrmod = thread_model;
6674 #endif
6676 fnotice (stderr, "Thread model: %s\n", thrmod);
6678 /* compiler_version is truncated at the first space when initialized
6679 from version string, so truncate version_string at the first space
6680 before comparing. */
6681 for (n = 0; version_string[n]; n++)
6682 if (version_string[n] == ' ')
6683 break;
6685 if (! strncmp (version_string, compiler_version, n)
6686 && compiler_version[n] == 0)
6687 fnotice (stderr, "gcc version %s %s\n", version_string,
6688 pkgversion_string);
6689 else
6690 fnotice (stderr, "gcc driver version %s %sexecuting gcc version %s\n",
6691 version_string, pkgversion_string, compiler_version);
6693 if (n_infiles == 0)
6694 return (0);
6697 if (n_infiles == added_libraries)
6698 fatal_error ("no input files");
6700 if (seen_error ())
6701 goto out;
6703 /* Make a place to record the compiler output file names
6704 that correspond to the input files. */
6706 i = n_infiles;
6707 i += lang_specific_extra_outfiles;
6708 outfiles = XCNEWVEC (const char *, i);
6710 /* Record which files were specified explicitly as link input. */
6712 explicit_link_files = XCNEWVEC (char, n_infiles);
6714 combine_inputs = have_o || flag_wpa;
6716 for (i = 0; (int) i < n_infiles; i++)
6718 const char *name = infiles[i].name;
6719 struct compiler *compiler = lookup_compiler (name,
6720 strlen (name),
6721 infiles[i].language);
6723 if (compiler && !(compiler->combinable))
6724 combine_inputs = false;
6726 if (lang_n_infiles > 0 && compiler != input_file_compiler
6727 && infiles[i].language && infiles[i].language[0] != '*')
6728 infiles[i].incompiler = compiler;
6729 else if (compiler)
6731 lang_n_infiles++;
6732 input_file_compiler = compiler;
6733 infiles[i].incompiler = compiler;
6735 else
6737 /* Since there is no compiler for this input file, assume it is a
6738 linker file. */
6739 explicit_link_files[i] = 1;
6740 infiles[i].incompiler = NULL;
6742 infiles[i].compiled = false;
6743 infiles[i].preprocessed = false;
6746 if (!combine_inputs && have_c && have_o && lang_n_infiles > 1)
6747 fatal_error ("cannot specify -o with -c, -S or -E with multiple files");
6749 for (i = 0; (int) i < n_infiles; i++)
6751 int this_file_error = 0;
6753 /* Tell do_spec what to substitute for %i. */
6755 input_file_number = i;
6756 set_input (infiles[i].name);
6758 if (infiles[i].compiled)
6759 continue;
6761 /* Use the same thing in %o, unless cp->spec says otherwise. */
6763 outfiles[i] = gcc_input_filename;
6765 /* Figure out which compiler from the file's suffix. */
6767 input_file_compiler
6768 = lookup_compiler (infiles[i].name, input_filename_length,
6769 infiles[i].language);
6771 if (input_file_compiler)
6773 /* Ok, we found an applicable compiler. Run its spec. */
6775 if (input_file_compiler->spec[0] == '#')
6777 error ("%s: %s compiler not installed on this system",
6778 gcc_input_filename, &input_file_compiler->spec[1]);
6779 this_file_error = 1;
6781 else
6783 if (compare_debug)
6785 free (debug_check_temp_file[0]);
6786 debug_check_temp_file[0] = NULL;
6788 free (debug_check_temp_file[1]);
6789 debug_check_temp_file[1] = NULL;
6792 value = do_spec (input_file_compiler->spec);
6793 infiles[i].compiled = true;
6794 if (value < 0)
6795 this_file_error = 1;
6796 else if (compare_debug && debug_check_temp_file[0])
6798 if (verbose_flag)
6799 inform (0, "recompiling with -fcompare-debug");
6801 compare_debug = -compare_debug;
6802 n_switches = n_switches_debug_check[1];
6803 n_switches_alloc = n_switches_alloc_debug_check[1];
6804 switches = switches_debug_check[1];
6806 value = do_spec (input_file_compiler->spec);
6808 compare_debug = -compare_debug;
6809 n_switches = n_switches_debug_check[0];
6810 n_switches_alloc = n_switches_alloc_debug_check[0];
6811 switches = switches_debug_check[0];
6813 if (value < 0)
6815 error ("during -fcompare-debug recompilation");
6816 this_file_error = 1;
6819 gcc_assert (debug_check_temp_file[1]
6820 && filename_cmp (debug_check_temp_file[0],
6821 debug_check_temp_file[1]));
6823 if (verbose_flag)
6824 inform (0, "comparing final insns dumps");
6826 if (compare_files (debug_check_temp_file))
6827 this_file_error = 1;
6830 if (compare_debug)
6832 free (debug_check_temp_file[0]);
6833 debug_check_temp_file[0] = NULL;
6835 free (debug_check_temp_file[1]);
6836 debug_check_temp_file[1] = NULL;
6841 /* If this file's name does not contain a recognized suffix,
6842 record it as explicit linker input. */
6844 else
6845 explicit_link_files[i] = 1;
6847 /* Clear the delete-on-failure queue, deleting the files in it
6848 if this compilation failed. */
6850 if (this_file_error)
6852 delete_failure_queue ();
6853 errorcount++;
6855 /* If this compilation succeeded, don't delete those files later. */
6856 clear_failure_queue ();
6859 /* Reset the input file name to the first compile/object file name, for use
6860 with %b in LINK_SPEC. We use the first input file that we can find
6861 a compiler to compile it instead of using infiles.language since for
6862 languages other than C we use aliases that we then lookup later. */
6863 if (n_infiles > 0)
6865 int i;
6867 for (i = 0; i < n_infiles ; i++)
6868 if (infiles[i].incompiler
6869 || (infiles[i].language && infiles[i].language[0] != '*'))
6871 set_input (infiles[i].name);
6872 break;
6876 if (!seen_error ())
6878 /* Make sure INPUT_FILE_NUMBER points to first available open
6879 slot. */
6880 input_file_number = n_infiles;
6881 if (lang_specific_pre_link ())
6882 errorcount++;
6885 /* Determine if there are any linker input files. */
6886 num_linker_inputs = 0;
6887 for (i = 0; (int) i < n_infiles; i++)
6888 if (explicit_link_files[i] || outfiles[i] != NULL)
6889 num_linker_inputs++;
6891 /* Run ld to link all the compiler output files. */
6893 if (num_linker_inputs > 0 && !seen_error () && print_subprocess_help < 2)
6895 int tmp = execution_count;
6897 if (! have_c)
6899 #if HAVE_LTO_PLUGIN > 0
6900 #if HAVE_LTO_PLUGIN == 2
6901 const char *fno_use_linker_plugin = "fno-use-linker-plugin";
6902 #else
6903 const char *fuse_linker_plugin = "fuse-linker-plugin";
6904 #endif
6905 #endif
6907 /* We'll use ld if we can't find collect2. */
6908 if (! strcmp (linker_name_spec, "collect2"))
6910 char *s = find_a_file (&exec_prefixes, "collect2", X_OK, false);
6911 if (s == NULL)
6912 linker_name_spec = "ld";
6915 #if HAVE_LTO_PLUGIN > 0
6916 #if HAVE_LTO_PLUGIN == 2
6917 if (!switch_matches (fno_use_linker_plugin,
6918 fno_use_linker_plugin
6919 + strlen (fno_use_linker_plugin), 0))
6920 #else
6921 if (switch_matches (fuse_linker_plugin,
6922 fuse_linker_plugin
6923 + strlen (fuse_linker_plugin), 0))
6924 #endif
6926 linker_plugin_file_spec = find_a_file (&exec_prefixes,
6927 LTOPLUGINSONAME, R_OK,
6928 false);
6929 if (!linker_plugin_file_spec)
6930 fatal_error ("-fuse-linker-plugin, but %s not found",
6931 LTOPLUGINSONAME);
6933 #endif
6934 lto_gcc_spec = argv[0];
6937 /* Rebuild the COMPILER_PATH and LIBRARY_PATH environment variables
6938 for collect. */
6939 putenv_from_prefixes (&exec_prefixes, "COMPILER_PATH", false);
6940 putenv_from_prefixes (&startfile_prefixes, LIBRARY_PATH_ENV, true);
6942 if (print_subprocess_help == 1)
6944 printf (_("\nLinker options\n==============\n\n"));
6945 printf (_("Use \"-Wl,OPTION\" to pass \"OPTION\""
6946 " to the linker.\n\n"));
6947 fflush (stdout);
6949 value = do_spec (link_command_spec);
6950 if (value < 0)
6951 errorcount = 1;
6952 linker_was_run = (tmp != execution_count);
6955 /* If options said don't run linker,
6956 complain about input files to be given to the linker. */
6958 if (! linker_was_run && !seen_error ())
6959 for (i = 0; (int) i < n_infiles; i++)
6960 if (explicit_link_files[i]
6961 && !(infiles[i].language && infiles[i].language[0] == '*'))
6962 warning (0, "%s: linker input file unused because linking not done",
6963 outfiles[i]);
6965 /* Delete some or all of the temporary files we made. */
6967 if (seen_error ())
6968 delete_failure_queue ();
6969 delete_temp_files ();
6971 if (print_help_list)
6973 printf (("\nFor bug reporting instructions, please see:\n"));
6974 printf ("%s\n", bug_report_url);
6977 out:
6978 return (signal_count != 0 ? 2
6979 : seen_error () ? (pass_exit_codes ? greatest_status : 1)
6980 : 0);
6983 /* Find the proper compilation spec for the file name NAME,
6984 whose length is LENGTH. LANGUAGE is the specified language,
6985 or 0 if this file is to be passed to the linker. */
6987 static struct compiler *
6988 lookup_compiler (const char *name, size_t length, const char *language)
6990 struct compiler *cp;
6992 /* If this was specified by the user to be a linker input, indicate that. */
6993 if (language != 0 && language[0] == '*')
6994 return 0;
6996 /* Otherwise, look for the language, if one is spec'd. */
6997 if (language != 0)
6999 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7000 if (cp->suffix[0] == '@' && !strcmp (cp->suffix + 1, language))
7001 return cp;
7003 error ("language %s not recognized", language);
7004 return 0;
7007 /* Look for a suffix. */
7008 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7010 if (/* The suffix `-' matches only the file name `-'. */
7011 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7012 || (strlen (cp->suffix) < length
7013 /* See if the suffix matches the end of NAME. */
7014 && !strcmp (cp->suffix,
7015 name + length - strlen (cp->suffix))
7017 break;
7020 #if defined (OS2) ||defined (HAVE_DOS_BASED_FILE_SYSTEM)
7021 /* Look again, but case-insensitively this time. */
7022 if (cp < compilers)
7023 for (cp = compilers + n_compilers - 1; cp >= compilers; cp--)
7025 if (/* The suffix `-' matches only the file name `-'. */
7026 (!strcmp (cp->suffix, "-") && !strcmp (name, "-"))
7027 || (strlen (cp->suffix) < length
7028 /* See if the suffix matches the end of NAME. */
7029 && ((!strcmp (cp->suffix,
7030 name + length - strlen (cp->suffix))
7031 || !strpbrk (cp->suffix, "ABCDEFGHIJKLMNOPQRSTUVWXYZ"))
7032 && !strcasecmp (cp->suffix,
7033 name + length - strlen (cp->suffix)))
7035 break;
7037 #endif
7039 if (cp >= compilers)
7041 if (cp->spec[0] != '@')
7042 /* A non-alias entry: return it. */
7043 return cp;
7045 /* An alias entry maps a suffix to a language.
7046 Search for the language; pass 0 for NAME and LENGTH
7047 to avoid infinite recursion if language not found. */
7048 return lookup_compiler (NULL, 0, cp->spec + 1);
7050 return 0;
7053 static char *
7054 save_string (const char *s, int len)
7056 char *result = XNEWVEC (char, len + 1);
7058 memcpy (result, s, len);
7059 result[len] = 0;
7060 return result;
7063 void
7064 pfatal_with_name (const char *name)
7066 perror_with_name (name);
7067 delete_temp_files ();
7068 exit (1);
7071 static void
7072 perror_with_name (const char *name)
7074 error ("%s: %m", name);
7077 static inline void
7078 validate_switches_from_spec (const char *spec, bool user)
7080 const char *p = spec;
7081 char c;
7082 while ((c = *p++))
7083 if (c == '%' && (*p == '{' || *p == '<' || (*p == 'W' && *++p == '{')))
7084 /* We have a switch spec. */
7085 p = validate_switches (p + 1, user);
7088 static void
7089 validate_all_switches (void)
7091 struct compiler *comp;
7092 struct spec_list *spec;
7094 for (comp = compilers; comp->spec; comp++)
7095 validate_switches_from_spec (comp->spec, false);
7097 /* Look through the linked list of specs read from the specs file. */
7098 for (spec = specs; spec; spec = spec->next)
7099 validate_switches_from_spec (*spec->ptr_spec, spec->user_p);
7101 validate_switches_from_spec (link_command_spec, false);
7104 /* Look at the switch-name that comes after START
7105 and mark as valid all supplied switches that match it. */
7107 static const char *
7108 validate_switches (const char *start, bool user_spec)
7110 const char *p = start;
7111 const char *atom;
7112 size_t len;
7113 int i;
7114 bool suffix = false;
7115 bool starred = false;
7117 #define SKIP_WHITE() do { while (*p == ' ' || *p == '\t') p++; } while (0)
7119 next_member:
7120 SKIP_WHITE ();
7122 if (*p == '!')
7123 p++;
7125 SKIP_WHITE ();
7126 if (*p == '.' || *p == ',')
7127 suffix = true, p++;
7129 atom = p;
7130 while (ISIDNUM (*p) || *p == '-' || *p == '+' || *p == '='
7131 || *p == ',' || *p == '.' || *p == '@')
7132 p++;
7133 len = p - atom;
7135 if (*p == '*')
7136 starred = true, p++;
7138 SKIP_WHITE ();
7140 if (!suffix)
7142 /* Mark all matching switches as valid. */
7143 for (i = 0; i < n_switches; i++)
7144 if (!strncmp (switches[i].part1, atom, len)
7145 && (starred || switches[i].part1[len] == '\0')
7146 && (switches[i].known || user_spec))
7147 switches[i].validated = true;
7150 if (*p) p++;
7151 if (*p && (p[-1] == '|' || p[-1] == '&'))
7152 goto next_member;
7154 if (*p && p[-1] == ':')
7156 while (*p && *p != ';' && *p != '}')
7158 if (*p == '%')
7160 p++;
7161 if (*p == '{' || *p == '<')
7162 p = validate_switches (p+1, user_spec);
7163 else if (p[0] == 'W' && p[1] == '{')
7164 p = validate_switches (p+2, user_spec);
7166 else
7167 p++;
7170 if (*p) p++;
7171 if (*p && p[-1] == ';')
7172 goto next_member;
7175 return p;
7176 #undef SKIP_WHITE
7179 struct mdswitchstr
7181 const char *str;
7182 int len;
7185 static struct mdswitchstr *mdswitches;
7186 static int n_mdswitches;
7188 /* Check whether a particular argument was used. The first time we
7189 canonicalize the switches to keep only the ones we care about. */
7191 static int
7192 used_arg (const char *p, int len)
7194 struct mswitchstr
7196 const char *str;
7197 const char *replace;
7198 int len;
7199 int rep_len;
7202 static struct mswitchstr *mswitches;
7203 static int n_mswitches;
7204 int i, j;
7206 if (!mswitches)
7208 struct mswitchstr *matches;
7209 const char *q;
7210 int cnt = 0;
7212 /* Break multilib_matches into the component strings of string
7213 and replacement string. */
7214 for (q = multilib_matches; *q != '\0'; q++)
7215 if (*q == ';')
7216 cnt++;
7218 matches
7219 = (struct mswitchstr *) alloca ((sizeof (struct mswitchstr)) * cnt);
7220 i = 0;
7221 q = multilib_matches;
7222 while (*q != '\0')
7224 matches[i].str = q;
7225 while (*q != ' ')
7227 if (*q == '\0')
7229 invalid_matches:
7230 fatal_error ("multilib spec %qs is invalid",
7231 multilib_matches);
7233 q++;
7235 matches[i].len = q - matches[i].str;
7237 matches[i].replace = ++q;
7238 while (*q != ';' && *q != '\0')
7240 if (*q == ' ')
7241 goto invalid_matches;
7242 q++;
7244 matches[i].rep_len = q - matches[i].replace;
7245 i++;
7246 if (*q == ';')
7247 q++;
7250 /* Now build a list of the replacement string for switches that we care
7251 about. Make sure we allocate at least one entry. This prevents
7252 xmalloc from calling fatal, and prevents us from re-executing this
7253 block of code. */
7254 mswitches
7255 = XNEWVEC (struct mswitchstr, n_mdswitches + (n_switches ? n_switches : 1));
7256 for (i = 0; i < n_switches; i++)
7257 if ((switches[i].live_cond & SWITCH_IGNORE) == 0)
7259 int xlen = strlen (switches[i].part1);
7260 for (j = 0; j < cnt; j++)
7261 if (xlen == matches[j].len
7262 && ! strncmp (switches[i].part1, matches[j].str, xlen))
7264 mswitches[n_mswitches].str = matches[j].replace;
7265 mswitches[n_mswitches].len = matches[j].rep_len;
7266 mswitches[n_mswitches].replace = (char *) 0;
7267 mswitches[n_mswitches].rep_len = 0;
7268 n_mswitches++;
7269 break;
7273 /* Add MULTILIB_DEFAULTS switches too, as long as they were not present
7274 on the command line nor any options mutually incompatible with
7275 them. */
7276 for (i = 0; i < n_mdswitches; i++)
7278 const char *r;
7280 for (q = multilib_options; *q != '\0'; q++)
7282 while (*q == ' ')
7283 q++;
7285 r = q;
7286 while (strncmp (q, mdswitches[i].str, mdswitches[i].len) != 0
7287 || strchr (" /", q[mdswitches[i].len]) == NULL)
7289 while (*q != ' ' && *q != '/' && *q != '\0')
7290 q++;
7291 if (*q != '/')
7292 break;
7293 q++;
7296 if (*q != ' ' && *q != '\0')
7298 while (*r != ' ' && *r != '\0')
7300 q = r;
7301 while (*q != ' ' && *q != '/' && *q != '\0')
7302 q++;
7304 if (used_arg (r, q - r))
7305 break;
7307 if (*q != '/')
7309 mswitches[n_mswitches].str = mdswitches[i].str;
7310 mswitches[n_mswitches].len = mdswitches[i].len;
7311 mswitches[n_mswitches].replace = (char *) 0;
7312 mswitches[n_mswitches].rep_len = 0;
7313 n_mswitches++;
7314 break;
7317 r = q + 1;
7319 break;
7325 for (i = 0; i < n_mswitches; i++)
7326 if (len == mswitches[i].len && ! strncmp (p, mswitches[i].str, len))
7327 return 1;
7329 return 0;
7332 static int
7333 default_arg (const char *p, int len)
7335 int i;
7337 for (i = 0; i < n_mdswitches; i++)
7338 if (len == mdswitches[i].len && ! strncmp (p, mdswitches[i].str, len))
7339 return 1;
7341 return 0;
7344 /* Work out the subdirectory to use based on the options. The format of
7345 multilib_select is a list of elements. Each element is a subdirectory
7346 name followed by a list of options followed by a semicolon. The format
7347 of multilib_exclusions is the same, but without the preceding
7348 directory. First gcc will check the exclusions, if none of the options
7349 beginning with an exclamation point are present, and all of the other
7350 options are present, then we will ignore this completely. Passing
7351 that, gcc will consider each multilib_select in turn using the same
7352 rules for matching the options. If a match is found, that subdirectory
7353 will be used. */
7355 static void
7356 set_multilib_dir (void)
7358 const char *p;
7359 unsigned int this_path_len;
7360 const char *this_path, *this_arg;
7361 const char *start, *end;
7362 int not_arg;
7363 int ok, ndfltok, first;
7365 n_mdswitches = 0;
7366 start = multilib_defaults;
7367 while (*start == ' ' || *start == '\t')
7368 start++;
7369 while (*start != '\0')
7371 n_mdswitches++;
7372 while (*start != ' ' && *start != '\t' && *start != '\0')
7373 start++;
7374 while (*start == ' ' || *start == '\t')
7375 start++;
7378 if (n_mdswitches)
7380 int i = 0;
7382 mdswitches = XNEWVEC (struct mdswitchstr, n_mdswitches);
7383 for (start = multilib_defaults; *start != '\0'; start = end + 1)
7385 while (*start == ' ' || *start == '\t')
7386 start++;
7388 if (*start == '\0')
7389 break;
7391 for (end = start + 1;
7392 *end != ' ' && *end != '\t' && *end != '\0'; end++)
7395 obstack_grow (&multilib_obstack, start, end - start);
7396 obstack_1grow (&multilib_obstack, 0);
7397 mdswitches[i].str = XOBFINISH (&multilib_obstack, const char *);
7398 mdswitches[i++].len = end - start;
7400 if (*end == '\0')
7401 break;
7405 p = multilib_exclusions;
7406 while (*p != '\0')
7408 /* Ignore newlines. */
7409 if (*p == '\n')
7411 ++p;
7412 continue;
7415 /* Check the arguments. */
7416 ok = 1;
7417 while (*p != ';')
7419 if (*p == '\0')
7421 invalid_exclusions:
7422 fatal_error ("multilib exclusions %qs is invalid",
7423 multilib_exclusions);
7426 if (! ok)
7428 ++p;
7429 continue;
7432 this_arg = p;
7433 while (*p != ' ' && *p != ';')
7435 if (*p == '\0')
7436 goto invalid_exclusions;
7437 ++p;
7440 if (*this_arg != '!')
7441 not_arg = 0;
7442 else
7444 not_arg = 1;
7445 ++this_arg;
7448 ok = used_arg (this_arg, p - this_arg);
7449 if (not_arg)
7450 ok = ! ok;
7452 if (*p == ' ')
7453 ++p;
7456 if (ok)
7457 return;
7459 ++p;
7462 first = 1;
7463 p = multilib_select;
7464 while (*p != '\0')
7466 /* Ignore newlines. */
7467 if (*p == '\n')
7469 ++p;
7470 continue;
7473 /* Get the initial path. */
7474 this_path = p;
7475 while (*p != ' ')
7477 if (*p == '\0')
7479 invalid_select:
7480 fatal_error ("multilib select %qs is invalid",
7481 multilib_select);
7483 ++p;
7485 this_path_len = p - this_path;
7487 /* Check the arguments. */
7488 ok = 1;
7489 ndfltok = 1;
7490 ++p;
7491 while (*p != ';')
7493 if (*p == '\0')
7494 goto invalid_select;
7496 if (! ok)
7498 ++p;
7499 continue;
7502 this_arg = p;
7503 while (*p != ' ' && *p != ';')
7505 if (*p == '\0')
7506 goto invalid_select;
7507 ++p;
7510 if (*this_arg != '!')
7511 not_arg = 0;
7512 else
7514 not_arg = 1;
7515 ++this_arg;
7518 /* If this is a default argument, we can just ignore it.
7519 This is true even if this_arg begins with '!'. Beginning
7520 with '!' does not mean that this argument is necessarily
7521 inappropriate for this library: it merely means that
7522 there is a more specific library which uses this
7523 argument. If this argument is a default, we need not
7524 consider that more specific library. */
7525 ok = used_arg (this_arg, p - this_arg);
7526 if (not_arg)
7527 ok = ! ok;
7529 if (! ok)
7530 ndfltok = 0;
7532 if (default_arg (this_arg, p - this_arg))
7533 ok = 1;
7535 if (*p == ' ')
7536 ++p;
7539 if (ok && first)
7541 if (this_path_len != 1
7542 || this_path[0] != '.')
7544 char *new_multilib_dir = XNEWVEC (char, this_path_len + 1);
7545 char *q;
7547 strncpy (new_multilib_dir, this_path, this_path_len);
7548 new_multilib_dir[this_path_len] = '\0';
7549 q = strchr (new_multilib_dir, ':');
7550 if (q != NULL)
7551 *q = '\0';
7552 multilib_dir = new_multilib_dir;
7554 first = 0;
7557 if (ndfltok)
7559 const char *q = this_path, *end = this_path + this_path_len;
7561 while (q < end && *q != ':')
7562 q++;
7563 if (q < end)
7565 char *new_multilib_os_dir = XNEWVEC (char, end - q);
7566 memcpy (new_multilib_os_dir, q + 1, end - q - 1);
7567 new_multilib_os_dir[end - q - 1] = '\0';
7568 multilib_os_dir = new_multilib_os_dir;
7569 break;
7573 ++p;
7576 if (multilib_dir == NULL && multilib_os_dir != NULL
7577 && strcmp (multilib_os_dir, ".") == 0)
7579 free (CONST_CAST (char *, multilib_os_dir));
7580 multilib_os_dir = NULL;
7582 else if (multilib_dir != NULL && multilib_os_dir == NULL)
7583 multilib_os_dir = multilib_dir;
7586 /* Print out the multiple library subdirectory selection
7587 information. This prints out a series of lines. Each line looks
7588 like SUBDIRECTORY;@OPTION@OPTION, with as many options as is
7589 required. Only the desired options are printed out, the negative
7590 matches. The options are print without a leading dash. There are
7591 no spaces to make it easy to use the information in the shell.
7592 Each subdirectory is printed only once. This assumes the ordering
7593 generated by the genmultilib script. Also, we leave out ones that match
7594 the exclusions. */
7596 static void
7597 print_multilib_info (void)
7599 const char *p = multilib_select;
7600 const char *last_path = 0, *this_path;
7601 int skip;
7602 unsigned int last_path_len = 0;
7604 while (*p != '\0')
7606 skip = 0;
7607 /* Ignore newlines. */
7608 if (*p == '\n')
7610 ++p;
7611 continue;
7614 /* Get the initial path. */
7615 this_path = p;
7616 while (*p != ' ')
7618 if (*p == '\0')
7620 invalid_select:
7621 fatal_error ("multilib select %qs is invalid", multilib_select);
7624 ++p;
7627 /* When --disable-multilib was used but target defines
7628 MULTILIB_OSDIRNAMES, entries starting with .: are there just
7629 to find multilib_os_dir, so skip them from output. */
7630 if (this_path[0] == '.' && this_path[1] == ':')
7631 skip = 1;
7633 /* Check for matches with the multilib_exclusions. We don't bother
7634 with the '!' in either list. If any of the exclusion rules match
7635 all of its options with the select rule, we skip it. */
7637 const char *e = multilib_exclusions;
7638 const char *this_arg;
7640 while (*e != '\0')
7642 int m = 1;
7643 /* Ignore newlines. */
7644 if (*e == '\n')
7646 ++e;
7647 continue;
7650 /* Check the arguments. */
7651 while (*e != ';')
7653 const char *q;
7654 int mp = 0;
7656 if (*e == '\0')
7658 invalid_exclusion:
7659 fatal_error ("multilib exclusion %qs is invalid",
7660 multilib_exclusions);
7663 if (! m)
7665 ++e;
7666 continue;
7669 this_arg = e;
7671 while (*e != ' ' && *e != ';')
7673 if (*e == '\0')
7674 goto invalid_exclusion;
7675 ++e;
7678 q = p + 1;
7679 while (*q != ';')
7681 const char *arg;
7682 int len = e - this_arg;
7684 if (*q == '\0')
7685 goto invalid_select;
7687 arg = q;
7689 while (*q != ' ' && *q != ';')
7691 if (*q == '\0')
7692 goto invalid_select;
7693 ++q;
7696 if (! strncmp (arg, this_arg,
7697 (len < q - arg) ? q - arg : len)
7698 || default_arg (this_arg, e - this_arg))
7700 mp = 1;
7701 break;
7704 if (*q == ' ')
7705 ++q;
7708 if (! mp)
7709 m = 0;
7711 if (*e == ' ')
7712 ++e;
7715 if (m)
7717 skip = 1;
7718 break;
7721 if (*e != '\0')
7722 ++e;
7726 if (! skip)
7728 /* If this is a duplicate, skip it. */
7729 skip = (last_path != 0
7730 && (unsigned int) (p - this_path) == last_path_len
7731 && ! filename_ncmp (last_path, this_path, last_path_len));
7733 last_path = this_path;
7734 last_path_len = p - this_path;
7737 /* If this directory requires any default arguments, we can skip
7738 it. We will already have printed a directory identical to
7739 this one which does not require that default argument. */
7740 if (! skip)
7742 const char *q;
7744 q = p + 1;
7745 while (*q != ';')
7747 const char *arg;
7749 if (*q == '\0')
7750 goto invalid_select;
7752 if (*q == '!')
7753 arg = NULL;
7754 else
7755 arg = q;
7757 while (*q != ' ' && *q != ';')
7759 if (*q == '\0')
7760 goto invalid_select;
7761 ++q;
7764 if (arg != NULL
7765 && default_arg (arg, q - arg))
7767 skip = 1;
7768 break;
7771 if (*q == ' ')
7772 ++q;
7776 if (! skip)
7778 const char *p1;
7780 for (p1 = last_path; p1 < p && *p1 != ':'; p1++)
7781 putchar (*p1);
7782 putchar (';');
7785 ++p;
7786 while (*p != ';')
7788 int use_arg;
7790 if (*p == '\0')
7791 goto invalid_select;
7793 if (skip)
7795 ++p;
7796 continue;
7799 use_arg = *p != '!';
7801 if (use_arg)
7802 putchar ('@');
7804 while (*p != ' ' && *p != ';')
7806 if (*p == '\0')
7807 goto invalid_select;
7808 if (use_arg)
7809 putchar (*p);
7810 ++p;
7813 if (*p == ' ')
7814 ++p;
7817 if (! skip)
7819 /* If there are extra options, print them now. */
7820 if (multilib_extra && *multilib_extra)
7822 int print_at = TRUE;
7823 const char *q;
7825 for (q = multilib_extra; *q != '\0'; q++)
7827 if (*q == ' ')
7828 print_at = TRUE;
7829 else
7831 if (print_at)
7832 putchar ('@');
7833 putchar (*q);
7834 print_at = FALSE;
7839 putchar ('\n');
7842 ++p;
7846 /* getenv built-in spec function.
7848 Returns the value of the environment variable given by its first
7849 argument, concatenated with the second argument. If the
7850 environment variable is not defined, a fatal error is issued. */
7852 static const char *
7853 getenv_spec_function (int argc, const char **argv)
7855 char *value;
7856 char *result;
7857 char *ptr;
7858 size_t len;
7860 if (argc != 2)
7861 return NULL;
7863 value = getenv (argv[0]);
7864 if (!value)
7865 fatal_error ("environment variable %qs not defined", argv[0]);
7867 /* We have to escape every character of the environment variable so
7868 they are not interpreted as active spec characters. A
7869 particularly painful case is when we are reading a variable
7870 holding a windows path complete with \ separators. */
7871 len = strlen (value) * 2 + strlen (argv[1]) + 1;
7872 result = XNEWVAR (char, len);
7873 for (ptr = result; *value; ptr += 2)
7875 ptr[0] = '\\';
7876 ptr[1] = *value++;
7879 strcpy (ptr, argv[1]);
7881 return result;
7884 /* if-exists built-in spec function.
7886 Checks to see if the file specified by the absolute pathname in
7887 ARGS exists. Returns that pathname if found.
7889 The usual use for this function is to check for a library file
7890 (whose name has been expanded with %s). */
7892 static const char *
7893 if_exists_spec_function (int argc, const char **argv)
7895 /* Must have only one argument. */
7896 if (argc == 1 && IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7897 return argv[0];
7899 return NULL;
7902 /* if-exists-else built-in spec function.
7904 This is like if-exists, but takes an additional argument which
7905 is returned if the first argument does not exist. */
7907 static const char *
7908 if_exists_else_spec_function (int argc, const char **argv)
7910 /* Must have exactly two arguments. */
7911 if (argc != 2)
7912 return NULL;
7914 if (IS_ABSOLUTE_PATH (argv[0]) && ! access (argv[0], R_OK))
7915 return argv[0];
7917 return argv[1];
7920 /* replace-outfile built-in spec function.
7922 This looks for the first argument in the outfiles array's name and
7923 replaces it with the second argument. */
7925 static const char *
7926 replace_outfile_spec_function (int argc, const char **argv)
7928 int i;
7929 /* Must have exactly two arguments. */
7930 if (argc != 2)
7931 abort ();
7933 for (i = 0; i < n_infiles; i++)
7935 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
7936 outfiles[i] = xstrdup (argv[1]);
7938 return NULL;
7941 /* remove-outfile built-in spec function.
7943 * This looks for the first argument in the outfiles array's name and
7944 * removes it. */
7946 static const char *
7947 remove_outfile_spec_function (int argc, const char **argv)
7949 int i;
7950 /* Must have exactly one argument. */
7951 if (argc != 1)
7952 abort ();
7954 for (i = 0; i < n_infiles; i++)
7956 if (outfiles[i] && !filename_cmp (outfiles[i], argv[0]))
7957 outfiles[i] = NULL;
7959 return NULL;
7962 /* Given two version numbers, compares the two numbers.
7963 A version number must match the regular expression
7964 ([1-9][0-9]*|0)(\.([1-9][0-9]*|0))*
7966 static int
7967 compare_version_strings (const char *v1, const char *v2)
7969 int rresult;
7970 regex_t r;
7972 if (regcomp (&r, "^([1-9][0-9]*|0)(\\.([1-9][0-9]*|0))*$",
7973 REG_EXTENDED | REG_NOSUB) != 0)
7974 abort ();
7975 rresult = regexec (&r, v1, 0, NULL, 0);
7976 if (rresult == REG_NOMATCH)
7977 fatal_error ("invalid version number %qs", v1);
7978 else if (rresult != 0)
7979 abort ();
7980 rresult = regexec (&r, v2, 0, NULL, 0);
7981 if (rresult == REG_NOMATCH)
7982 fatal_error ("invalid version number %qs", v2);
7983 else if (rresult != 0)
7984 abort ();
7986 return strverscmp (v1, v2);
7990 /* version_compare built-in spec function.
7992 This takes an argument of the following form:
7994 <comparison-op> <arg1> [<arg2>] <switch> <result>
7996 and produces "result" if the comparison evaluates to true,
7997 and nothing if it doesn't.
7999 The supported <comparison-op> values are:
8001 >= true if switch is a later (or same) version than arg1
8002 !> opposite of >=
8003 < true if switch is an earlier version than arg1
8004 !< opposite of <
8005 >< true if switch is arg1 or later, and earlier than arg2
8006 <> true if switch is earlier than arg1 or is arg2 or later
8008 If the switch is not present, the condition is false unless
8009 the first character of the <comparison-op> is '!'.
8011 For example,
8012 %:version-compare(>= 10.3 mmacosx-version-min= -lmx)
8013 adds -lmx if -mmacosx-version-min=10.3.9 was passed. */
8015 static const char *
8016 version_compare_spec_function (int argc, const char **argv)
8018 int comp1, comp2;
8019 size_t switch_len;
8020 const char *switch_value = NULL;
8021 int nargs = 1, i;
8022 bool result;
8024 if (argc < 3)
8025 fatal_error ("too few arguments to %%:version-compare");
8026 if (argv[0][0] == '\0')
8027 abort ();
8028 if ((argv[0][1] == '<' || argv[0][1] == '>') && argv[0][0] != '!')
8029 nargs = 2;
8030 if (argc != nargs + 3)
8031 fatal_error ("too many arguments to %%:version-compare");
8033 switch_len = strlen (argv[nargs + 1]);
8034 for (i = 0; i < n_switches; i++)
8035 if (!strncmp (switches[i].part1, argv[nargs + 1], switch_len)
8036 && check_live_switch (i, switch_len))
8037 switch_value = switches[i].part1 + switch_len;
8039 if (switch_value == NULL)
8040 comp1 = comp2 = -1;
8041 else
8043 comp1 = compare_version_strings (switch_value, argv[1]);
8044 if (nargs == 2)
8045 comp2 = compare_version_strings (switch_value, argv[2]);
8046 else
8047 comp2 = -1; /* This value unused. */
8050 switch (argv[0][0] << 8 | argv[0][1])
8052 case '>' << 8 | '=':
8053 result = comp1 >= 0;
8054 break;
8055 case '!' << 8 | '<':
8056 result = comp1 >= 0 || switch_value == NULL;
8057 break;
8058 case '<' << 8:
8059 result = comp1 < 0;
8060 break;
8061 case '!' << 8 | '>':
8062 result = comp1 < 0 || switch_value == NULL;
8063 break;
8064 case '>' << 8 | '<':
8065 result = comp1 >= 0 && comp2 < 0;
8066 break;
8067 case '<' << 8 | '>':
8068 result = comp1 < 0 || comp2 >= 0;
8069 break;
8071 default:
8072 fatal_error ("unknown operator %qs in %%:version-compare", argv[0]);
8074 if (! result)
8075 return NULL;
8077 return argv[nargs + 2];
8080 /* %:include builtin spec function. This differs from %include in that it
8081 can be nested inside a spec, and thus be conditionalized. It takes
8082 one argument, the filename, and looks for it in the startfile path.
8083 The result is always NULL, i.e. an empty expansion. */
8085 static const char *
8086 include_spec_function (int argc, const char **argv)
8088 char *file;
8090 if (argc != 1)
8091 abort ();
8093 file = find_a_file (&startfile_prefixes, argv[0], R_OK, true);
8094 read_specs (file ? file : argv[0], false, false);
8096 return NULL;
8099 /* %:find-file spec function. This function replaces its argument by
8100 the file found through find_file, that is the -print-file-name gcc
8101 program option. */
8102 static const char *
8103 find_file_spec_function (int argc, const char **argv)
8105 const char *file;
8107 if (argc != 1)
8108 abort ();
8110 file = find_file (argv[0]);
8111 return file;
8115 /* %:find-plugindir spec function. This function replaces its argument
8116 by the -iplugindir=<dir> option. `dir' is found through find_file, that
8117 is the -print-file-name gcc program option. */
8118 static const char *
8119 find_plugindir_spec_function (int argc, const char **argv ATTRIBUTE_UNUSED)
8121 const char *option;
8123 if (argc != 0)
8124 abort ();
8126 option = concat ("-iplugindir=", find_file ("plugin"), NULL);
8127 return option;
8131 /* %:print-asm-header spec function. Print a banner to say that the
8132 following output is from the assembler. */
8134 static const char *
8135 print_asm_header_spec_function (int arg ATTRIBUTE_UNUSED,
8136 const char **argv ATTRIBUTE_UNUSED)
8138 printf (_("Assembler options\n=================\n\n"));
8139 printf (_("Use \"-Wa,OPTION\" to pass \"OPTION\" to the assembler.\n\n"));
8140 fflush (stdout);
8141 return NULL;
8144 /* Get a random number for -frandom-seed */
8146 static unsigned HOST_WIDE_INT
8147 get_random_number (void)
8149 unsigned HOST_WIDE_INT ret = 0;
8150 int fd;
8152 fd = open ("/dev/urandom", O_RDONLY);
8153 if (fd >= 0)
8155 read (fd, &ret, sizeof (HOST_WIDE_INT));
8156 close (fd);
8157 if (ret)
8158 return ret;
8161 /* Get some more or less random data. */
8162 #ifdef HAVE_GETTIMEOFDAY
8164 struct timeval tv;
8166 gettimeofday (&tv, NULL);
8167 ret = tv.tv_sec * 1000 + tv.tv_usec / 1000;
8169 #else
8171 time_t now = time (NULL);
8173 if (now != (time_t)-1)
8174 ret = (unsigned) now;
8176 #endif
8178 return ret ^ getpid();
8181 /* %:compare-debug-dump-opt spec function. Save the last argument,
8182 expected to be the last -fdump-final-insns option, or generate a
8183 temporary. */
8185 static const char *
8186 compare_debug_dump_opt_spec_function (int arg,
8187 const char **argv ATTRIBUTE_UNUSED)
8189 const char *ret;
8190 char *name;
8191 int which;
8192 static char random_seed[HOST_BITS_PER_WIDE_INT / 4 + 3];
8194 if (arg != 0)
8195 fatal_error ("too many arguments to %%:compare-debug-dump-opt");
8197 do_spec_2 ("%{fdump-final-insns=*:%*}");
8198 do_spec_1 (" ", 0, NULL);
8200 if (VEC_length (const_char_p, argbuf) > 0
8201 && strcmp (argv[VEC_length (const_char_p, argbuf) - 1], "."))
8203 if (!compare_debug)
8204 return NULL;
8206 name = xstrdup (argv[VEC_length (const_char_p, argbuf) - 1]);
8207 ret = NULL;
8209 else
8211 const char *ext = NULL;
8213 if (VEC_length (const_char_p, argbuf) > 0)
8215 do_spec_2 ("%{o*:%*}%{!o:%{!S:%b%O}%{S:%b.s}}");
8216 ext = ".gkd";
8218 else if (!compare_debug)
8219 return NULL;
8220 else
8221 do_spec_2 ("%g.gkd");
8223 do_spec_1 (" ", 0, NULL);
8225 gcc_assert (VEC_length (const_char_p, argbuf) > 0);
8227 name = concat (VEC_last (const_char_p, argbuf), ext, NULL);
8229 ret = concat ("-fdump-final-insns=", name, NULL);
8232 which = compare_debug < 0;
8233 debug_check_temp_file[which] = name;
8235 if (!which)
8237 unsigned HOST_WIDE_INT value = get_random_number ();
8239 sprintf (random_seed, HOST_WIDE_INT_PRINT_HEX, value);
8242 if (*random_seed)
8243 ret = concat ("%{!frandom-seed=*:-frandom-seed=", random_seed, "} ",
8244 ret, NULL);
8246 if (which)
8247 *random_seed = 0;
8249 return ret;
8252 static const char *debug_auxbase_opt;
8254 /* %:compare-debug-self-opt spec function. Expands to the options
8255 that are to be passed in the second compilation of
8256 compare-debug. */
8258 static const char *
8259 compare_debug_self_opt_spec_function (int arg,
8260 const char **argv ATTRIBUTE_UNUSED)
8262 if (arg != 0)
8263 fatal_error ("too many arguments to %%:compare-debug-self-opt");
8265 if (compare_debug >= 0)
8266 return NULL;
8268 do_spec_2 ("%{c|S:%{o*:%*}}");
8269 do_spec_1 (" ", 0, NULL);
8271 if (VEC_length (const_char_p, argbuf) > 0)
8272 debug_auxbase_opt = concat ("-auxbase-strip ",
8273 VEC_last (const_char_p, argbuf),
8274 NULL);
8275 else
8276 debug_auxbase_opt = NULL;
8278 return concat ("\
8279 %<o %<MD %<MMD %<MF* %<MG %<MP %<MQ* %<MT* \
8280 %<fdump-final-insns=* -w -S -o %j \
8281 %{!fcompare-debug-second:-fcompare-debug-second} \
8282 ", compare_debug_opt, NULL);
8285 /* %:compare-debug-auxbase-opt spec function. Expands to the auxbase
8286 options that are to be passed in the second compilation of
8287 compare-debug. It expects, as an argument, the basename of the
8288 current input file name, with the .gk suffix appended to it. */
8290 static const char *
8291 compare_debug_auxbase_opt_spec_function (int arg,
8292 const char **argv)
8294 char *name;
8295 int len;
8297 if (arg == 0)
8298 fatal_error ("too few arguments to %%:compare-debug-auxbase-opt");
8300 if (arg != 1)
8301 fatal_error ("too many arguments to %%:compare-debug-auxbase-opt");
8303 if (compare_debug >= 0)
8304 return NULL;
8306 len = strlen (argv[0]);
8307 if (len < 3 || strcmp (argv[0] + len - 3, ".gk") != 0)
8308 fatal_error ("argument to %%:compare-debug-auxbase-opt "
8309 "does not end in .gk");
8311 if (debug_auxbase_opt)
8312 return debug_auxbase_opt;
8314 #define OPT "-auxbase "
8316 len -= 3;
8317 name = (char*) xmalloc (sizeof (OPT) + len);
8318 memcpy (name, OPT, sizeof (OPT) - 1);
8319 memcpy (name + sizeof (OPT) - 1, argv[0], len);
8320 name[sizeof (OPT) - 1 + len] = '\0';
8322 #undef OPT
8324 return name;
8327 /* %:pass-through-libs spec function. Finds all -l options and input
8328 file names in the lib spec passed to it, and makes a list of them
8329 prepended with the plugin option to cause them to be passed through
8330 to the final link after all the new object files have been added. */
8332 const char *
8333 pass_through_libs_spec_func (int argc, const char **argv)
8335 char *prepended = xstrdup (" ");
8336 int n;
8337 /* Shlemiel the painter's algorithm. Innately horrible, but at least
8338 we know that there will never be more than a handful of strings to
8339 concat, and it's only once per run, so it's not worth optimising. */
8340 for (n = 0; n < argc; n++)
8342 char *old = prepended;
8343 /* Anything that isn't an option is a full path to an output
8344 file; pass it through if it ends in '.a'. Among options,
8345 pass only -l. */
8346 if (argv[n][0] == '-' && argv[n][1] == 'l')
8348 const char *lopt = argv[n] + 2;
8349 /* Handle both joined and non-joined -l options. If for any
8350 reason there's a trailing -l with no joined or following
8351 arg just discard it. */
8352 if (!*lopt && ++n >= argc)
8353 break;
8354 else if (!*lopt)
8355 lopt = argv[n];
8356 prepended = concat (prepended, "-plugin-opt=-pass-through=-l",
8357 lopt, " ", NULL);
8359 else if (!strcmp (".a", argv[n] + strlen (argv[n]) - 2))
8361 prepended = concat (prepended, "-plugin-opt=-pass-through=",
8362 argv[n], " ", NULL);
8364 if (prepended != old)
8365 free (old);
8367 return prepended;